/* RONIN BARBER CO. — PREMIUM EDITORIAL BARBERSHOP */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Brand — warm editorial */
  --ink:#1F1B17;
  --ink2:#2A2520;
  --ink3:#3A332C;
  --cream:#F4EFE5;
  --cream2:#EAE3D4;
  --cream3:#DBD3BF;
  --tobacco:#8B6F47;
  --gold:#C8A661;
  --gold-light:#D4B575;
  --wine:#5C2A2A;
  --line:#3A332C;
  --line-light:#D8D1C0;
  --text:#1F1B17;
  --text2:#4A4239;
  --muted:#8A8175;
  --muted2:#A8A095;

  --r:8px;
  --r-lg:16px;
  --shadow:0 4px 24px rgba(31,27,23,.08);
  --shadow-lg:0 20px 60px rgba(31,27,23,.18);
  --shadow-gold:0 8px 32px rgba(200,166,97,.3);
}

html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;font-size:15px;color:var(--text);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{display:block;max-width:100%}
.container{max-width:1240px;margin:0 auto;padding:0 32px}

em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;color:inherit;letter-spacing:-.01em}

h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:600;letter-spacing:-.02em;line-height:1.05;color:var(--text)}

.eyebrow{display:inline-block;font-size:11px;font-weight:600;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:14px;font-family:'Inter',sans-serif}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border-radius:0;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .25s;font-family:'Inter',sans-serif;text-decoration:none;line-height:1;letter-spacing:1.5px;text-transform:uppercase}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:var(--shadow-gold)}
.btn-gold-lg{background:var(--gold);color:var(--ink);padding:18px 36px;font-size:14px}
.btn-gold-lg:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn-gold-sm{background:var(--gold);color:var(--ink);padding:10px 18px;font-size:12px;letter-spacing:1px}
.btn-gold-sm:hover{background:var(--gold-light)}
.btn-ghost-light{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn-ghost-dark{background:transparent;color:var(--text2);border:1px solid var(--line-light)}
.btn-ghost-dark:hover{border-color:var(--ink);color:var(--ink)}

/* ANNOUNCE */
.announce{background:var(--ink);color:var(--cream);padding:9px 0;font-size:12px;letter-spacing:.5px;border-bottom:1px solid var(--ink3)}
.announce-inner{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.sep{opacity:.4}
.announce a{color:var(--gold);font-weight:600;display:inline-flex;align-items:center;gap:5px;text-transform:uppercase;font-size:11px;letter-spacing:1px}

/* NAVBAR */
.navbar{position:sticky;top:0;z-index:100;background:rgba(244,239,229,.95);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--cream3)}
.nav-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:16px 0;gap:20px}
.nav-left{display:flex;align-items:center;gap:4px}
.nav-right{display:flex;align-items:center;gap:14px;justify-content:flex-end}
.nav-left li a{font-size:12px;font-weight:600;color:var(--text2);padding:8px 14px;letter-spacing:1.2px;transition:color .2s;text-transform:uppercase;font-family:'Inter',sans-serif}
.nav-left li a:hover{color:var(--ink)}
.nav-phone{font-size:13px;font-weight:500;color:var(--text2);display:inline-flex;align-items:center;gap:6px;letter-spacing:.5px}
.nav-phone i{color:var(--gold);font-size:16px}
.logo{display:flex;align-items:center;gap:10px;justify-content:center}
.logo-mark{width:38px;height:38px;color:var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-mark svg{width:100%;height:100%}
.logo-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}
.lt-1{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;letter-spacing:.15em;color:var(--ink)}
.lt-2{font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-family:'Inter',sans-serif;margin-top:2px}
.lt-2 em{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold);text-transform:none;letter-spacing:0;font-size:11px}
.hamburger{display:none;background:none;border:none;cursor:pointer;font-size:22px;color:var(--ink);padding:4px}

/* HERO */
.hero{position:relative;min-height:90vh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,27,23,.45) 0%,rgba(31,27,23,.55) 100%);z-index:1}
.hero-content{position:relative;z-index:2;color:var(--cream);padding:160px 0 80px;max-width:780px}
.hero-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.hm-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:12.5px;font-weight:500;letter-spacing:.3px;backdrop-filter:blur(8px)}
.hm-pill i{font-size:14px;color:var(--gold-light)}
.hero h1{font-size:clamp(48px,8vw,108px);font-weight:600;line-height:.95;letter-spacing:-.04em;margin-bottom:24px;color:#fff;font-family:'Cormorant Garamond',serif}
.hero h1 em{color:var(--gold-light)}
.hero p{font-size:18px;max-width:520px;margin-bottom:36px;line-height:1.55;color:rgba(244,239,229,.85)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

.hero-strip{position:relative;z-index:2;background:rgba(31,27,23,.6);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.1)}
.hero-strip-inner{display:flex;align-items:center;justify-content:space-around;padding:24px 0;gap:20px}
.hs-item{text-align:center}
.hs-item strong{display:block;font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:600;color:var(--gold-light);line-height:1}
.hs-item span{font-size:11px;color:rgba(244,239,229,.6);font-weight:500;letter-spacing:1.5px;text-transform:uppercase;margin-top:4px;display:inline-block}
.hs-divider{width:1px;height:36px;background:rgba(255,255,255,.15)}

/* SECTIONS */
.section{padding:100px 0}
.section-head{margin-bottom:60px;text-align:center;max-width:680px;margin-left:auto;margin-right:auto}
.section-head h2{font-size:clamp(36px,5.5vw,68px);font-weight:600;letter-spacing:-.025em;line-height:1.05;margin-bottom:14px}
.section-head .lead{font-size:17px;color:var(--text2);line-height:1.65;font-family:'Inter',sans-serif}

/* INTRO */
.intro-section{background:var(--cream)}
.intro-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.intro-text .eyebrow{margin-bottom:14px}
.intro-text h2{font-size:clamp(36px,5vw,60px);margin-bottom:24px;font-weight:600}
.intro-text p{font-size:16px;color:var(--text2);line-height:1.8;margin-bottom:16px}
.intro-values{display:flex;flex-direction:column;gap:18px;margin-top:36px}
.iv{display:flex;align-items:flex-start;gap:14px}
.iv i{font-size:22px;color:var(--gold);flex-shrink:0;margin-top:2px}
.iv strong{display:block;font-size:15px;font-weight:600;color:var(--ink);font-family:'Inter',sans-serif;margin-bottom:3px}
.iv span{font-size:13px;color:var(--muted);font-family:'Inter',sans-serif}

.intro-imgs{position:relative;height:540px}
.ii{position:absolute;background-size:cover;background-position:center;border-radius:var(--r)}
.ii-1{top:0;left:0;width:70%;height:65%}
.ii-2{bottom:0;right:0;width:55%;height:55%;border:6px solid var(--cream);box-shadow:var(--shadow)}
.ii-3{top:30%;right:5%;width:38%;height:30%;display:none}

/* SERVICES */
.services-section{background:var(--ink);color:var(--cream)}
.services-section .section-head h2,.services-section .section-head .lead{color:var(--cream)}
.services-section .eyebrow{color:var(--gold-light)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{background:var(--ink2);border:1px solid var(--ink3);padding:32px;display:flex;flex-direction:column;transition:all .3s;border-radius:var(--r)}
.service-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.service-card.featured{background:linear-gradient(180deg,rgba(200,166,97,.08),var(--ink2));border-color:var(--gold)}
.sc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.sc-tag{font-size:10px;font-weight:600;padding:4px 10px;letter-spacing:1px;text-transform:uppercase;color:var(--ink);background:var(--gold);border-radius:999px}
.sc-tag.light{background:transparent;color:var(--gold);border:1px solid rgba(200,166,97,.3)}
.sc-time{font-size:12px;color:var(--muted2);font-family:'Inter',sans-serif}
.service-card h3{font-size:26px;color:var(--cream);margin-bottom:10px;font-weight:600}
.service-card p{font-size:14px;color:rgba(244,239,229,.7);line-height:1.7;margin-bottom:24px;flex:1;font-family:'Inter',sans-serif}
.sc-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--ink3)}
.sc-price{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:var(--gold-light)}
.sc-link{font-size:12px;font-weight:600;color:var(--cream);letter-spacing:1px;text-transform:uppercase;display:inline-flex;align-items:center;gap:5px;transition:all .2s;font-family:'Inter',sans-serif}
.sc-link:hover{color:var(--gold);gap:8px}

/* BARBERS */
.barbers-section{background:var(--cream)}
.barbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.barber-card{background:#fff;border:1px solid var(--line-light);border-radius:var(--r);overflow:hidden;transition:all .3s}
.barber-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.bc-img{aspect-ratio:3/4;background-size:cover;background-position:center}
.bc-info{padding:24px 20px}
.bc-meta{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.bc-rating{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;font-weight:600;color:var(--ink);font-family:'Inter',sans-serif}
.bc-rating i{color:var(--gold);font-size:14px}
.bc-years{font-size:11px;color:var(--muted);letter-spacing:.5px;font-family:'Inter',sans-serif}
.barber-card h3{font-size:24px;font-weight:600;margin-bottom:4px}
.bc-role{display:block;font-size:11px;font-weight:600;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;font-family:'Inter',sans-serif}
.bc-info p{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:14px;font-family:'Inter',sans-serif}
.bc-tags{display:flex;gap:5px;flex-wrap:wrap}
.bc-tags span{font-size:10.5px;padding:3px 9px;background:var(--cream2);border-radius:999px;color:var(--text2);font-weight:500;font-family:'Inter',sans-serif;letter-spacing:.3px}

/* BOOK STRIP */
.book-strip{background:var(--gold);padding:64px 0;color:var(--ink)}
.book-strip-inner{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.book-strip h2{font-size:clamp(32px,4vw,48px);font-weight:600;line-height:1.1;margin-bottom:6px}
.book-strip p{font-size:15px;font-family:'Inter',sans-serif;color:var(--ink2)}
.book-strip .btn-gold-lg{background:var(--ink);color:var(--gold)}
.book-strip .btn-gold-lg:hover{background:var(--ink2)}

/* STORY */
.story-section{background:var(--cream)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-images{position:relative;height:580px}
.si-main{position:absolute;top:0;left:0;width:80%;height:80%;background-size:cover;background-position:center;border-radius:var(--r)}
.si-sub{position:absolute;bottom:0;right:0;width:50%;height:45%;background-size:cover;background-position:center;border:6px solid var(--cream);border-radius:var(--r);box-shadow:var(--shadow-lg)}
.story-text .eyebrow{margin-bottom:14px}
.story-text h2{font-size:clamp(36px,5vw,60px);margin-bottom:24px;font-weight:600}
.story-text p{font-size:16px;color:var(--text2);line-height:1.8;margin-bottom:16px;font-family:'Inter',sans-serif}
.story-quote{margin-top:32px;padding:28px;background:var(--cream2);border-left:3px solid var(--gold);border-radius:var(--r);position:relative}
.story-quote i{font-size:32px;color:var(--gold);position:absolute;top:14px;right:18px;opacity:.4}
.story-quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;color:var(--ink);line-height:1.5;margin-bottom:10px;font-weight:500}
.story-quote span{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.5px;font-family:'Inter',sans-serif}

/* REVIEWS */
.reviews-section{background:var(--cream2)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{background:var(--cream);border:1px solid var(--line-light);border-radius:var(--r-lg);padding:32px}
.r-stars{color:var(--gold);font-size:18px;margin-bottom:16px;letter-spacing:2px}
.review p{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:17px;color:var(--ink);line-height:1.5;margin-bottom:22px}
.r-author{display:flex;align-items:center;gap:12px}
.ra-av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:'Inter',sans-serif}
.r-author strong{display:block;font-size:14px;font-weight:600;font-family:'Inter',sans-serif}
.r-author span{font-size:12px;color:var(--muted);font-family:'Inter',sans-serif}

/* VISIT */
.visit-section{background:var(--cream)}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.visit-info h2{font-size:clamp(36px,5vw,56px);margin-bottom:14px}
.visit-info>p{font-size:16px;color:var(--text2);line-height:1.7;margin-bottom:32px;font-family:'Inter',sans-serif}
.visit-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.vc{display:flex;align-items:flex-start;gap:14px;padding:18px;background:#fff;border:1px solid var(--line-light);border-radius:var(--r)}
.vc i{font-size:22px;color:var(--gold);flex-shrink:0;margin-top:2px}
.vc strong{display:block;font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px;font-family:'Inter',sans-serif}
.vc span{font-size:13px;color:var(--text2);font-family:'Inter',sans-serif;line-height:1.5}

.visit-map{position:relative;height:560px;background-size:cover;background-position:center;border-radius:var(--r-lg);overflow:hidden}
.visit-map::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,27,23,.1),rgba(31,27,23,.4))}
.vm-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);z-index:2;display:flex;flex-direction:column;align-items:center}
.vm-pin-inner{width:48px;height:48px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(0,0,0,.3);animation:pinBounce 2s infinite}
.vm-pin-inner i{font-size:24px;color:var(--ink)}
.vm-pin-label{background:var(--ink);color:var(--cream);font-size:11px;padding:5px 12px;border-radius:4px;margin-top:8px;font-weight:600;letter-spacing:1px;text-transform:uppercase;font-family:'Inter',sans-serif}
@keyframes pinBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* FOOTER */
.footer{background:var(--ink);color:var(--cream);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:60px;padding-bottom:48px;border-bottom:1px solid var(--ink3)}
.footer-brand .logo{justify-content:flex-start;margin-bottom:18px}
.footer-brand .logo-mark{color:var(--gold)}
.footer-brand .lt-1{color:var(--cream)}
.footer-brand .lt-2{color:var(--muted2)}
.footer-brand p{font-size:14px;color:rgba(244,239,229,.65);margin-bottom:24px;line-height:1.7;font-family:'Inter',sans-serif}
.footer-socials{display:flex;gap:8px}
.footer-socials a{width:38px;height:38px;border-radius:50%;background:var(--ink2);border:1px solid var(--ink3);display:flex;align-items:center;justify-content:center;color:var(--muted2);transition:all .2s;font-size:18px}
.footer-socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.footer-col h4{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-family:'Inter',sans-serif}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:13.5px;color:rgba(244,239,229,.65);transition:color .2s;font-family:'Inter',sans-serif}
.footer-col ul li a:hover{color:var(--gold)}
.hrs li{display:flex;justify-content:space-between;font-size:12.5px;color:rgba(244,239,229,.65);font-family:'Inter',sans-serif}
.hrs li span:last-child{color:var(--cream)}
.contact-list li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(244,239,229,.65);margin-bottom:8px;font-family:'Inter',sans-serif}
.contact-list i{font-size:15px;color:var(--gold);margin-top:3px;flex-shrink:0}
.footer-bottom{padding:24px 0}
.fb-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:12.5px;color:var(--muted2);font-family:'Inter',sans-serif}
.fb-inner strong{color:var(--gold);font-weight:600}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:999;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.4);font-size:28px;transition:all .25s}
.wa-float:hover{transform:scale(1.08) translateY(-2px)}

/* ============================== BOOKING PAGE ============================== */
.book-body{background:var(--cream2)}
.book-nav{background:var(--cream);border-bottom:1px solid var(--line-light)}
.book-nav .nav-inner{grid-template-columns:auto 1fr;padding:14px 0}
.book-nav .logo{justify-content:flex-start;margin-right:auto}
.back-link{font-size:13px;color:var(--text2);display:inline-flex;align-items:center;gap:6px;font-weight:500;transition:color .2s;justify-self:end}
.back-link:hover{color:var(--ink)}

.booking{padding:48px 0 80px}
.booking-container{max-width:1240px;margin:0 auto;padding:0 32px}
.booking-header{text-align:center;margin-bottom:48px;max-width:680px;margin-left:auto;margin-right:auto}
.booking-header h1{font-size:clamp(36px,5vw,56px);font-weight:600;letter-spacing:-.025em;line-height:1.05;margin-bottom:12px}
.booking-header p{font-size:15px;color:var(--text2);font-family:'Inter',sans-serif}

/* STEPS */
.steps{display:flex;justify-content:center;align-items:center;gap:0;margin-bottom:48px;max-width:760px;margin-left:auto;margin-right:auto}
.step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--cream);border:2px solid var(--line-light);color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;font-family:'Inter',sans-serif;transition:all .3s}
.step-label{font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-family:'Inter',sans-serif}
.step.active .step-num{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.step.active .step-label{color:var(--ink)}
.step.complete .step-num{background:var(--ink);border-color:var(--ink);color:var(--gold)}
.step.complete .step-num::before{content:'\\2713';font-size:18px}
.step.complete .step-num span{display:none}
.step-line{flex:1;height:2px;background:var(--line-light);min-width:30px;max-width:80px;margin:0 6px;margin-bottom:24px;transition:background .3s}
.step.complete + .step-line{background:var(--ink)}

/* BOOKING LAYOUT */
.booking-layout{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start}
.booking-main{background:var(--cream);border:1px solid var(--line-light);border-radius:var(--r-lg);padding:40px;min-height:520px}
.step-panel{display:none;animation:fadeIn .3s ease}
.step-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.step-panel h2{font-size:32px;font-weight:600;margin-bottom:8px}
.panel-sub{font-size:14px;color:var(--text2);margin-bottom:32px;font-family:'Inter',sans-serif}

/* SERVICE OPTIONS */
.svc-list{display:flex;flex-direction:column;gap:10px}
.svc-option{display:flex;align-items:center;gap:18px;padding:20px;background:#fff;border:2px solid var(--line-light);border-radius:var(--r);cursor:pointer;transition:all .2s;position:relative}
.svc-option:hover{border-color:var(--gold)}
.svc-option input{position:absolute;opacity:0;pointer-events:none}
.svc-option:has(input:checked){border-color:var(--gold);background:rgba(200,166,97,.05)}
.svc-content{flex:1}
.svc-tag-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.svc-pill{font-size:10px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--cream2);color:var(--text2);letter-spacing:.5px;text-transform:uppercase;font-family:'Inter',sans-serif}
.svc-pill.gold{background:var(--gold);color:var(--ink)}
.svc-time{font-size:12px;color:var(--muted);font-family:'Inter',sans-serif}
.svc-content h3{font-size:20px;font-weight:600;margin-bottom:4px}
.svc-content p{font-size:13px;color:var(--text2);line-height:1.5;font-family:'Inter',sans-serif}
.svc-price{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--gold);flex-shrink:0}

/* BARBER OPTIONS */
.barber-options{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.barber-option{display:flex;align-items:center;gap:14px;padding:16px;background:#fff;border:2px solid var(--line-light);border-radius:var(--r);cursor:pointer;transition:all .2s;position:relative}
.barber-option:hover{border-color:var(--gold)}
.barber-option input{position:absolute;opacity:0;pointer-events:none}
.barber-option:has(input:checked){border-color:var(--gold);background:rgba(200,166,97,.05)}
.bo-img{width:80px;height:80px;border-radius:50%;background-size:cover;background-position:center;flex-shrink:0;background-color:var(--cream2)}
.bo-img.any{background:var(--ink);display:flex;align-items:center;justify-content:center}
.bo-img.any i{font-size:32px;color:var(--gold)}
.bo-info{flex:1}
.bo-info h3{font-size:16px;font-weight:600;margin-bottom:2px}
.bo-role{display:block;font-size:11px;color:var(--gold);font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px;font-family:'Inter',sans-serif}
.bo-meta{display:flex;gap:10px;margin-bottom:6px}
.bo-rating{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;color:var(--ink);font-family:'Inter',sans-serif}
.bo-rating i{color:var(--gold);font-size:13px}
.bo-years{font-size:11px;color:var(--muted);font-family:'Inter',sans-serif}
.bo-tags{display:flex;gap:4px;flex-wrap:wrap}
.bo-tags span{font-size:10px;padding:2px 7px;background:var(--cream2);border-radius:999px;color:var(--text2);font-family:'Inter',sans-serif}

/* DATE & TIME */
.datetime-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.dt-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:16px;font-family:'Inter',sans-serif;letter-spacing:.5px}
.calendar{background:#fff;border:1px solid var(--line-light);border-radius:var(--r);padding:20px}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cal-month{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--ink)}
.cal-nav{background:none;border:1px solid var(--line-light);width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all .2s}
.cal-nav:hover{background:var(--ink);color:var(--gold);border-color:var(--ink)}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}
.cal-dow span{text-align:center;font-size:10.5px;font-weight:600;color:var(--muted);letter-spacing:.5px;padding:6px 0;font-family:'Inter',sans-serif}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;border-radius:50%;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;color:var(--ink)}
.cal-day.empty{cursor:default}
.cal-day.disabled{color:var(--muted2);cursor:not-allowed}
.cal-day:not(.empty):not(.disabled):hover{background:var(--cream2)}
.cal-day.selected{background:var(--gold)!important;color:var(--ink);font-weight:700}
.cal-day.today{font-weight:700;color:var(--gold)}

.time-section{background:#fff;border:1px solid var(--line-light);border-radius:var(--r);padding:20px}
.time-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ts-empty{grid-column:span 3;text-align:center;padding:60px 0;color:var(--muted);font-family:'Inter',sans-serif}
.ts-empty i{font-size:36px;margin-bottom:12px;display:block;opacity:.4}
.ts-empty p{font-size:13px}
.time-slot{padding:11px 8px;background:var(--cream);border:1px solid var(--line-light);border-radius:var(--r);text-align:center;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink);transition:all .2s;font-family:'Inter',sans-serif}
.time-slot:hover{border-color:var(--gold)}
.time-slot.selected{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.time-slot.unavail{background:transparent;color:var(--muted2);text-decoration:line-through;cursor:not-allowed}
.time-slot.unavail:hover{border-color:var(--line-light)}

/* CONFIRM */
.confirm-grid{display:grid;grid-template-columns:1fr;gap:20px}
.form-card{background:#fff;border:1px solid var(--line-light);border-radius:var(--r);padding:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:12px;font-weight:600;color:var(--text2);font-family:'Inter',sans-serif}
.fg input,.fg textarea{padding:12px 14px;border:1px solid var(--line-light);border-radius:var(--r);font-size:14px;font-family:'Inter',sans-serif;background:var(--cream);color:var(--ink);transition:all .2s}
.fg input:focus,.fg textarea:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(200,166,97,.15)}
.fg textarea{resize:vertical;min-height:80px}
.agree{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:13px;color:var(--text2);font-family:'Inter',sans-serif;cursor:pointer}
.agree input{accent-color:var(--gold)}

/* SUMMARY SIDEBAR */
.booking-summary{position:sticky;top:96px;display:flex;flex-direction:column;gap:14px}
.summary-card{background:var(--ink);color:var(--cream);border-radius:var(--r-lg);padding:28px}
.summary-card h3{font-size:20px;color:var(--cream);margin-bottom:18px}
.sum-list{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.sum-row{display:flex;align-items:flex-start;gap:10px;font-size:13px;font-family:'Inter',sans-serif}
.sum-row i{color:var(--gold);font-size:18px;flex-shrink:0;margin-top:1px}
.sum-row.empty{color:var(--muted2)}
.sum-row strong{display:block;color:var(--cream);font-weight:600;margin-bottom:2px}
.sum-row span{color:rgba(244,239,229,.6);font-size:12px}
.sum-total{padding-top:18px;border-top:1px solid var(--ink3)}
.st-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;color:rgba(244,239,229,.7);font-family:'Inter',sans-serif}
.st-row strong{color:var(--cream);font-weight:600}
.st-row.total{font-size:14px;margin-top:14px;padding-top:14px;border-top:1px solid var(--ink3);color:var(--cream)}
.st-row.total strong{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:var(--gold)}
.sum-note{display:block;margin-top:14px;padding-top:14px;border-top:1px solid var(--ink3);font-size:11px;color:var(--muted2);letter-spacing:.5px;font-family:'Inter',sans-serif}

.summary-help{background:var(--cream);border:1px solid var(--line-light);padding:18px;border-radius:var(--r);display:flex;align-items:center;gap:14px}
.summary-help i{font-size:24px;color:var(--gold)}
.summary-help strong{display:block;font-size:13px;color:var(--ink);margin-bottom:2px;font-family:'Inter',sans-serif}
.summary-help p{font-size:12px;color:var(--text2);font-family:'Inter',sans-serif;line-height:1.4}
.summary-help a{color:var(--gold);font-weight:600;text-decoration:none}

/* BOOKING NAV */
.booking-nav{display:flex;justify-content:space-between;align-items:center;margin-top:32px;gap:14px}

/* SUCCESS MODAL */
.success-overlay{position:fixed;inset:0;background:rgba(31,27,23,.85);backdrop-filter:blur(8px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.success-overlay.active{display:flex;animation:fadeIn .3s}
.success-modal{background:var(--cream);border-radius:var(--r-lg);padding:48px;max-width:480px;text-align:center;animation:scaleIn .4s cubic-bezier(.4,0,.2,1)}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.success-icon{width:80px;height:80px;border-radius:50%;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:42px;margin:0 auto 24px}
.success-modal h2{font-size:36px;font-weight:600;margin-bottom:12px}
.success-modal>p{font-size:15px;color:var(--text2);line-height:1.65;margin-bottom:24px;font-family:'Inter',sans-serif}
.success-summary{background:#fff;border:1px solid var(--line-light);border-radius:var(--r);padding:20px;margin-bottom:24px;text-align:left}
.success-summary .ss-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;font-family:'Inter',sans-serif;color:var(--text2)}
.success-summary .ss-row+.ss-row{border-top:1px solid var(--line-light)}
.success-summary .ss-row strong{color:var(--ink);font-weight:600}

/* RESPONSIVE */
@media(max-width:1024px){
  .nav-inner{grid-template-columns:auto 1fr auto}
  .nav-left{display:none}
  .intro-grid,.story-grid,.visit-grid{grid-template-columns:1fr;gap:48px}
  .intro-imgs,.story-images{height:400px}
  .visit-map{height:400px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .barbers-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .booking-layout{grid-template-columns:1fr}
  .booking-summary{position:static;order:-1;margin-bottom:20px}
  .summary-help{display:none}
  .barber-options{grid-template-columns:1fr}
  .datetime-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .container,.booking-container{padding:0 20px}
  .hamburger{display:block}
  .nav-right .nav-phone{display:none}
  .hero{min-height:80vh}
  .hero-content{padding:120px 0 60px}
  .hero-strip-inner{flex-wrap:wrap;gap:14px}
  .hs-divider{display:none}
  .section{padding:64px 0}
  .section-head{margin-bottom:40px}
  .services-grid,.barbers-grid{grid-template-columns:1fr}
  .intro-imgs,.story-images{height:320px}
  .ii-2,.si-sub{border-width:4px}
  .book-strip-inner{flex-direction:column;text-align:center}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .fb-inner{flex-direction:column;text-align:center}
  .booking-main{padding:24px}
  .steps{max-width:100%}
  .step-label{display:none}
  .step-line{margin-bottom:0}
  .step{flex-direction:row;gap:0}
  .svc-option{flex-wrap:wrap}
  .svc-price{width:100%;text-align:right;margin-top:8px}
  .form-row{grid-template-columns:1fr}
  .booking-nav{flex-direction:column-reverse;gap:10px}
  .booking-nav .btn{width:100%;justify-content:center}
  .booking-nav .btn[style*="hidden"]{display:none!important}
  .success-modal{padding:32px 24px}
}