/* ==========================================================================
   NF IMPEX TRADING — DESIGN SYSTEM
   Palette pulled from the logo: cobalt blue → violet, deep navy ink.
   Display: Sora · Body: Inter · Utility/specs: IBM Plex Mono
   Signature: export-document "spec strips" + the logo's globe-arc motif.
   ========================================================================== */

/* ---------- 1. TOKENS ---------------------------------------------------- */
:root{
  /* brand — kept from the logo (used on brand marks, buttons, links) */
  --blue:#1f3dcb;
  --blue-deep:#16258c;
  --violet:#7a22c9;
  --violet-deep:#531a99;

  /* ink & text — warm near-black with a faint indigo cast */
  --ink:#191630;
  --ink-soft:#4b4763;
  --muted:#857f6e;          /* warm taupe for secondary text */

  /* accents */
  --gold:#c08a12;           /* harvest gold — warm accent, used sparingly */
  --gold-soft:#e3b23c;
  --gold-deep:#9a6e08;
  --fresh:#3c7a2c;          /* leaf green — availability / fresh cues only */

  /* surfaces — warm "rice paper", not cold white */
  --bg:#faf6ed;             /* page background */
  --bg-tint:#f3ebda;        /* wheat section band */
  --bg-violet:#f5eee0;      /* warm alt band */
  --card:#fffdf7;           /* card surface, warm white */
  --line:#e8dec9;           /* warm sand hairline */
  --line-soft:#f0e8d7;

  /* brand gradient — reserved for buttons & small brand marks (NOT section washes) */
  --grad:linear-gradient(118deg,#1f3dcb 0%,#6a2bcf 100%);
  --grad-soft:linear-gradient(118deg,rgba(31,61,203,.09),rgba(122,34,201,.09));
  --grad-gold:linear-gradient(118deg,#e3b23c 0%,#c08a12 100%);
  --ink-deep:#13112a;       /* deep indigo for dark bands / hero base */

  /* type */
  --f-display:'Bricolage Grotesque',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',Menlo,monospace;

  /* scale */
  --wrap:1200px;
  --gap:clamp(1rem,3vw,2rem);
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 1px 2px rgba(25,22,48,.05),0 12px 32px -14px rgba(25,22,48,.18);
  --shadow-lg:0 34px 70px -30px rgba(25,22,48,.45);
  --ring:0 0 0 4px rgba(192,138,18,.22);
}


/* ---------- 2. RESET / BASE --------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--f-body);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:16.5px;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--blue);text-decoration:none;transition:color .18s}
a:hover{color:var(--violet)}
h1,h2,h3,h4{font-family:var(--f-display);color:var(--ink);line-height:1.12;margin:0 0 .5em;font-weight:700;letter-spacing:-.02em}
h1{font-size:clamp(2.3rem,5.4vw,4.1rem);font-weight:800}
h2{font-size:clamp(1.8rem,3.6vw,2.85rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
p{margin:0 0 1rem}
ul{margin:0 0 1rem;padding-left:1.1rem}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}
::selection{background:rgba(122,34,201,.18)}

/* ---------- 3. LAYOUT ---------------------------------------------------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(1.1rem,4vw,2rem)}
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section--tint{background:var(--bg-tint)}
.section--violet{background:var(--bg-violet)}
.section--ink{background:var(--ink-deep);color:#e7e1d2}
.section--ink h2,.section--ink h3{color:#fff}
.center{text-align:center}
.grid{display:grid;gap:var(--gap)}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-soft)}
.mono{font-family:var(--f-mono)}

/* eyebrow — the trade-document label device */
.eyebrow{
  font-family:var(--f-mono);font-size:.74rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--grad-gold);border-radius:2px}
.eyebrow--center{justify-content:center}

.section-head{max-width:680px;margin:0 auto clamp(2rem,4vw,3rem)}
.section-head.center{text-align:center}
.section-head p{color:var(--muted);margin-bottom:0}

/* globe-arc divider motif */
.arc{display:none}

/* ---------- 4. BUTTONS --------------------------------------------------- */
.btn{
  --b:var(--grad);
  display:inline-flex;align-items:center;gap:.55rem;justify-content:center;
  font-family:var(--f-display);font-weight:600;font-size:.97rem;letter-spacing:-.01em;
  padding:.85rem 1.5rem;border-radius:999px;border:0;cursor:pointer;
  background:var(--b);color:#fff;transition:transform .18s,box-shadow .18s,filter .18s;
  box-shadow:0 10px 24px -10px rgba(90,40,194,.6);white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(90,40,194,.7);color:#fff;filter:saturate(1.08)}
.btn:active{transform:translateY(0)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn--ghost:hover{border-color:var(--violet);color:var(--violet);transform:translateY(-2px);background:#fff}
.btn--light{background:#fff;color:var(--blue-deep);box-shadow:0 8px 24px -10px rgba(0,0,0,.4)}
.btn--light:hover{color:var(--violet-deep)}
.btn--sm{padding:.6rem 1.1rem;font-size:.88rem}
.btn--block{display:flex;width:100%}
.btn svg{width:18px;height:18px}

/* ---------- 5. HEADER + MEGA MENU --------------------------------------- */
.topbar{background:var(--ink);color:#c8cdf0;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:38px;flex-wrap:wrap}
.topbar a{color:#c8cdf0}.topbar a:hover{color:#fff}
.topbar__l,.topbar__r{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap}
.topbar__r a{display:inline-flex;align-items:center;gap:.4rem}
.topbar svg{width:14px;height:14px;opacity:.8}
@media(max-width:680px){.topbar__l{display:none}.topbar .wrap{justify-content:center}}

.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--line-soft);
  transition:box-shadow .25s}
.header.scrolled{box-shadow:0 6px 24px -14px rgba(14,19,48,.4)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--f-display);font-weight:800;
  font-size:1.18rem;color:var(--ink);letter-spacing:-.02em}
.brand img{width:46px;height:46px;object-fit:contain}
.brand small{display:block;font-family:var(--f-mono);font-weight:500;font-size:.6rem;
  letter-spacing:.18em;color:var(--violet);text-transform:uppercase;margin-top:1px}
.brand:hover{color:var(--ink)}

.menu{display:flex;align-items:center;gap:.2rem;list-style:none;margin:0;padding:0}
.menu>li>a,.menu__btn{
  display:inline-flex;align-items:center;gap:.35rem;font-family:var(--f-display);
  font-weight:500;font-size:.95rem;color:var(--ink-soft);padding:.6rem .85rem;border-radius:10px;
  background:none;border:0;cursor:pointer;letter-spacing:-.01em;
}
.menu>li>a:hover,.menu__btn:hover,.menu>li.active>a{color:var(--blue);background:var(--bg-tint)}
.menu__btn svg{width:14px;height:14px;transition:transform .2s}
.has-mega.open .menu__btn svg{transform:rotate(180deg)}
.nav__cta{display:flex;align-items:center;gap:.6rem}

/* mega menu panel */
.has-mega{position:static}
.mega{
  position:absolute;left:50%;transform:translateX(-50%) translateY(8px);
  top:calc(100% + 6px);width:min(940px,calc(100vw - 2rem));
  background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);
  padding:1.4rem;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60;
}
.has-mega.open .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.mega__item{display:flex;gap:.85rem;padding:.85rem;border-radius:14px;transition:background .15s;align-items:flex-start}
.mega__item:hover{background:var(--bg-tint)}
.mega__ic{flex:0 0 42px;width:42px;height:42px;border-radius:11px;background:var(--grad-soft);
  display:grid;place-items:center;color:var(--violet)}
.mega__ic svg{width:22px;height:22px}
.mega__t{font-family:var(--f-display);font-weight:600;font-size:.97rem;color:var(--ink);display:block;line-height:1.2}
.mega__d{font-size:.8rem;color:var(--muted);display:block;margin-top:2px}
.mega__foot{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.mega__foot span{font-size:.85rem;color:var(--muted)}

/* burger */
.burger{display:none;background:none;border:0;cursor:pointer;padding:.5rem;border-radius:10px}
.burger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.burger span+span{margin-top:6px}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- 6. MOBILE NAV ----------------------------------------------- */
@media(max-width:980px){
  .menu,.nav__cta .btn{display:none}
  .burger{display:block}
  .mobile{
    position:fixed;inset:0 0 0 auto;width:min(380px,86vw);background:#fff;z-index:80;
    transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
    box-shadow:-20px 0 60px -20px rgba(14,19,48,.4);overflow-y:auto;padding:1.2rem 1.2rem 3rem;
  }
  .mobile.open{transform:translateX(0)}
  .mobile__scrim{position:fixed;inset:0;background:rgba(14,19,48,.5);opacity:0;visibility:hidden;
    transition:opacity .3s;z-index:70}
  .mobile__scrim.open{opacity:1;visibility:visible}
}
@media(min-width:981px){.mobile,.mobile__scrim{display:none}}
.mobile__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.mobile__close{background:none;border:0;font-size:1.7rem;line-height:1;cursor:pointer;color:var(--muted)}
.mobile a{display:block;padding:.8rem .4rem;font-family:var(--f-display);font-weight:500;
  color:var(--ink);border-bottom:1px solid var(--line-soft)}
.mobile .m-acc>button{width:100%;display:flex;justify-content:space-between;align-items:center;
  background:none;border:0;border-bottom:1px solid var(--line-soft);padding:.8rem .4rem;
  font-family:var(--f-display);font-weight:500;font-size:1rem;color:var(--ink);cursor:pointer}
.mobile .m-acc__body{display:none;padding-left:.9rem}
.mobile .m-acc.open .m-acc__body{display:block}
.mobile .m-acc__body a{font-size:.92rem;color:var(--ink-soft);border-bottom:1px dashed var(--line)}
.mobile .m-acc>button svg{width:16px;height:16px;transition:transform .2s}
.mobile .m-acc.open>button svg{transform:rotate(180deg)}
.mobile .btn{margin-top:1.2rem}

/* ---------- 7. HERO ------------------------------------------------------ */
.hero{position:relative;overflow:hidden;background:var(--ink-deep);color:#fff;
  padding:clamp(3.5rem,8vw,6.5rem) 0 clamp(4rem,9vw,7rem)}
.hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(19,17,42,.66) 0%,rgba(19,17,42,.80) 60%,rgba(19,17,42,.92) 100%),
    linear-gradient(112deg,rgba(20,18,46,.75) 0%,rgba(31,61,203,.30) 55%,rgba(122,34,201,.30) 100%)}
.hero__field{position:absolute;right:-8%;bottom:-22%;width:min(760px,82vw);height:auto;z-index:1;opacity:.9}
.hero__arc{display:none}
.hero__glow{display:none}
.hero__glow--a{background:#2746d8;top:-160px;left:-120px}
.hero__glow--b{background:#8b2bd6;bottom:-200px;right:-80px}
.hero .wrap{position:relative;z-index:2}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,4vw,3.5rem);align-items:center}
.hero h1{color:#fff;margin-bottom:1rem}
.hero h1 .g{color:var(--gold-soft);-webkit-text-fill-color:var(--gold-soft)}
.hero__eyebrow{color:var(--gold-soft)}
.hero__lead{color:#cfc8b8;font-size:clamp(1.05rem,1.6vw,1.22rem);max-width:30ch;margin-bottom:1.8rem}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2rem}
.hero__pillars{display:flex;gap:1.6rem;flex-wrap:wrap}
.hero__pillar{display:flex;flex-direction:column}
.hero__pillar b{font-family:var(--f-display);font-size:1.5rem;color:#fff;line-height:1}
.hero__pillar span{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:#8e98d6;margin-top:.35rem}

/* hero trade-desk card */
.trade-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:22px;padding:1.3rem;backdrop-filter:blur(8px)}
.trade-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.trade-card__head span{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;color:#a9b4ff;text-transform:uppercase}
.trade-card__dot{width:8px;height:8px;border-radius:50%;background:var(--fresh);box-shadow:0 0 0 4px rgba(19,160,90,.2)}
.trade-row{display:flex;align-items:center;gap:.8rem;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.trade-row:last-child{border-bottom:0}
.trade-row__ic{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#c79bff;flex:0 0 38px}
.trade-row__ic svg{width:20px;height:20px}
.trade-row__t{flex:1;font-family:var(--f-display);font-weight:600;font-size:.95rem;color:#fff}
.trade-row__m{font-family:var(--f-mono);font-size:.72rem;color:#8e98d6}
@media(max-width:880px){.hero__grid{grid-template-columns:1fr}.hero__lead{max-width:48ch}}

/* ---------- 8. TRUST STRIP / LOGOS -------------------------------------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--card)}
.trust .wrap{display:flex;align-items:center;gap:clamp(1rem,4vw,3rem);flex-wrap:wrap;justify-content:center;padding-top:1.4rem;padding-bottom:1.4rem}
.trust span{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.trust b{font-family:var(--f-display);font-weight:700;color:var(--ink-soft);font-size:1.02rem;display:inline-flex;align-items:center;gap:.5rem}
.trust b svg{width:18px;height:18px;color:var(--violet)}

/* ---------- 9. CARDS ----------------------------------------------------- */
.cards{display:grid;gap:var(--gap)}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.cards--2{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.cards--4{grid-template-columns:repeat(2,1fr)}.cards--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.cards--4,.cards--3,.cards--2{grid-template-columns:1fr}}

.pcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s,border-color .22s}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.pcard__media{aspect-ratio:4/3;background:var(--grad-soft);position:relative;overflow:hidden;display:grid;place-items:center}
.pcard__media img,.pcard__media svg{width:100%;height:100%;object-fit:cover}
.pcard__cat{position:absolute;top:.8rem;left:.8rem;font-family:var(--f-mono);font-size:.66rem;
  letter-spacing:.12em;text-transform:uppercase;background:rgba(255,255,255,.92);color:var(--violet);
  padding:.3rem .6rem;border-radius:8px;font-weight:500}
.pcard__body{padding:1.2rem 1.25rem 1.35rem;display:flex;flex-direction:column;flex:1}
.pcard__body h3{margin-bottom:.4rem}
.pcard__body p{color:var(--muted);font-size:.92rem;margin-bottom:1rem;flex:1}
.pcard__foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:auto}
.pcard__link{font-family:var(--f-display);font-weight:600;font-size:.9rem;color:var(--blue);display:inline-flex;align-items:center;gap:.35rem}
.pcard__link svg{width:15px;height:15px;transition:transform .18s}
.pcard:hover .pcard__link svg{transform:translateX(3px)}

/* availability badge — the only place --fresh is used */
.avail{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--f-mono);font-size:.7rem;
  letter-spacing:.06em;color:var(--fresh);background:rgba(19,160,90,.08);padding:.3rem .6rem;border-radius:8px;font-weight:500}
.avail::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--fresh)}

/* category tile (products index) */
.cat-tile{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  background:#fff;padding:1.6rem;display:flex;flex-direction:column;gap:.8rem;transition:transform .22s,box-shadow .22s;min-height:200px}
.cat-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.cat-tile__ic{width:56px;height:56px;border-radius:15px;background:var(--grad);display:grid;place-items:center;color:#fff}
.cat-tile__ic svg{width:30px;height:30px}
.cat-tile h3{margin:0}
.cat-tile p{color:var(--muted);font-size:.9rem;margin:0;flex:1}
.cat-tile__n{font-family:var(--f-mono);font-size:.72rem;color:var(--violet)}

/* ---------- 10. FEATURE / VALUE GRID ------------------------------------ */
.feat{display:flex;gap:1rem;align-items:flex-start}
.feat__ic{flex:0 0 50px;width:50px;height:50px;border-radius:14px;background:var(--grad-soft);display:grid;place-items:center;color:var(--violet)}
.feat__ic svg{width:26px;height:26px}
.feat h3{font-size:1.15rem;margin-bottom:.3rem}
.feat p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------- 11. SPEC STRIP (SIGNATURE) ---------------------------------- */
.spec{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-tint)}
.spec__bar{height:4px;background:var(--grad)}
.spec__grid{display:grid;grid-template-columns:repeat(2,1fr)}
.spec__row{padding:.85rem 1.1rem;border-bottom:1px solid var(--line);border-right:1px solid var(--line);background:#fff}
.spec__row:nth-child(2n){border-right:0}
.spec__k{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.2rem}
.spec__v{font-family:var(--f-display);font-weight:600;font-size:.95rem;color:var(--ink)}
@media(max-width:520px){.spec__grid{grid-template-columns:1fr}.spec__row{border-right:0}}

/* ---------- 12. PRODUCT DETAIL ------------------------------------------ */
.pdp{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
@media(max-width:880px){.pdp{grid-template-columns:1fr}}
.pdp__media{position:sticky;top:96px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--grad-soft);aspect-ratio:1/1}
.pdp__media img,.pdp__media svg{width:100%;height:100%;object-fit:cover}
@media(max-width:880px){.pdp__media{position:static}}
.pdp h1{font-size:clamp(2rem,4vw,2.9rem);margin-bottom:.3rem}
.feature-list{list-style:none;padding:0;margin:1.4rem 0}
.feature-list li{display:flex;gap:.7rem;padding:.55rem 0;align-items:flex-start;font-size:.97rem;color:var(--ink-soft)}
.feature-list li svg{flex:0 0 20px;width:20px;height:20px;color:var(--fresh);margin-top:2px}

/* ---------- 13. PROCESS / TIMELINE -------------------------------------- */
.steps{counter-reset:s;display:grid;gap:1.1rem}
.step{display:flex;gap:1.1rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.2rem 1.3rem;position:relative}
.step__n{flex:0 0 44px;width:44px;height:44px;border-radius:12px;background:var(--grad);color:#fff;
  font-family:var(--f-mono);font-weight:600;display:grid;place-items:center;font-size:.95rem}
.step h3{font-size:1.1rem;margin-bottom:.25rem}
.step p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------- 14. FOUNDERS ------------------------------------------------- */
.founder{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;display:flex;flex-direction:column;gap:.4rem}
.founder__role{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--violet)}
.founder h3{margin:.2rem 0 .1rem}
.founder__cred{font-size:.88rem;color:var(--blue);font-weight:600;margin-bottom:.6rem}
.founder p{color:var(--muted);font-size:.93rem;margin:0}
.founder__av{width:64px;height:64px;border-radius:16px;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--f-display);font-weight:800;font-size:1.5rem;margin-bottom:.4rem}

/* ---------- 15. CERTIFICATION CARDS ------------------------------------- */
.cert{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.4rem;text-align:center}
.cert__badge{width:60px;height:60px;border-radius:16px;background:var(--grad-soft);display:grid;place-items:center;color:var(--violet);margin:0 auto .8rem}
.cert__badge svg{width:32px;height:32px}
.cert h3{font-size:1.05rem;margin-bottom:.4rem}
.cert p{color:var(--muted);font-size:.85rem;margin:0}

/* ---------- 16. GALLERY -------------------------------------------------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}
.gallery__item{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;border:1px solid var(--line);background:var(--grad-soft)}
.gallery__item img,.gallery__item svg{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery__item:hover img,.gallery__item:hover svg{transform:scale(1.06)}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(14,19,48,.55));opacity:0;transition:opacity .25s}
.gallery__item:hover::after{opacity:1}
.gallery__cap{position:absolute;left:.9rem;bottom:.8rem;color:#fff;font-family:var(--f-display);font-weight:600;font-size:.9rem;z-index:2;opacity:0;transform:translateY(6px);transition:.25s}
.gallery__item:hover .gallery__cap{opacity:1;transform:translateY(0)}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(8,11,28,.92);z-index:120;display:none;
  align-items:center;justify-content:center;padding:2rem}
.lightbox.open{display:flex}
.lightbox__stage{max-width:min(1000px,92vw);max-height:86vh;position:relative}
.lightbox__stage img,.lightbox__stage svg{max-width:100%;max-height:86vh;border-radius:14px;display:block;margin:0 auto;background:#fff}
.lightbox__cap{color:#cfd5f5;text-align:center;margin-top:1rem;font-family:var(--f-mono);font-size:.82rem}
.lightbox__btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);color:#fff;width:48px;height:48px;border-radius:50%;
  cursor:pointer;display:grid;place-items:center;transition:background .2s}
.lightbox__btn:hover{background:rgba(255,255,255,.25)}
.lightbox__btn svg{width:22px;height:22px}
.lightbox__prev{left:-64px}.lightbox__next{right:-64px}
.lightbox__close{position:fixed;top:1.4rem;right:1.6rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.5rem;line-height:1;display:grid;place-items:center}
@media(max-width:760px){.lightbox__prev{left:.4rem}.lightbox__next{right:.4rem}.lightbox__btn{width:40px;height:40px}}

/* ---------- 17. BLOG ----------------------------------------------------- */
.bcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s}
.bcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.bcard__media{aspect-ratio:16/9;overflow:hidden;background:var(--grad-soft)}
.bcard__media img,.bcard__media svg{width:100%;height:100%;object-fit:cover}
.bcard__body{padding:1.3rem;display:flex;flex-direction:column;flex:1}
.bcard__meta{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--violet);margin-bottom:.6rem}
.bcard h3{font-size:1.18rem;margin-bottom:.5rem}
.bcard p{color:var(--muted);font-size:.92rem;flex:1;margin-bottom:1rem}
.article{max-width:760px;margin:0 auto}
.article p{font-size:1.06rem;color:var(--ink-soft);line-height:1.75}
.article h2{margin-top:2.2rem}
.article h3{margin-top:1.6rem}
.article img{border-radius:var(--radius);margin:1.6rem 0}
.article blockquote{border-left:3px solid;border-image:var(--grad) 1;padding:.4rem 0 .4rem 1.3rem;margin:1.6rem 0;font-family:var(--f-display);font-size:1.2rem;color:var(--ink)}
.faq{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;margin:1rem 0}
.faq summary{cursor:pointer;padding:1rem 1.2rem;font-family:var(--f-display);font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.3rem;color:var(--violet)}
.faq[open] summary::after{content:"–"}
.faq__body{padding:0 1.2rem 1.1rem;color:var(--muted);font-size:.95rem}

/* ---------- 18. PAGE HEADER (interior) ---------------------------------- */
.phead{background:var(--ink-deep);color:#fff;position:relative;overflow:hidden;padding:clamp(2.6rem,6vw,4.5rem) 0 clamp(2.6rem,6vw,4rem)}
.phead__arc{display:none}
.phead__glow{display:none}
.phead .wrap{position:relative;z-index:2}
.phead h1{color:#fff;margin-bottom:.4rem}
.phead p{color:#cfc8b8;max-width:60ch;margin:0}
.crumbs{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.08em;color:#8e98d6;margin-bottom:1rem;text-transform:uppercase}
.crumbs a{color:#a9b4ff}.crumbs a:hover{color:#fff}

/* ---------- 19. CTA BANNER ---------------------------------------------- */
.cta-band{background:var(--grad);border-radius:var(--radius);padding:clamp(2rem,5vw,3.5rem);color:#fff;position:relative;overflow:hidden;text-align:center}
.cta-band h2{color:#fff;margin-bottom:.6rem}
.cta-band p{color:rgba(255,255,255,.88);max-width:55ch;margin:0 auto 1.6rem}
.cta-band__arc{display:none}

/* ---------- 20. FORMS ---------------------------------------------------- */
.field{margin-bottom:1rem}
.field label{display:block;font-family:var(--f-display);font-weight:500;font-size:.88rem;color:var(--ink);margin-bottom:.4rem}
.field input,.field textarea,.field select{
  width:100%;padding:.8rem .95rem;border:1.5px solid var(--line);border-radius:11px;font-family:var(--f-body);
  font-size:.97rem;color:var(--ink);background:#fff;transition:border-color .18s,box-shadow .18s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue);box-shadow:var(--ring)}
.field textarea{resize:vertical;min-height:120px}
.field--hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.82rem;color:var(--muted);margin-top:.4rem}
.form-msg{display:none;padding:.9rem 1.1rem;border-radius:11px;font-size:.92rem;margin-top:1rem}
.form-msg.ok{display:block;background:rgba(19,160,90,.1);color:#0c7a44;border:1px solid rgba(19,160,90,.25)}
.form-msg.err{display:block;background:rgba(214,40,40,.08);color:#c01f1f;border:1px solid rgba(214,40,40,.2)}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.4rem,3vw,2rem)}

/* contact info list */
.cinfo{list-style:none;padding:0;margin:0;display:grid;gap:1.1rem}
.cinfo li{display:flex;gap:.9rem;align-items:flex-start}
.cinfo__ic{flex:0 0 44px;width:44px;height:44px;border-radius:12px;background:var(--grad-soft);display:grid;place-items:center;color:var(--violet)}
.cinfo__ic svg{width:22px;height:22px}
.cinfo strong{font-family:var(--f-display);display:block;font-size:.95rem}
.cinfo span,.cinfo a{font-size:.92rem;color:var(--muted)}

/* ---------- 21. MODAL (ENQUIRY) ----------------------------------------- */
.modal{position:fixed;inset:0;z-index:130;display:none;align-items:center;justify-content:center;padding:1.2rem}
.modal.open{display:flex}
.modal__scrim{position:absolute;inset:0;background:rgba(8,11,28,.62);backdrop-filter:blur(4px)}
.modal__box{position:relative;background:#fff;border-radius:22px;max-width:520px;width:100%;
  max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:pop .25s cubic-bezier(.34,1.56,.64,1)}
@keyframes pop{from{transform:translateY(16px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.modal__top{background:var(--grad);color:#fff;padding:1.4rem 1.6rem;border-radius:22px 22px 0 0;position:relative;overflow:hidden}
.modal__top h3{color:#fff;margin:0;font-size:1.3rem}
.modal__top p{color:rgba(255,255,255,.85);margin:.3rem 0 0;font-size:.88rem}
.modal__prod{display:inline-block;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  background:rgba(255,255,255,.2);padding:.25rem .6rem;border-radius:7px;margin-bottom:.6rem}
.modal__close{position:absolute;top:1rem;right:1.1rem;background:rgba(255,255,255,.18);border:0;color:#fff;
  width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1.3rem;line-height:1;z-index:2}
.modal__body{padding:1.5rem 1.6rem 1.7rem}

/* ---------- 22. FOOTER --------------------------------------------------- */
.footer{background:var(--ink);color:#aab2dd;padding:clamp(3rem,6vw,4.5rem) 0 0}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2rem}
@media(max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}
.footer h4{color:#fff;font-size:.82rem;font-family:var(--f-mono);letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem;font-weight:500}
.footer a{color:#aab2dd;font-size:.92rem;display:block;padding:.28rem 0}
.footer a:hover{color:#fff}
.footer__brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.footer__brand img{width:44px;height:44px;background:#fff;border-radius:10px;padding:4px}
.footer__brand b{font-family:var(--f-display);color:#fff;font-size:1.1rem}
.footer__about{font-size:.9rem;color:#b6ae9b;max-width:34ch;margin-bottom:1.2rem}
.footer__social{display:flex;gap:.6rem}
.footer__social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;padding:0}
.footer__social a:hover{background:var(--grad)}
.footer__social svg{width:18px;height:18px;color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:3rem;padding:1.4rem 0;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:#7a83bc}
.footer__bottom a{display:inline;color:#aab2dd}

/* ---------- 23. WHATSAPP FLOAT ------------------------------------------ */
.wa-float{position:fixed;right:1.2rem;bottom:1.2rem;z-index:90;width:56px;height:56px;border-radius:50%;
  background:#25d366;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);
  transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;color:#fff}

/* ---------- 24. ANIMATION ------------------------------------------------ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@keyframes floatArc{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero__arc,.phead__arc{animation:floatArc 9s ease-in-out infinite}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- 25. UTIL ----------------------------------------------------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-2{margin-top:2rem}
.flex{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
.divider{height:1px;background:var(--line);border:0;margin:2.5rem 0}
.tag{display:inline-block;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--violet);background:var(--bg-violet);padding:.3rem .65rem;border-radius:7px}
.skip{position:absolute;left:-999px;top:0;background:#fff;padding:.6rem 1rem;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}
