/* ===== Fonts ===== */
@font-face{font-family:"Saira Condensed";src:url("./fonts/saira-condensed-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Saira Condensed";src:url("./fonts/saira-condensed-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:"Public Sans";src:url("./fonts/public-sans.woff2") format("woff2");font-weight:400 700;font-style:normal;font-display:swap;}

/* ===== Tokens ===== */
:root{
  --ink:#15171A;
  --steel:#22262C;
  --steel-2:#2C313A;
  --paper:#F5F3EF;
  --paper-2:#ECE8E1;
  --signal:#E11D2A;
  --signal-d:#BB1320;
  --amber:#F2A900;
  --line:#3A3F47;
  --line-soft:#DAD5CC;
  --muted:#6A6F77;
  --muted-d:#9AA1AB;
  --txt:#1B1E22;

  --disp:"Saira Condensed",system-ui,sans-serif;
  --body:"Public Sans",system-ui,sans-serif;

  --wrap:1140px;
  --r:14px;
  --r-sm:9px;
  --shadow:0 18px 50px -22px rgba(0,0,0,.45);
  --shadow-sm:0 6px 18px -10px rgba(0,0,0,.4);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ===== Base ===== */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--body);color:var(--txt);background:var(--paper);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;}
h1,h2,h3{font-family:var(--disp);font-weight:700;line-height:1.02;margin:0;letter-spacing:.005em;}
p{margin:0 0 1em;}
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:22px;}

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

:focus-visible{outline:3px solid var(--signal);outline-offset:2px;border-radius:4px;}

/* ===== Buttons ===== */
.btn{
  --bg:var(--signal);
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--disp);font-weight:700;font-size:1.08rem;letter-spacing:.02em;
  text-transform:uppercase;text-decoration:none;cursor:pointer;
  padding:14px 22px;min-height:48px;border:0;border-radius:var(--r-sm);
  background:var(--bg);color:#fff;transition:transform .15s var(--ease),background .2s,box-shadow .2s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-2px);background:var(--signal-d);}
.btn:active{transform:translateY(0);}
.btn-lg{font-size:1.18rem;padding:16px 28px;min-height:56px;}
.btn-block{width:100%;}
.btn-call-ico{font-size:1.15em;transform:translateY(1px);}
.btn-ghost{background:transparent;color:var(--paper);border:2px solid rgba(255,255,255,.4);box-shadow:none;}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff;color:#fff;}
.kicker,.eyebrow{font-family:var(--disp);text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-size:.82rem;}

/* ===== Header ===== */
.site-head{
  position:sticky;top:0;z-index:90;background:rgba(21,23,26,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.head-row{display:flex;align-items:center;gap:18px;min-height:68px;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:#fff;margin-right:auto;}
.brand-mark{
  width:40px;height:40px;flex:none;display:grid;place-items:center;
  background:var(--signal);color:#fff;border-radius:9px;
  font-family:var(--disp);font-weight:700;font-size:1.5rem;line-height:1;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.14);
}
.brand-words{display:flex;flex-direction:column;line-height:1;}
.brand-name{font-family:var(--disp);font-weight:700;font-size:1.32rem;letter-spacing:.01em;}
.brand-sub{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-d);margin-top:3px;}
.head-nav{display:flex;gap:26px;}
.head-nav a{color:#D9DCE1;text-decoration:none;font-weight:500;font-size:.96rem;transition:color .2s;}
.head-nav a:hover{color:#fff;}
.head-call{font-size:.98rem;padding:11px 18px;min-height:44px;}

/* ===== Hero ===== */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 38%;}
.hero-scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(15,16,18,.94) 0%, rgba(15,16,18,.82) 42%, rgba(15,16,18,.30) 100%),
    linear-gradient(0deg, rgba(15,16,18,.7) 0%, rgba(15,16,18,0) 45%);
}
.hero-inner{position:relative;z-index:1;display:flex;align-items:center;min-height:min(86vh,720px);padding-block:74px;}
.hero-copy{max-width:660px;}
.eyebrow{display:inline-flex;align-items:center;gap:9px;color:#fff;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  padding:7px 14px;border-radius:999px;margin:0 0 22px;}
.dot-live{width:9px;height:9px;border-radius:50%;background:#36d07a;box-shadow:0 0 0 0 rgba(54,208,122,.7);animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(54,208,122,.6);}70%{box-shadow:0 0 0 9px rgba(54,208,122,0);}100%{box-shadow:0 0 0 0 rgba(54,208,122,0);}}
.hero h1{font-size:clamp(2.7rem,6.6vw,5rem);text-transform:uppercase;letter-spacing:-.01em;margin-bottom:.42em;}
.hero h1 .hl{color:var(--signal);}
.lede{font-size:clamp(1.06rem,1.9vw,1.28rem);color:#E3E5E8;max-width:54ch;margin-bottom:1.7em;}
.lede strong{color:#fff;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px;}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:10px 26px;margin:0;padding:24px 0 0;border-top:1px solid rgba(255,255,255,.14);}
.hero-trust li{font-size:.96rem;color:#C9CDD3;}
.hero-trust strong{font-family:var(--disp);font-weight:700;font-size:1.18rem;color:#fff;letter-spacing:.01em;margin-right:.35em;}

/* ===== Sections ===== */
.section{padding-block:clamp(64px,8vw,104px);}
.sec-head{max-width:760px;margin-bottom:48px;}
.kicker{color:var(--signal);display:block;margin-bottom:14px;}
.kicker-light{color:var(--amber);}
h2{font-size:clamp(2rem,4.2vw,3.1rem);text-transform:uppercase;letter-spacing:-.005em;}
.sec-lede{font-size:1.12rem;color:var(--muted);margin-top:18px;max-width:60ch;}

/* Services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.svc{
  background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);
  padding:26px 24px;position:relative;overflow:hidden;
  transition:transform .2s var(--ease),box-shadow .2s,border-color .2s;
}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--signal);transform:scaleY(0);transform-origin:top;transition:transform .25s var(--ease);}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#fff;}
.svc:hover::before{transform:scaleY(1);}
.svc h3{font-size:1.42rem;text-transform:uppercase;margin-bottom:.5em;letter-spacing:.005em;}
.svc p{color:var(--muted);margin:0;font-size:1rem;}
.svc-note{text-align:center;margin:42px auto 0;font-size:1.08rem;color:var(--txt);}
.svc-note a,.rev-cta a{color:var(--signal-d);font-weight:700;text-decoration:none;border-bottom:2px solid rgba(225,29,42,.3);}
.svc-note a:hover,.rev-cta a:hover{border-color:var(--signal);}

/* Open band (signature) */
.open-band{background:var(--ink);color:#fff;position:relative;}
.open-band::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(135deg,rgba(242,169,0,.05) 0 14px,transparent 14px 28px);}
.open-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center;position:relative;z-index:1;}
.open-copy h2{margin-bottom:.55em;}
.open-copy>p{color:#CBCFD5;font-size:1.1rem;max-width:52ch;}
.open-points{list-style:none;margin:30px 0 0;padding:0;display:grid;gap:2px;}
.open-points li{display:grid;gap:3px;padding:18px 0;border-top:1px solid var(--line);}
.open-points li:last-child{border-bottom:1px solid var(--line);}
.op-k{font-family:var(--disp);font-weight:700;font-size:1.2rem;text-transform:uppercase;letter-spacing:.01em;color:#fff;}
.op-v{color:#AEB4BC;font-size:1rem;}
.open-photo{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);position:relative;}
.open-photo img{width:100%;aspect-ratio:1/1;object-fit:cover;}
.open-photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:38px 20px 16px;
  font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.96rem;color:#fff;
  background:linear-gradient(0deg,rgba(15,16,18,.9),transparent);}

/* Gallery */
.work{background:var(--paper-2);}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px;}
.g-item{margin:0;position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.g-item:hover img{transform:scale(1.05);}
.g-tall{grid-row:span 2;}
.g-wide{grid-column:span 2;}
.g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 13px;
  font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;color:#fff;
  background:linear-gradient(0deg,rgba(15,16,18,.85),transparent);opacity:0;transform:translateY(6px);transition:.25s var(--ease);}
.g-item:hover figcaption{opacity:1;transform:none;}

/* Reviews */
.reviews{background:var(--paper);}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.rev{
  margin:0;background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);
  padding:28px 26px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
}
.stars{color:var(--amber);font-size:1.1rem;letter-spacing:2px;margin-bottom:14px;}
.rev p{font-size:1.04rem;color:var(--txt);margin:0 0 18px;flex:1;}
.rev cite{font-family:var(--disp);font-weight:700;font-style:normal;text-transform:uppercase;letter-spacing:.04em;font-size:1.02rem;color:var(--ink);}
.rev cite::before{content:"— ";color:var(--signal);}
.rev-cta{text-align:center;margin:40px 0 0;font-size:1.08rem;}

/* Visit + contact */
.visit{background:var(--steel);color:#fff;}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.visit-info h2{margin-bottom:.5em;}
.nap{margin:6px 0 30px;}
.nap-row{display:grid;grid-template-columns:96px 1fr;gap:16px;padding:18px 0;border-top:1px solid var(--line);align-items:start;}
.nap-row:first-child{border-top:0;}
.nap-k{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.84rem;color:var(--muted-d);padding-top:3px;}
.nap-v{color:#fff;text-decoration:none;font-size:1.06rem;line-height:1.45;}
a.nap-v{border-bottom:1px solid rgba(255,255,255,.25);}
a.nap-v:hover{border-color:var(--signal);}
.nap-v.big{font-family:var(--disp);font-weight:700;font-size:1.7rem;letter-spacing:.01em;}
.hours{border-collapse:collapse;width:100%;max-width:320px;}
.hours th{text-align:left;font-weight:500;font-family:var(--body);color:#D7DADF;padding:3px 18px 3px 0;font-size:1rem;}
.hours td{text-align:right;font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.03em;}
.hours .open24{color:#36d07a;}
.hours .closed{color:var(--muted-d);}

/* Contact card */
.contact-card{background:#fff;color:var(--txt);border-radius:var(--r);padding:34px 32px;box-shadow:var(--shadow);}
.contact-card h3{font-size:1.7rem;text-transform:uppercase;margin-bottom:.35em;color:var(--ink);}
.contact-sub{color:var(--muted);font-size:1rem;margin-bottom:22px;}
.field{margin-bottom:15px;}
.field label{display:block;font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;color:var(--ink);margin-bottom:6px;}
.field input,.field textarea{
  width:100%;font-family:var(--body);font-size:1rem;color:var(--txt);
  padding:13px 14px;border:1.5px solid var(--line-soft);border-radius:var(--r-sm);background:var(--paper);
  transition:border-color .2s,background .2s;min-height:48px;
}
.field textarea{min-height:auto;resize:vertical;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--signal);background:#fff;}
.form-status{margin:14px 0 0;font-weight:600;font-size:.98rem;min-height:1.2em;}
.form-status.ok{color:#0f8a45;}
.form-status.err{color:var(--signal-d);}
.form-fine{margin:10px 0 0;font-size:.84rem;color:var(--muted);}

/* Footer */
.site-foot{background:var(--ink);color:#fff;padding-block:44px 30px;}
.foot-grid{display:flex;flex-wrap:wrap;gap:28px;justify-content:space-between;align-items:center;}
.foot-brand{display:flex;align-items:center;gap:14px;}
.foot-name{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:1.3rem;margin:0;letter-spacing:.01em;}
.foot-tag{margin:2px 0 0;color:var(--muted-d);font-size:.92rem;}
.foot-nap{display:flex;flex-direction:column;gap:6px;text-align:right;}
.foot-nap a{color:#D9DCE1;text-decoration:none;font-size:.98rem;}
.foot-nap a:hover{color:#fff;}
.foot-bottom{display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:space-between;margin-top:30px;padding-top:22px;border-top:1px solid var(--line);}
.foot-bottom p{margin:0;color:var(--muted-d);font-size:.86rem;}

/* Mobile call bar */
.call-bar{display:none;}

/* ===== Reveal ===== */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.js .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important;}
  .js .reveal{opacity:1!important;transform:none!important;transition:none!important;}
}

/* ===== Responsive ===== */
@media (max-width:980px){
  .open-grid{grid-template-columns:1fr;gap:36px;}
  .open-photo{order:-1;}
  .open-photo img{aspect-ratio:16/10;}
  .visit-grid{grid-template-columns:1fr;gap:32px;}
}
@media (max-width:820px){
  .head-nav{display:none;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .rev-grid{grid-template-columns:1fr;}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px;}
  .g-wide{grid-column:span 2;}
}
@media (max-width:680px){
  .head-call .btn-call-ico{font-size:1.3em;}
  .head-call span:not(.btn-call-ico){display:none;}
  .head-call{padding:11px 14px;}
  body{padding-bottom:70px;}
  .hero-inner{min-height:auto;padding-block:54px 60px;}
  .hero-media img{object-position:center 30%;}
  .call-bar{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:120;align-items:center;gap:13px;
    background:var(--signal);color:#fff;text-decoration:none;padding:11px 18px;min-height:62px;
    box-shadow:0 -8px 24px -10px rgba(0,0,0,.5);
  }
  .call-bar-ico{font-size:1.6rem;}
  .call-bar-text{display:flex;flex-direction:column;line-height:1.25;font-size:.86rem;}
  .call-bar-text strong{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:1.06rem;letter-spacing:.02em;}
}
@media (max-width:480px){
  body{font-size:16px;}
  .wrap{padding-inline:18px;}
  .svc-grid{grid-template-columns:1fr;}
  .gallery{grid-template-columns:1fr;grid-auto-rows:auto;}
  .g-item{height:auto;aspect-ratio:16/10;}
  .g-tall,.g-wide{grid-row:auto;grid-column:auto;}
  .g-item figcaption{opacity:1;transform:none;}
  .nap-row{grid-template-columns:1fr;gap:5px;}
  .nap-k{padding-top:0;}
  .hero-cta .btn{width:100%;}
  .contact-card{padding:26px 20px;}
}
