/* Shore Lookin' Good Grooming — coastal grooming identity
   Palette: ocean teal #0E4A47 · dune sand #F3E9D6 · coral #E0795B · ink #16302E · foam #CFE0DA */
:root{
  --teal:#0E4A47;
  --teal-d:#0B3B38;
  --teal-dd:#082F2D;
  --sand:#F3E9D6;
  --sand-2:#EFE2CB;
  --paper:#FBF6EC;
  --coral:#E0795B;        /* bright: decorative strokes only (waves, underline, pin) */
  --coral-d:#C9603F;
  --rust:#A8481F;         /* text accent on LIGHT grounds (AA: 5.4:1 on paper) */
  --coral-lt:#F2A98E;     /* text accent on DARK teal grounds (AA: 5.2:1 on teal) */
  --coral-btn:#C0542E;    /* button fill, white text (AA: 4.65:1) */
  --coral-btn-h:#A8481F;  /* button hover (AA: 5.8:1) */
  --foam:#CFE0DA;
  --ink:#16302E;
  --ink-soft:#3C5754;
  --line:rgba(22,48,46,.14);
  --line-on:rgba(243,233,214,.22);
  --r:3px;
  --maxw:1140px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:"Hanken Grotesque",system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",system-ui,sans-serif;font-weight:800;line-height:1.04;margin:0;letter-spacing:-.015em}
p{margin:0}
a{color:inherit}
img,svg{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

.skip{position:absolute;left:-999px;top:0;background:var(--coral-btn);color:#fff;padding:10px 16px;z-index:200;border-radius:var(--r)}
.skip:focus{left:12px;top:12px}

/* branded focus ring */
a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid var(--coral);outline-offset:3px;border-radius:2px}
.nav a:focus-visible,.hero a:focus-visible,.why a:focus-visible,.contact a:focus-visible,.loc-panel a:focus-visible,.footer a:focus-visible{outline-color:var(--coral-lt)}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:"Hanken Grotesque",sans-serif;font-weight:700;font-size:.98rem;
  padding:13px 22px;border-radius:var(--r);text-decoration:none;cursor:pointer;
  border:1.5px solid transparent;transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease);
  letter-spacing:.01em;
}
.btn-coral{background:var(--coral-btn);color:#fff}
.btn-coral:hover{background:var(--coral-btn-h)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--sand)}
.btn-onteal{border-color:var(--foam);color:var(--sand)}
.btn-onteal:hover{background:var(--sand);color:var(--teal)}
.btn-block{width:100%;justify-content:center;padding:15px}

.kicker{
  font-family:"Hanken Grotesque",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;
  color:var(--rust);margin-bottom:14px;
}
.kicker.light{color:var(--coral-lt)}
.lede{color:var(--ink-soft);font-size:1.08rem;max-width:54ch}
.sec-head{max-width:64ch;margin-bottom:46px}
.sec-head h2{font-size:clamp(1.9rem,4.2vw,3rem);margin-bottom:16px}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s var(--ease),box-shadow .3s var(--ease)}
.nav::before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,47,45,.55),transparent);pointer-events:none;transition:opacity .3s}
.nav-in{position:relative;max-width:var(--maxw);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--sand);z-index:2}
.brand-mark{color:var(--sand);flex:none}
.brand-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.12rem;letter-spacing:-.01em}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--sand);text-decoration:none;font-weight:600;font-size:.96rem;position:relative;padding:4px 0}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--coral);transition:right .25s var(--ease)}
.nav-links a:not(.nav-cta):hover::after{right:0}
.nav-links a.nav-cta{background:var(--coral-btn);color:#fff;padding:9px 18px;border-radius:var(--r);font-weight:700;transition:background .2s var(--ease)}
.nav-links a.nav-cta:hover{background:var(--coral-btn-h)}

/* scrolled state */
.nav.scrolled{background:var(--teal);box-shadow:0 1px 0 rgba(0,0,0,.18),0 8px 24px rgba(8,47,45,.18)}
.nav.scrolled::before{opacity:0}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:2}
.nav-toggle span{width:24px;height:2.5px;background:var(--sand);border-radius:2px;transition:transform .25s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-menu{display:none;flex-direction:column;background:var(--teal);border-top:1px solid var(--line-on)}
.mobile-menu a{color:var(--sand);text-decoration:none;padding:15px 24px;font-weight:600;border-bottom:1px solid var(--line-on)}
.mobile-menu a:active{background:var(--teal-d)}
.mobile-menu .m-call{color:var(--coral-lt);font-weight:700}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--teal);color:var(--sand);padding:150px 0 96px;overflow:hidden}
.hero-waves{position:absolute;left:0;right:0;bottom:0;height:220px;pointer-events:none}
.wavefield{width:100%;height:100%}
.hero-in{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:"Hanken Grotesque",sans-serif;font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;color:var(--foam)}
.hero-h{font-size:clamp(2.9rem,8vw,5.6rem);margin:18px 0 0;letter-spacing:-.025em}
.ul-wrap{position:relative;display:inline-block;color:var(--sand)}
.ul{position:absolute;left:0;right:-4px;bottom:-.12em;width:100%;height:.34em;overflow:visible}
.ul path{stroke-dasharray:520;stroke-dashoffset:520}
.hero-sub{margin:26px 0 0;font-size:clamp(1.05rem,2vw,1.22rem);max-width:50ch;color:#e9ddc6;line-height:1.6}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero .btn-ghost{border-color:var(--foam);color:var(--sand)}
.hero .btn-ghost:hover{background:var(--sand);color:var(--teal)}

/* ---------- trust strip ---------- */
.trust{background:var(--teal-d);color:var(--sand)}
.trust-in{max-width:var(--maxw);margin:0 auto;padding:0 24px;list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust-in li{padding:30px 24px;border-left:1px solid var(--line-on);transition:background .25s var(--ease)}
.trust-in li:first-child{border-left:0}
.trust-in li:hover{background:var(--teal)}
.t-n{display:block;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.5rem;color:var(--sand);letter-spacing:-.01em}
.t-l{display:block;color:var(--foam);font-size:.92rem;margin-top:4px}

/* ---------- services ---------- */
.services{padding:96px 0;background:var(--paper)}
.svc-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.svc{position:relative;padding:34px 30px 38px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .25s var(--ease)}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--coral);transform:scaleY(0);transform-origin:top;transition:transform .28s var(--ease)}
.svc:hover{background:#fff}
.svc:hover::before{transform:scaleY(1)}
.svc h3{font-size:1.28rem;margin-bottom:10px;transition:color .25s var(--ease)}
.svc:hover h3{color:var(--rust)}
.svc p{color:var(--ink-soft);font-size:.99rem}
.svc-note{margin-top:32px;color:var(--ink-soft);font-size:1.02rem}
.svc-note a{color:var(--rust);font-weight:700;text-decoration:none;border-bottom:2px solid transparent;transition:border-color .2s}
.svc-note a:hover{border-color:var(--rust)}

/* ---------- why ---------- */
.why{background:var(--teal);color:var(--sand);padding:96px 0}
.why-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:60px;align-items:center}
.why h2{font-size:clamp(1.9rem,4vw,2.85rem);margin-bottom:22px}
.why-copy p{color:#e8dcc5;margin-bottom:16px;max-width:56ch}
.why-points{list-style:none;margin:26px 0 0;padding:0}
.why-points li{display:flex;align-items:flex-start;gap:13px;padding:11px 0;border-bottom:1px solid var(--line-on);color:var(--sand);font-weight:500}
.why-points li svg{color:var(--coral);flex:none;margin-top:3px}
.why-card{background:var(--teal-d);border:1px solid var(--line-on);border-radius:var(--r);padding:18px;align-self:stretch}
.rig{width:100%;height:auto;border-radius:var(--r)}
.why-card-cap{margin-top:16px;color:var(--foam);font-size:.96rem;line-height:1.55}

/* ---------- expect ---------- */
.expect{background:var(--sand);padding:96px 0}
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.step{position:relative;padding:0 28px;border-left:1px solid var(--line)}
.step:first-child{padding-left:0;border-left:0}
.step-n{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.05rem;color:var(--rust);display:inline-block;padding:5px 0;border-bottom:2px solid var(--coral);margin-bottom:18px;letter-spacing:.04em}
.step h3{font-size:1.22rem;margin-bottom:9px}
.step p{color:var(--ink-soft);font-size:.97rem}

/* ---------- faq ---------- */
.faq{background:var(--paper);padding:96px 0}
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:56px;align-items:start}
.faq-head h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:14px}
.faq-head .lede a,.qa-body a,.hrs-note a{color:var(--rust);font-weight:700}
.faq-head{position:sticky;top:90px}
.faq-list{display:flex;flex-direction:column}
.qa{border-top:1px solid var(--line)}
.qa:last-child{border-bottom:1px solid var(--line)}
.qa summary{
  list-style:none;cursor:pointer;padding:22px 40px 22px 0;position:relative;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.12rem;color:var(--ink);
  transition:color .2s var(--ease);
}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"";position:absolute;right:6px;top:50%;width:11px;height:11px;border-right:2.5px solid var(--coral);border-bottom:2.5px solid var(--coral);transform:translateY(-70%) rotate(45deg);transition:transform .25s var(--ease)}
.qa[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.qa summary:hover{color:var(--rust)}
.qa-body{padding:0 40px 24px 0}
.qa-body p{color:var(--ink-soft)}
.qa-body a{text-decoration:none;border-bottom:2px solid transparent;transition:border-color .2s}
.qa-body a:hover{border-color:var(--rust)}

/* ---------- contact ---------- */
.contact{background:var(--teal-d);color:var(--sand);padding:96px 0}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start}
.contact-copy h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:18px}
.contact-copy p{color:#e8dcc5;max-width:46ch}
.contact-facts{list-style:none;margin:30px 0 0;padding:0}
.contact-facts li{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line-on);font-weight:600}
.contact-facts li svg{color:var(--coral);flex:none}
.contact-facts a{color:var(--sand);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.contact-facts a:hover{color:var(--foam);border-color:var(--foam)}

.form{background:var(--sand);color:var(--ink);border-radius:var(--r);padding:30px;border:1px solid rgba(0,0,0,.06)}
.field{margin-bottom:16px;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{font-weight:700;font-size:.9rem;margin-bottom:7px}
.field .opt{font-weight:500;color:var(--ink-soft)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r);
  padding:12px 13px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
  width:100%;
}
.field textarea{resize:vertical;min-height:84px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,74,71,.16)}
.field.invalid input,.field.invalid select{border-color:var(--coral-d);box-shadow:0 0 0 3px rgba(201,96,63,.16)}
.select-wrap{position:relative}
.select-wrap select{appearance:none;-webkit-appearance:none;padding-right:40px;cursor:pointer}
.select-wrap svg{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--ink-soft);pointer-events:none}
.err{display:none;color:var(--rust);font-size:.82rem;font-weight:600;margin-top:6px}
.field.invalid .err{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-fine{margin-top:14px;font-size:.84rem;color:var(--ink-soft);text-align:center}
.form-success{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1.5px solid var(--teal);border-radius:var(--r);padding:22px;margin-top:6px}
.form-success svg{color:var(--teal);flex:none}
.form-success a{color:var(--rust);font-weight:700}

/* ---------- visit ---------- */
.visit{background:var(--paper);padding:96px 0}
.visit-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.hours h2{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:22px}
.hrs{width:100%;border-collapse:collapse;margin-bottom:16px}
.hrs th,.hrs td{text-align:left;padding:13px 4px;border-bottom:1px solid var(--line);font-weight:500}
.hrs th{font-family:"Hanken Grotesque",sans-serif;font-weight:600;color:var(--ink)}
.hrs td{text-align:right;color:var(--ink-soft)}
.hrs tr{transition:background .2s var(--ease)}
.hrs tbody tr:hover{background:var(--sand)}
.hrs .closed td{color:var(--rust);font-weight:700}
.hrs-note{color:var(--ink-soft);font-size:.95rem}

.loc-panel{background:var(--teal);border-radius:var(--r);overflow:hidden;color:var(--sand)}
.loc-art{width:100%;height:auto;display:block}
.loc-body{padding:28px 30px 32px}
.loc-body h3{font-size:1.5rem;margin-bottom:10px;color:var(--sand)}
.loc-body p{color:#e8dcc5;margin-bottom:20px;max-width:42ch}

/* ---------- footer ---------- */
.footer{background:var(--teal-dd);color:var(--sand);padding:64px 0 30px}
.footer-in{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--line-on)}
.f-mark{margin-bottom:14px}
.f-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.25rem;margin-bottom:8px}
.f-tag{color:var(--foam);font-size:.96rem;max-width:34ch}
.f-col h4{font-family:"Hanken Grotesque",sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--coral);margin-bottom:14px;font-weight:700}
.f-col p{color:#dcd0b9;margin-bottom:12px;font-size:.96rem;line-height:1.5}
.f-col a{color:#dcd0b9;text-decoration:none;border-bottom:1px solid transparent;transition:color .2s,border-color .2s}
.f-col a:hover{color:var(--sand);border-color:var(--foam)}
.f-base{display:flex;justify-content:space-between;align-items:center;padding-top:24px;gap:16px;flex-wrap:wrap}
.f-base p{color:var(--foam);font-size:.86rem}
.f-top{color:var(--foam);text-decoration:none;font-size:.86rem;font-weight:600}
.f-top:hover{color:var(--sand)}

/* ---------- reveal / motion ---------- */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .hero .reveal{opacity:0;transform:translateY(22px)}
.js .hero.lit .reveal{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .hero.lit .reveal[data-d="1"]{transition-delay:.05s}
.js .hero.lit .reveal[data-d="2"]{transition-delay:.16s}
.js .hero.lit .reveal[data-d="3"]{transition-delay:.30s}
.js .hero.lit .reveal[data-d="4"]{transition-delay:.44s}
.hero.lit .ul path{animation:draw 1s var(--ease) .7s forwards}
@keyframes draw{to{stroke-dashoffset:0}}

@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .ul path{stroke-dashoffset:0!important;animation:none!important}
  .wv{animation:none!important}
}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .why-grid,.faq-grid,.contact-grid,.visit-grid{grid-template-columns:1fr;gap:40px}
  .faq-head{position:static}
  .svc-list{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:30px 0}
  .step{padding:0 22px}
  .step:nth-child(odd){padding-left:0;border-left:0}
  .why-card{max-width:440px}
}
@media (max-width:760px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .mobile-menu:not([hidden]){display:flex}
  .trust-in{grid-template-columns:1fr 1fr}
  .trust-in li:nth-child(odd){border-left:0}
  .trust-in li:nth-child(-n+2){border-bottom:1px solid var(--line-on)}
}
@media (max-width:560px){
  body{font-size:16px}
  .hero{padding:124px 0 72px}
  .services,.why,.expect,.faq,.contact,.visit{padding:64px 0}
  .sec-head{margin-bottom:34px}
  .svc-list{grid-template-columns:1fr;border-left:0}
  .svc{border-left:0;border-right:0;padding:26px 0 28px}
  .svc::before{width:100%;height:3px;top:0;bottom:auto;transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}
  .svc:hover::before{transform:scaleX(1)}
  .steps{grid-template-columns:1fr;gap:8px 0}
  .step{padding:22px 0;border-left:0;border-top:1px solid var(--line)}
  .step:first-child{border-top:0}
  .trust-in{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:1fr}
  .form{padding:22px}
  .footer-in{grid-template-columns:1fr;gap:30px}
  .hero-cta .btn{flex:1;justify-content:center}
}
