/* Caplinger's Fresh Catch — brand system v2 (teal/gold/cream) */
:root{
  --teal:#176B82; --teal-dk:#0F4F61; --teal-deep:#0A3C49; --teal-soft:#E3EFF1;
  --gold:#EFA838; --gold-dk:#DE9526; --gold-lt:#F7CC76; --gold-soft:#FBEFD6;
  --red:#C8402F; --red-dk:#A8331F; --blue:#2E7CB0;
  --cream:#F6EEDF; --cream-2:#FBF6EC; --paper:#FDFAF3;
  --ink:#16323B; --muted:#5E7C84; --line:#E7DECC; --white:#fff;
  --shadow-sm:0 3px 14px rgba(15,79,97,.08);
  --shadow:0 18px 44px -18px rgba(15,79,97,.30);
  --shadow-lg:0 36px 80px -28px rgba(10,60,73,.45);
  --r:18px; --r-lg:26px; --r-xl:34px; --maxw:1180px;
  --display:"Baloo 2",system-ui,sans-serif; --script:"Caveat",cursive;
  --body:"Nunito Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.68;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.08;letter-spacing:-.005em;margin:0;text-wrap:balance}
p{margin:0 0 1em;text-wrap:pretty}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.eyebrow{font-family:var(--script);font-weight:700;font-size:25px;line-height:1;color:var(--gold-dk);display:inline-block;margin:0 0 8px;transform:rotate(-1.5deg)}
.eyebrow.light{color:var(--gold-lt)}
.section{padding:clamp(58px,8vw,108px) 0;position:relative}
.lead{font-size:clamp(18px,2.1vw,21px);color:var(--muted);max-width:62ch;font-weight:500}
.center{text-align:center;margin-left:auto;margin-right:auto}
.script-accent{font-family:var(--script);color:var(--gold);font-weight:700}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:16px;padding:14px 28px;border-radius:100px;cursor:pointer;border:2.5px solid transparent;transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s,background .2s,color .2s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--teal-deep);box-shadow:0 10px 22px -8px rgba(222,149,38,.7)}
.btn-gold:hover{background:var(--gold-dk)}
.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{background:var(--teal-dk)}
.btn-ghost{border-color:rgba(255,255,255,.6);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.14);border-color:#fff}
.btn-out{border-color:var(--teal);color:var(--teal)}.btn-out:hover{background:var(--teal);color:#fff}
.topbar{background:var(--teal-deep);color:#bfe0e6;font-size:13.5px;text-align:center;padding:9px 16px;font-weight:600}
.topbar b{color:var(--gold-lt);font-weight:700}
.topbar .sep{opacity:.4;margin:0 10px}
.nav{position:sticky;top:0;z-index:60;background:transparent;transition:background .3s,box-shadow .3s,padding .3s;padding:14px 0}
.nav.solid{background:var(--cream-2);box-shadow:0 1px 0 var(--line),0 10px 30px -22px rgba(15,79,97,.5);padding:9px 0}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:11px}
.brand .logo-img{height:50px;width:auto;transition:height .3s}
.nav.solid .brand .logo-img{height:44px}
.brand .logo-on-dark{display:block}.brand .logo-on-light{display:none}
.nav.solid .brand .logo-on-dark{display:none}.nav.solid .brand .logo-on-light{display:block}
.brand .capword{font-family:var(--script);font-weight:700;font-size:23px;line-height:.8;color:#fff;transform:rotate(-2deg)}
.nav.solid .brand .capword{color:var(--teal)}
.nav-links{display:flex;align-items:center;gap:26px;font-family:var(--display);font-size:15.5px;font-weight:600}
.nav-links a{color:#fff;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2.5px;background:var(--gold);border-radius:2px;transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav.solid .nav-links a{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.nav-toggle span{position:absolute;left:0;width:100%;height:3px;background:#fff;border-radius:2px;transition:.3s}
.nav.solid .nav-toggle span{background:var(--teal)}
.nav-toggle span:nth-child(1){top:0}.nav-toggle span:nth-child(2){top:10px}.nav-toggle span:nth-child(3){top:20px}
.wave-b{position:relative}
.wave-b::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:42px;z-index:2;background:var(--wave-color,var(--cream));-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 42' preserveAspectRatio='none'%3E%3Cpath d='M0 42 V18 C120 2 240 2 360 14 C500 28 560 30 700 18 C840 6 980 4 1100 16 C1140 20 1170 22 1200 20 V42 Z'/%3E%3C/svg%3E") bottom/100% 100% no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 42' preserveAspectRatio='none'%3E%3Cpath d='M0 42 V18 C120 2 240 2 360 14 C500 28 560 30 700 18 C840 6 980 4 1100 16 C1140 20 1170 22 1200 20 V42 Z'/%3E%3C/svg%3E") bottom/100% 100% no-repeat}
.home-hero{position:relative;background:linear-gradient(160deg,var(--teal) 0%,var(--teal-dk) 100%);color:#fff;margin-top:-78px;padding-top:120px;overflow:hidden}
.home-hero::before{content:"";position:absolute;top:-80px;right:-60px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%)}
.home-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,64px);align-items:center;padding-bottom:clamp(70px,9vw,120px);padding-top:18px}
.home-hero h1{font-size:clamp(38px,5.6vw,66px);font-weight:800;line-height:1.02;letter-spacing:-.015em}
.home-hero h1 .hl{color:var(--gold-lt)}
.home-hero .script-top{font-family:var(--script);font-weight:700;font-size:clamp(28px,3.4vw,40px);color:var(--gold-lt);transform:rotate(-2deg);display:inline-block;margin-bottom:4px}
.home-hero .sub{font-size:clamp(17px,2vw,20px);color:#e6f1f2;max-width:50ch;margin:18px 0 28px;font-weight:500}
.home-hero .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-media{position:relative}
.hero-media .frame{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);border:6px solid #fff;transform:rotate(1.4deg);aspect-ratio:4/3}
.hero-media .frame img{width:100%;height:100%;object-fit:cover}
.hero-media .seal{position:absolute;bottom:-26px;left:-26px;width:128px;height:128px;border-radius:50%;background:var(--gold);color:var(--teal-deep);display:grid;place-content:center;text-align:center;transform:rotate(-8deg);box-shadow:var(--shadow);border:3px dashed var(--teal-deep)}
.hero-media .seal .b{font-family:var(--display);font-weight:800;font-size:13px;line-height:1.05;padding:0 8px}
.hero-media .seal .s{font-family:var(--script);font-weight:700;font-size:30px;line-height:.8;margin-bottom:2px}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap;margin-top:30px;padding-top:24px;border-top:1px solid rgba(255,255,255,.2)}
.hero-trust .ti{display:flex;flex-direction:column;gap:2px}
.hero-trust .stars{color:var(--gold-lt);font-size:17px;letter-spacing:1px}
.hero-trust .tn{font-family:var(--display);font-weight:800;font-size:24px;line-height:1}
.hero-trust .tl{font-size:12.5px;color:#bfe0e6}
.hero{position:relative;min-height:min(72vh,620px);display:flex;align-items:flex-end;margin-top:-78px;padding-top:78px;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,60,73,.55),rgba(10,60,73,.40) 40%,rgba(10,60,73,.88))}
.hero-in{padding-bottom:clamp(46px,7vw,86px);padding-top:50px;max-width:780px}
.hero h1{font-size:clamp(38px,6vw,72px);font-weight:800}
.hero h1 .hl{color:var(--gold-lt)}
.hero .sub{font-size:clamp(17px,2.1vw,21px);max-width:54ch;margin:18px 0 30px;color:#eaf4f5;font-weight:500}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.crumb{font-family:var(--display);font-size:13px;font-weight:600;color:var(--gold-lt);margin-bottom:14px}
.crumb a{color:var(--gold-lt);opacity:.9}
.sec-head{max-width:720px;margin-bottom:46px}
.sec-head.center{margin-left:auto;margin-right:auto}
.sec-head h2{font-size:clamp(30px,4.4vw,48px);color:var(--teal)}
.sec-head p{margin-top:14px}
.dark{background:var(--teal);color:#e6f1f2}
.dark .sec-head h2,.dark h2,.dark h3{color:#fff}
.dark .lead,.dark .muted{color:#bcdde2}
.deep{background:var(--teal-deep)}
.cream{background:var(--cream)}
.creaml{background:var(--cream-2)}
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,68px);align-items:center}
.split .media{position:relative}
.split .media img{border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/3;object-fit:cover;border:6px solid #fff;transform:rotate(-1.2deg)}
.split .media .chip{position:absolute;bottom:-20px;right:-14px;background:var(--red);color:#fff;border-radius:18px;padding:16px 22px;box-shadow:var(--shadow);max-width:220px;transform:rotate(2deg)}
.split .media .chip .n{font-family:var(--display);font-size:28px;font-weight:800;line-height:1}
.split .media .chip .l{font-size:13px;opacity:.95;margin-top:3px;font-weight:600}
.manifesto p{font-size:clamp(17px,2vw,20px);color:var(--ink)}
.dark .manifesto p{color:#dcebed}
.pullquote{font-family:var(--script);font-size:clamp(26px,3vw,34px);line-height:1.2;color:var(--teal);padding-left:22px;border-left:4px solid var(--gold);margin:24px 0;font-weight:700}
.dark .pullquote{color:#fff;border-color:var(--gold-lt)}
.pullquote cite{display:block;font-family:var(--body);font-size:14px;font-style:normal;color:var(--muted);font-weight:700;margin-top:8px}
.dark .pullquote cite{color:#bcdde2}
.spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.spec{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:330px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow);isolation:isolate}
.spec img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.spec::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,60,73,0) 32%,rgba(10,60,73,.88) 100%)}
.spec:hover img{transform:scale(1.06)}
.spec .body{padding:24px}
.spec h3{font-size:24px;color:#fff;font-weight:700}
.spec .price{font-family:var(--script);font-size:20px;font-weight:700;color:var(--gold-lt);display:block;line-height:1}
.spec p{font-size:14.5px;color:#dbe7ea;margin:6px 0 0;font-weight:500}
.spec.tall{min-height:430px}
.ways{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.way{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:38px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.way:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.way .ic{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:var(--teal-soft);color:var(--teal);margin-bottom:18px}
.way h3{font-size:26px;margin-bottom:10px;color:var(--teal)}
.way ul{list-style:none;padding:0;margin:16px 0 0}
.way li{padding:9px 0 9px 28px;position:relative;border-top:1px solid var(--line);font-size:15.5px;font-weight:600}
.way li::before{content:"";position:absolute;left:0;top:16px;width:10px;height:10px;border-radius:50%;background:var(--gold)}
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.loc{background:var(--white);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.loc:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.loc .ph{position:relative;aspect-ratio:3/2;overflow:hidden}
.loc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.loc:hover .ph img{transform:scale(1.05)}
.loc .tag{position:absolute;top:14px;left:14px;background:var(--teal);color:#fff;font-family:var(--display);font-size:12px;font-weight:700;padding:6px 13px;border-radius:100px}
.loc .tag.market{background:var(--red)}
.loc .b{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.loc h3{font-size:23px;color:var(--teal)}
.loc .rate{display:flex;align-items:center;gap:7px;margin:9px 0 4px;font-size:14px;font-weight:700}
.loc .rate .s{color:var(--gold);letter-spacing:1px}
.loc .rate span{color:var(--muted);font-weight:600}
.loc .addr{color:var(--muted);font-size:14.5px;margin:8px 0 16px;flex:1;font-weight:600}
.loc .lk{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-weight:700;font-size:15px;font-family:var(--display)}
.loc .lk svg{transition:transform .25s}.loc:hover .lk svg{transform:translateX(4px)}
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.press{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.press:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.press .src{font-family:var(--display);font-weight:800;color:var(--teal);font-size:15px;display:flex;align-items:center;gap:8px;margin-bottom:12px}
.press .src .dot{width:9px;height:9px;border-radius:50%;background:var(--gold)}
.press .headline{font-family:var(--display);font-weight:700;font-size:19px;color:var(--ink);line-height:1.2;margin-bottom:10px}
.press p{font-size:14.5px;color:var(--muted);font-weight:500;flex:1}
.press .lk{margin-top:14px;font-family:var(--display);font-weight:700;font-size:14px;color:var(--red);display:inline-flex;align-items:center;gap:6px}
.badges{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:8px}
.badge{display:flex;align-items:center;gap:12px;background:var(--gold-soft);border:2px solid var(--gold-lt);border-radius:100px;padding:12px 22px}
.badge .num{font-family:var(--display);font-weight:800;font-size:26px;color:var(--red);line-height:1}
.badge .txt{font-family:var(--display);font-weight:700;font-size:14px;color:var(--teal-dk);line-height:1.1;text-align:left}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev{background:var(--white);border-radius:var(--r-lg);padding:28px;border:1px solid var(--line);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;position:relative}
.dark .rev{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14)}
.rev .s{color:var(--gold);letter-spacing:2px;margin-bottom:12px;font-size:16px}
.rev p{font-size:15.5px;color:var(--ink);flex:1;font-weight:500}
.dark .rev p{color:#eaf4f5}
.rev .by{margin-top:16px;font-size:13.5px;color:var(--muted);display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:13px;font-weight:600}
.dark .rev .by{border-color:rgba(255,255,255,.14);color:#bcdde2}
.rev .by b{color:var(--teal);font-family:var(--display)}.dark .rev .by b{color:#fff}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .n{font-family:var(--display);font-size:clamp(34px,4.5vw,52px);font-weight:800;color:var(--gold-lt);line-height:1}
.stat .l{font-size:14px;color:#bcdde2;margin-top:8px;font-weight:600}
.cta-band{background:linear-gradient(135deg,var(--gold),var(--gold-dk));color:var(--teal-deep);border-radius:var(--r-xl);padding:clamp(40px,6vw,70px);text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta-band h2{font-size:clamp(28px,4vw,46px);color:var(--teal-deep)}
.cta-band p{color:#4a3410;max-width:54ch;margin:14px auto 26px;font-size:18px;font-weight:600}
.faq{max-width:820px;margin:0 auto}
.faq details{border-bottom:2px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;padding:20px 44px 20px 0;font-family:var(--display);font-weight:700;font-size:clamp(18px,2.2vw,22px);color:var(--teal);position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:28px;color:var(--gold-dk);transition:transform .3s;font-family:var(--body)}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq .ans{padding:0 44px 20px 0;color:var(--muted);font-size:16px;font-weight:500}
.footer{background:var(--teal-deep);color:#a7cdd5;padding:70px 0 28px;font-size:14.5px}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:38px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.13)}
.footer .capword{font-family:var(--script);color:#fff;font-size:22px;font-weight:700;display:block;transform:rotate(-2deg)}
.footer .logo-img{height:54px;margin:4px 0 12px}
.footer h4{color:#fff;font-family:var(--display);font-size:14px;letter-spacing:.04em;margin-bottom:14px;font-weight:700}
.footer a{display:block;padding:6px 0;color:#a7cdd5;transition:color .2s;font-weight:600}
.footer a:hover{color:var(--gold-lt)}
.footer .social{display:flex;gap:11px;margin-top:16px}
.footer .social a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.09);display:grid;place-items:center;padding:0}
.footer .social a:hover{background:var(--gold)}
.foot-loc{font-size:13.5px;line-height:1.5;margin-bottom:13px;font-weight:600}
.foot-loc b{color:#fff;display:block}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:22px;font-size:12.5px;color:#6f9aa3}
.foot-bot a{display:inline;color:#6f9aa3}
.loc-hero{position:relative;color:#fff;padding:clamp(120px,15vw,170px) 0 clamp(46px,6vw,74px);margin-top:-78px;overflow:hidden}
.loc-hero .hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,60,73,.5),rgba(10,60,73,.85))}
.loc-hero h1{font-size:clamp(38px,6vw,64px);font-weight:800}
.loc-meta{display:flex;gap:26px;flex-wrap:wrap;margin-top:20px;font-size:15px;color:#eaf4f5;font-weight:600}
.loc-meta .stars{color:var(--gold-lt)}
.info-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:38px;align-items:start}
.info-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-sm)}
.info-card h3{font-size:22px;margin-bottom:16px;color:var(--teal)}
.info-row{display:flex;gap:14px;padding:13px 0;border-top:1px solid var(--line);font-size:15px;font-weight:600}
.info-row:first-of-type{border-top:0}
.info-row .ic{color:var(--red);flex-shrink:0;margin-top:2px}
.info-row b{color:var(--teal)}
.hours-tbl{width:100%;border-collapse:collapse;font-size:14.5px;font-weight:600}
.hours-tbl td{padding:9px 0;border-top:1px solid var(--line)}
.hours-tbl td:last-child{text-align:right;color:var(--muted)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
.gallery a{border-radius:16px;overflow:hidden;aspect-ratio:1;box-shadow:var(--shadow-sm)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery a:hover img{transform:scale(1.07)}
.gallery .big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.sibling{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sib{display:flex;gap:14px;align-items:center;background:var(--white);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow-sm);transition:transform .25s}
.sib:hover{transform:translateY(-3px)}
.sib img{width:74px;height:74px;border-radius:14px;object-fit:cover;flex-shrink:0}
.sib b{display:block;font-family:var(--display);font-size:18px;color:var(--teal)}
.sib span{font-size:13px;color:var(--muted);font-weight:600}
.pill{font-family:var(--display);font-size:12.5px;font-weight:700;padding:7px 15px;border-radius:100px;background:var(--teal-soft);color:var(--teal);margin:4px 6px 4px 0;display:inline-block}
.dark .pill{background:rgba(255,255,255,.12);color:#cfeaee}
.badge-row{display:flex;gap:0;flex-wrap:wrap;margin-top:10px}
.note{background:var(--gold-soft);color:#6a4d18;border-radius:14px;padding:14px 18px;font-size:13.5px;border:1px solid var(--gold-lt);font-weight:600}
@media(max-width:980px){
  .home-hero .wrap,.split,.info-grid{grid-template-columns:1fr}
  .home-hero .hero-media{order:-1;max-width:520px;margin:0 auto}
  .split .media{order:-1}
  .spec-grid,.rev-grid,.press-grid{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 22px}
}
@media(max-width:760px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--cream-2);padding:16px 26px 24px;gap:4px;box-shadow:var(--shadow);align-items:stretch}
  .nav-links.open a{color:var(--ink);padding:13px 0;border-bottom:1px solid var(--line)}
  .nav-links.open a::after{display:none}
  .g2,.g3,.ways,.loc-grid,.spec-grid,.rev-grid,.press-grid,.sibling,.gallery{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}.gallery .big{grid-column:span 2}
  .stats{grid-template-columns:1fr 1fr}
  .hero-cta .btn,.home-hero .hero-cta .btn{flex:1;justify-content:center}
  .hero-media .seal{width:104px;height:104px;left:auto;right:-8px;bottom:-22px}
  .split .media .chip{right:50%;transform:translateX(50%) rotate(2deg);bottom:-24px}
}
@media(max-width:430px){
  body{font-size:16px}
  .hero-trust{gap:16px}
  .gallery{grid-template-columns:1fr 1fr}
}

/* ===== v4: solid nav + COLORED logo + dropdown menus ===== */
.nav{background:rgba(251,246,236,.97);-webkit-backdrop-filter:saturate(1.3) blur(10px);backdrop-filter:saturate(1.3) blur(10px);box-shadow:0 1px 0 var(--line)}
.nav.solid{box-shadow:0 1px 0 var(--line),0 10px 30px -22px rgba(15,79,97,.5);padding:7px 0}
.brand .logo-on-dark{display:none!important}
.brand .logo-on-light{display:block!important}
.brand .capword{color:var(--teal)!important}
.nav-links a{color:var(--ink)!important}
.nav-toggle span{background:var(--teal)!important}
.home-hero{margin-top:0;padding-top:clamp(34px,5vw,60px)}
.hero{margin-top:0;padding-top:60px}
.loc-hero{margin-top:0;padding-top:clamp(56px,8vw,92px)}
/* dropdowns */
.nav-links{gap:6px}
.nav-group{position:relative;display:flex;align-items:center}
.nav-top,.nav-links>a{display:inline-flex;align-items:center;gap:5px;padding:10px 14px;border-radius:10px;transition:background .2s,color .2s}
.nav-links>a:hover,.nav-top:hover{background:var(--teal-soft)}
.nav-top .caret{width:11px;height:11px;transition:transform .25s;opacity:.65}
.nav-group:hover .nav-top .caret,.nav-group:focus-within .nav-top .caret{transform:rotate(180deg)}
.nav-links a::after{display:none}
.dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:248px;background:#fff;
  border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:10px;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .22s,transform .22s,visibility .22s;z-index:70}
.nav-group:hover .dropdown,.nav-group:focus-within .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown a{display:block;padding:11px 14px;border-radius:10px;font-size:15px;font-weight:600;
  color:var(--ink)!important;white-space:nowrap}
.dropdown a:hover{background:var(--teal-soft);color:var(--teal)!important}
.dropdown a .sm{display:block;font-size:12px;font-weight:600;color:var(--muted);font-family:var(--body)}
.dropdown a:hover .sm{color:var(--teal)}
@media(max-width:760px){
  .nav-group{display:block}
  .nav-top,.nav-links>a{padding:13px 0;width:100%}
  .nav-top .caret{display:none}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    padding:0 0 8px 14px;min-width:0;background:transparent}
  .dropdown a{padding:9px 0;font-size:14.5px}
  .nav-links.open .nav-group:not(:last-child){border-bottom:1px solid var(--line)}
}

/* ================= v5: overlapping logo emblem + de-block ================= */
/* nav transparent over the (dark) hero, solid cream on scroll */
.nav{background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:none!important;padding:15px 0}
.nav.solid{background:rgba(251,246,236,.97)!important;-webkit-backdrop-filter:saturate(1.3) blur(10px)!important;backdrop-filter:saturate(1.3) blur(10px)!important;box-shadow:0 1px 0 var(--line),0 12px 30px -22px rgba(15,79,97,.5)!important;padding:7px 0}
.nav-in{align-items:flex-start}
.nav-links,.nav-cta{align-self:center}
.nav-links a,.nav-top{color:#fff!important}
.nav-top:hover,.nav-links>a:hover{background:rgba(255,255,255,.16)!important}
.nav.solid .nav-links a,.nav.solid .nav-top{color:var(--ink)!important}
.nav.solid .nav-top:hover,.nav.solid .nav-links>a:hover{background:var(--teal-soft)!important}
.nav-toggle span{background:#fff!important}
.nav.solid .nav-toggle span{background:var(--teal)!important}

/* LOGO EMBLEM — a white "shop sign" that hangs from the top and overlaps the hero */
.brand{background:#fff;border-radius:0 0 28px 28px;padding:16px 26px 20px;gap:3px;
  flex-direction:column;align-items:center;line-height:1;
  box-shadow:0 22px 44px -16px rgba(10,60,73,.5);
  margin-top:-15px;margin-bottom:-52px;position:relative;z-index:9;transition:margin .3s,padding .3s}
.brand .capword{color:var(--teal)!important;font-size:25px;margin:0;transform:rotate(-2deg)}
.brand .logo-img{height:74px!important;width:auto}
.brand .logo-on-light{display:block!important}.brand .logo-on-dark{display:none!important}
.nav.solid .brand{margin-top:-9px;margin-bottom:-40px;padding:11px 22px 15px}
.nav.solid .brand .logo-img{height:60px!important}
.nav.solid .brand .capword{font-size:22px}

/* restore hero sitting UNDER the transparent nav so the emblem overlaps onto it */
.home-hero{margin-top:-84px;padding-top:132px}
.hero{margin-top:-84px;padding-top:92px}
.loc-hero{margin-top:-84px;padding-top:clamp(118px,15vw,164px)}

/* de-block the hero image → organic shape, layered depth, no hard frame */
.hero-media .frame{border:0!important;transform:rotate(0)!important;aspect-ratio:1/1!important;
  border-radius:60% 40% 56% 44% / 50% 54% 46% 50%!important;
  box-shadow:0 44px 90px -26px rgba(10,60,73,.62),0 0 0 12px rgba(255,255,255,.10)!important}
.hero-media::before{content:"";position:absolute;inset:-26px;z-index:-1;
  background:radial-gradient(circle at 62% 38%,rgba(247,204,118,.30),transparent 60%)}
.hero-media .seal{bottom:8px;left:-6px;box-shadow:0 16px 34px -10px rgba(10,60,73,.5)}
.home-hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle at 10% 16%,rgba(255,255,255,.06),transparent 24%),radial-gradient(circle at 90% 84%,rgba(255,255,255,.05),transparent 28%)}

/* softer, less-boxy cards (float on shadow, gentle borders, rounder) */
.way,.press,.rev,.info-card,.menu-card,.cform{border:0!important;border-radius:28px!important;
  box-shadow:0 22px 50px -26px rgba(15,79,97,.30),0 2px 8px rgba(15,79,97,.05)!important}
.loc{border:0!important;border-radius:28px!important;box-shadow:0 20px 46px -24px rgba(15,79,97,.32)!important}
.spec{border-radius:28px!important}
.sib{border:0!important;border-radius:22px!important;box-shadow:0 12px 30px -18px rgba(15,79,97,.3)!important}
.badge{border-radius:22px!important}

/* warm the flat color blocks with a soft vertical wash so sections feel less like slabs */
.section.cream{background:linear-gradient(180deg,var(--cream) 0%,#F2E7D2 100%)}
.section.dark{background:linear-gradient(155deg,var(--teal) 0%,var(--teal-dk) 70%,var(--teal-deep) 100%)}

/* eyebrow gets a hand-drawn underline flourish */
.sec-head .eyebrow{position:relative}

@media(max-width:760px){
  .nav-in{align-items:center}
  .brand{margin-top:-12px;margin-bottom:0;padding:10px 18px 13px;border-radius:0 0 22px 22px}
  .brand .logo-img{height:54px!important}
  .brand .capword{font-size:21px}
  .home-hero{margin-top:-78px;padding-top:96px}
  .hero-media .frame{aspect-ratio:4/3!important}
}

/* ===== v5b: nav = cream "sign rail" always; emblem hangs onto hero ===== */
.nav{background:rgba(251,246,236,.97)!important;-webkit-backdrop-filter:saturate(1.3) blur(10px)!important;backdrop-filter:saturate(1.3) blur(10px)!important;box-shadow:0 1px 0 var(--line),0 8px 24px -20px rgba(15,79,97,.45)!important;padding:10px 0!important}
.nav.solid{padding:6px 0!important}
.nav-in{align-items:center!important}
.nav-links a,.nav-top{color:var(--ink)!important}
.nav-top:hover,.nav-links>a:hover{background:var(--teal-soft)!important}
.nav-toggle span{background:var(--teal)!important}
/* heroes sit directly below the rail; emblem overlaps down onto them */
.home-hero{margin-top:0!important;padding-top:clamp(46px,6vw,76px)!important}
.hero{margin-top:0!important;padding-top:70px!important}
.loc-hero{margin-top:0!important;padding-top:clamp(60px,8vw,98px)!important}
.brand{margin-top:-4px!important;margin-bottom:-46px!important;padding:12px 22px 16px!important;
  border-radius:0 0 24px 24px!important;box-shadow:0 20px 40px -16px rgba(10,60,73,.45)!important}
.brand .logo-img{height:62px!important}
.brand .capword{font-size:23px!important}
.nav.solid .brand{margin-bottom:-38px!important;padding:9px 20px 13px!important}
.nav.solid .brand .logo-img{height:54px!important}
@media(max-width:760px){
  .brand{margin-bottom:0!important;padding:9px 16px 12px!important}
  .brand .logo-img{height:48px!important}
  .home-hero{padding-top:54px!important}
}

/* ===== v5c: replace emoji that box-out in award badges (CSS-only) ===== */
.badges .badge:nth-child(2) .num{font-size:0!important;line-height:1}
.badges .badge:nth-child(2) .num::after{content:"USA";font-size:21px;font-family:var(--display);font-weight:800;color:var(--red)}
.badges .badge:nth-child(3) .num{font-size:0!important;line-height:1}
.badges .badge:nth-child(3) .num::after{content:"\2605";font-size:27px;color:var(--red)}
