/* ═══════════════════════════════════════════════════════════
   BestCut Barber Shop — Business Site
   Shared system · Street + Comic-Book · Noir Studio
   ═══════════════════════════════════════════════════════════ */

:root{
  --bg:#0b0b0d; --surface:#141417; --ink:#f4f1ea; --muted:#7f7c78; --line:#262629;
  --red:#e0241f; --yellow:#ffd400; --paper:#f4f1ea;
  --disp:'Anton',sans-serif; --body:'DM Sans',sans-serif; --stencil:'Saira Stencil One',sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-weight:300;line-height:1.6;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:1280px;margin:0 auto;padding:0 40px;}
.ey{font-family:var(--stencil);font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--red);}

/* street grit film */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:3;opacity:0.06;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;background:rgba(11,11,13,0.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.logo{font-family:var(--disp);font-size:26px;letter-spacing:0.04em;color:var(--ink);}
.logo span{color:var(--red);}
.nav-links{display:flex;gap:30px;list-style:none;align-items:center;}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink);opacity:.7;transition:opacity .2s,color .2s;}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--red);}
.nav-book{border:1px solid var(--red);color:var(--ink);padding:11px 22px;font-size:11px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;transition:background .2s;}
.nav-book:hover{background:var(--red);}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.25s;}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--body);font-size:12px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;padding:16px 34px;border:1px solid var(--ink);cursor:pointer;transition:all .2s;}
.btn--red{background:var(--red);border-color:var(--red);color:var(--ink);}
.btn--red:hover{transform:translateY(-2px);}
.btn--ghost{background:transparent;color:var(--ink);}
.btn--ghost:hover{background:var(--red);border-color:var(--red);}

/* PAGE HEADER */
.phead{padding:150px 0 70px;border-bottom:3px solid var(--ink);position:relative;}
.phead .crumb{font-family:var(--stencil);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;}
.phead .crumb a:hover{color:var(--red);}
.phead h1{font-family:var(--disp);font-size:clamp(56px,11vw,150px);line-height:0.84;text-transform:uppercase;letter-spacing:0.01em;}
.phead h1 .red{color:var(--red);}
.phead h1 .out{-webkit-text-stroke:1.5px var(--ink);color:transparent;}
.phead p{font-size:16px;color:var(--muted);max-width:520px;line-height:1.7;margin-top:24px;}

.sec{padding:110px 0;border-bottom:1px solid var(--line);}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:50px;gap:20px;flex-wrap:wrap;}
.sec-head h2{font-family:var(--disp);font-size:clamp(40px,6vw,84px);line-height:0.9;text-transform:uppercase;}

/* ── COMIC COMPONENTS ───────────────────────────────────────── */
/* halftone (Ben-Day dots) */
.halftone{background-image:radial-gradient(rgba(244,241,234,0.14) 1.4px,transparent 1.6px);background-size:7px 7px;}
.halftone-red{background-image:radial-gradient(rgba(224,36,31,0.5) 1.4px,transparent 1.6px);background-size:7px 7px;}

/* comic panel — thick border + hard offset shadow */
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.cpanel{position:relative;background:var(--surface);border:3px solid var(--ink);box-shadow:7px 7px 0 var(--red);padding:30px 28px;transition:transform .15s,box-shadow .15s;overflow:hidden;}
.cpanel:hover{transform:translate(-2px,-2px);box-shadow:11px 11px 0 var(--red);}
.cpanel .dots{position:absolute;inset:0;opacity:.5;pointer-events:none;}
.cpanel .pn{position:relative;font-family:var(--disp);font-size:20px;color:var(--red);margin-bottom:14px;}
.cpanel h3{position:relative;font-family:var(--disp);font-size:30px;text-transform:uppercase;line-height:0.95;margin-bottom:12px;}
.cpanel p{position:relative;font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:22px;}
.cpanel .pfoot{position:relative;display:flex;align-items:center;justify-content:space-between;}
.cpanel .go{font-family:var(--stencil);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);}

/* starburst price tag */
.burst{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background:#0b0b0d;border:2px solid var(--ink);color:var(--red);font-family:var(--disp);font-size:24px;letter-spacing:0.02em;transform:rotate(-2deg);}
.burst small{font-size:12px;}

/* speech bubble */
.bubble{position:relative;background:var(--paper);color:#0b0b0d;border:3px solid #0b0b0d;border-radius:16px;padding:24px 26px;}
.bubble::after{content:'';position:absolute;bottom:-16px;left:38px;width:0;height:0;border:14px solid transparent;border-top-color:#0b0b0d;border-bottom:0;}
.bubble::before{content:'';position:absolute;bottom:-11px;left:41px;width:0;height:0;border:11px solid transparent;border-top-color:var(--paper);border-bottom:0;z-index:1;}
.bubble p{font-size:15px;font-weight:400;line-height:1.6;margin-bottom:14px;}
.bubble .by{font-family:var(--stencil);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);}
.bubble-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:46px 22px;}
@media(max-width:900px){ .bubble-grid{grid-template-columns:1fr;} }

/* onomatopoeia */
.onomato{font-family:var(--disp);text-transform:uppercase;color:var(--yellow);-webkit-text-stroke:2px #0b0b0d;font-size:clamp(40px,7vw,90px);line-height:1;display:inline-block;transform:rotate(-7deg);}

/* BARBER PANELS */
.bgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.barber-c{border:3px solid var(--ink);box-shadow:7px 7px 0 var(--red);background:var(--surface);overflow:hidden;transition:transform .15s,box-shadow .15s;}
.barber-c:hover{transform:translate(-2px,-2px);box-shadow:11px 11px 0 var(--red);}
.barber-c .ph{height:280px;background:linear-gradient(160deg,#1e1e22,#0b0b0d);position:relative;display:flex;align-items:center;justify-content:center;font-size:60px;color:rgba(244,241,234,0.1);border-bottom:3px solid var(--ink);}
.barber-c .ph .dots{position:absolute;inset:0;opacity:.4;}
.barber-c .bd{padding:22px 24px;}
.barber-c .bd .nm{font-family:var(--disp);font-size:26px;text-transform:uppercase;line-height:1;}
.barber-c .bd .rl{font-family:var(--stencil);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin:6px 0 10px;}
.barber-c .bd p{font-size:13px;color:var(--muted);line-height:1.6;}

/* GALLERY PANELS */
.gpanel{position:relative;background:linear-gradient(160deg,#1e1e22,#0b0b0d);border:3px solid var(--ink);box-shadow:7px 7px 0 var(--red);min-height:300px;display:flex;align-items:flex-end;overflow:hidden;}
.gpanel .dots{position:absolute;inset:0;opacity:.4;pointer-events:none;}
.gpanel .gi{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:84px;opacity:.08;}
.gpanel .gl{position:relative;padding:20px;z-index:1;}
.gpanel .gl .s{font-family:var(--stencil);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);}
.gpanel .gl .t{font-family:var(--disp);font-size:26px;text-transform:uppercase;}
.span2{grid-column:span 2;}
@media(max-width:1000px){ .bgrid{grid-template-columns:1fr 1fr;} }
@media(max-width:560px){ .bgrid{grid-template-columns:1fr;} }
@media(max-width:900px){ .span2{grid-column:span 1;} }

/* COMIC ARTICLE */
.cart{max-width:720px;margin:0 auto;}
.cart .am{font-family:var(--stencil);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:16px;}
.cart h2{font-family:var(--disp);font-size:30px;text-transform:uppercase;margin:40px 0 14px;line-height:0.95;}
.cart p{font-size:17px;line-height:1.85;color:var(--ink);opacity:.92;margin-bottom:20px;}
.cart p.lead{font-size:21px;opacity:1;}
.cart ul{list-style:none;border-top:2px solid var(--ink);margin:0 0 22px;}
.cart ul li{padding:13px 0 13px 26px;border-bottom:1px solid var(--line);position:relative;font-size:16px;}
.cart ul li::before{content:'✶';position:absolute;left:0;color:var(--red);}
.cart .back{font-family:var(--stencil);font-size:12px;letter-spacing:0.1em;color:var(--muted);margin-top:36px;display:inline-block;}
.cart .back:hover{color:var(--red);}

/* BOOKING WIDGET (comic) */
.bk{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start;}
.bk-steps{display:flex;border:3px solid var(--ink);}
.bk-step{flex:1;padding:14px 8px;text-align:center;font-family:var(--stencil);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);border-right:2px solid var(--ink);}
.bk-step:last-child{border-right:none;}
.bk-step.active{background:var(--red);color:#0b0b0d;}
.bk-step.done{color:var(--red);}
.bk-panel{display:none;border:3px solid var(--ink);border-top:none;background:var(--surface);padding:30px;}
.bk-panel.active{display:block;}
.bk-panel h3{font-family:var(--disp);font-size:26px;text-transform:uppercase;margin-bottom:4px;}
.bk-panel .sub{font-size:13px;color:var(--muted);margin-bottom:22px;}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.opt{border:2px solid var(--line);background:#0b0b0d;color:var(--ink);padding:15px 16px;text-align:left;cursor:pointer;font-family:var(--body);font-size:14px;transition:all .15s;}
.opt:hover{border-color:var(--ink);}
.opt.sel{border-color:var(--red);box-shadow:inset 4px 0 0 var(--red);}
.opt span{display:block;font-family:var(--stencil);font-size:11px;color:var(--red);margin-top:4px;}
.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:22px;}
.slot{border:2px solid var(--line);background:#0b0b0d;color:var(--ink);padding:12px;text-align:center;cursor:pointer;font-family:var(--body);font-size:13px;transition:all .15s;}
.slot:hover{border-color:var(--ink);}
.slot.sel{background:var(--red);border-color:var(--red);color:#0b0b0d;}
.bk-label{font-family:var(--stencil);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.bk-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.bk-field label{font-family:var(--stencil);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);}
.bk-field input{border:2px solid var(--line);background:#0b0b0d;color:var(--ink);padding:12px 14px;font-family:var(--body);font-size:14px;outline:none;}
.bk-field input:focus{border-color:var(--red);}
.bk-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.bk-nav{display:flex;justify-content:space-between;margin-top:22px;}
.bk-sum{position:sticky;top:100px;border:3px solid var(--ink);box-shadow:7px 7px 0 var(--red);background:var(--surface);}
.bk-sum .h{padding:16px 20px;border-bottom:3px solid var(--ink);font-family:var(--stencil);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);}
.bk-sum .r{display:flex;justify-content:space-between;gap:12px;padding:13px 20px;border-bottom:1px solid var(--line);font-size:14px;align-items:baseline;}
.bk-sum .r span{font-family:var(--stencil);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);flex-shrink:0;}
.bk-sum .r b{font-family:var(--disp);text-transform:uppercase;text-align:right;font-size:15px;}
.bk-confirm{text-align:center;padding:24px 6px;}
.bk-confirm .ic{font-family:var(--disp);font-size:52px;color:var(--red);line-height:1;}
.bk-confirm h3{font-size:28px;text-transform:uppercase;margin:12px 0 10px;}
.bk-confirm p{color:var(--muted);max-width:420px;margin:0 auto;line-height:1.6;}
.bk-confirm .cf{font-family:var(--stencil);font-size:12px;color:var(--ink);margin-top:14px;letter-spacing:0.04em;}
@media(max-width:900px){ .bk{grid-template-columns:1fr;} .bk-sum{position:static;} .opt-grid{grid-template-columns:1fr;} .slot-grid{grid-template-columns:1fr 1fr;} .bk-2{grid-template-columns:1fr;} }

/* MARQUEE */
.marquee{background:var(--red);color:#0b0b0d;overflow:hidden;white-space:nowrap;padding:14px 0;border-top:1px solid #0b0b0d;border-bottom:1px solid #0b0b0d;}
.marquee-row{display:inline-block;animation:slide 26s linear infinite;}
.marquee-row span{font-family:var(--disp);font-size:18px;letter-spacing:0.05em;text-transform:uppercase;margin:0 24px;}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* BOOK CTA */
.book{position:relative;padding:150px 0;text-align:center;overflow:hidden;}
.book-bg{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(224,36,31,0.16),transparent 60%);}
.book .wrap{position:relative;}
.book h2{font-family:var(--disp);font-size:clamp(50px,9vw,130px);line-height:0.86;text-transform:uppercase;margin:18px 0 26px;}
.book h2 .red{color:var(--red);}
.book .sub{color:var(--muted);font-size:13px;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:34px;}

/* FOOTER */
footer{padding:64px 0 32px;}
footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;}
.f-logo{font-family:var(--disp);font-size:30px;text-transform:uppercase;}
.f-logo span{color:var(--red);}
.f-logo p{font-family:var(--body);font-size:13px;color:var(--muted);max-width:300px;margin-top:14px;line-height:1.7;}
.f-col h4{font-family:var(--stencil);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);margin-bottom:16px;}
.f-col a,.f-col p{display:block;font-size:14px;color:var(--ink);margin-bottom:10px;opacity:.8;}
.f-bar{border-top:1px solid var(--line);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;font-family:var(--stencil);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

@media(max-width:900px){
  .wrap{padding:0 22px;} nav{padding:16px 22px;}
  .nav-links{position:fixed;inset:0;background:var(--bg);flex-direction:column;justify-content:center;gap:26px;display:none;}
  nav.open .nav-links{display:flex;} .nav-toggle{display:flex;z-index:101;}
  nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  nav.open .nav-toggle span:nth-child(2){opacity:0;}
  nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .nav-links a{font-size:18px;}
  .phead{padding:120px 0 50px;}
  .cgrid{grid-template-columns:1fr;}
  footer .wrap{grid-template-columns:1fr;} .f-bar{flex-direction:column;gap:8px;}
  .sec{padding:70px 0;}
}
