/* ============================================================
   KORA BRANDING — modern design system
   ============================================================ */
:root{
  --black:#0c0d10;
  --ink:#15171c;
  --charcoal:#1c1f26;
  --yellow:#ffd21f;
  --yellow-deep:#e6b400;
  --yellow-soft:#fff4cc;
  --gray-700:#3a3f4a;
  --gray-600:#565d6b;
  --gray-500:#717886;
  --gray-400:#9aa0ad;
  --gray-300:#d6dae1;
  --gray-200:#e7eaef;
  --gray-100:#f1f3f6;
  --gray-50:#f8f9fb;
  --white:#ffffff;
  --surface:#ffffff;
  --border:#e6e9ef;
  --radius:18px;
  --radius-sm:12px;
  --radius-lg:26px;
  --shadow-sm:0 2px 8px rgba(15,18,25,.06);
  --shadow:0 14px 40px rgba(15,18,25,.10);
  --shadow-lg:0 30px 70px rgba(15,18,25,.18);
  --maxw:1220px;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --display:"Plus Jakarta Sans","Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--body);color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:44px 0}
.section--tight{padding:30px 0}
.bg-gray{background:var(--gray-50)}
.bg-black{background:var(--black);color:var(--white)}
.bg-mesh{background:
  radial-gradient(1100px 480px at 88% -10%, rgba(255,210,31,.16), transparent 60%),
  radial-gradient(760px 420px at -5% 110%, rgba(255,210,31,.08), transparent 55%),
  var(--black);}
.center{text-align:left}
[id]{scroll-margin-top:70px}
/* ---------- Photo-left info cards (industries / digital) ---------- */
.icards{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}
.icards--2{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}
.icard{display:flex;flex-direction:column;background:transparent;border:none;border-radius:0;overflow:visible;text-decoration:none;color:inherit;transition:transform .2s}
.icard:hover{transform:translateY(-6px)}
.icard-media{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--gray-100);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .2s}
.icard:hover .icard-media{box-shadow:var(--shadow-lg);border-color:transparent}
.icard-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s}
.icard:hover .icard-media img{transform:scale(1.06)}
.icard-body{padding:14px 4px 0;display:flex;flex-direction:column;text-align:left}
.icard-body h3{margin-bottom:0;font-size:1.05rem}
.icard:hover .icard-body h3{color:var(--yellow-deep)}
.icard-body p{font-size:.94rem;color:var(--gray-600)}
@media(max-width:560px){.icards,.icards--2{grid-template-columns:repeat(2,1fr);gap:12px}.icard-body h3{font-size:.9rem}}
/* ---------- Deals / offers cards ---------- */
.deals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.deal-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px 26px;transition:transform .2s,box-shadow .2s}
.deal-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.deal-badge{align-self:flex-start;background:var(--yellow);color:var(--ink);font-family:var(--display);font-weight:800;font-size:.8rem;letter-spacing:.04em;padding:6px 14px;border-radius:50px;margin-bottom:16px}
.deal-card h3{font-size:1.3rem;margin-bottom:8px}
.deal-card p{color:var(--gray-600);font-size:.95rem;flex:1}
.deal-card .fine{font-size:.82rem;color:var(--gray-400);margin-top:12px}
.deal-card .btn{align-self:flex-start;margin-top:18px}
.legal{max-width:820px}
.legal h2{font-size:1.4rem;margin:34px 0 12px}
.legal p,.legal li{color:var(--gray-700);line-height:1.75}
.legal ul{margin:10px 0 10px 22px}
.legal .upd{color:var(--gray-500);font-size:.92rem;margin-bottom:8px}
.ind-card{scroll-margin-top:140px}

h1,h2,h3,h4{font-family:var(--display);line-height:1.08;font-weight:700;letter-spacing:-.03em;color:var(--ink)}
h1{font-size:clamp(2.6rem,5.6vw,4.6rem);font-weight:600;line-height:1.03;letter-spacing:-.038em}
h2{font-size:clamp(1.55rem,2.6vw,2.15rem);font-weight:600;letter-spacing:-.034em}
h3{font-size:1.22rem;font-weight:700;letter-spacing:-.015em}
p{color:var(--gray-600)}
.lead{font-size:1.05rem;color:var(--gray-500);max-width:680px;line-height:1.55;font-weight:400}
.bg-black p,.bg-mesh p,.bg-black .lead{color:#c4c9d4}
.bg-black h1,.bg-black h2,.bg-black h3,.bg-black h4,.bg-mesh h1,.bg-mesh h2,.bg-mesh h3,.bg-mesh h4{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gray-500);background:none;padding:0;margin-bottom:14px}
.eyebrow::before{content:none}
.bg-black .eyebrow,.bg-mesh .eyebrow{color:var(--gray-300)}
.section-head{max-width:760px;margin:0 0 24px}
.section-head .lead{margin-top:10px}
.section-head.center{margin-left:0;margin-right:0;text-align:left}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:.92rem;
  padding:10px 18px;border-radius:9px;cursor:pointer;border:2px solid transparent;transition:transform .25s cubic-bezier(.4,.2,.2,1),box-shadow .25s,background .2s,color .2s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--yellow);color:var(--ink)}
.btn--primary:hover{background:#ffdb47;transform:translateY(-2px)}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--gray-300)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--ghost-light{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28)}
.btn--ghost-light:hover{background:#fff;color:var(--ink);border-color:#fff;transform:translateY(-2px)}
.btn--wa{background:#25D366;color:#fff}
.btn--wa:hover{background:#1da851;transform:translateY(-2px)}
.btn--lg{padding:12px 22px;font-size:.95rem}
.btn--sm{padding:8px 14px;font-size:.84rem}

/* ---------- Top bar ---------- */
.topbar{background:var(--black);color:#cfd3db;font-size:.84rem;position:relative;z-index:101}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:18px;height:40px}
.topbar a:hover{color:var(--yellow)}
.topbar .tb-right{display:flex;gap:18px;align-items:center;flex:none}
.tb-marquee{flex:1;min-width:0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent)}
.tb-track{display:flex;width:max-content;animation:tbscroll 42s linear infinite}
.topbar:hover .tb-track{animation-play-state:paused}
.tb-promo{color:var(--yellow);font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;margin-right:60px}
.tb-ic{width:14px;height:14px;fill:currentColor;margin-right:8px;flex:none}
@keyframes tbscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.tb-track{animation:none}.tb-marquee{overflow-x:auto}}
.ci{width:16px;height:16px;flex:none;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.form-note .ci{display:inline-block;vertical-align:-3px;margin-right:5px;stroke:var(--gray-500)}

/* ---------- Header ---------- */
.site-header{position:relative;z-index:100;background:transparent;border:0;padding:12px 18px}
.navbar{max-width:1240px;margin:0 auto;background:rgba(255,255,255,.97);-webkit-backdrop-filter:blur(14px) saturate(1.4);backdrop-filter:blur(14px) saturate(1.4);
  border:1px solid rgba(230,233,239,.9);box-shadow:0 12px 34px rgba(15,18,25,.12);border-radius:22px;padding:0 18px;transition:box-shadow .3s,background .3s}
.navbar.scrolled{box-shadow:0 18px 48px rgba(15,18,25,.18);background:rgba(255,255,255,.99)}
.nav-top{display:flex;align-items:center;gap:18px;height:64px}
.nav-bottom{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);height:48px}
.hsearch{flex:1;max-width:540px;display:flex;align-items:center;gap:10px;background:var(--gray-50);border:1px solid var(--border);border-radius:50px;padding:0 16px;height:42px;cursor:text;transition:.15s}
.hsearch:hover,.hsearch:focus-within{border-color:var(--gray-300);background:#fff}
.hsearch .hs-ic{width:18px;height:18px;flex:none;fill:none;stroke:var(--gray-400);stroke-width:2;stroke-linecap:round}
.hsearch input{flex:1;border:0;background:transparent;outline:0;font-family:inherit;font-size:.95rem;cursor:text;color:var(--ink);min-width:0}
.nav-bottom .nav-links{gap:4px}
.nav-bottom .nav-links>li>a{padding:8px 13px;font-size:.95rem}
.nav-cta{flex:none}
.nav-top .nav-cta{gap:10px}
.nav-top .nav-cta .btn{padding:11px 20px;font-size:.93rem}
.nav-bottom .nav-links{flex:1;justify-content:space-between}
.nav-bottom .nav-links>li>a.nav-deal{color:var(--yellow-deep);font-weight:800}
.nav-bottom .nav-links>li>a.nav-deal:hover{background:var(--yellow-soft);color:var(--yellow-deep)}
.site-header .basket-btn{width:42px;height:42px;border-radius:12px;border-color:var(--gray-200)}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand-logo{height:40px;width:auto;max-width:none;flex:none;display:block}
.footer .brand-logo{height:52px}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links>li>a{display:inline-flex;align-items:center;gap:5px;padding:10px 11px;border-radius:10px;font-weight:600;font-size:.93rem;color:var(--gray-700);transition:.15s;white-space:nowrap}
.nav-links>li>a:hover,.nav-links>li>a.active{background:var(--gray-100);color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:10px}
.has-dropdown{position:relative}
.has-dropdown>a::after{content:"▾";font-size:1em;margin-left:6px;opacity:1;color:var(--yellow-deep);font-weight:700;display:inline-block;transition:transform .2s}
.has-dropdown:hover>a::after{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 10px);left:0;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);min-width:280px;padding:10px;opacity:0;visibility:hidden;transform:translateY(10px);transition:.18s;list-style:none}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:.92rem;font-weight:500;color:var(--gray-700)}
.dropdown li a:hover{background:var(--yellow-soft);color:var(--ink)}
.dropdown li a::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--yellow-deep);flex:0 0 auto}
.dropdown{max-height:min(74vh,560px);overflow-y:auto}
.dropdown .dh{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-400);padding:11px 12px 5px;pointer-events:none}
.dropdown .dh:first-child{padding-top:4px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:36px 24px 42px}
/* Hero slider */
.hero-slider{position:relative;overflow:hidden}
.hero-track{display:flex;transition:transform .9s cubic-bezier(.55,0,.2,1);will-change:transform}
.hslide{flex:0 0 100%;min-width:0;display:flex;align-items:center}
.hslide>.container{width:100%}
.hs-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.12);color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;display:grid;place-items:center;backdrop-filter:blur(6px);transition:background .2s,color .2s}
.hs-arrow:hover{background:#fff;color:var(--ink)}
.hs-prev{left:16px}.hs-next{right:16px}
.hs-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:9px}
.hs-dots button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.42);cursor:pointer;padding:0;transition:width .25s,background .25s}
.hs-dots button.active{background:var(--yellow);width:26px;border-radius:6px}
@media(max-width:760px){.hs-arrow{display:none}.hs-dots{bottom:14px}}
.hero h1{font-size:clamp(1.95rem,2.9vw,2.65rem);line-height:1.07}
.hero h1 .hl{color:transparent;-webkit-text-stroke:0;background:linear-gradient(100deg,var(--yellow),#ffb800);-webkit-background-clip:text;background-clip:text}
.hero p{font-size:1.08rem;margin:16px 0 24px;max-width:540px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{margin-top:18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:.92rem;color:var(--gray-500)}
.hero-trust .stars{color:var(--yellow-deep);letter-spacing:2px}
.hero-visual{position:relative}
.hero-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/11}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 56%}
.hero-badge{position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:14px 18px;display:flex;align-items:center;gap:12px}
.hero-badge .ic{width:42px;height:42px;border-radius:11px;background:var(--yellow);display:grid;place-items:center;flex:0 0 auto}
.hero-badge .ic svg{width:22px;height:22px;stroke:var(--ink)}
.hero-badge b{font-family:var(--display);font-size:1.05rem;display:block;line-height:1.1}
.hero-badge span{font-size:.78rem;color:var(--gray-500)}
.hero-badge.b1{left:-26px;bottom:36px}
.hero-badge.b2{right:-22px;top:40px}

/* ---------- Trust strip ---------- */
.trust{background:var(--yellow);overflow:hidden}
.trust-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.trust-track{display:flex;width:max-content;animation:trustscroll 34s linear infinite}
.trust:hover .trust-track{animation-play-state:paused}
.trust-item{display:flex;align-items:center;gap:10px;font-weight:700;font-family:var(--display);color:var(--ink);font-size:.97rem;white-space:nowrap;padding:20px 0;margin-right:70px}
.trust-item svg{width:22px;height:22px;flex:0 0 auto;stroke:var(--ink)}
@keyframes trustscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.trust-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:14px}.trust-marquee{overflow:visible;-webkit-mask-image:none;mask-image:none}}

/* ---------- Category / media cards ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}
.cat-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.cat-card{background:transparent;border:none;border-radius:0;overflow:visible;box-shadow:none;transition:transform .2s;display:flex;flex-direction:column}
.cat-card:hover{transform:translateY(-6px)}
.cat-card .media{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--gray-100);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .2s}
.cat-card:hover .media{box-shadow:var(--shadow-lg);border-color:transparent}
.cat-card .media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s}
.cat-card:hover .media img{transform:scale(1.06)}
.cat-card .tag{position:absolute;top:14px;left:14px;z-index:2;background:rgba(255,255,255,.92);color:var(--ink);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:50px}
.cat-card .body{padding:14px 4px 0;display:flex;flex-direction:column;text-align:left}
.cat-card h3{margin-bottom:0;font-size:.95rem}
.cat-card:hover h3{color:var(--yellow-deep)}
.cat-card p{font-size:.95rem;flex:1}
/* Horizontal single-row scroller (homepage card sections) */
.hscroll{position:relative}
.hrow{display:flex;gap:16px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;padding:2px 2px 12px;scrollbar-width:thin}
.hrow::-webkit-scrollbar{height:8px}
.hrow::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}
.hrow::-webkit-scrollbar-track{background:transparent}
.hrow>*{flex:0 0 190px;scroll-snap-align:start}
.hscroll-arrow{position:absolute;top:42%;transform:translateY(-50%);z-index:4;width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow);cursor:pointer;font-size:1.6rem;line-height:1;color:var(--ink);display:grid;place-items:center;transition:background .15s,border-color .15s}
.hscroll-arrow:hover{background:var(--yellow);border-color:var(--yellow)}
.hscroll-arrow.hs-l{left:-8px}
.hscroll-arrow.hs-r{right:-8px}
@media(max-width:560px){.hrow>*{flex-basis:150px}.hscroll-arrow{display:none}}
.cat-card .more{margin-top:16px;font-family:var(--display);font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:gap .2s}
.cat-card:hover .more{gap:12px;color:var(--yellow-deep)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.stats .num{font-family:var(--display);font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:800;color:var(--yellow);line-height:1}
.stats .lbl{color:#c4c9d4;font-weight:500;margin-top:8px}
/* Mobile moving stats marquee */
.stats-mq{display:none;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.stats-mq-track{display:flex;width:max-content;animation:statscroll 20s linear infinite}
.stats-mq .st{flex:0 0 auto;text-align:center;padding:0 26px}
.stats-mq .num{font-family:var(--display);font-size:2rem;font-weight:800;color:var(--yellow);line-height:1}
.stats-mq .lbl{color:#c4c9d4;font-weight:500;margin-top:6px;font-size:.88rem;white-space:nowrap}
@keyframes statscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.stats-mq-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:18px 0}}

/* ---------- Why-us feature cards ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px;transition:.2s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.feature .ic{width:54px;height:54px;border-radius:14px;background:var(--yellow);display:grid;place-items:center;margin-bottom:18px}
.feature .ic svg{width:28px;height:28px;stroke:var(--ink)}
.feature h3{margin-bottom:8px}
.feature p{font-size:.95rem}
a.feature{text-decoration:none;color:inherit;cursor:pointer;display:flex;flex-direction:column}
a.feature p{flex:1}
.feature .more{margin-top:14px;font-family:var(--display);font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:gap .2s}
a.feature:hover .more{gap:12px;color:var(--yellow-deep)}
/* event service detail */
.evs-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.evs-includes{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;margin-top:8px}
.evs-includes li{display:flex;gap:10px;align-items:flex-start;font-size:.96rem;color:var(--gray-700)}
.evs-includes li svg{width:20px;height:20px;stroke:var(--yellow-deep);fill:none;stroke-width:2.4;flex:0 0 auto;margin-top:2px}
.evs-includes--links{gap:12px 18px}
.evs-includes--links li{display:block}
.evs-includes--links li a{display:flex;align-items:center;gap:11px;padding:13px 16px;background:var(--gray-50);border:1px solid var(--border);border-radius:12px;color:var(--gray-700);font-weight:500;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}
.evs-includes--links li a span{flex:1}
.evs-includes--links li a svg{margin-top:0}
.evs-includes--links li a::after{content:"→";color:var(--gray-400);font-weight:700;transition:transform .18s,color .18s}
.evs-includes--links li a:hover{background:#fff;border-color:var(--yellow-deep);box-shadow:0 8px 20px rgba(15,18,25,.07);transform:translateY(-2px)}
.evs-includes--links li a:hover::after{color:var(--yellow-deep);transform:translateX(4px)}
.evs-related{display:flex;flex-wrap:wrap;gap:10px}
.evs-related a{font-size:.88rem;font-weight:600;padding:8px 15px;border-radius:50px;background:var(--gray-100);color:var(--gray-700);transition:.15s}
.evs-related a:hover{background:var(--yellow);color:var(--ink)}
@media(max-width:880px){.evs-hero{grid-template-columns:1fr;gap:30px}.evs-includes{grid-template-columns:1fr}}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px 26px 26px}
.step .n{position:absolute;top:-18px;left:26px;width:42px;height:42px;border-radius:12px;background:var(--ink);color:var(--yellow);font-family:var(--display);font-weight:800;font-size:1.1rem;display:grid;place-items:center}
.step h3{margin:16px 0 7px;font-size:1.1rem}
.step p{font-size:.93rem}

/* ---------- Work gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery .shot{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1/1;background:var(--gray-100)}
.gallery .shot.wide{grid-column:span 2;aspect-ratio:2/1}
.gallery .shot img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery .shot:hover img{transform:scale(1.07)}

/* ---------- Logos ---------- */
.logos{display:flex;flex-wrap:wrap;gap:16px 42px;justify-content:center;align-items:center}
.logos span{font-family:var(--display);font-weight:800;color:var(--gray-400);font-size:1.05rem}
.logo-marquee{margin-top:30px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logo-track{display:flex;align-items:center;gap:60px;width:max-content;animation:logoscroll 70s linear infinite}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-track img{height:46px;width:auto;flex:0 0 auto;opacity:.6;filter:grayscale(1);transition:opacity .25s,filter .25s}
.logo-track img:hover{opacity:1;filter:grayscale(0)}
@keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (max-width:640px){.logo-track{gap:40px}.logo-track img{height:38px}}
@media (prefers-reduced-motion:reduce){.logo-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}

/* ---------- Testimonials ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
/* Moving testimonials row */
.tmarquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.ttrack{display:flex;align-items:stretch;gap:26px;width:max-content;animation:revscroll 45s linear infinite}
.tmarquee:hover .ttrack{animation-play-state:paused}
.ttrack .tcard{flex:0 0 380px;width:380px;display:flex;flex-direction:column}
.ttrack .tcard p{display:-webkit-box;-webkit-line-clamp:7;-webkit-box-orient:vertical;overflow:hidden}
.ttrack .tcard .who{margin-top:auto;padding-top:18px}
@keyframes revscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:640px){.ttrack .tcard{flex-basis:300px;width:300px}}
@media(prefers-reduced-motion:reduce){.ttrack{animation:none;flex-wrap:wrap;width:auto;justify-content:center}.tmarquee{overflow:visible;-webkit-mask-image:none;mask-image:none}}
.tcard{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.tcard .stars{color:var(--yellow-deep);font-size:1.05rem;letter-spacing:2px;margin-bottom:14px}
.tcard p{color:var(--gray-700);font-style:italic}
.tcard .who{margin-top:18px;display:flex;align-items:center;gap:12px}
.tcard .who .av{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--yellow);font-family:var(--display);font-weight:800;display:grid;place-items:center;flex:0 0 auto}
.tcard .who b{font-family:var(--display);font-size:.96rem;display:block}
.tcard .who span{font-size:.83rem;color:var(--gray-500)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:54px;display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap}
.cta-band::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,210,31,.30),transparent 65%)}
.cta-band>div{position:relative;z-index:1}
.cta-band h2{color:#fff;max-width:620px}
.cta-band p{color:#c4c9d4;margin-top:10px;max-width:560px}
.cta-band.yellow{background:var(--yellow)}
.cta-band.yellow h2{color:var(--ink)}
.cta-band.yellow p{color:#5a4d12}
.cta-band.yellow::before{background:radial-gradient(circle,rgba(255,255,255,.5),transparent 65%)}

/* ---------- Footer ---------- */
.footer{background:var(--black);color:#aeb4c0;padding:0 0 28px;position:relative}
.footer::before{content:"";display:block;width:100%;height:clamp(220px,32vw,440px);background-image:linear-gradient(to bottom,var(--white) 0%,rgba(255,255,255,0) 26%,rgba(12,13,16,0) 50%,var(--black) 100%),url('img/footer-kigali.jpg');background-size:cover,cover;background-position:center 44%,center 44%;background-repeat:no-repeat,no-repeat;background-color:#0a0c10}
.footer>.container{padding-top:56px}
.footer a:hover{color:var(--yellow)}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.25fr;gap:42px}
.footer h4{font-family:var(--display);color:#fff;font-size:1.02rem;margin-bottom:16px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:.92rem}
.footer .fdesc{margin:18px 0;font-size:.93rem;max-width:300px;line-height:1.6}
.fcontact li{display:flex;gap:10px;align-items:flex-start;font-size:.92rem}
.fsocial{display:flex;gap:10px;margin-top:8px}
.fsocial a{width:38px;height:38px;border-radius:10px;background:#1a1d24;display:grid;place-items:center;transition:.2s}
.fsocial a:hover{background:var(--yellow)}
.fsocial svg{width:18px;height:18px;fill:#cfd3db}
.fsocial a:hover svg{fill:var(--ink)}
.fbar{border-top:1px solid #20242c;margin-top:52px;padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.85rem;color:#7c828f}

/* ---------- Inner page hero ---------- */
.page-hero{position:relative;overflow:hidden;padding:88px 0 58px;background:
  radial-gradient(1100px 480px at 88% -10%, rgba(255,210,31,.18), transparent 60%),
  radial-gradient(760px 420px at -5% 110%, rgba(255,210,31,.08), transparent 55%),
  var(--black)}
.page-hero .crumb{font-size:.82rem;letter-spacing:.04em;color:#aeb4c0;margin-bottom:20px;display:inline-flex;align-items:center;gap:10px}
.page-hero .crumb::before{content:none}
.page-hero .crumb a:hover{color:var(--yellow)}
.page-hero h1{color:#fff;max-width:20ch;font-size:clamp(1.9rem,3.2vw,2.55rem);line-height:1.08}
.page-hero p{color:#c4c9d4;margin-top:12px;max-width:660px;font-size:1.05rem;line-height:1.55}

/* ---------- Products page ---------- */
.prodnav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:12px 0}
.prodnav .container{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}
.prodnav .container::-webkit-scrollbar{display:none}
.prodnav a{white-space:nowrap;font-size:.88rem;font-weight:600;padding:9px 15px;border-radius:50px;background:var(--gray-100);color:var(--gray-700);transition:.15s}
.prodnav a:hover{background:var(--yellow);color:var(--ink)}
.prod-cat{margin-bottom:64px;scroll-margin-top:150px}
.prod-cat-head{display:flex;align-items:center;gap:16px;margin-bottom:26px;padding-bottom:16px;border-bottom:3px solid var(--yellow)}
.prod-cat-head .ic{display:none}
.prod-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}
.pitem{display:flex;flex-direction:column;background:transparent;text-align:left;transition:transform .18s}
.pitem:hover{transform:translateY(-5px)}
.pitem-link{text-decoration:none;color:inherit;display:flex;flex-direction:column}
.pitem .media{aspect-ratio:1/1;background:var(--gray-100);overflow:hidden;border-radius:var(--radius-sm);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .18s,border-color .18s}
.pitem:hover .media{box-shadow:var(--shadow);border-color:var(--yellow)}
.pitem .media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .4s}
.pitem:hover .media img{transform:scale(1.06)}
.pitem .pitem-name{font-family:var(--display);font-size:1rem;font-weight:700;margin-top:12px}
.pitem:hover .pitem-name{color:var(--yellow-deep)}
.pitem .pitem-desc{font-size:.84rem;color:var(--gray-600);margin-top:5px}
.pitem .pitem-cta{display:inline-block;margin-top:8px;font-size:.85rem;font-weight:700;color:var(--ink);font-family:var(--display);text-decoration:none}
.pitem .pitem-cta:hover{color:var(--yellow-deep)}

/* ---------- About ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.media-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3}
.media-frame img{width:100%;height:100%;object-fit:cover}

/* ---------- FAQ ---------- */
.faq{max-width:860px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:14px;overflow:hidden;background:#fff}
.faq-q{width:100%;text-align:left;background:#fff;border:0;padding:21px 24px;font-family:var(--display);font-size:1.05rem;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.faq-q:hover{background:var(--gray-50)}
.faq-q .plus{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-items:center;font-weight:800;transition:.2s}
.faq-item.open .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s ease;background:var(--gray-50)}
.faq-a p{padding:0 24px 22px}
.faq-item.open .faq-a{max-height:420px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.req{color:#e11d2a;font-weight:700;margin-left:1px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--gray-300);border-radius:11px;font-family:inherit;font-size:.96rem;transition:.15s;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--yellow-deep);box-shadow:0 0 0 3px rgba(255,210,31,.28)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.info-block{margin-bottom:24px}
.info-block h3{font-size:1.05rem;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.info-block .ic{width:42px;height:42px;border-radius:11px;background:var(--yellow);display:grid;place-items:center;flex:0 0 auto}
.info-block .ic svg{width:22px;height:22px;stroke:var(--ink)}
.info-block p{color:var(--gray-700);font-size:.96rem;margin-left:52px}
.info-block p a:hover{color:var(--yellow-deep)}
.map-embed{border:0;width:100%;height:280px;border-radius:var(--radius);margin-top:8px}
.form-success{display:none;background:#e9f9ef;border:1px solid #25D366;color:#13703c;padding:14px 18px;border-radius:11px;margin-bottom:18px;font-weight:600}

/* ---------- Product detail / configurator ---------- */
.product-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.gallery-main{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--gray-100);box-shadow:var(--shadow)}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-main{position:relative}
.gal-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);transition:background .15s,transform .15s}
.gal-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.07)}
.gal-prev{left:12px}.gal-next{right:12px}
.card-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:30px;height:30px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:var(--ink);font-size:1.15rem;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-sm);opacity:0;transition:opacity .15s,background .15s}
.pitem:hover .card-arrow{opacity:1}
.card-prev{left:8px}.card-next{right:8px}
@media(hover:none){.card-arrow{opacity:.95}}
/* Plan-your-event form */
.plan-h{font-family:var(--display);font-weight:700;font-size:1.05rem;margin:28px 0 14px;padding-bottom:8px;border-bottom:1px solid var(--border);color:var(--ink)}
.needs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px;margin-bottom:6px}
.needs-grid label{display:flex;align-items:center;gap:10px;padding:11px 14px;border:1px solid var(--border);border-radius:12px;cursor:pointer;font-size:.92rem;background:#fff;transition:border-color .15s,background .15s}
.needs-grid label:hover{border-color:var(--ink)}
.needs-grid input{accent-color:var(--yellow-deep);width:17px;height:17px;flex:0 0 auto}
.needs-grid label:has(input:checked){border-color:var(--yellow-deep);background:rgba(255,210,31,.12)}
.gallery-thumbs{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.gallery-thumbs img{width:88px;height:66px;object-fit:cover;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:.15s}
.gallery-thumbs img:hover{border-color:var(--gray-300)}
.gallery-thumbs img.active{border-color:var(--yellow-deep)}
.product-tag{display:inline-block;background:var(--yellow-soft);color:#7a6200;font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:50px;margin-bottom:12px}
/* "From" prices */
.price-from{margin-top:6px;font-family:var(--display);font-weight:800;font-size:.9rem;color:var(--ink);text-align:left}
.price-from::before{content:none}
.price-block{margin:14px 0 4px;padding:14px 16px;background:var(--yellow-soft);border:1px solid #f0dca0;border-radius:12px}
.price-block .pf{display:block;font-family:var(--display);font-weight:800;font-size:1.35rem;color:var(--ink);line-height:1.1}
.price-block small{display:block;margin-top:5px;font-size:.82rem;color:#7a6200}
.product-info h1{font-size:clamp(1.8rem,3.4vw,2.4rem);margin-bottom:8px}
.product-info .short{font-size:1.1rem;color:var(--gray-600);margin-bottom:18px}
.specs-acc{margin-top:22px;border-top:1px solid var(--border)}
.specs-acc>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 2px;font-family:var(--display);font-weight:700;font-size:1.15rem;color:var(--ink)}
.specs-acc>summary::-webkit-details-marker{display:none}
.specs-acc>summary::after{content:"";width:10px;height:10px;border-right:2.5px solid var(--gray-500);border-bottom:2.5px solid var(--gray-500);transform:rotate(45deg);transition:transform .2s;flex:0 0 auto;margin-right:4px}
.specs-acc[open]>summary::after{transform:rotate(-135deg)}
.qty-input{margin-top:12px;width:100%;max-width:240px;border:1.5px solid var(--gray-300);border-radius:12px;padding:11px 14px;font-family:inherit;font-size:.95rem;color:var(--ink);outline:0}
.qty-input:focus{border-color:var(--ink)}
.chip-custom{border-style:dashed}
.specs-table{width:100%;border-collapse:collapse;margin-top:8px}
.specs-table td{padding:10px 0;border-bottom:1px solid var(--border);font-size:.93rem;vertical-align:top;color:var(--gray-700)}
.specs-table td:first-child{font-weight:600;width:36%;color:var(--ink)}
.config{position:sticky;top:100px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.config h3{font-size:1.15rem;margin-bottom:4px}
.config .step-note{font-size:.85rem;color:var(--gray-500);margin-bottom:18px}
.opt-group{margin-bottom:18px}
.opt-group .lbl{font-family:var(--display);font-weight:700;font-size:.9rem;margin-bottom:9px;display:flex;align-items:center;gap:8px}
.opt-group .lbl .n{width:20px;height:20px;border-radius:50%;background:var(--ink);color:var(--yellow);font-size:.7rem;display:grid;place-items:center;flex:0 0 auto}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1.5px solid var(--gray-300);background:#fff;border-radius:50px;padding:8px 14px;font-size:.86rem;cursor:pointer;transition:.15s;font-weight:600;color:var(--gray-700)}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--yellow);border-color:var(--yellow);color:var(--ink)}
/* Plan selector cards */
.plan-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.plan-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;text-align:left;border:1.5px solid var(--gray-300);background:#fff;border-radius:14px;padding:16px;cursor:pointer;transition:.15s;gap:7px}
.plan-card:hover{border-color:var(--ink)}
.plan-card.active{background:#fff;border-color:var(--yellow);box-shadow:0 0 0 3px var(--yellow-soft)}
.plan-card .pc-name{font-family:var(--display);font-weight:800;font-size:1rem;color:var(--ink)}
.plan-card .pc-price{font-family:var(--display);font-weight:800;color:var(--ink);font-size:1.16rem;display:flex;align-items:baseline;gap:5px;flex-wrap:wrap}
.plan-card .pc-price small{font-weight:600;font-size:.72rem;color:var(--gray-500)}
.plan-card .pc-feat{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:6px;font-size:.8rem;color:var(--gray-700);font-weight:500}
.plan-card .pc-feat li{position:relative;padding-left:18px;line-height:1.3}
.plan-card .pc-feat li:before{content:"✓";position:absolute;left:0;top:0;color:var(--yellow-deep);font-weight:800}
.plan-card .pc-best{position:absolute;top:-9px;right:12px;background:var(--ink);color:var(--yellow);font-size:.62rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:50px}
.pf-per{font-weight:600;font-size:.78rem;color:#7a6200}
@media(max-width:680px){.plan-cards{grid-template-columns:1fr}}
/* Digital Services page */
.ds-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:8px}
.ds-pillar{background:#fff;border:1px solid var(--gray-200);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm)}
.ds-pillar .ic{width:48px;height:48px;border-radius:12px;background:var(--yellow-soft);display:grid;place-items:center;margin-bottom:14px}
.ds-pillar .ic svg{width:24px;height:24px;stroke:var(--ink)}
.ds-pillar h3{font-family:var(--display);font-size:1.1rem;margin-bottom:6px}
.ds-pillar p{color:var(--gray-700);font-size:.92rem;line-height:1.5}
.ds-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:8px}
.ds-step{position:relative;padding:24px;border-radius:16px;border:1px dashed var(--gray-300)}
.ds-step .num{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--yellow);font-family:var(--display);font-weight:800;margin-bottom:12px}
.ds-step h3{font-family:var(--display);font-size:1.05rem;margin-bottom:6px}
.ds-step p{color:var(--gray-700);font-size:.92rem;line-height:1.5}
@media(max-width:820px){.ds-pillars,.ds-steps{grid-template-columns:1fr}}
.summary{background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:12px;padding:16px 18px;margin:8px 0 18px}
.summary h4{font-family:var(--display);font-size:.95rem;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.summary ul{list-style:none;font-size:.9rem;color:var(--gray-700);display:flex;flex-direction:column;gap:6px}
.summary li{display:flex;justify-content:space-between;gap:14px}
.summary li b{color:var(--ink);font-weight:700;text-align:right}
.config .field{margin-bottom:14px}
.breadcrumb-bar{background:#fff;border-bottom:1px solid var(--border);padding:14px 0}
.breadcrumb-bar .container{font-size:.88rem;color:var(--gray-500)}
.breadcrumb-bar a:hover{color:var(--yellow-deep)}

/* ---------- Basket: header icon + badge ---------- */
.search-btn{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;border:1.5px solid var(--gray-300);background:#fff;cursor:pointer;transition:.15s}
.search-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.search-btn svg{width:21px;height:21px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round}
.search-modal{position:fixed;inset:0;z-index:210;background:rgba(12,13,16,.55);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:.2s;display:flex;align-items:flex-start;justify-content:center;padding:14vh 18px 18px}
.search-modal.open{opacity:1;visibility:visible}
.search-card{width:100%;max-width:620px;background:#fff;border-radius:18px;box-shadow:0 30px 70px rgba(0,0,0,.35);overflow:hidden;transform:translateY(-12px);transition:.2s}
.search-modal.open .search-card{transform:none}
.search-input-row{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border)}
.search-input-row .si{width:22px;height:22px;stroke:var(--gray-400);fill:none;stroke-width:2;flex:none}
.search-input-row input{flex:1;border:0;outline:0;font-family:inherit;font-size:1.05rem;background:transparent}
.search-close{border:0;background:var(--gray-100);width:32px;height:32px;border-radius:8px;cursor:pointer;color:var(--gray-500);font-size:.9rem;flex:none}
.search-close:hover{background:var(--gray-200);color:var(--ink)}
.search-results{max-height:54vh;overflow-y:auto;padding:8px}
.search-count{font-size:.8rem;color:var(--gray-400);padding:8px 12px 4px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.sresult{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:11px;text-decoration:none;transition:.12s}
.sresult:hover{background:var(--gray-50)}
.sr-name{font-weight:600;color:var(--ink);flex:1}
.sr-cat{font-size:.82rem;color:var(--gray-400)}
.sr-go{color:var(--yellow-deep);font-weight:700}
.sresult--more{border-top:1px dashed var(--border);margin-top:6px;border-radius:0 0 11px 11px}
.sresult--more .sr-name{color:var(--gray-500);font-weight:500}
.search-hint{padding:18px 14px}
.search-hint p{font-size:.8rem;color:var(--gray-400);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}
.schips{display:flex;flex-wrap:wrap;gap:8px}
.schip{border:1px solid var(--gray-300);background:#fff;border-radius:50px;padding:8px 15px;font-family:inherit;font-size:.88rem;cursor:pointer;transition:.12s;color:var(--ink)}
.schip:hover{border-color:var(--yellow-deep);background:var(--gray-50)}
.search-empty{text-align:center;padding:34px 22px}
.search-empty .se-ic{margin-bottom:10px}
.search-empty .se-ic svg{width:42px;height:42px;stroke:var(--gray-400);fill:none}
.file-list li svg.ci{stroke:var(--gray-500)}
.search-empty h3{font-size:1.2rem;margin-bottom:8px}
.search-empty p{color:var(--gray-500);max-width:380px;margin:0 auto 18px}
.se-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
@media(max-width:560px){.search-modal{padding:8vh 12px 12px}.search-input-row input{font-size:1rem}}
.basket-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;border:1.5px solid var(--gray-300);background:#fff;cursor:pointer;transition:.15s}
.basket-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.basket-btn svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:2}
.basket-badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:50px;background:var(--ink);color:var(--yellow);font-family:var(--display);font-size:.72rem;font-weight:800;display:none;align-items:center;justify-content:center}
.basket-badge.show{display:flex}
/* Currency switcher */
.cur-switch{position:relative}
.cur-btn{display:inline-flex;align-items:center;gap:5px;height:46px;padding:0 10px;border-radius:12px;border:1.5px solid var(--gray-300);background:#fff;cursor:pointer;font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--ink);transition:.15s}
.cur-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.cur-globe{width:17px;height:17px;fill:none;stroke:var(--ink);stroke-width:1.7}
.cur-car{width:14px;height:14px;fill:none;stroke:var(--gray-500);stroke-width:2.4;transition:transform .2s}
.cur-switch.open .cur-car{transform:rotate(180deg)}
.cur-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:148px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;margin:0;list-style:none;opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s;z-index:120}
.cur-switch.open .cur-menu{opacity:1;visibility:visible;transform:translateY(0)}
.cur-menu li{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 12px;border-radius:9px;cursor:pointer;font-size:.92rem;color:var(--ink)}
.cur-menu li small{color:var(--gray-500);font-weight:700}
.cur-menu li:hover{background:var(--gray-100)}
.cur-menu li.on{background:var(--yellow);font-weight:700}
.cur-menu li.on small{color:var(--ink)}
@media(max-width:1024px){.cur-btn{height:42px;padding:0 8px}.cur-globe{display:none}}

/* ---------- Basket drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(12,13,16,.5);opacity:0;visibility:hidden;transition:.25s;z-index:200}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:#fff;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .28s ease;z-index:201;display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border)}
.drawer-head h3{font-size:1.2rem}
.drawer-close{background:none;border:0;cursor:pointer;font-size:1.6rem;line-height:1;color:var(--gray-500);padding:4px 8px;border-radius:8px}
.drawer-close:hover{background:var(--gray-100);color:var(--ink)}
.drawer-body{flex:1;overflow-y:auto;padding:18px 22px}
.drawer-foot{border-top:1px solid var(--border);padding:18px 22px;display:flex;flex-direction:column;gap:10px}
.basket-empty{text-align:center;color:var(--gray-500);padding:50px 10px}
.basket-empty svg{width:54px;height:54px;stroke:var(--gray-300);fill:none;stroke-width:1.6;margin-bottom:14px}

/* basket line item */
.bitem{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}
.bitem:last-child{border-bottom:0}
.bitem .thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;flex:0 0 auto;background:var(--gray-100)}
.bitem .info{flex:1;min-width:0}
.bitem .info h4{font-family:var(--display);font-size:1rem;margin-bottom:4px}
.bitem .specs{font-size:.82rem;color:var(--gray-500);line-height:1.5}
.bitem .row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:10px}
.qty-ctrl{display:inline-flex;align-items:center;border:1px solid var(--gray-300);border-radius:50px;overflow:hidden}
.qty-ctrl button{width:30px;height:30px;border:0;background:#fff;cursor:pointer;font-size:1.1rem;line-height:1;color:var(--ink)}
.qty-ctrl button:hover{background:var(--gray-100)}
.qty-ctrl span{min-width:30px;text-align:center;font-weight:700;font-size:.9rem}
.bprice{margin-top:6px;font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--ink)}
.basket-subtotal{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.basket-subtotal span{font-size:.9rem;color:var(--gray-500)}
.basket-subtotal b{font-family:var(--display);font-size:1.25rem;color:var(--ink)}
.basket-note{font-size:.78rem;color:var(--gray-500);margin:2px 0 6px;line-height:1.4}
.bitem .remove{background:none;border:0;color:var(--gray-400);cursor:pointer;font-size:.82rem;font-weight:600;text-decoration:underline}
.bitem .remove:hover{color:#d23b3b}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{background:var(--ink);color:#fff;padding:13px 20px;border-radius:50px;font-weight:600;font-size:.92rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(14px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast .tick{width:22px;height:22px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-items:center;font-weight:800;flex:0 0 auto}

/* ---------- Product action buttons ---------- */
.config-actions{display:flex;gap:12px;margin-top:6px}
.config-actions .btn{flex:1;justify-content:center}
@media(max-width:420px){.config-actions{flex-direction:column}}

/* ---------- Quote page ---------- */
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.quote-summary{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.quote-summary h3{font-size:1.15rem;margin-bottom:14px}
.qline{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.qline:last-of-type{border-bottom:0}
.qline .thumb{width:56px;height:56px;border-radius:9px;object-fit:cover;flex:0 0 auto;background:var(--gray-100)}
.qline .info h4{font-family:var(--display);font-size:.98rem}
.qline .specs{font-size:.8rem;color:var(--gray-500);line-height:1.45}
.qline .remove{background:none;border:0;color:var(--gray-400);cursor:pointer;font-size:.8rem;text-decoration:underline}
.qline .remove:hover{color:#d23b3b}
.phone-row{display:grid;grid-template-columns:108px 1fr;gap:10px}
.file-drop{border:1.6px dashed var(--gray-300);border-radius:12px;padding:22px;text-align:center;cursor:pointer;transition:.15s;color:var(--gray-500)}
.file-drop:hover{border-color:var(--yellow-deep);background:var(--gray-50)}
.file-drop svg{width:30px;height:30px;stroke:var(--gray-400);fill:none;stroke-width:1.8;margin-bottom:6px}
.file-drop b{color:var(--ink)}
.file-list{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:8px}
.file-list li{display:flex;align-items:center;gap:10px;background:var(--gray-50);border:1px solid var(--border);border-radius:9px;padding:8px 12px;font-size:.86rem}
.file-list li .fx{margin-left:auto;color:var(--gray-400);cursor:pointer;font-weight:700}
.file-list li .fx:hover{color:#d23b3b}
.hint{font-size:.86rem;color:var(--gray-500);text-align:center;margin-top:10px}
.form-note{text-align:center;font-size:.95rem;color:var(--ink);font-weight:600;margin-top:12px}
.alt-action{margin-top:22px;padding-top:20px;border-top:1px solid var(--border);text-align:center}

/* ---------- Quote form: sections + line items ---------- */
.qsection{font-family:var(--display);font-size:1.18rem;margin:30px 0 16px;padding-top:22px;border-top:1px solid var(--border)}
.qrows{display:flex;flex-direction:column;gap:10px}
.qrow{display:grid;grid-template-columns:minmax(0,1.6fr) 88px minmax(0,1.4fr) 40px;gap:10px;align-items:center}
.qrow select,.qrow input{width:100%;padding:11px 12px;border:1px solid var(--gray-300);border-radius:10px;font-family:inherit;font-size:.92rem;background:#fff;transition:.15s}
.qrow select:focus,.qrow input:focus{outline:none;border-color:var(--yellow-deep);box-shadow:0 0 0 3px rgba(255,210,31,.25)}
.qrow .qrm{padding:0;height:40px;border:1px solid var(--gray-300);border-radius:10px;background:#fff;color:var(--gray-500);cursor:pointer;font-size:.95rem;transition:.15s}
.qrow .qrm:hover{border-color:#e0b4b4;background:#fdeaea;color:#a33}
.qadd{margin-top:12px;background:var(--gray-50);border:1.5px dashed var(--gray-300);color:var(--ink);border-radius:11px;padding:12px 18px;font-family:inherit;font-weight:600;font-size:.92rem;cursor:pointer;transition:.15s}
.qadd:hover{border-color:var(--yellow-deep);background:#fff}
.qlist-upload{margin-top:18px}
.qlist-or{display:flex;align-items:center;text-align:center;color:var(--gray-400);font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;margin:6px 0 14px}
.qlist-or::before,.qlist-or::after{content:"";flex:1;height:1px;background:var(--border)}
.qlist-or span{padding:0 12px}
.qlist-upload>label[for="qlist"]{display:block;font-weight:600;font-size:.9rem;margin-bottom:0}
@media(max-width:640px){
  .qrow{grid-template-columns:1fr 64px;grid-template-areas:"prod prod" "qty rm" "spec spec";gap:8px;padding-bottom:14px;border-bottom:1px dashed var(--border)}
  .qrow .qprod{grid-area:prod}.qrow .qqty{grid-area:qty}.qrow .qspec{grid-area:spec}.qrow .qrm{grid-area:rm}
}

/* ---------- Loading spinner on buttons ---------- */
.btn.loading{position:relative;color:transparent!important;pointer-events:none}
.btn.loading::after{content:"";position:absolute;width:18px;height:18px;border:2.5px solid rgba(0,0,0,.25);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}
.btn--dark.loading::after,.btn--wa.loading::after{border-color:rgba(255,255,255,.35);border-top-color:#fff}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Big success panel ---------- */
.success-panel{display:none;text-align:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:46px 30px;box-shadow:var(--shadow)}
.success-panel.show{display:block}
.success-panel .big-tick{width:74px;height:74px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-items:center;margin:0 auto 18px;font-size:2.2rem;font-weight:800}
.big-tick svg{width:38px;height:38px;stroke:var(--ink);fill:none}
.toast .tick svg{width:14px;height:14px;vertical-align:-2px}
.fx svg{width:13px;height:13px}
.qrow .qrm svg{width:15px;height:15px}
.search-close svg{width:14px;height:14px}
.success-panel h2{margin-bottom:10px}
.success-panel p{max-width:460px;margin:0 auto 22px}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:150;width:60px;height:60px;border-radius:50%;background:#25D366;box-shadow:0 10px 26px rgba(37,211,102,.45);display:flex;align-items:center;justify-content:center;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px;fill:#fff}
.wa-float .wa-pulse{position:absolute;inset:0;border-radius:50%;background:#25D366;opacity:.5;animation:wapulse 2.4s infinite}
@keyframes wapulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.6);opacity:0}100%{opacity:0}}
@media(max-width:560px){.wa-float{width:54px;height:54px;right:16px;bottom:16px}.wa-float svg{width:28px;height:28px}}

/* ---------- Accessibility: focus rings ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.basket-btn:focus-visible{outline:3px solid rgba(255,210,31,.65);outline-offset:2px;border-radius:6px}

/* ---------- Language switcher ---------- */
.lang-switch{display:inline-flex;align-items:center;gap:2px;margin-left:6px}
.lang-switch button{background:none;border:0;color:#9aa0ad;font-size:.78rem;font-weight:700;cursor:pointer;padding:2px 7px;border-radius:6px;font-family:var(--display)}
.lang-switch button:hover{color:#fff}
.lang-switch button.active{color:var(--yellow)}
.lang-switch .sep{color:#3a3f4a;font-size:.7rem}

/* ---------- Sticky mobile CTA bar ---------- */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:140;display:none;gap:10px;padding:9px 12px;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);border-top:1px solid var(--border)}
.mobile-cta .btn{flex:1;justify-content:center;padding:13px 10px}
@media(max-width:760px){.mobile-cta{display:flex}.wa-float{bottom:80px}}

/* ---------- Blog / resources ---------- */
.post-meta{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--gray-500);margin-bottom:6px}
.post-tag{display:inline-block;background:var(--yellow-soft);color:#7a6200;font-weight:700;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;padding:4px 11px;border-radius:50px}
.article{max-width:760px;margin:0 auto}
.article .lede{font-size:1.18rem;color:var(--gray-600);line-height:1.6;margin:14px 0 26px}
.article h2{font-size:1.5rem;margin:34px 0 12px}
.article h3{font-size:1.18rem;margin:24px 0 8px}
.article p{margin:0 0 16px;line-height:1.75}
.article ul,.article ol{margin:0 0 18px;padding-left:22px;line-height:1.75}
.article li{margin-bottom:8px}
.article .callout{background:var(--gray-50);border:1px solid var(--border);border-left:4px solid var(--yellow-deep);border-radius:0 12px 12px 0;padding:16px 20px;margin:22px 0}
.article .callout p{margin:0}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none}}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero .container{grid-template-columns:1fr;gap:40px}
  .hero-media{aspect-ratio:16/11;max-width:560px}
  .tgrid,.features{grid-template-columns:repeat(2,1fr)}
  .stats,.steps{grid-template-columns:repeat(2,1fr)}
  .prod-items{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .fgrid{grid-template-columns:1fr 1fr}
  .split,.contact-grid{grid-template-columns:minmax(0,1fr)}
  .field-row{grid-template-columns:1fr}
  .product-wrap{grid-template-columns:minmax(0,1fr);gap:32px}
  .config{position:static}
  .quote-grid{grid-template-columns:minmax(0,1fr);gap:28px}
}
@media(max-width:1024px){
  .nav-bottom{display:contents}
  .nav-bottom .nav-links{justify-content:flex-start;flex:none}
  .nav-top{gap:10px}
  .hsearch{flex:0 0 auto;width:46px;height:46px;padding:0;justify-content:center;border-radius:12px;margin-left:auto}
  .hsearch input{display:none}
  .hsearch .hs-ic{stroke:var(--ink)}
  .prodnav{top:0}
  .nav-links{position:absolute;top:84px;left:18px;right:18px;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:12px 16px 16px;border:1px solid var(--border);border-radius:22px;box-shadow:0 18px 44px rgba(15,18,25,.16);display:none;max-height:calc(100dvh - 150px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .nav-links.open{display:flex}
  .nav-links>li>a{padding:15px 10px}
  .has-dropdown>a{display:flex;align-items:center;justify-content:space-between}
  .dropdown{position:static;display:none;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--yellow);border-radius:0;margin:2px 0 8px 10px;padding:0 0 0 8px;min-width:0}
  .has-dropdown.open>.dropdown{display:block;animation:navdrop .22s ease}
  .has-dropdown.open>a::after{transform:rotate(180deg)}
  @keyframes navdrop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
  body.nav-locked{overflow:hidden}
  .burger{display:flex}
  .nav-cta .btn:not(.burger){display:none}
  .topbar .tb-right .hide-sm{display:none}
  .hero-badge{display:none}
  /* Compact mobile header */
  .site-header{padding:8px 12px}
  .navbar{padding:0 12px;border-radius:18px}
  .nav-top{height:54px;gap:8px}
  .brand-logo{height:30px}
  .site-header .basket-btn{width:40px;height:40px}
  .hsearch{width:40px;height:40px}
  .cur-btn{height:40px;padding:0 8px;gap:3px;font-size:.82rem}
  .burger{padding:6px}
  .nav-links{top:72px;left:12px;right:12px}
}
@media(max-width:760px){
  /* Phone hero: catch-words + buttons only (no photo, like a clean app header) */
  .hero-visual{display:none}
  .hero p{display:none}
  .hero-trust{display:none}
  .hero .container{padding:26px 20px 52px;gap:0;text-align:left}
  .hero h1{font-size:1.75rem;line-height:1.16}
  .hero .eyebrow{margin-bottom:10px}
  .hero-cta{justify-content:flex-start;flex-wrap:wrap;gap:10px;margin-top:24px}
  .hero-cta .btn{width:auto;padding:10px 18px;font-size:.9rem;border-radius:9px}
  .hs-dots{bottom:18px}
}
@media(max-width:560px){
  .tgrid,.features,.steps,.gallery,.fgrid{grid-template-columns:minmax(0,1fr)}
  .stats{display:none}
  .stats-mq{display:block}
  .cat-grid,.cat-grid.cols-2{grid-template-columns:repeat(2,1fr);gap:12px}
  .cat-card h3{font-size:.9rem}
  /* Products & services: keep two compact cards side by side on mobile */
  .prod-items{grid-template-columns:repeat(2,1fr);gap:12px}
  /* Smaller category headings so they fit and match the icon */
  .prod-cat-head{gap:12px;margin-bottom:18px;padding-bottom:12px}
  .prod-cat-head .ic{width:40px;height:40px;border-radius:11px}
  .prod-cat-head .ic svg{width:21px;height:21px}
  .prod-cat-head h2{font-size:1.2rem;line-height:1.2}
  .prod-cat-head p{font-size:.82rem;margin-top:2px}
  .pitem .pitem-name{font-size:.9rem;margin-top:9px}
  .pitem .pitem-desc{font-size:.78rem;margin-top:4px}
  .pitem .pitem-cta{font-size:.8rem;margin-top:6px}
  .pitem .price-from{font-size:.82rem}
  .section{padding:30px 0}
  .cta-band{padding:34px}
  .gallery .shot.wide{grid-column:span 1;aspect-ratio:1/1}
  /* Configurator: stack the action buttons so they never overflow */
  .config{padding:22px 18px}
  .config-actions{flex-direction:column}
  .config-actions .btn{width:100%}
  .summary li b{word-break:break-word}
}

/* ===== Products & Services mega-menu (full-width, 5-column) ===== */
.nav-bottom{position:relative}
.nav-links li.has-dropdown.mega-parent{position:static}
.dropdown.mega{left:50%;transform:translateX(-50%) translateY(10px);top:calc(100% + 8px);width:100vw;max-width:100vw;min-width:0;padding:26px clamp(20px,4vw,64px) 22px;border-radius:0 0 16px 16px;max-height:min(82vh,720px);overflow-y:auto}
.has-dropdown.mega-parent:hover .dropdown.mega{transform:translateX(-50%) translateY(0)}
.mega-inner{display:grid;grid-template-columns:repeat(5,1fr);gap:0 34px}
.mega-cols-2 .mega-inner{grid-template-columns:repeat(2,1fr)}
.mega-cols-3 .mega-inner{grid-template-columns:repeat(3,1fr)}
.mega-cols-4 .mega-inner{grid-template-columns:repeat(4,1fr)}
.mega-cols-5 .mega-inner{grid-template-columns:repeat(5,1fr)}
.mega-colgroup{min-width:0}
.mega-cat{margin:0 0 20px}
.mega-cat>a.mega-h{display:block;font-weight:800;font-size:.82rem;letter-spacing:.02em;text-transform:uppercase;color:var(--ink);padding:0 0 6px;margin:0 0 7px;border-bottom:2px solid var(--yellow)}
.mega-cat>a.mega-h::before{display:none}
.mega-cat ul{list-style:none;margin:0;padding:0}
.mega-cat ul li a{display:block;padding:3px 0;font-size:.82rem;font-weight:500;color:#4a5160;line-height:1.3}
.mega-cat ul li a::before{display:none}
.mega-cat ul li a:hover{background:none;color:var(--yellow-deep);text-decoration:underline}
.mega-foot{margin-top:4px;padding-top:14px;border-top:1px solid var(--border)}
.mega-foot a{display:inline-block;font-weight:800;font-size:.86rem;color:var(--ink)}
.mega-foot a::before{display:none}
@media(max-width:1280px){.mega-cols-5 .mega-inner{grid-template-columns:repeat(4,1fr)}}
@media(max-width:1024px){
  .dropdown.mega{position:static;left:auto;transform:none;width:auto;max-width:none;max-height:none;overflow:visible;padding:0 0 0 8px;border:0;border-left:2px solid var(--yellow);border-radius:0;box-shadow:none}
  .has-dropdown.mega-parent:hover .dropdown.mega{transform:none}
  .dropdown.mega .mega-inner{grid-template-columns:1fr;gap:0}
  .mega-cat{margin:0}
  /* Category = tappable accordion header; products hidden until opened */
  .mega-cat>a.mega-h{position:relative;display:block;border-bottom:1px solid var(--border);padding:12px 30px 12px 4px;margin:0;color:var(--gray-700);font-size:.92rem;font-weight:600;letter-spacing:0;text-transform:none;cursor:pointer}
  .mega-cat>a.mega-h::after{content:"▾";position:absolute;right:8px;top:12px;color:var(--yellow-deep);font-weight:700;transition:transform .2s}
  .mega-cat.open>a.mega-h::after{transform:rotate(180deg)}
  .mega-cat>ul{display:none;margin:0;padding:4px 0 10px 14px;border-left:2px solid var(--yellow-soft)}
  .mega-cat.open>ul{display:block}
  .mega-cat ul li a{font-size:.88rem;padding:6px 0}
  .mega-foot{margin-top:8px}
}
