:root{
  --navy:#033958;
  --navy-deep:#02263a;
  --navy-soft:#0a4a73;
  --gold:#ffc20e;
  --gold-deep:#e6a800;
  --plantain:#2f6b3a;
  --plantain-deep:#214d2a;
  --chili:#c1432a;
  --cream:#fbf6ec;
  --cream-dim:#f3ead8;
  --ink:#17120c;
  --ink-soft:#4a4136;
  --line:rgba(23,18,12,0.10);
  --line-strong:rgba(23,18,12,0.18);
  --radius-lg:28px;
  --radius-md:18px;
  --radius-sm:12px;
  --shadow-soft:0 18px 40px -20px rgba(3,57,88,0.35);
  --shadow-card:0 14px 30px -22px rgba(23,18,12,.3);
  --ease:cubic-bezier(.22,.88,.4,1);
  --header-h:74px;
}
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;margin:0;line-height:1.05;}
p{margin:0;}
button{font-family:inherit;border:none;background:none;cursor:pointer;}
.wrap{max-width:1240px;margin:0 auto;padding:0 24px;}
@media (max-width:600px){.wrap{padding:0 18px;}}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  padding:7px 16px;border-radius:999px;
}
.eyebrow::before{
  content:"";width:6px;height:6px;border-radius:2px;background:currentColor;opacity:.6;
  transform:rotate(45deg);
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:700;font-size:14px;letter-spacing:.02em;
  padding:14px 26px;border-radius:14px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:0 10px 24px -10px rgba(255,194,14,.7);}
.btn-gold:hover{box-shadow:0 16px 30px -10px rgba(255,194,14,.85);background:var(--gold-deep);}
.btn-navy{background:var(--navy);color:#fff;box-shadow:var(--shadow-soft);}
.btn-navy:hover{background:var(--navy-deep);}
.btn-ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(251,246,236,.4);}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn-block{width:100%;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(251,246,236,.9);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
  gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:800;font-size:22px;color:var(--navy);flex-shrink:0;}
.brand img{height:36px;width:auto;}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{
  font-size:13px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink);
  position:relative;padding:4px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--gold);
  transition:width .25s var(--ease);
}
.nav-links a:hover::after{width:100%;}
.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.icon-btn{
  position:relative;
  width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:rgba(3,57,88,.08);color:var(--navy);transition:background .25s var(--ease),color .25s var(--ease);
  flex-shrink:0;
}
.icon-btn:hover{background:var(--navy);color:#fff;}
.cart-count{
  position:absolute;top:-2px;right:-2px;background:var(--chili);color:#fff;
  width:18px;height:18px;border-radius:50%;font-size:10px;font-weight:800;
  display:flex;align-items:center;justify-content:center;border:2px solid var(--cream);
}
.hamburger{display:none;}
@media (max-width:880px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .header-cta .btn-navy{display:none;}
}

/* ---------- Mobile drawer ---------- */
.mobile-drawer{
  position:fixed;inset:0;z-index:300;visibility:hidden;
}
.mobile-drawer.open{visibility:visible;}
.drawer-scrim{
  position:absolute;inset:0;background:rgba(2,38,58,.45);
  opacity:0;transition:opacity .3s var(--ease);
}
.mobile-drawer.open .drawer-scrim{opacity:1;}
.drawer-panel{
  position:absolute;top:0;right:0;height:100%;width:min(82vw,340px);
  background:var(--cream);box-shadow:-20px 0 50px -20px rgba(23,18,12,.4);
  transform:translateX(100%);transition:transform .35s var(--ease);
  display:flex;flex-direction:column;padding:24px 22px;gap:6px;
  padding-top:max(24px, env(safe-area-inset-top));
}
.mobile-drawer.open .drawer-panel{transform:translateX(0);}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
.drawer-panel a.drawer-link{
  font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--ink);
  padding:14px 4px;border-bottom:1px solid var(--line);
}
.drawer-actions{margin-top:auto;display:flex;flex-direction:column;gap:12px;}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:56px 0 0;
  overflow:hidden;
}
.hero-blob{
  position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;pointer-events:none;
}
.hero-blob.b1{width:420px;height:420px;background:#e8f3e9;top:-140px;right:-120px;}
.hero-blob.b2{width:320px;height:320px;background:#fff2cf;bottom:-120px;left:-100px;}
.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  padding-bottom:56px;
}
@media (max-width:920px){
  .hero-inner{grid-template-columns:1fr;text-align:center;padding-bottom:40px;}
  .hero-copy{order:1;}
  .hero-art{order:2;margin-top:8px;}
}
.hero-copy .eyebrow{background:rgba(3,57,88,.08);color:var(--navy);margin-bottom:20px;}
.hero h1{
  font-size:clamp(34px,6vw,68px);
  font-weight:800;
  color:var(--ink);
  letter-spacing:-0.01em;
}
.hero h1 em{
  font-style:normal;color:var(--navy);
  background:linear-gradient(180deg,transparent 62%,var(--gold) 62%);
  padding:0 4px;
}
.hero-tagline{
  margin-top:20px;font-size:17px;color:var(--ink-soft);max-width:480px;font-weight:500;line-height:1.6;
}
@media (max-width:920px){.hero-tagline{margin-left:auto;margin-right:auto;}}
.hero-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
@media (max-width:920px){.hero-actions{justify-content:center;}}
@media (max-width:480px){.hero-actions{flex-direction:column;width:100%;}.hero-actions .btn{width:100%;}}
.hero-lines{
  display:flex;gap:10px;margin-top:36px;flex-wrap:wrap;
}
@media (max-width:920px){.hero-lines{justify-content:center;}}
.hero-line-chip{
  display:flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:999px;background:#fff;
  font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  box-shadow:0 8px 18px -10px rgba(23,18,12,.25);
}
.hero-line-chip .swatch{width:10px;height:10px;border-radius:50%;}

.hero-art{position:relative;}
.hero-card{
  position:relative;border-radius:32px;overflow:hidden;
  background:linear-gradient(155deg,var(--navy),var(--navy-deep));
  aspect-ratio:4/5;
  box-shadow:0 40px 70px -30px rgba(3,57,88,.55);
  isolation:isolate;
}
.hero-card video,
.hero-card img{
  position:absolute;inset:0;
  width:100%;height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  z-index:0;
}
.hero-card-content,
.hero-card .torn{
  z-index:1;
}
@media (max-width:480px){.hero-card{border-radius:24px;aspect-ratio:1/1;}}
.hero-card .torn{
  position:absolute;left:0;right:0;bottom:0;height:54px;
  background:var(--cream);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M0 10 L8 2 L16 14 L24 4 L32 16 L40 3 L48 13 L56 5 L64 15 L72 2 L80 12 L88 6 L96 16 L104 3 L112 13 L120 5 L128 15 L136 2 L144 12 L152 6 L160 16 L168 3 L176 13 L184 5 L192 15 L200 8 L200 20 L0 20 Z'/%3E%3C/svg%3E") bottom/100% 100%;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M0 10 L8 2 L16 14 L24 4 L32 16 L40 3 L48 13 L56 5 L64 15 L72 2 L80 12 L88 6 L96 16 L104 3 L112 13 L120 5 L128 15 L136 2 L144 12 L152 6 L160 16 L168 3 L176 13 L184 5 L192 15 L200 8 L200 20 L0 20 Z'/%3E%3C/svg%3E") bottom/100% 100%;
}
.hero-card-content{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;
  padding:28px;color:#fff;
}
.hero-card-top{display:flex;justify-content:space-between;align-items:flex-start;}
.hero-badge{
  background:var(--gold);color:var(--ink);font-weight:800;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;padding:8px 14px;border-radius:999px;
}
.hero-card-bottom h3{color:#fff;font-size:clamp(20px,3vw,26px);margin-bottom:8px;}
.hero-card-bottom p{color:rgba(255,255,255,.75);font-size:13.5px;max-width:240px;font-weight:500;}
.float-tag{
  position:absolute;background:#fff;border-radius:18px;padding:13px 17px;
  box-shadow:0 20px 40px -20px rgba(23,18,12,.35);display:flex;align-items:center;gap:10px;
}
.float-tag.tag-1{top:8%;left:-10%;}
.float-tag.tag-2{bottom:14%;right:-8%;}
@media (max-width:1080px){.float-tag.tag-1{left:-4%;}.float-tag.tag-2{right:-4%;}}
@media (max-width:920px){.float-tag{display:none;}}
.float-tag strong{font-family:'Fraunces',serif;font-size:17px;color:var(--navy);}
.float-tag span{font-size:10.5px;color:var(--ink-soft);font-weight:700;text-transform:uppercase;letter-spacing:.05em;}

/* signature zigzag divider — chip-bag tear */
.zig{width:100%;height:30px;background:var(--cream);}
.zig-navy{
  background-color:var(--navy);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M0 4 L10 16 L20 2 L30 18 L40 4 L50 16 L60 2 L70 18 L80 4 L90 16 L100 2 L110 18 L120 4 L130 16 L140 2 L150 18 L160 4 L170 16 L180 2 L190 18 L200 4 L200 0 L0 0 Z'/%3E%3C/svg%3E") top/100% 100%;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M0 4 L10 16 L20 2 L30 18 L40 4 L50 16 L60 2 L70 18 L80 4 L90 16 L100 2 L110 18 L120 4 L130 16 L140 2 L150 18 L160 4 L170 16 L180 2 L190 18 L200 4 L200 0 L0 0 Z'/%3E%3C/svg%3E") top/100% 100%;
}

/* ---------- Section scaffolding ---------- */
section{padding:76px 0;}
@media (max-width:760px){section{padding:54px 0;}}
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:38px;flex-wrap:wrap;
}
.section-head h2{font-size:clamp(26px,4vw,42px);color:var(--ink);}
.section-head p{color:var(--ink-soft);font-size:14.5px;font-weight:500;max-width:420px;margin-top:10px;}
.section-link{
  font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);
  display:inline-flex;align-items:center;gap:6px;
}

/* ---------- Search / filter bar ---------- */
.filter-bar{
  background:#fff;border-radius:var(--radius-md);
  padding:16px;display:flex;gap:12px;flex-wrap:wrap;align-items:center;
  box-shadow:var(--shadow-card);
  margin-bottom:32px;
  position:sticky;top:calc(var(--header-h) + 12px);z-index:20;
}
.filter-bar form{display:flex;gap:12px;flex:1;flex-wrap:wrap;}
.filter-bar input[type="text"]{
  flex:1;min-width:180px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  padding:13px 16px;font-size:14px;font-family:inherit;background:var(--cream);
}
.filter-bar select.cat-select{
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:13px 16px;font-size:14px;
  font-family:inherit;background:var(--cream);color:var(--ink);
}
.filter-bar input:focus,.filter-bar select:focus{outline:2px solid var(--gold);outline-offset:1px;}
@media (max-width:560px){
  .filter-bar{position:static;flex-direction:column;align-items:stretch;}
  .filter-bar form{flex-direction:column;}
  .filter-bar .cat-select{display:block !important;}
  .filter-bar .btn{width:100%;}
}

/* ---------- Product grid ---------- */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media (max-width:1080px){.product-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:760px){.product-grid{grid-template-columns:repeat(2,1fr);gap:14px;}}
@media (max-width:420px){.product-grid{grid-template-columns:1fr;}}
.product-card{
  background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--line);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-5px);box-shadow:0 22px 40px -24px rgba(23,18,12,.32);border-color:var(--line-strong);}
.product-media{
  aspect-ratio:1/1;background:var(--cream-dim);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.product-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.product-card:hover .product-media img{transform:scale(1.06);}
.product-stock{
  position:absolute;top:10px;left:10px;background:var(--plantain);color:#fff;
  font-size:10.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;
}
.product-stock.low{background:var(--chili);}
.product-body{padding:15px 15px 17px;display:flex;flex-direction:column;gap:7px;flex:1;}
.product-cat{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);opacity:.7;}
.product-name{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--ink);}
.product-desc{font-size:12.5px;color:var(--ink-soft);line-height:1.5;flex:1;}
.product-foot{display:flex;align-items:center;justify-content:space-between;margin-top:6px;gap:8px;}
.product-price{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--navy);}
.add-btn{
  width:38px;height:38px;min-width:38px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;
  transition:background .25s var(--ease), transform .25s var(--ease);
}
.add-btn:hover{background:var(--gold);color:var(--ink);transform:rotate(90deg);}
.add-btn:active{transform:scale(.92) rotate(90deg);}
.empty-state{
  text-align:center;padding:54px 20px;color:var(--ink-soft);font-weight:500;
  background:#fff;border-radius:var(--radius-md);border:1px dashed var(--line);
}

/* ---------- Category rail ---------- */
.cat-rail{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.cat-rail::-webkit-scrollbar{height:6px;}
.cat-rail::-webkit-scrollbar-thumb{background:rgba(23,18,12,.15);border-radius:10px;}
.cat-pill{
  flex:0 0 auto;scroll-snap-align:start;
  display:flex;align-items:center;gap:10px;
  padding:13px 20px;border-radius:999px;background:#fff;
  border:1.5px solid var(--line);font-weight:700;font-size:13.5px;color:var(--ink);
  transition:border-color .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.cat-pill:hover,.cat-pill.active{border-color:var(--navy);background:var(--navy);color:#fff;}
.cat-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);}

/* ---------- Banners ---------- */
.banner{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  padding:48px 40px;color:#fff;display:flex;flex-wrap:wrap;gap:28px;justify-content:space-between;align-items:center;
}
@media (max-width:600px){.banner{padding:36px 24px;border-radius:22px;}}
.banner.banner-gift{background:linear-gradient(125deg,#15110c 0%,#2a2118 55%,#3a2a18 100%);}
.banner.banner-holiday{background:linear-gradient(120deg,var(--plantain-deep),#0f4f3a);}
.banner-copy{max-width:540px;}
.banner .eyebrow{background:rgba(255,255,255,.14);color:#fff;margin-bottom:14px;}
.banner h2{color:#fff;font-size:clamp(24px,4vw,40px);margin-bottom:12px;}
.banner p{color:rgba(255,255,255,.78);font-size:14.5px;line-height:1.6;font-weight:500;}
.banner .btn{margin-top:22px;}

/* ---------- Storyboard / video rail ---------- */
.story-rail{display:flex;gap:20px;overflow-x:auto;padding-bottom:16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.story-rail::-webkit-scrollbar{height:6px;}
.story-rail::-webkit-scrollbar-thumb{background:rgba(23,18,12,.15);border-radius:10px;}
.story-card{
  flex:0 0 auto;width:220px;aspect-ratio:9/16;border-radius:24px;overflow:hidden;position:relative;
  scroll-snap-align:start;background:linear-gradient(160deg,#222,#0c0c0c);
  box-shadow:0 22px 46px -28px rgba(23,18,12,.4);
}
@media (max-width:560px){.story-card{width:170px;border-radius:18px;}}
.story-card img{width:100%;height:100%;object-fit:cover;opacity:.85;}
.story-overlay{
  position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(8,8,8,.92) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:18px;color:#fff;
}
.story-overlay h4{color:#fff;font-size:16px;margin-bottom:4px;}
.story-overlay p{font-size:11.5px;color:rgba(255,255,255,.7);font-weight:500;}

/* ---------- Partners marquee ---------- */
.partners-section{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.partners-head{color:#fff;}
.partners-head .eyebrow{background:rgba(255,194,14,.16);color:var(--gold);}
.partners-head h2{color:#fff;}
.partners-head p{color:rgba(255,255,255,.7);}
.partner-track{
  display:flex;
  gap:18px;
  width:max-content;
  overflow:hidden;
  padding-bottom:6px;
  animation:partner-scroll 34s linear infinite;
  will-change:transform;
}
.partner-track:hover{animation-play-state:paused;}
.partner-track::-webkit-scrollbar{display:none;}
.partner-card{
  flex:0 0 auto;width:260px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:20px;padding:20px;backdrop-filter:blur(6px);
  transition:background .25s var(--ease), transform .25s var(--ease);
}
.partner-card:hover{background:rgba(255,255,255,.1);transform:translateY(-3px);}
.partner-mark{
  width:100%;height:84px;background:#fff;border-radius:14px;margin-bottom:15px;
  display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:700;
  color:var(--navy);font-size:13.5px;text-align:center;padding:8px;
}
.partner-card h3{color:#fff;font-size:15.5px;margin-bottom:7px;}
.partner-card p{color:rgba(255,255,255,.68);font-size:12.5px;line-height:1.55;font-weight:500;}
@keyframes partner-scroll{
  from{transform:translateX(0);} 
  to{transform:translateX(-50%);} 
}

/* ---------- CTA / community ---------- */
.community{
  background:linear-gradient(140deg,#15110c,#241b12);
  border-radius:var(--radius-lg);padding:56px 36px;text-align:center;color:#fff;
}
@media (max-width:600px){.community{padding:40px 22px;border-radius:22px;}}
.community h2{color:#fff;font-size:clamp(26px,4vw,42px);margin-bottom:13px;}
.community p{color:rgba(255,255,255,.72);max-width:480px;margin:0 auto 28px;font-size:14.5px;line-height:1.6;font-weight:500;}
.community-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
@media (max-width:420px){.community-actions{flex-direction:column;}.community-actions .btn{width:100%;}}

/* ---------- Footer ---------- */
footer{background:#fff;border-top:1px solid var(--line);padding:64px 0 calc(28px + env(safe-area-inset-bottom));}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:48px;}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px 24px;}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr;gap:30px;}}
.footer-grid h4{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:16px;font-family:'Inter',sans-serif;font-weight:800;}
.footer-grid a{display:block;font-size:14px;font-weight:600;color:var(--ink-soft);margin-bottom:11px;}
.footer-grid a:hover{color:var(--navy);}
.footer-brand p{color:var(--ink-soft);font-size:14px;line-height:1.6;max-width:320px;margin:14px 0 18px;font-weight:500;}
.social-row{display:flex;gap:10px;}
.social-row a{width:38px;height:38px;border-radius:50%;background:var(--cream-dim);display:flex;align-items:center;justify-content:center;transition:background .25s var(--ease),color .25s var(--ease);}
.social-row a:hover{background:var(--navy);color:#fff;}
.network-block{border-top:1px solid var(--line);padding-top:26px;margin-bottom:26px;}
.network-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px;}
@media (max-width:480px){.network-actions{flex-direction:column;}.network-actions .btn{width:100%;}}
.footer-bottom{
  border-top:1px solid var(--line);padding-top:26px;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--ink-soft);font-weight:600;
}

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed;bottom:max(24px, env(safe-area-inset-bottom));right:20px;z-index:90;
  width:54px;height:54px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 16px 30px -10px rgba(37,211,102,.6);
  transition:transform .25s var(--ease);
}
.wa-float:hover{transform:scale(1.07);}
.wa-float svg{width:26px;height:26px;}

/* ---------- Misc ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important;}
  html{scroll-behavior:auto;}
}
:focus-visible{outline:2px solid var(--navy);outline-offset:3px;}