/* ==========================================================================
   Softerizer — Main Stylesheet (Final, Clean, Overflow-Safe)
   ========================================================================== */

/* ===== Design Tokens ===== */
:root{
  /* Colors (light) */
  --color-bg:#fff;
  --color-text:#0f172a;
  --color-muted:#6b7280;
  --color-border:#e5e7eb;
  --color-primary:#7068f4;
  --color-accent:#12b981;

  /* Layout */
  --radius:12px;
  --radius-sm:8px;
  --container:1200px;
  --gutter:clamp(16px,3vw,28px);

  /* Spacing */
  --space-2:.25rem; --space-3:.5rem; --space-4:.75rem;
  --space-5:1rem;  --space-6:1.25rem; --space-7:1.5rem;
  --space-8:2rem;  --space-9:2.5rem;  --space-10:3rem;
}

/* Dark mode */
[data-theme="dark"]{
  --color-bg:#0b1220;
  --color-text:#e9eef9;
  --color-muted:#a5b4c6;
  --color-border:#1f2a44;
  --color-primary:#8aa2f8;
  --color-accent:#15c79a;
}

/* ===== Base Reset + Overflow Fix (no horizontal scroll) ===== */
*{box-sizing:border-box}
html,body{height:100%}
html{overflow-x:clip}
body{
  margin:0;
  color:var(--color-text);
  background:var(--color-bg);
  font:16px/1.6 system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji";
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}

/* Containers + full-bleed helpers (dvw fallback-safe) */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding:var(--space-10) 0}
.alignwide{max-width:1200px;margin-inline:auto}
.alignfull{width:100vw;width:100dvw;margin-left:50%;transform:translateX(-50%)}

/* ===== Typography ===== */
h1{font-size:clamp(2rem,3.5vw,2.5rem);line-height:1.2;margin:.2em 0}
h2{font-size:clamp(1.75rem,3vw,2rem);line-height:1.25;margin:.25em 0}
h3{font-size:clamp(1.5rem,2.5vw,1.75rem);line-height:1.3;margin:.3em 0}
h4{font-size:clamp(1.25rem,2vw,1.5rem);margin:.4em 0}
p,li{font-size:1rem}

/* ===== Cards ===== */
.card{
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  padding:var(--space-7);
  background:var(--color-bg);
  box-shadow:0 1px 2px rgba(0,0,0,.04);
  transition:transform .2s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.08)}
.gradient{background:linear-gradient(135deg,rgba(112,104,244,.08),rgba(18,185,129,.08))}

/* ===== Buttons ===== */
.button,.wp-block-button__link{
  display:inline-block;border:none;cursor:pointer;user-select:none;
  padding:.7rem 1rem;border-radius:calc(var(--radius) - 4px);
  background:var(--color-primary);color:#fff;
  transition:filter .2s ease,transform .1s ease;
}
.button:hover,.wp-block-button__link:hover{filter:brightness(1.08)}
.button:active,.wp-block-button__link:active{transform:translateY(1px)}
.button.cta{
  background:linear-gradient(135deg,var(--color-primary),var(--color-accent));
  box-shadow:0 6px 18px rgba(0,0,0,.07);
  font-size:.95rem;padding:.55rem .9rem;border-radius:12px;
}
.button.cta:hover{filter:brightness(1.06)}
@media (max-width:900px){.button.cta{font-size:.85rem;padding:.4rem .7rem;box-shadow:none}}
@media (max-width:600px){.button.cta{font-size:.65rem;padding:.3rem .55rem;border-radius:8px}}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:9999;

  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid var(--color-border);
    backface-visibility:hidden;transform:translateZ(0); /* sticky glitch guard */

}
[data-theme="dark"] .site-header{background:rgba(11,18,32,.7)}
.site-header::before{
  content:"";display:block;height:2px;
  background:linear-gradient(90deg,var(--color-primary),var(--color-accent));
  opacity:.28;
}
.site-header.is-scrolled{box-shadow:0 10px 30px rgba(0,0,0,.07)}
@media (min-width:1200px){ .custom-logo{max-height:128px !important} }  
.site-header.is-scrolled .custom-logo{max-height:80px}       


.header-main{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem 0}
.brand{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}
.custom-logo{height:auto;max-height:64px;width:auto}
.site-title{font-weight:700;margin:0}
.site-tagline{font-size:.9rem;color:var(--color-muted)}
.header-actions{display:flex;align-items:center;gap:.5rem}

/* ===== Toggles ===== */
.nav-toggle,.search-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.35rem .7rem;font-size:.9rem;border:none;border-radius:8px;
  background:#f3f4f6;color:#222;cursor:pointer;transition:background .2s ease;
}
.nav-toggle:hover,.search-toggle:hover{background:#e9eaee}
@media (min-width:901px){.nav-toggle,.search-toggle{display:none}}

/* ===== Primary Nav ===== */
.primary-nav{
  background:#f7f7f8;border-top:1px solid #e3e3e6;border-bottom:1px solid #e3e3e6;
  font-family:"Helvetica Neue",Arial,sans-serif;
  overflow:hidden;max-height:0;transition:max-height .28s ease;
  max-height:0;
}
.primary-nav.active{max-height:70vh}
.primary-nav .menu{list-style:none;margin:0;padding:.25rem 0}
.primary-nav .menu li{border-bottom:1px solid #ececef}
.primary-nav .menu li:last-child{border-bottom:none}
.primary-nav .menu a{
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1rem;background:transparent;
  color:color-mix(in oklab,var(--color-text),#000 10%);
  text-decoration:none;transition:background .15s ease,color .15s ease;font-size:.95rem;
}
.primary-nav .menu a:hover{background:#f0f1f3;color:#000}

/* ===== MOBILE NAV (<=900px) ===== */

@media (max-width:900px){
  /* collapsed by default; opens on .active (toggle JS) */
  .primary-nav{
    display:block;
    max-height:0;
    overflow:hidden;
    transition:max-height .28s ease;
  }
  .primary-nav.active{max-height:80vh}

  /* list layout */
  .primary-nav .menu{display:block;margin:0;padding:.25rem 0}
  .primary-nav .menu>li{display:block;border-bottom:1px solid #ececef}
  .primary-nav .menu>li:last-child{border-bottom:none}

  /* link sizing */
  .primary-nav .menu>li>a{
    display:block;
    padding:.85rem 1rem;
    font-size:.86rem;font-weight:600;letter-spacing:.01em;color:#1f2937;
  }
  [data-theme="dark"] .primary-nav .menu>li>a{color:#e5e7eb}

  /* parent row: label + toggle same line, submenu wraps below */
    .primary-nav .menu li.menu-item-has-children{
    position:relative;             /* anchor + absolute toggle */
    display:block;
  }

  /* label (left): reserve space on right for the toggle */
  .primary-nav .menu li.menu-item-has-children > a{
    display:block;
    padding:.85rem 3.25rem .85rem 1rem;  /* 1rem left, 3.25rem right (≈ 40px toggle + gap) */
    min-height:44px;
    line-height:1.3;
    white-space:nowrap;                 /* optional: keep single line */
    overflow:hidden;
    text-overflow:ellipsis;
  }

  /* toggle (right): absolute centered vertically */
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle{
    position:absolute;top:50%;right:10px;transform:translateY(-50%);
    width:40px;height:40px;margin:0;
    display:inline-flex;align-items:center;justify-content:center;
    border-radius:8px;background:#f8f9fb;border:1px solid #e6e7ea;
    cursor:pointer;pointer-events:auto;
  }
  [data-theme="dark"] .primary-nav .menu li.menu-item-has-children > .submenu-toggle{
    background:#111632;border-color:#232a4e;
  }
  .submenu-toggle svg{width:16px;height:16px;transition:transform .25s ease}
  li.submenu-open > .submenu-toggle svg,
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle[aria-expanded="true"] svg{
    transform:rotate(180deg);
  }

  /* submenu: slide down under the same parent row */
  .primary-nav .menu li.menu-item-has-children > .sub-menu{
    position:static;overflow:hidden;
    margin:0;padding:0 0 0 1.1rem;border-left:2px solid #e6e7ea;
    max-height:0;opacity:0;transform:translateY(-6px);
    transition:max-height .28s ease,opacity .28s ease,transform .28s ease,padding .28s ease;
  }
  .primary-nav li.submenu-open > .sub-menu,
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle[aria-expanded="true"] ~ .sub-menu{
    max-height:600px;opacity:1;transform:translateY(0);padding:.45rem 0 .5rem 1.1rem;
  }
}




/* ===== DESKTOP NAV (>=901px) ===== */
@media (min-width:901px){
  .site-header .primary-nav{
    background:#fff;
    border:2px solid var(--color-border);
    border-radius:12px;
    padding:.01rem;
    box-shadow:0 8px 24px rgba(15,23,42,.08);
    max-width:var(--container);
    margin:.4rem auto;          /* center within header */
    display:flex;               /* keep your existing layout */
    justify-content:center;
  }
  [data-theme="dark"] .site-header .primary-nav{
    background:rgba(11,18,32,.78);
    border-color:#1f2a44;
    box-shadow:0 12px 28px rgba(0,0,0,.25);
  }

  /* link sizing + chip hover */
  .primary-nav .menu>li>a{
    font-size:.77rem;           /* smaller */
    font-weight:600;            /* slightly bolder */
    padding:.5rem .9rem;        /* tighter */
    letter-spacing:.001rem;
    border-radius:10px;
  }

  /* desktop layout */
  .primary-nav{
    max-height:none;overflow:visible;background:transparent;border:none;
    display:flex;justify-content:center;
  }
  .primary-nav .menu{display:flex;gap:1rem;align-items:center;padding:.35rem 0}
  .primary-nav .menu li{border:none;position:relative}

  /* underline glow */
  .primary-nav .menu a::after{
    content:"";position:absolute;left:12px;right:12px;bottom:4px;height:2px;
    background:linear-gradient(90deg,var(--color-primary),var(--color-accent));
    transform:scaleX(0);transform-origin:left;transition:transform .18s ease
  }
  .primary-nav .menu a:hover::after,
  .primary-nav .menu a:focus::after{transform:scaleX(1)}
  .primary-nav .menu a:hover{box-shadow:0 0 .5rem rgba(112,104,244,.22);background:#f7f7fb}

  /* desktop dropdown */
  .primary-nav .sub-menu{
    position:absolute;top:100%;left:0;min-width:220px;display:none;z-index:10000;
    background:var(--color-bg);border:1px solid var(--color-border);
    border-radius:12px;padding:.5rem;box-shadow:0 12px 32px rgba(0,0,0,.08)
  }
  .primary-nav li:hover> .sub-menu{display:block}
}


/* ===== Content & Footer ===== */
.content-area{display:grid;grid-template-columns:1fr 320px;gap:var(--space-8)}
@media (max-width:1100px){.content-area{grid-template-columns:1fr}}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-7)}
@media (max-width:1100px){.posts-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.posts-grid{grid-template-columns:1fr}}
.post-meta{color:var(--color-muted);font-size:.9rem}
.site-footer{background:#fafafa;border-top:1px solid var(--color-border);margin-top:var(--space-10)}
[data-theme="dark"] .site-footer{background:#0e1628}
.footer-widgets{display:grid;gap:var(--space-7);grid-template-columns:repeat(3,1fr)}
@media (max-width:900px){.footer-widgets{grid-template-columns:1fr}}
.site-info{border-top:1px solid var(--color-border);padding:var(--space-5) 0;color:var(--color-muted)}

/* ===== Gutenberg niceties ===== */
.wp-block-image figcaption{color:var(--color-muted)}

/* ===== Search panel ===== */
.search-bar{padding:.5rem 0}
.search-bar[hidden]{display:none}

/* ===== Reduced Motion ===== */
@media (prefers-reduced-motion:reduce){
  .primary-nav{transition:none}
  .primary-nav .menu a::after{transition:none}
}

/* ===== ARTICLES (viewport-wide background, overflow-safe) ===== */
.Home-articles{
  position:relative;padding:clamp(28px,5vw,56px) 0;margin:0 0 clamp(28px,5vw,56px);
  overflow:hidden;background:#f7fafc;
}
.Home-articles::before{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:220%;height:220%;z-index:0;pointer-events:none;
  background:
    radial-gradient(circle at center,rgba(255,255,255,.6) 0%,rgba(255,255,255,0) 40%),
    radial-gradient(circle at center,rgba(99,102,241,.4) 0%,rgba(56,189,248,.25) 30%,rgba(34,197,94,.2) 55%,transparent 75%);
  background-blend-mode:screen;filter:blur(70px);opacity:.55;animation:HomeArticlesGlow 14s ease-in-out infinite;
}
@keyframes HomeArticlesGlow{
  0%{transform:translate(-50%,-50%) scale(1);opacity:.45}
  50%{transform:translate(-50%,-50%) scale(1.12);opacity:.65}
  100%{transform:translate(-50%,-50%) scale(1);opacity:.45}
}
.Home-articleCard{
  display:block;background:#fff;border:1px solid #e5e7eb;border-radius:var(--Home-r,14px);
  padding:10px;color:#0f172a;text-decoration:none;box-shadow:0 6px 18px rgba(2,6,23,.05);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.Home-articleThumb{border-radius:var(--Home-rs,10px);overflow:hidden;aspect-ratio:16/9;background:#f1f5f9}
.Home-articleThumb img{width:100%;height:100%;display:block;object-fit:cover;transform:scale(1);transition:transform .35s ease}
.Home-articleTitle{font-size:1rem;margin:.6rem 0 .25rem;color:#0f172a;font-weight:700}
.Home-articleMeta{display:block;font-size:.88rem;color:#64748b;margin-bottom:.35rem}
.Home-articleMore{font-weight:700;color:#1f2a7a;display:inline-flex;align-items:center;gap:.25rem}
.Home-articleMore .Home-arrow{display:inline-block;transform:translateX(0);transition:transform .2s ease}
.Home-articleCard:hover{transform:translateY(-4px);border-color:#d1d5db;box-shadow:0 14px 28px rgba(2,6,23,.08)}
.Home-articleCard:hover .Home-articleThumb img{transform:scale(1.06)}
.Home-articleCard:hover .Home-articleMore .Home-arrow{transform:translateX(3px)}
.Home-carousel{overflow:auto;-webkit-overflow-scrolling:touch}
.Home-carouselTrack{display:grid;grid-auto-flow:column;grid-auto-columns:clamp(260px,26vw,320px);gap:14px;scroll-snap-type:x mandatory;padding-bottom:.6rem}
.Home-carouselItem{scroll-snap-align:start}
@media (prefers-reduced-motion:reduce){
  .Home-articles::before{animation:none}
  .Home-articleThumb img,.Home-articleCard{transition:none}
}
/* Section Title box */
.Home-articlesTitleBox{
  display:inline-block;background:linear-gradient(135deg,#fff 0%,#f3f4f6 50%,#fff 100%);
  border:2px solid #e5e7eb;border-radius:14px;padding:.8rem 1.6rem;margin-bottom:1.5rem;
  font-size:clamp(1.4rem,3vw,2rem);font-weight:800;color:#0f172a;text-align:center;position:relative;z-index:1;
  box-shadow:0 6px 16px rgba(17,24,39,.08);letter-spacing:.5px;
}
.Home-articlesTitleBox::after{
  content:"";display:block;width:80px;height:4px;margin:.6rem auto 0;border-radius:999px;
  background:linear-gradient(90deg,#06b6d4,#3b82f6,#8b5cf6);opacity:.85;
}

/* ===== ABOUT (full-bleed, safe) — FIXED ===== */
.Home-about{
  position:relative;
  /* if this file is pure .css, keep a static url here */
  background-image:url('/wp-content/themes/softerizer/assets/about-bg.jpg');
  background-size:cover;background-position:center;background-attachment:fixed;
  padding:clamp(32px,6vw,72px) 0;
  margin-bottom:clamp(28px,5vw,56px);
  isolation:isolate;

  /* full-bleed without alignfull shift */
  width:100vw; width:100dvw;
  margin-left:calc(50% - 50vw); margin-left:calc(50% - 50dvw);
  transform:none; /* neutralize .alignfull translateX */
}
@media (max-width:900px){.Home-about{background-attachment:scroll}}
/* center inner container inside the full-bleed section */
.Home-about.alignfull > .container{
  max-width:var(--container);
  width:min(100%,var(--container));
  margin-inline:auto;
  padding-inline:var(--gutter);
}

.Home-aboutGrid{
  position:relative;z-index:1;display:grid;grid-template-columns:180px 1fr;
  gap:clamp(18px,3vw,32px);align-items:center
}
@media (max-width:720px){.Home-aboutGrid{grid-template-columns:1fr;text-align:center}}
.Home-aboutLogo{display:grid;place-items:center}
.Home-aboutLogo .custom-logo-link,.Home-logoFallback{
  display:grid;place-items:center;width:132px;height:132px;background:#fff;border-radius:24px;
  box-shadow:0 12px 30px rgba(0,0,0,.18),0 3px 10px rgba(0,0,0,.12);
  border:1px solid rgba(15,23,42,.06);overflow:hidden;text-decoration:none;color:#0f172a
}
.Home-aboutLogo img.custom-logo{max-width:86%;height:auto;display:block}
.Home-logoFallback{font-weight:800;font-size:2rem}
.Home-aboutCopy p{line-height:1.65;color:#e8edf7}
.Home-aboutCopy .Home-muted{opacity:.9}
.Home-about .Home-sectionTitle{
  color:#fff;font-weight:900;font-size:clamp(1.5rem,3.2vw,2.2rem);line-height:1.15;margin:0 0 .85rem;letter-spacing:.2px;
  text-shadow:0 2px 14px rgba(0,0,0,.25)
}
.Home-about .Home-sectionTitle::after{
  content:"";display:block;width:72px;height:3px;margin-top:.65rem;border-radius:999px;
  background:linear-gradient(90deg,#12b981,#6366f1);opacity:.9
}
.Home-btnRow{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
.Home-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem 1rem;border-radius:12px;font-weight:700;text-decoration:none}
.Home-btnPrimary{background:#10b981;color:#05121f;border:1px solid #0ea67a}
.Home-btnPrimary:hover{filter:brightness(1.05)}
.Home-btnGhost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.Home-btnGhost:hover{background:rgba(255,255,255,.08)}
.Home-about .Home-aboutCopy,.Home-about .Home-sectionTitle{color:#fff}


/* ===== SKILLS ===== */
.Home-skills{margin:0 0 clamp(28px,5vw,56px);padding:0}
.Home-skills .Home-sectionTitle{
  color:var(--Home-ink,#0f172a);font-weight:800;font-size:clamp(1.3rem,2.8vw,1.9rem);line-height:1.25;margin:0 0 1.2rem;
  letter-spacing:.3px;position:relative;text-transform:uppercase;background:linear-gradient(90deg,#12b981,#6366f1);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent
}
.Home-skills .Home-sectionTitle::after{
  content:"";display:block;width:90px;height:4px;margin:.7rem auto 0;border-radius:999px;
  background:linear-gradient(90deg,#12b981 0%,#34d399 25%,#6366f1 75%,#4338ca 100%);
  box-shadow:0 2px 6px rgba(99,102,241,.25);animation:pulse-bar 2.8s infinite ease-in-out
}
@keyframes pulse-bar{0%,100%{transform:scaleX(.8);opacity:.6}50%{transform:scaleX(1);opacity:1}}
.Home-tags{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0;padding:0}
.Home-tag{
  padding:.55rem .8rem;border-radius:999px;background:var(--Home-chip-bg,#f7f8fc);border:1px solid var(--Home-chip-border,#e5e7eb);
  color:var(--Home-chip-ink,#0f172a);font-size:.95rem;line-height:1;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;white-space:nowrap
}
.Home-tag:hover{transform:translateY(-1px);border-color:var(--Home-primary,#6366f1);box-shadow:0 6px 14px rgba(99,102,241,.12)}
.is-dark .Home-tag{background:#0e1530;border-color:#232a4e;color:#dbe3ff}

/* ===== PRODUCTS ===== */
.Home-products{margin:clamp(32px,6vw,72px) 0;padding:0}
.Home-products .Home-sectionTitle{
  color:var(--Home-ink,#0f172a);font-weight:800;font-size:clamp(1.3rem,2.8vw,1.9rem);line-height:1.25;margin:0 0 1.2rem;
  letter-spacing:.3px;position:relative;text-transform:uppercase;background:linear-gradient(90deg,#12b981,#6366f1);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent
}
.Home-products .Home-sectionTitle::after{
  content:"";display:block;width:80px;height:4px;margin-top:.6rem;border-radius:999px;
  background:linear-gradient(90deg,#12b981 0%,#34d399 30%,#6366f1 100%);animation:shine 2.5s infinite linear
}
@keyframes shine{0%{opacity:.5;transform:scaleX(.8)}50%{opacity:1;transform:scaleX(1)}100%{opacity:.5;transform:scaleX(.8)}}
.Home-carousel{overflow:auto;-webkit-overflow-scrolling:touch}
.Home-carouselTrack{display:grid;grid-auto-flow:column;grid-auto-columns:clamp(240px,26vw,300px);gap:14px;scroll-snap-type:x mandatory;padding-bottom:.5rem}
.Home-carouselItem{scroll-snap-align:start}
.Home-productCard{display:block;background:#0e1530;border:1px solid #1b2140;border-radius:var(--Home-r,12px);padding:10px;text-decoration:none;color:var(--Home-ink,#e5e7eb)}
.Home-productThumb img{width:100%;height:auto;border-radius:var(--Home-rs,10px)}
.Home-productTitle{font-size:1rem;margin:.6rem 0 .25rem}
.Home-productPrice{color:#0ea5a7;font-weight:700;margin-bottom:.4rem}
.Home-productMore{display:inline-block;font-weight:600;color:#6366f1}

/* ===== WHY (full-bleed, modern cards) — FIXED ===== */
.Home-why{
  position:relative;
  background:linear-gradient(120deg,#0b162b 0%,#0a1224 60%,#0b162b 100%);
  padding:clamp(24px,4vw,48px) 0;
  isolation:isolate;

  /* full-bleed without alignfull shift */
  width:100vw; width:100dvw;
  margin-left:calc(50% - 50vw); margin-left:calc(50% - 50dvw);
  transform:none; /* neutralize .alignfull translateX */
}
/* center inner container inside the full-bleed section */
.Home-why.alignfull > .container{
  max-width:var(--container);
  width:min(100%,var(--container));
  margin-inline:auto;
  padding-inline:var(--gutter);
}

.Home-why::before{
  content:"";position:absolute;inset:0 0 auto 0;height:2px;
  background:linear-gradient(90deg,var(--Home-brand),var(--Home-acc));opacity:.25
}
.Home-whyGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(16px,2.8vw,24px)}
@media (max-width:900px){.Home-whyGrid{grid-template-columns:1fr}}
.Home-card--why{
  position:relative;overflow:hidden;background:#0e1530;color:#e5e7eb;border:1px solid #1b2140;border-radius:var(--Home-r);
  padding:1.2rem;box-shadow:0 10px 28px rgba(0,0,0,.28),0 1px 0 rgba(255,255,255,.04) inset;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease
}
.Home-card--why::after{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  background:radial-gradient(1200px 300px at 10% -10%,rgba(112,104,244,.18),transparent 60%),
             radial-gradient(1200px 300px at 110% 110%,rgba(18,185,129,.18),transparent 60%);
  opacity:0;pointer-events:none;transition:opacity .2s ease
}
.Home-card--why:hover{transform:translateY(-2px);border-color:#2a3570;box-shadow:0 16px 40px rgba(0,0,0,.35),0 0 0 1px rgba(112,104,244,.12) inset}
.Home-card--why:hover::after{opacity:.6}
.Home-card--why h3{margin:.2rem 0 .5rem;font-size:1.15rem;letter-spacing:.2px}
.Home-card--why p{color:#cbd5e1;margin:0}
.Home-whyCTA{text-align:center;margin-top:clamp(16px,2.2vw,22px)}


/* ===== Micro Ticker (full width) ===== */
.Home-ticker{
  position:relative;top:auto;z-index:10;background:#0d1326;color:#e5e7eb;border-bottom:1px solid #1c2241;
  width:100vw;width:100dvw;margin-left:calc(50% - 50vw);margin-left:calc(50% - 50dvw);
  box-shadow:0 10px 24px rgba(0,0,0,.25);font-size:.9rem
}
.Home-tickerTrack{
  display:flex;gap:3rem;padding:.5rem var(--Home-g);white-space:nowrap;overflow:hidden;width:max-content;
  --speed:22s;animation:ticker-ltr var(--speed) linear infinite;will-change:transform
}
.Home-tickerTrack>span{display:inline-block;padding-right:3rem;flex:0 0 auto}
@keyframes ticker-ltr{from{transform:translateX(-50%)}to{transform:translateX(0%)}}
@media (prefers-reduced-motion:reduce){.Home-tickerTrack{animation:none}}

/* ===== BRANDS ===== */
.Home-brands{background:#fff;color:#0f172a;padding:2.8rem 0 2.4rem}
.Home-brandsHead{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.7rem;margin-bottom:1.1rem;max-width:var(--Home-w);margin-inline:auto}
.Home-dividerDark{
  width:100%;height:6px;border-radius:999px;position:relative;
  background:linear-gradient(90deg,#1b2147 0%,#132042 25%,#0f3b34 75%,#0c6a54 100%);
  box-shadow:0 10px 22px rgba(17,24,39,.18),0 6px 14px rgba(12,106,84,.12)
}
.Home-proudBox{margin-top:.15rem}
.Home-proudBadge{
  position:relative;display:inline-block;padding:.6rem 1.05rem;border-radius:14px;background:#0b1220;color:#e5e7eb;border:1px solid #1f2a44;
  box-shadow:0 10px 28px rgba(0,0,0,.25),0 0 0 2px rgba(255,255,255,.65) inset;letter-spacing:.02em;white-space:nowrap
}
.Home-proudBadge>strong{
  background:linear-gradient(90deg,var(--Home-brand,#7068f4),var(--Home-acc,#12b981));
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:900
}
.Home-brandsNote{margin:.55rem 0 0;color:#6b7280;font-size:.95rem}
.Home-brandMarquee{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)
}
.Home-brandTrack{
  list-style:none;margin:0;padding:.7rem 0;display:flex;align-items:center;gap:clamp(16px,4vw,36px);
  animation:Home-marquee 18s linear infinite;will-change:transform
}
@keyframes Home-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.Home-brandItem{flex:0 0 auto;list-style:none}
.Home-brandCard{
  display:grid;place-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:var(--Home-r);padding:1rem;
  transition:transform .2s ease,box-shadow .2s ease
}
.Home-brandCard:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.08)}
.Home-brandCard img{max-height:56px;width:auto;height:auto}
@media (prefers-reduced-motion:reduce){.Home-brandTrack{animation:none}.Home-brandMarquee{-webkit-mask-image:none;mask-image:none}}

/* ===== HERO (full-bleed) ===== */
.Home-hero{position:relative;background:linear-gradient(120deg,#0b1020,#10183a)}
.Home-hero .Home-heroSlider{
  padding-bottom: 36px; width:100vw;width:100dvw;margin-left:calc(50% - 50vw);margin-left:calc(50% - 50dvw);
  position:relative;isolation:isolate;min-height:clamp(520px,78svh,880px)
}
.Home-heroSlides{list-style:none;margin:0;padding:0;position:relative}
.Home-heroSlide{
  position:absolute;inset:0;min-height:clamp(520px,78svh,880px);display:grid;place-items:center;
  background-image:var(--bg);background-size:cover;background-position:center;opacity:0;pointer-events:none;transition:opacity .5s ease
}
.Home-heroSlide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,13,25,.62),rgba(9,13,25,.78))}
.Home-heroSlide.is-active{opacity:1;pointer-events:auto}
.Home-heroInner{position:relative;z-index:1;text-align:center;padding:5rem 1rem}
.Home-heroTitle{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:.2px;color:#fff}
.Home-heroSub{margin:.9rem auto 1.4rem;max-width:820px;color:#d1d5db;font-size:clamp(1rem,1.5vw,1.15rem)}
.Home-heroCTA{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.Home-heroMicro{margin-top:.6rem;font-size:.9rem;color:#cbd5e1;opacity:.9}
.Home-heroDots{
  position:absolute;left:50%;bottom:clamp(12px,3vw,28px);
  transform:translateX(-50%);z-index:2;padding:0;gap:.6rem;
}
.Home-heroDots button{width:20px;height:20px} /* 2× bigger */

.Home-heroDots button[aria-current="true"]{background:#fff}
/* center + robust on hero */
.Home-hero .button.cta{
  display:flex;align-items:center;justify-content:center;
  text-align:center;white-space:normal;line-height:1.2;
}

/* mobile sizing */
@media (max-width:600px){
  .Home-hero .button.cta{
    width:100%;max-width:340px;
    font-size:.9rem;padding:.7rem 1rem;border-radius:12px;
  }
}

@media (prefers-reduced-motion:reduce){.Home-heroSlide{transition:none}}

/* ===== Base utilities (scoped) ===== */
.Home-root{
  --Home-c1:#0b1020;--Home-c2:#0e1530;--Home-c3:#0d142b;--Home-c4:#0c1224;
  --Home-ink:#e5e7eb;--Home-brand:#7068f4;--Home-acc:#12b981;--Home-r:14px;--Home-rs:10px;
  --Home-w:1200px;--Home-g:clamp(16px,3vw,28px);color:var(--Home-ink)
}
.Home-container{max-width:var(--Home-w);padding-inline:var(--Home-g);margin-inline:auto}
.Home-muted{color:#b7bfd0}
.Home-sectionTitle{font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.2;margin:2rem 0 1rem}
.Home-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 1.1rem;border-radius:999px;border:1px solid transparent;font-weight:700;text-decoration:none}
.Home-btnPrimary{background:var(--Home-brand);color:#fff;box-shadow:0 6px 20px rgba(112,104,244,.35)}
.Home-btnGhost{background:transparent;color:#fff;border-color:#313956}

/* --- FINAL OVERRIDES: Mobile nav & toggle --- */
@media (max-width:900px){
  .nav-toggle{display:inline-flex !important}

  /* collapsed by default; opens on .active */
  .primary-nav{
    display:block;                /* stop any flex leaks */
    max-height:0; 
    overflow:hidden;
    transition:max-height .28s ease;
  }
  .primary-nav.active{max-height:80vh}

  /* mobile layout = vertical list */
  .primary-nav .menu{display:block}
  .primary-nav .menu>li{display:block}
}

/* =========================
   Floating Actions (Top + Theme)
   ========================= */
.Home-fabStack{position:fixed;right:16px;bottom:16px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.Home-fab,.Home-floatTop,#themeToggle{
  width:46px;height:46px;border-radius:999px;border:0;cursor:pointer;
  display:grid;place-items:center;font-size:18px;box-shadow:0 8px 24px rgba(0,0,0,.12);
  background:var(--color-primary);color:#fff;transition:transform .15s ease,filter .2s ease
}
.Home-fab:hover,.Home-floatTop:hover,#themeToggle:hover{transform:translateY(-2px);filter:brightness(1.08)}
.Home-floatTop{background:var(--color-accent);display:none}
[data-theme="dark"] #themeToggle{background:#0f172a;color:#ffd84a}

/* =========================
   Header + Search panel
   ========================= */
#header-search[hidden]{display:none !important}
#header-search{
  background:var(--color-bg);border:1px solid var(--color-border);
  border-radius:10px;padding:.6rem;box-shadow:0 10px 30px rgba(0,0,0,.08)
}
#header-search input[type="search"]{width:100%;padding:.55rem .75rem;border:1px solid var(--color-border);border-radius:8px;background:transparent;color:var(--color-text)}



/* =========================
   Hero Slider
   ========================= */
.Home-hero{position:relative}
.Home-heroSlider{position:relative;border-radius:14px;overflow:hidden}
.Home-heroSlides{list-style:none;margin:0;padding:0}
.Home-heroSlide{
  position:relative;min-height:54vh;display:none;place-items:center;padding:clamp(16px,3vw,32px);
  background:linear-gradient( to bottom, rgba(0,0,0,.35), rgba(0,0,0,.35) ), var(--bg, #000 );
  background-image:linear-gradient(to bottom, rgba(0,0,0,.35), rgba(0,0,0,.35)), var(--bg);
  background-size:cover;background-position:center;opacity:0;transition:opacity .35s ease
}
.Home-heroSlide.is-active{display:grid;opacity:1}
.Home-heroSlide .Home-heroInner{max-width:900px;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.35)}
.Home-heroTitle{margin:0 0 .35rem}
.Home-heroSub{margin:.25rem 0 .8rem;font-size:1.05rem;opacity:.95}
.Home-heroCTA{display:flex;flex-wrap:wrap;gap:.5rem}
.Home-heroMicro{margin:.6rem 0 0;opacity:.9;font-size:.9rem}
.Home-heroDots{
  position:absolute;left:50%;bottom:14px;transform:translateX(-50%);
  display:flex;gap:8px;background:rgba(0,0,0,.25);padding:6px 8px;border-radius:999px;backdrop-filter:blur(6px)
}
.Home-heroDots > button{
  width:8px;height:8px;border:0;border-radius:999px;background:#fff;opacity:.55;cursor:pointer
}
.Home-heroDots > button[aria-current="true"]{opacity:1;transform:scale(1.2)}

/* =========================
   Auto-Scroll Carousels (posts/products)
   ========================= */
.Home-carousel{position:relative}
.Home-carouselTrack{
  display:flex;gap:14px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x proximity;
  padding-bottom:6px
}
.Home-carouselTrack::-webkit-scrollbar{height:8px}
.Home-carouselTrack::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:999px}
.Home-carouselItem{flex:0 0 clamp(220px, 26vw, 320px);scroll-snap-align:start}
.Home-articleCard,.Home-productCard{
  display:flex;flex-direction:column;gap:.5rem;border-radius:12px;padding:12px;background:var(--color-bg);
  border:1px solid var(--color-border);box-shadow:0 6px 18px rgba(0,0,0,.06);height:100%
}
.Home-articleThumb,.Home-productThumb{aspect-ratio:16/9;overflow:hidden;border-radius:10px}
.Home-articleThumb img,.Home-productThumb img{width:100%;height:100%;object-fit:cover}
.Home-articleTitle,.Home-productTitle{font-size:1rem;line-height:1.35;margin:.15rem 0}
.Home-productPrice{font-weight:700}
.Home-articleMore{font-size:.9rem;opacity:.8}

/* =========================
   Misc polish
   ========================= */
.Home-sectionTitle{margin:.4rem 0 var(--space-6)}
.Home-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:var(--space-7);box-shadow:0 1px 2px rgba(0,0,0,.04)}
.site-header.is-scrolled .header-main{padding:.3rem 0}



/***** FAQ *****/
.Home-faq .Home-sectionTitle{margin-bottom:var(--space-7)}
.Home-faqList{display:grid;gap:var(--space-5)}
.Home-faqItem{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);box-shadow:0 1px 2px rgba(0,0,0,.04)}
.Home-faqQ{list-style:none;display:flex;align-items:center;gap:.6rem;padding:var(--space-6) var(--space-7);cursor:pointer;font-weight:700}
.Home-faqQ::-webkit-details-marker{display:none}
.Home-faqQ::after{content:"";margin-left:auto;width:18px;height:18px;border-radius:6px;border:1px solid var(--color-border);display:inline-grid;place-items:center}
.Home-faqItem[open] .Home-faqQ::after{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-color:transparent}
.Home-faqA{padding:0 var(--space-7) var(--space-7);color:var(--color-muted)}



/* ---------------------------
   HOME SECTION TITLE (global)
   --------------------------- */
/* Light (default) */
.Home-sectionTitle{
  color: var(--color-text);
  text-shadow: none;
}
/* Dark */
[data-theme="dark"] .Home-sectionTitle{
  color: #e9eef9;
  text-shadow: 0 1px 8px rgba(0,0,0,.25);
}

/* ---------------------------
   WHY SECTION
   --------------------------- */
/* Light (override previous dark look) */
.Home-why{
  background: linear-gradient(120deg,#f8fafc 0%, #eef2ff 60%, #f8fafc 100%);
}
.Home-why .Home-card--why{
  background:#ffffff;
  border:1px solid var(--color-border);
  color: var(--color-text);
  box-shadow:0 8px 22px rgba(0,0,0,.06);
}
.Home-why .Home-card--why p{ color: var(--color-muted); }
.Home-why .Home-card--why:hover{
  border-color:#d6d9e0;
  box-shadow:0 14px 28px rgba(0,0,0,.08);
}
.Home-why::before{
  background: linear-gradient(90deg,var(--color-primary),var(--color-accent));
  opacity:.18;
}

/* Dark */
[data-theme="dark"] .Home-why{
  background: linear-gradient(120deg,#0b162b 0%, #0a1224 60%, #0b162b 100%);
}
[data-theme="dark"] .Home-why .Home-card--why{
  background:#0e1530;
  border:1px solid #1b2140;
  color:#e5e7eb;
  box-shadow:0 10px 28px rgba(0,0,0,.28), 0 1px 0 rgba(255,255,255,.04) inset;
}
[data-theme="dark"] .Home-why .Home-card--why p{ color:#cbd5e1; }
[data-theme="dark"] .Home-why::before{
  background: linear-gradient(90deg,var(--Home-brand,#7068f4),var(--Home-acc,#12b981));
  opacity:.25;
}

/* Keep inner container centered in both themes */
.Home-why.alignfull > .container{
  max-width: var(--container);
  width: min(100%, var(--container));
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* ---------------------------
   ABOUT SECTION (with overlay)
   --------------------------- */
/* Shared: full-bleed + centering */
.Home-about{
  transform: none;
}
.Home-about.alignfull > .container{
  max-width: var(--container);
  width: min(100%, var(--container));
  margin-inline: auto;
  padding-inline: var(--gutter);
}
/* Add an overlay using ::before (no HTML change needed) */
.Home-about{ position:relative; isolation:isolate; }
.Home-about::before{
  content:""; position:absolute; inset:0; z-index:0;
  pointer-events:none;
  transition: background .25s ease, opacity .25s ease;
}
/* Content stays above overlay */
.Home-about .Home-aboutGrid{ position:relative; z-index:1; }

/* Light */
.Home-about::before{
  /* subtle darkening for readability on images */
  background: linear-gradient(180deg, rgba(6,11,25,.22), rgba(6,11,25,.22));
}
.Home-about .Home-aboutCopy p{ color:#0f172a; }
.Home-about .Home-sectionTitle{ color:#0f172a; text-shadow:none; }
.Home-btnGhost{ border-color:rgba(0,0,0,.25); color:#0f172a; }
.Home-btnGhost:hover{ background:rgba(0,0,0,.06); }

/* Dark */
[data-theme="dark"] .Home-about::before{
  background: linear-gradient(180deg, rgba(6,11,25,.55), rgba(6,11,25,.55));
}
[data-theme="dark"] .Home-about .Home-aboutCopy p{ color:#e8edf7; }
[data-theme="dark"] .Home-about .Home-sectionTitle{
  color:#ffffff; text-shadow:0 2px 14px rgba(0,0,0,.25);
}
[data-theme="dark"] .Home-btnGhost{
  color:#fff; border-color:rgba(255,255,255,.35);
}
[data-theme="dark"] .Home-btnGhost:hover{ background:rgba(255,255,255,.08); }

/* ---------------------------
   FAQs
   --------------------------- */
/* Light (default) */
.Home-faqItem{
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.Home-faqQ{ color: var(--color-text); }
.Home-faqA{ color: var(--color-muted); }
.Home-faqQ::after{
  border-color: var(--color-border);
  background: #fff;
}
/* Open state accent stays same in both themes */
.Home-faqItem[open] .Home-faqQ::after{
  background: linear-gradient(135deg,var(--color-primary),var(--color-accent));
  border-color: transparent;
}

/* Dark */
[data-theme="dark"] .Home-faqItem{
  background:#0b1220;
  border:1px solid #1f2a44;
  box-shadow: 0 1px 2px rgba(0,0,0,.25);
}
[data-theme="dark"] .Home-faqQ{ color:#e9eef9; }
[data-theme="dark"] .Home-faqA{ color:#a5b4c6; }
[data-theme="dark"] .Home-faqQ::after{
  border-color:#2a3456;
  background:#0e162a;
}


/* =========================
   TESTIMONIALS (Light + Dark)
   ========================= */

/* Layout */
.Testimonials-section{padding:var(--space-10) 0}
.Testimonials-container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.Testimonials-title{
  font-size:clamp(1.4rem,2.4vw,2rem);
  font-weight:800; line-height:1.2; margin:0 0 var(--space-6);
}

/* Cards grid */
.Testimonials-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(14px,2.5vw,22px);
}
@media (max-width:1100px){ .Testimonials-list{grid-template-columns:repeat(2,1fr)} }
@media (max-width:700px){ .Testimonials-list{grid-template-columns:1fr} }

/* Card base (Light default) */
.Testimonials-card{
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  background:var(--color-bg);
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  padding:var(--space-7);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.Testimonials-card:hover{
  transform:translateY(-2px);
  border-color:#d7dbe3;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}

/* Quote & meta (Light) */
.Testimonials-quote{margin:0 0 var(--space-5); color:var(--color-text)}
.Testimonials-quote p{margin:0}
.Testimonials-meta{color:var(--color-muted); font-size:.95rem}
.Testimonials-name{font-weight:700; color:var(--color-text)}
.Testimonials-role{opacity:.95}

/* Decorative accent (subtle) */
.Testimonials-card::after{
  content:""; display:block; height:3px; margin-top:var(--space-5);
  border-radius:999px;
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  opacity:.25;
}

/* Title accent (Light) */
.Testimonials-title{
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* -------- Dark theme overrides -------- */
[data-theme="dark"] .Testimonials-title{
  color:#e9eef9; text-shadow:0 1px 8px rgba(0,0,0,.25);
  /* keep gradient tint but readable */
  background:linear-gradient(90deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

[data-theme="dark"] .Testimonials-card{
  background:#0b1220;
  border:1px solid #1f2a44;
  box-shadow:0 8px 22px rgba(0,0,0,.28);
}
[data-theme="dark"] .Testimonials-card:hover{
  border-color:#243055; box-shadow:0 14px 32px rgba(0,0,0,.35);
}
[data-theme="dark"] .Testimonials-quote{color:#e9eef9}
[data-theme="dark"] .Testimonials-meta{color:#a5b4c6}
[data-theme="dark"] .Testimonials-name{color:#ffffff}
[data-theme="dark"] .Testimonials-card::after{opacity:.35}


/* =========================
   Mobile Submenus (CSS hooks used by JS) — FIXED
   ========================= */
@media (max-width:900px){
  /* Parent row = single line (label + absolute toggle), submenu always below */
  .primary-nav .menu li.menu-item-has-children{
    position: relative;
    display: block;               /* column flow; no side-by-side submenu */
  }

  /* Label (left) — reserve right space for toggle */
  .primary-nav .menu li.menu-item-has-children > a{
    display: block;
    padding: .85rem 3.25rem .85rem 1rem; /* 1rem left, 3.25rem right (toggle area) */
    min-height: 44px;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #1f2937;
    background: transparent;
  }
  [data-theme="dark"] .primary-nav .menu li.menu-item-has-children > a{
    color: #e5e7eb;
  }

  /* Toggle (right) — absolute center vertically */
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle{
    position: absolute; top: 50%; right: 10px; transform: translateY(-50%);
    width: 40px; height: 40px; margin: 0;
    display: grid; place-items: center;
    border-radius: 8px; background: #f8f9fb; border: 1px solid #e6e7ea;
    cursor: pointer; pointer-events: auto;
    color: #111827;
  }
  [data-theme="dark"] .primary-nav .menu li.menu-item-has-children > .submenu-toggle{
    background: #111632; border-color: #232a4e; color: #e5e7eb;
  }
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle svg{
    width: 16px; height: 16px; transition: transform .25s ease;
  }
  .primary-nav .menu li.submenu-open > .submenu-toggle svg,
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle[aria-expanded="true"] svg{
    transform: rotate(180deg);
  }

  /* Submenu — ALWAYS below the parent row */
  .primary-nav .menu li.menu-item-has-children > .sub-menu{
    position: static; width: 100%; display: block;
    list-style: none; margin: 0; padding: 0 0 0 1.1rem;
    border-left: 2px solid var(--color-border);
    max-height: 0; opacity: 0; overflow: hidden;
    transform: translateY(-6px);
    transition: max-height .28s ease, opacity .28s ease, transform .28s ease, padding .28s ease;
    background: transparent;
  }
  [data-theme="dark"] .primary-nav .menu li.menu-item-has-children > .sub-menu{
    border-left-color: #232a4e;
  }

  /* Open states (works with .submenu-open OR [aria-expanded="true"]) */
  .primary-nav .menu li.submenu-open > .sub-menu,
  .primary-nav .menu li.menu-item-has-children > .submenu-toggle[aria-expanded="true"] ~ .sub-menu{
    max-height: 600px; opacity: 1; transform: translateY(0); padding: .45rem 0 .5rem 1.1rem;
  }

  /* Submenu links */
  .primary-nav .menu li.menu-item-has-children > .sub-menu > li > a{
    display: block; padding: .6rem 1rem; font-size: .86rem;
    color: #374151; background: transparent;
  }
  .primary-nav .menu li.menu-item-has-children > .sub-menu > li > a:hover{
    background: #f0f1f3;
  }
  [data-theme="dark"] .primary-nav .menu li.menu-item-has-children > .sub-menu > li > a{
    color: #cbd5e1;
  }
  [data-theme="dark"] .primary-nav .menu li.menu-item-has-children > .sub-menu > li > a:hover{
    background: #0f172a;
  }
}



/* ================== Softerize Footer ================== */
.Home-footerDivider{
  width:100%; height:6px; border-radius:999px;
  background:linear-gradient(90deg,#1b2147 0%,#132042 25%,#0f3b34 75%,#0c6a54 100%);
  box-shadow:0 10px 22px rgba(17,24,39,.18),0 6px 14px rgba(12,106,84,.12);
}

.Home-footer{
  --ft-bg: #0b1020;
  --ft-bg2:#0f172a;
  --ft-text:#e5e7eb;
  --ft-muted:#9ca3af;
  --ft-border:#1f2937;
  --ft-link:#d1d5db;
  --ft-link-hover:#ffffff;
  background:linear-gradient(180deg,var(--ft-bg2) 0%,var(--ft-bg) 100%);
  color:var(--ft-text);
  margin-top: var(--space-9, 2.5rem);
  border-top:1px solid var(--ft-border);
}

.Home-footerInner{
  max-width: var(--container, 1200px);
  margin: 0 auto;
  padding: clamp(28px,4vw,48px) var(--gutter, 24px);
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1.2fr;
  gap: clamp(18px,2.5vw,28px);
}

.Home-footerCol{min-width:0}
.Home-footerTitle{
  font-size: clamp(1rem,1.6vw,1.125rem);
  font-weight: 700;
  letter-spacing:.2px;
  margin: 0 0 .85rem;
  color:#f3f4f6;
}

.Home-footerLogo img{
  width:160px; height:auto; display:block;
  filter: drop-shadow(0 4px 10px rgba(0,0,0,.25));
  margin-bottom:.6rem;
}

.Home-footerIntro{color:var(--ft-muted); line-height:1.6; margin:.25rem 0 1rem}

.Home-footerSocial{display:flex; gap:.6rem; list-style:none; padding:0; margin:.25rem 0 0}
.Home-footerSocial a{
  display:grid; place-items:center; width:38px; height:38px;
  border:1px solid var(--ft-border); border-radius:10px;
  color:var(--ft-link); text-decoration:none;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.Home-footerSocial a:hover{transform:translateY(-2px); background:rgba(255,255,255,.06); color:var(--ft-link-hover); border-color:#2b3649}

.Home-footerList{list-style:none; padding:0; margin:0}
.Home-footerList li{margin:.45rem 0}
.Home-footerList a{
  color:var(--ft-link); text-decoration:none;
  border-bottom:1px dashed transparent;
  transition:color .18s ease, border-color .18s ease;
}
.Home-footerList a:hover{color:var(--ft-link-hover); border-color:rgba(255,255,255,.25)}

.Home-footerNote{color:var(--ft-muted); margin:.2rem 0 .8rem}
.Home-newsletter{display:flex; gap:.5rem; align-items:center}
.Home-newsEmail{
  flex:1; min-width:0;
  background:#0e152a; color:#e5e7eb;
  border:1px solid var(--ft-border); border-radius: var(--radius, 12px);
  padding:.7rem .9rem; outline:none;
}
.Home-newsEmail::placeholder{color:#6b7280}
.Home-newsEmail:focus{border-color:#334155; box-shadow:0 0 0 3px rgba(99,102,241,.15)}

.Home-newsBtn{
  border:1px solid #3b82f6;
  background:linear-gradient(180deg,#4f46e5 0%, #3b82f6 100%);
  color:#fff; font-weight:600;
  padding:.72rem 1rem; border-radius: var(--radius-sm, 8px);
  cursor:pointer; transition:transform .16s ease, box-shadow .16s ease;
}
.Home-newsBtn:hover{transform:translateY(-1px); box-shadow:0 6px 18px rgba(59,130,246,.25)}
.Home-privacyHint{display:block; margin-top:.6rem; color:var(--ft-muted); font-size:.85rem}

.Home-subFooter{
  border-top:1px solid var(--ft-border);
  background: rgba(0,0,0,.15);
}
.Home-subFooterInner{
  max-width: var(--container, 1200px);
  margin: 0 auto;
  padding: .9rem var(--gutter, 24px);
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  font-size:.95rem; color:#cbd5e1;
}
.Home-copy,.Home-powered{margin:0}

/* A11y helper */
.Home-visuallyHidden{
  position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}

/* ===== Responsive ===== */
@media (max-width: 900px){
  .Home-footerInner{grid-template-columns:1fr 1fr; gap:18px}
}
@media (max-width: 600px){
  .Home-footerInner{grid-template-columns:1fr}
  .Home-newsletter{flex-direction:column; align-items:stretch}
  .Home-newsBtn{width:100%}
  .Home-subFooterInner{flex-direction:column; text-align:center}
}

/* ============== Brand Banner (big logo above footer) — CLEAN ============== */
.Home-brandBanner{
  /* Full-viewport, white background */
  --scroll: 0;                      /* updated by tiny JS below */
  position: relative;
  background: #ffffff;
  min-height: 100svh;
  display: grid;
  place-items: center;
  
  overflow: hidden;
  border-top: 1px solid rgba(0,0,0,.05);
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.Home-brandBanner::before{
  /* soft focus glow behind logo (very subtle, on white) */
  content:"";
  position:absolute; inset: 0;
  background:
    radial-gradient(60% 40% at 50% 45%, rgba(99,102,241,.08), transparent 70%),
    radial-gradient(40% 30% at 50% 55%, rgba(34,197,94,.05), transparent 70%);
  pointer-events:none;
  filter: blur(14px);
  transform: translateY(calc(var(--scroll) * -2px));
}
.Home-brandInner{
  max-width: var(--container, 1200px);
  margin: 0 auto; text-align: center; position: relative; z-index: 1;
}

/* WordPress Site Logo (custom_logo) — NO STRETCH */
.Home-brandBanner .custom-logo-link{ display:inline-block; line-height:0 }
.Home-brandBanner .custom-logo,
.Home-brandLogo{                 /* fallback if someone used .Home-brandLogo */
  width: auto;                   /* keep aspect ratio */
  height: auto;
  max-width: min(90vw, 1200px);  /* never overflow horizontally */
  max-height: min(26vh, 260px);  /* never overflow vertically */
  object-fit: contain;
  display: block; margin: 0 auto;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.18));
  transform:
    translateY(calc(var(--scroll) * -8px))
    scale(calc(1 + (var(--scroll) * 0.04)));
  transition: transform .2s ease;
}

/* Tagline under logo */
.Home-brandTag{
  margin-top: clamp(8px, 1.6vh, 16px);
  font-size: clamp(1rem, 1.8vw, 1.4rem);
  color: #1f2937;
  letter-spacing: .2px;
  opacity: calc(1 - (var(--scroll) * .35));
  transition: opacity .2s ease, transform .2s ease;
  transform: translateY(calc(var(--scroll) * -4px));
}

/* ============== Footer logo (bigger, safe) ============== */
.Home-footerLogo .custom-logo-link{ display:inline-block; line-height:0 }
.Home-footerLogo .custom-logo{
  width: auto; height: auto;
  max-width: clamp(220px, 24vw, 360px);
  max-height: 72px;              /* keep footer compact; no stretch */
  object-fit: contain; display:block;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.18));
    overflow: hidden;

}

/* ============== Responsive tweaks ============== */
@media (max-width: 900px){
  .Home-brandBanner{ min-height: 92svh }
  .Home-brandBanner .custom-logo,
  .Home-brandLogo{
    max-width: min(92vw, 1000px);
    max-height: min(30vh, 240px);
  }
}
@media (max-width: 600px){
  .Home-brandBanner{ min-height: 88svh }
  .Home-brandBanner .custom-logo,
  .Home-brandLogo{
    max-width: 94vw;
    max-height: min(32vh, 220px);
  }
  .Home-brandTag{ font-size: clamp(1rem, 4.5vw, 1.2rem) }
}


/* 3-column layout: first column is double width */
.Home-footerInner{
  max-width: var(--container, 1200px);
  margin: 0 auto;
  padding: clamp(28px,4vw,48px) var(--gutter, 24px);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;   /* first = double */
  gap: clamp(18px,2.5vw,28px);
}

/* Links column subsections */
.Home-footerSub{
  margin: .2rem 0 .4rem;
  font-size: .95rem;
  font-weight: 700;
  color: #e5e7eb;
}
.Home-linksGroup + .Home-linksGroup{ margin-top: .8rem }

/* Responsive: tablet → brand full row; phone → stack */
@media (max-width: 900px){
  .Home-footerInner{
    grid-template-columns: 1fr 1fr;
  }
  .Home-footerBrand{
    grid-column: 1 / -1;   /* brand spans full width on tablet */
  }
}
@media (max-width: 600px){
  .Home-footerInner{
    grid-template-columns: 1fr;
  }
}


/* ===== HERO — FINAL HARD OVERRIDES (add-only) ===== */

/* container: keep dots inside; remove stray bottom gap */
.Home-hero{ margin-bottom:0 !important; padding-bottom:0 !important; overflow:clip; }
@supports not (overflow:clip){ .Home-hero{ overflow:hidden; } }
.Home-hero .Home-heroSlider{ position:relative; padding-bottom:0 !important; margin-bottom:0 !important; }

/* slides wrapper keeps height; avoids collapsing when rules conflict */
.Home-hero .Home-heroSlides{ position:relative; min-height:clamp(520px,78svh,880px); }

/* SHOW ONLY ACTIVE SLIDE — override any earlier rule that sets display:grid */
.Home-hero .Home-heroSlides > .Home-heroSlide{
  position:relative !important;
  display:none !important;        /* hide all by default */
  min-height:inherit;
  background-image:var(--bg);
  background-size:cover; background-position:center;
  opacity:1 !important;           /* we control visibility via display */
  pointer-events:auto !important;
}
.Home-hero .Home-heroSlides > .Home-heroSlide.is-active{
  display:grid !important;        /* only active is rendered */
}

/* dots sit inside the hero, not below */
.Home-hero .Home-heroDots{
  position:absolute; left:50%; bottom:14px; transform:translateX(-50%);
  z-index:3; display:flex; gap:8px; background:rgba(0,0,0,.25);
  padding:6px 8px; border-radius:999px; backdrop-filter:blur(6px);
}

/* make sure hero inner content never bleeds while changing slides */
.Home-hero .Home-heroSlide .Home-heroInner{ will-change:opacity, transform; }

/* small touch target on mobile (optional) */
@media (max-width:600px){
  .Home-hero .Home-heroDots > button{ width:10px; height:10px; }
}
