/* ==========================================================================
   SENTINEL — Uniform Manufacturing & Retail
   Premium design system. White dominant, institutional navy, badge gold.
   Display: Fraunces. Body: Hanken Grotesk.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  /* palette */
  --paper:#ffffff;
  --mist:#f5f7f9;
  --mist-2:#eef1f4;
  --line:#e3e8ee;
  --line-strong:#d3dae2;

  --navy:#0e2438;
  --navy-600:#16344f;
  --navy-400:#3a5570;
  --steel:#5b6e82;
  --slate:#8092a3;

  --green:#10503a;
  --green-bright:#1c7a57;
  --gold:#a8782a;
  --gold-soft:#c79a4a;

  --ink:#0e2438;
  --body:#41576b;
  --muted:#8092a3;

  /* type */
  --display:'Fraunces',Georgia,serif;
  --sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,sans-serif;

  /* spacing + shape */
  --r-sm:8px;
  --r:14px;
  --r-lg:22px;
  --r-pill:999px;
  --shadow-1:0 1px 2px rgba(14,36,56,.05),0 2px 8px rgba(14,36,56,.04);
  --shadow-2:0 4px 14px rgba(14,36,56,.07),0 18px 48px rgba(14,36,56,.08);
  --shadow-3:0 10px 30px rgba(14,36,56,.12),0 30px 80px rgba(14,36,56,.14);
  --ease:cubic-bezier(.22,.61,.36,1);
  --wrap:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--body);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- type scale ---------- */
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.08;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:600}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
h4{font-size:1.15rem}
p{margin-bottom:1rem}
.lead{font-size:clamp(1.1rem,1.6vw,1.3rem);color:var(--steel);line-height:1.6}

/* ---------- layout helpers ---------- */
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 24px}
.section{padding:clamp(64px,9vw,128px) 0}
.section-sm{padding:clamp(48px,6vw,84px) 0}
.bg-mist{background:var(--mist)}
.center{text-align:center}
.grid{display:grid;gap:28px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}

/* eyebrow / tag */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.on-dark{color:var(--gold-soft)}
.eyebrow.center-line{justify-content:center}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:.96rem;
  padding:15px 28px;border-radius:var(--r-pill);
  border:1px solid transparent;cursor:pointer;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s;
  position:relative;
}
.btn svg{width:17px;height:17px;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 10px 24px rgba(14,36,56,.22)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(14,36,56,.3);background:var(--navy-600)}
.btn-gold{background:var(--gold);color:#fff;box-shadow:0 10px 24px rgba(168,120,42,.28)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(168,120,42,.38);background:var(--gold-soft)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:var(--shadow-1)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.28)}
.btn-ghost.on-dark:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn-lg{padding:17px 34px;font-size:1rem}

/* ==========================================================================
   HEADER
   ========================================================================== */
.topbar{
  background:var(--navy);color:#c6d2de;font-size:.85rem;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:20px}
.topbar a{color:#c6d2de;transition:color .25s}
.topbar a:hover{color:#fff}
.topbar .tb-left{display:flex;gap:24px;align-items:center}
.topbar .tb-right{display:flex;gap:18px;align-items:center}
.tb-item{display:inline-flex;align-items:center;gap:7px}
.tb-item svg{width:14px;height:14px;color:var(--gold-soft)}
.tb-cert{color:#8fa3b5;letter-spacing:.04em}

.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid transparent;
  transition:box-shadow .4s var(--ease),border-color .4s,background .4s;
}
.site-header.scrolled{box-shadow:0 6px 30px rgba(14,36,56,.08);border-color:var(--line);background:rgba(255,255,255,.94)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}

.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-mark{
  width:40px;height:40px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(145deg,var(--navy),var(--navy-600));
  display:grid;place-items:center;position:relative;
  box-shadow:0 6px 16px rgba(14,36,56,.25);
}
.brand-mark::after{content:"";position:absolute;inset:6px;border:1.5px solid var(--gold-soft);border-radius:6px;opacity:.85}
.brand-mark span{font-family:var(--display);color:#fff;font-weight:700;font-size:1.2rem;position:relative;z-index:1}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text b{font-family:var(--display);font-size:1.32rem;color:var(--ink);font-weight:600;letter-spacing:.01em}
.brand-text small{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-top:3px}

.menu{display:flex;align-items:center;gap:4px}
.menu>li{position:relative}
.menu>li>a{
  display:flex;align-items:center;gap:6px;
  padding:10px 16px;font-weight:600;font-size:.95rem;color:var(--navy);
  border-radius:var(--r-sm);transition:color .25s,background .25s;
}
.menu>li>a .chev{width:12px;height:12px;transition:transform .3s}
.menu>li:hover>a{color:var(--gold)}
.menu>li:hover>a .chev{transform:rotate(180deg)}

/* mega menu */
.mega{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(10px);
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-3);padding:26px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  min-width:560px;
}
.mega.narrow{min-width:300px}
li:hover>.mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 26px}
.mega-grid.one{grid-template-columns:1fr}
.mega-link{display:flex;gap:13px;padding:11px 12px;border-radius:var(--r);transition:background .25s}
.mega-link:hover{background:var(--mist)}
.mega-ico{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:var(--mist);display:grid;place-items:center;color:var(--navy);
  transition:background .25s,color .25s;
}
.mega-link:hover .mega-ico{background:var(--navy);color:var(--gold-soft)}
.mega-ico svg{width:18px;height:18px}
.mega-link b{display:block;color:var(--ink);font-size:.95rem;font-family:var(--sans);font-weight:600}
.mega-link span{font-size:.82rem;color:var(--muted);line-height:1.4}

.nav-cta{display:flex;align-items:center;gap:14px;flex-shrink:0}
.icon-btn{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--navy);cursor:pointer;
  transition:border-color .25s,color .25s,transform .25s;background:#fff;
}
.icon-btn:hover{border-color:var(--navy);transform:translateY(-2px)}
.icon-btn svg{width:18px;height:18px}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile panel */
.mobile-nav{
  position:fixed;inset:0 0 0 auto;width:min(86vw,380px);background:#fff;z-index:80;
  transform:translateX(100%);transition:transform .45s var(--ease);
  box-shadow:-20px 0 60px rgba(14,36,56,.18);padding:90px 26px 40px;overflow-y:auto;
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{display:block;padding:14px 4px;font-weight:600;font-size:1.05rem;color:var(--navy);border-bottom:1px solid var(--line)}
.mobile-nav .sub a{padding-left:18px;font-size:.95rem;color:var(--steel);font-weight:500}
.mobile-nav .m-head{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:22px 0 6px}
.mobile-nav .btn{width:100%;justify-content:center;margin-top:24px}
.overlay{position:fixed;inset:0;background:rgba(14,36,56,.4);backdrop-filter:blur(3px);z-index:70;opacity:0;visibility:hidden;transition:.4s}
.overlay.open{opacity:1;visibility:visible}
.m-close{position:absolute;top:24px;right:24px}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{position:relative;overflow:hidden;padding:clamp(70px,10vw,130px) 0 clamp(60px,8vw,110px);background:var(--paper)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 480px at 80% -10%,rgba(28,122,87,.07),transparent 60%),
    radial-gradient(820px 520px at 12% 10%,rgba(14,36,56,.06),transparent 60%);
}
/* faint engineering grid */
.hero-bg::after{
  content:"";position:absolute;inset:0;opacity:.45;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 70% 30%,#000,transparent 72%);
  -webkit-mask-image:radial-gradient(circle at 70% 30%,#000,transparent 72%);
}
.shape{position:absolute;border-radius:30%;will-change:transform;pointer-events:none}
.shape.ring{border-radius:50%;background:transparent;border:1.5px solid rgba(168,120,42,.35)}
.shape.dot{background:linear-gradient(145deg,var(--gold),var(--gold-soft));border-radius:50%;box-shadow:0 12px 30px rgba(168,120,42,.3)}
.shape.sq{background:linear-gradient(145deg,rgba(14,36,56,.9),var(--navy-600));border-radius:18px;box-shadow:var(--shadow-2)}
.shape.plus{color:var(--green-bright)}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{margin-bottom:22px}
.hero h1 .accent{font-style:italic;color:var(--gold);position:relative}
.hero .lead{max-width:520px;margin-bottom:32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero-trust{display:flex;gap:28px;flex-wrap:wrap;align-items:center;padding-top:26px;border-top:1px solid var(--line)}
.trust-item b{display:block;font-family:var(--display);font-size:1.7rem;color:var(--ink);line-height:1}
.trust-item span{font-size:.82rem;color:var(--muted)}

/* hero visual stack */
.hero-visual{position:relative;perspective:1400px}
.hero-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-3);overflow:hidden;position:relative;
}
.hero-card .hc-img{aspect-ratio:4/3;background:
  linear-gradient(135deg,var(--navy),var(--navy-600));position:relative;overflow:hidden}
.hero-card .hc-img::after{content:"";position:absolute;inset:0;background:
  radial-gradient(380px 220px at 75% 18%,rgba(168,120,42,.4),transparent 65%),
  repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 12px,transparent 12px 24px)}
.hc-badge{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;
  padding:7px 13px;border-radius:var(--r-pill);font-size:.76rem;font-weight:600;letter-spacing:.04em;backdrop-filter:blur(6px)}
.hc-body{padding:22px}
.hc-body h4{margin-bottom:4px}
.hc-meta{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.hc-price{font-family:var(--display);font-size:1.3rem;color:var(--green)}
.float-chip{
  position:absolute;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-2);padding:14px 18px;display:flex;align-items:center;gap:12px;z-index:3;
}
.float-chip .fc-ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#fff;flex-shrink:0}
.float-chip b{display:block;font-family:var(--display);font-size:1.05rem;color:var(--ink);line-height:1.1}
.float-chip span{font-size:.76rem;color:var(--muted)}
.chip-a{top:-26px;right:8%;animation:floaty 6s var(--ease) infinite}
.chip-b{bottom:-26px;left:-6%;animation:floaty 7s var(--ease) infinite .8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ==========================================================================
   MARQUEE / LOGOS
   ========================================================================== */
.logos{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0;background:#fff;overflow:hidden}
.logos .wrap{display:flex;align-items:center;gap:38px;flex-wrap:wrap;justify-content:center}
.logos-label{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.logo-pill{font-family:var(--display);font-weight:600;color:var(--steel);font-size:1.15rem;opacity:.7;transition:opacity .3s}
.logo-pill:hover{opacity:1}

/* ==========================================================================
   SECTION HEADER
   ========================================================================== */
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head p{margin-top:14px;font-size:1.08rem;color:var(--steel)}

/* ==========================================================================
   CARDS
   ========================================================================== */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s;
  position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-soft));transition:width .5s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-3);border-color:transparent}
.card:hover::before{width:100%}
.card-ico{
  width:58px;height:58px;border-radius:15px;display:grid;place-items:center;margin-bottom:22px;
  background:var(--mist);color:var(--navy);transition:background .4s,color .4s,transform .4s var(--ease);
}
.card:hover .card-ico{background:var(--navy);color:var(--gold-soft);transform:rotate(-6deg)}
.card-ico svg{width:26px;height:26px}
.card h3{margin-bottom:10px;font-size:1.3rem}
.card p{font-size:.97rem;color:var(--steel);margin-bottom:18px}
.card-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:var(--navy)}
.card-link svg{width:15px;height:15px;transition:transform .3s}
.card:hover .card-link svg{transform:translateX(5px)}
.card-link.gold{color:var(--gold)}

/* product card */
.product{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.product:hover{transform:translateY(-8px);box-shadow:var(--shadow-3)}
.product-img{aspect-ratio:1/1;position:relative;overflow:hidden;background:var(--mist-2)}
.product-img .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--navy-400);transition:transform .6s var(--ease)}
.product:hover .product-img .ph{transform:scale(1.06)}
.product-tag{position:absolute;top:14px;left:14px;background:var(--navy);color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.04em;padding:6px 12px;border-radius:var(--r-pill)}
.product-tag.gold{background:var(--gold)}
.product-tag.green{background:var(--green)}
.product-body{padding:22px}
.product-body small{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.product-body h4{margin:6px 0 4px;font-size:1.15rem}
.product-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px}
.product-price{font-family:var(--display);font-size:1.2rem;color:var(--green)}

/* industry tile */
.ind-tile{
  position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:260px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:28px;color:#fff;
  background:linear-gradient(160deg,var(--navy),var(--navy-600));isolation:isolate;
  transition:transform .5s var(--ease);
}
.ind-tile::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background:radial-gradient(300px 200px at 80% 0%,rgba(168,120,42,.5),transparent 60%)}
.ind-tile::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(8,22,36,.85),transparent 70%)}
.ind-tile:hover{transform:translateY(-8px)}
.ind-tile .ind-ico{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;margin-bottom:auto;color:var(--gold-soft)}
.ind-tile .ind-ico svg{width:22px;height:22px}
.ind-tile h4{color:#fff;font-size:1.3rem;margin-top:18px}
.ind-tile span{font-size:.88rem;color:#b7c4d1}
.ind-tile.green{background:linear-gradient(160deg,var(--green),#0a3a29)}
.ind-tile.green::before{background:radial-gradient(300px 200px at 80% 0%,rgba(199,154,74,.45),transparent 60%)}

/* ==========================================================================
   FEATURE SPLIT
   ========================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative}
.media-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-2);border:1px solid var(--line)}
.media-frame .mf-img{aspect-ratio:5/4;background:linear-gradient(150deg,var(--navy),var(--navy-600));position:relative}
.media-frame .mf-img::after{content:"";position:absolute;inset:0;
  background:radial-gradient(300px 200px at 30% 20%,rgba(168,120,42,.35),transparent 60%),
  repeating-linear-gradient(135deg,rgba(255,255,255,.03) 0 14px,transparent 14px 28px)}
.media-tag{position:absolute;bottom:-22px;left:-22px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);box-shadow:var(--shadow-2);padding:18px 22px}
.media-tag b{font-family:var(--display);font-size:2rem;color:var(--green);display:block;line-height:1}
.media-tag span{font-size:.82rem;color:var(--muted)}

.check-list li{display:flex;gap:14px;padding:13px 0;border-bottom:1px solid var(--line)}
.check-list li:last-child{border-bottom:none}
.check-list .ck{width:26px;height:26px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.check-list .ck svg{width:13px;height:13px}
.check-list b{color:var(--ink);font-family:var(--sans);font-weight:600;display:block}
.check-list span{font-size:.92rem;color:var(--steel)}

/* ==========================================================================
   STATS BAND
   ========================================================================== */
.stats{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;opacity:.4;
  background:radial-gradient(600px 300px at 15% 0%,rgba(28,122,87,.3),transparent 60%),
  radial-gradient(600px 300px at 85% 100%,rgba(168,120,42,.25),transparent 60%)}
.stats .wrap{position:relative;z-index:1}
.stat{text-align:center;padding:18px}
.stat b{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.6rem);color:#fff;display:block;line-height:1}
.stat b .u{color:var(--gold-soft)}
.stat span{font-size:.92rem;color:#b7c4d1;letter-spacing:.02em}

/* ==========================================================================
   PROCESS / TIMELINE
   ========================================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step .num{font-family:var(--display);font-size:3rem;color:var(--mist-2);line-height:1;font-weight:600;transition:color .4s}
.step:hover .num{color:var(--gold)}
.step h4{margin:8px 0 8px}
.step p{font-size:.94rem;color:var(--steel)}
.step:not(:last-child)::after{content:"";position:absolute;top:24px;right:-12px;width:24px;height:1px;background:var(--line-strong)}

/* ==========================================================================
   TESTIMONIALS
   ========================================================================== */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;position:relative;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.quote:hover{transform:translateY(-6px);box-shadow:var(--shadow-2)}
.quote .mark{font-family:var(--display);font-size:3.4rem;color:var(--gold-soft);line-height:.6;height:28px}
.quote p{color:var(--ink);font-size:1.05rem;line-height:1.6}
.quote-by{display:flex;align-items:center;gap:14px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(145deg,var(--navy),var(--navy-600));color:var(--gold-soft);display:grid;place-items:center;font-family:var(--display);font-weight:600}
.quote-by b{display:block;color:var(--ink);font-family:var(--sans);font-weight:600;font-size:.98rem}
.quote-by span{font-size:.84rem;color:var(--muted)}
.stars{display:flex;gap:3px;margin-bottom:16px;color:var(--gold)}
.stars svg{width:16px;height:16px}

/* ==========================================================================
   CTA BAND
   ========================================================================== */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-lg);background:linear-gradient(150deg,var(--navy),var(--navy-600));color:#fff;padding:clamp(44px,6vw,72px);text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(500px 300px at 20% 10%,rgba(28,122,87,.4),transparent 60%),
  radial-gradient(500px 300px at 85% 90%,rgba(168,120,42,.35),transparent 60%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:16px}
.cta-band p{color:#c6d2de;max-width:560px;margin:0 auto 30px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ==========================================================================
   FORMS
   ========================================================================== */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-2);padding:clamp(28px,4vw,44px)}
.field{margin-bottom:20px}
.field label{display:block;font-weight:600;font-size:.88rem;color:var(--ink);margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line-strong);border-radius:var(--r);
  font-family:var(--sans);font-size:.97rem;color:var(--ink);background:#fff;transition:border-color .25s,box-shadow .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 4px rgba(14,36,56,.08)}
.field textarea{min-height:130px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* ==========================================================================
   PAGE HEADER (inner pages)
   ========================================================================== */
.page-head{position:relative;overflow:hidden;background:var(--navy);color:#fff;padding:clamp(70px,9vw,110px) 0 clamp(54px,7vw,80px)}
.page-head::before{content:"";position:absolute;inset:0;opacity:.55;
  background:radial-gradient(700px 360px at 80% -10%,rgba(28,122,87,.35),transparent 60%),
  radial-gradient(600px 360px at 10% 120%,rgba(168,120,42,.3),transparent 60%)}
.page-head::after{content:"";position:absolute;inset:0;opacity:.18;
  background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:60px 60px;mask-image:radial-gradient(circle at 70% 40%,#000,transparent 70%);
  -webkit-mask-image:radial-gradient(circle at 70% 40%,#000,transparent 70%)}
.page-head .wrap{position:relative;z-index:1}
.page-head h1{color:#fff;margin-bottom:14px}
.page-head .lead{color:#c6d2de;max-width:620px}
.crumbs{display:flex;gap:10px;align-items:center;font-size:.85rem;color:#8fa3b5;margin-bottom:22px}
.crumbs a:hover{color:#fff}
.crumbs .sep{opacity:.5}
.page-head .eyebrow{color:var(--gold-soft)}

/* ==========================================================================
   BLOG
   ========================================================================== */
.post{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease);display:flex;flex-direction:column}
.post:hover{transform:translateY(-8px);box-shadow:var(--shadow-3)}
.post-img{aspect-ratio:16/10;background:linear-gradient(150deg,var(--navy),var(--navy-600));position:relative;overflow:hidden}
.post-img::after{content:"";position:absolute;inset:0;background:radial-gradient(260px 160px at 75% 20%,rgba(168,120,42,.4),transparent 60%)}
.post-cat{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.72rem;font-weight:600;padding:6px 12px;border-radius:var(--r-pill);backdrop-filter:blur(6px)}
.post-body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-meta{font-size:.8rem;color:var(--muted);margin-bottom:10px;display:flex;gap:12px}
.post-body h3{font-size:1.25rem;margin-bottom:10px}
.post-body p{font-size:.95rem;color:var(--steel);flex:1}
.post-body .card-link{margin-top:16px}

/* ==========================================================================
   FAQ ACCORDION
   ========================================================================== */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;overflow:hidden;transition:border-color .3s,box-shadow .3s}
.faq-item.active{border-color:var(--navy-400);box-shadow:var(--shadow-1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 26px;cursor:pointer;font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--ink)}
.faq-q .pm{width:30px;height:30px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;flex-shrink:0;transition:.35s var(--ease);color:var(--navy)}
.faq-item.active .pm{background:var(--navy);color:#fff;border-color:var(--navy);transform:rotate(135deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a-inner{padding:0 26px 24px;color:var(--steel);font-size:.97rem}

/* ==========================================================================
   GALLERY
   ========================================================================== */
.gal-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.gal-filter button{padding:10px 20px;border:1px solid var(--line-strong);background:#fff;border-radius:var(--r-pill);font-family:var(--sans);font-weight:600;font-size:.88rem;color:var(--steel);cursor:pointer;transition:.3s}
.gal-filter button.active,.gal-filter button:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gal-item{border-radius:var(--r);overflow:hidden;position:relative;aspect-ratio:4/3;background:linear-gradient(150deg,var(--navy),var(--navy-600));cursor:pointer;transition:transform .5s var(--ease)}
.gal-item::after{content:"";position:absolute;inset:0;background:radial-gradient(200px 140px at 70% 25%,rgba(168,120,42,.4),transparent 60%),linear-gradient(to top,rgba(8,22,36,.7),transparent 60%);opacity:.85;transition:opacity .4s}
.gal-item:hover{transform:scale(.98)}
.gal-item .gal-cap{position:absolute;bottom:16px;left:16px;z-index:2;color:#fff}
.gal-item .gal-cap b{font-family:var(--display);font-size:1.05rem;display:block}
.gal-item .gal-cap span{font-size:.78rem;color:#b7c4d1}
.gal-item .gal-ico{position:absolute;top:14px;right:14px;z-index:2;width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;color:#fff;opacity:0;transform:scale(.8);transition:.4s}
.gal-item:hover .gal-ico{opacity:1;transform:scale(1)}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--navy);color:#9fb0bf;padding-top:72px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0;opacity:.4;
  background:radial-gradient(600px 320px at 90% 0%,rgba(28,122,87,.22),transparent 60%)}
.site-footer .wrap{position:relative;z-index:1}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .brand-text b{color:#fff}
.foot-brand .brand-text small{color:#7f93a6}
.foot-brand p{margin:20px 0;font-size:.94rem;color:#9fb0bf;max-width:300px}
.foot-col h4{color:#fff;font-size:1rem;margin-bottom:20px;font-family:var(--sans);font-weight:600}
.foot-col ul li{margin-bottom:12px}
.foot-col a{font-size:.94rem;color:#9fb0bf;transition:color .25s,padding .25s}
.foot-col a:hover{color:#fff;padding-left:5px}
.foot-news p{font-size:.92rem;margin-bottom:16px}
.news-form{display:flex;gap:10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-pill);padding:6px 6px 6px 18px}
.news-form input{flex:1;background:none;border:none;color:#fff;font-family:var(--sans);font-size:.92rem}
.news-form input::placeholder{color:#7f93a6}
.news-form input:focus{outline:none}
.news-form button{width:42px;height:42px;border-radius:50%;border:none;background:var(--gold);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.3s;flex-shrink:0}
.news-form button:hover{background:var(--gold-soft);transform:translateX(2px)}
.foot-certs{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.cert-chip{font-size:.72rem;color:#b7c4d1;border:1px solid rgba(255,255,255,.14);border-radius:var(--r-sm);padding:6px 11px;letter-spacing:.04em}
.socials{display:flex;gap:10px;margin-top:24px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;color:#9fb0bf;transition:.3s}
.socials a:hover{background:var(--gold);color:#fff;border-color:var(--gold);transform:translateY(-3px)}
.socials svg{width:17px;height:17px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:26px 0;flex-wrap:wrap;font-size:.86rem;color:#7f93a6}
.foot-bottom a:hover{color:#fff}
.foot-legal{display:flex;gap:22px}

/* ==========================================================================
   SCROLL REVEAL
   ========================================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* progress bar */
.scroll-prog{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--green-bright));z-index:100;transition:width .1s}

/* back to top */
.to-top{position:fixed;bottom:28px;right:28px;width:48px;height:48px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;cursor:pointer;z-index:50;opacity:0;transform:translateY(20px);transition:.4s;box-shadow:var(--shadow-2);border:none}
.to-top.show{opacity:1;transform:none}
.to-top:hover{background:var(--gold)}
.to-top svg{width:20px;height:20px}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:1080px){
  .menu{display:none}
  .burger{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-visual{max-width:520px;margin:0 auto}
  .foot-top{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:860px){
  .g-4{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:40px}
  .split.rev .split-media{order:0}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step:not(:last-child)::after{display:none}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .stats .g-4{grid-template-columns:repeat(2,1fr)}
  .topbar .tb-left .tb-item:not(:first-child){display:none}
}
@media(max-width:560px){
  body{font-size:16px}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr}
  .hero-trust{gap:18px}
  .foot-top{grid-template-columns:1fr}
  .float-chip{display:none}
  .foot-bottom{flex-direction:column;text-align:center}
  .topbar .tb-left .tb-item:nth-child(2){display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   WORDPRESS SUPPLEMENTAL STYLES
   Classes used only by the dynamic theme (not the static demo).
   ============================================================ */

/* Featured images inside card media */
.post-img img,.product-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.post-img{display:block}
.product-img{display:block;position:relative}

/* Page header date/read meta on single posts */
.post-meta-row{display:flex;gap:14px;justify-content:center;color:var(--muted);font-size:.9rem;margin-top:10px}
.dot-sep{opacity:.5}

/* Entry content (the_content output) */
.entry-content{max-width:760px;margin:0 auto;font-size:1.06rem;line-height:1.8;color:var(--ink)}
.entry-content > *{margin:0 0 1.2em}
.entry-content h2{font-family:var(--font-display);font-size:1.7rem;margin:1.8em 0 .6em;line-height:1.2}
.entry-content h3{font-family:var(--font-display);font-size:1.32rem;margin:1.6em 0 .5em}
.entry-content a{color:var(--green);text-decoration:underline;text-underline-offset:3px}
.entry-content ul,.entry-content ol{padding-left:1.3em}
.entry-content li{margin:.4em 0}
.entry-content blockquote{border-left:3px solid var(--gold);padding:.4em 0 .4em 1.2em;margin:1.4em 0;font-family:var(--font-display);font-size:1.2rem;color:var(--navy)}
.entry-content img{border-radius:var(--r-lg);height:auto}
.entry-content code{background:var(--surface);padding:2px 7px;border-radius:6px;font-size:.92em}
.entry-content pre{background:var(--navy);color:#fff;padding:18px;border-radius:var(--r-lg);overflow:auto}
.single-media{border-radius:var(--r-xl);overflow:hidden;margin:0 0 2.4rem;border:1px solid var(--line)}
.single-media img{display:block;width:100%;height:auto}

/* Post tags + prev/next nav */
.post-tags{max-width:760px;margin:2rem auto 0;display:flex;flex-wrap:wrap;gap:8px}
.post-tags a{font-size:.8rem;padding:6px 14px;border:1px solid var(--line);border-radius:var(--r-pill);color:var(--muted);transition:all .3s var(--ease)}
.post-tags a:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.post-nav{max-width:760px;margin:2.6rem auto 0;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.post-nav a{flex:1;min-width:200px;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 20px;transition:all .35s var(--ease)}
.post-nav a:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.post-nav small{display:block;color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.post-nav span{font-family:var(--font-display);color:var(--navy);font-weight:600}
.pn-next{text-align:right}

/* Pagination */
.pagination{margin-top:3rem;display:flex;justify-content:center}
.pagination .nav-links{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.pagination .page-numbers{min-width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--line);border-radius:12px;color:var(--navy);font-weight:600;transition:all .3s var(--ease)}
.pagination .page-numbers:hover,.pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
.pagination .page-numbers.dots{border:none}

/* Empty state */
.empty-state{text-align:center;max-width:520px;margin:0 auto;padding:3rem 0}
.empty-state h3{font-family:var(--font-display);font-size:1.6rem;color:var(--navy);margin-bottom:.6rem}
.empty-state p{color:var(--muted);margin-bottom:1.6rem}

/* Search */
.search-panel{max-height:0;overflow:hidden;background:var(--navy);transition:max-height .4s var(--ease)}
.search-panel.open{max-height:140px}
.search-panel .wrap{padding:22px 0}
.search-form{display:flex;gap:10px;align-items:center}
.search-field{flex:1;padding:14px 18px;border:1px solid var(--line);border-radius:12px;font:inherit;background:#fff}
.search-field:focus{outline:none;border-color:var(--gold)}
.search-submit{width:50px;height:50px;border:none;border-radius:12px;background:var(--gold);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .3s var(--ease)}
.search-submit:hover{transform:translateY(-2px)}
.search-inline{max-width:520px;margin:1.4rem auto 0}
.search-inline .search-field{background:var(--surface)}

/* Sidebar widgets */
.sidebar{display:flex;flex-direction:column;gap:28px}
.widget{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px}
.widget-title{font-family:var(--font-display);font-size:1.12rem;color:var(--navy);margin-bottom:14px}
.widget ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.widget ul a{color:var(--muted);transition:color .3s var(--ease)}
.widget ul a:hover{color:var(--green)}

/* Footer menu lists from wp_nav_menu */
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}

/* Error page */
.error-head{text-align:center}
.error-code{display:inline-block;font-family:var(--font-display);font-size:clamp(3.4rem,9vw,6rem);font-weight:700;color:var(--gold);line-height:1}

/* Comments */
.comments-area{max-width:760px;margin:3rem auto 0;border-top:1px solid var(--line);padding-top:2.4rem}
.comments-title{font-family:var(--font-display);font-size:1.4rem;color:var(--navy);margin-bottom:1.4rem}
.comment-list{list-style:none;display:flex;flex-direction:column;gap:1.4rem;margin-bottom:2rem}
.comment-list .children{list-style:none;padding-left:1.6rem;margin-top:1.4rem;display:flex;flex-direction:column;gap:1.4rem}
.comment-body{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px}
.comment-author{font-weight:600;color:var(--navy);display:flex;align-items:center;gap:10px}
.comment-author img{border-radius:50%}
.comment-meta{font-size:.82rem;color:var(--muted);margin:4px 0 8px}
.comment-respond{margin-top:1rem}
.comment-form{display:flex;flex-direction:column;gap:14px}
.comment-form label{font-size:.86rem;font-weight:600;color:var(--navy)}
.comment-form input,.comment-form textarea{width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:12px;font:inherit;background:#fff}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--gold)}
.comment-form .form-submit{margin:0}

/* Page head variant for single posts */
.page-head-post .post-meta-row{margin-top:14px}

/* Section spacing helper */
.section-tight{padding-top:0}

/* Reduced motion already handled globally; ensure search panel respects it */
@media (prefers-reduced-motion:reduce){.search-panel{transition:none}}
