*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --black:#0d0d0d;
  --white:#f8f7f4;
  --gray:#8a8a8a;
  --light:#ebebeb;
  --line:#d8d8d8;
  --accent:#000;
}

html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--black);overflow-x:hidden}

/* CURSOR */
.cursor{position:fixed;width:10px;height:10px;background:var(--black);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,width .2s,height .2s;display:none}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid var(--black);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .12s ease;display:none}
@media(hover:hover) and (pointer:fine){
  body{cursor:none}
  body *{cursor:none !important}
  .cursor,.cursor-ring{display:block}
}
.cursor.hover{width:4px;height:4px}
.cursor-ring.hover{width:52px;height:52px;opacity:.5}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 56px;background:rgba(248,247,244,0.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;text-decoration:none;color:var(--black)}
.logo span{display:inline-block;width:6px;height:6px;background:var(--black);border-radius:50%;margin:0 2px 5px}
nav ul{list-style:none;display:flex;gap:40px}
nav ul a{text-decoration:none;color:var(--gray);font-size:12px;letter-spacing:2px;text-transform:uppercase;transition:color .2s}
nav ul a:hover{color:var(--black)}
.nav-actions{display:flex;gap:16px;align-items:center}
.nav-book{padding:10px 24px;background:var(--black);color:var(--white);font-family:'DM Sans',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;border:none;transition:opacity .2s}
.nav-book:hover{opacity:.8}
.nav-cart-btn{position:relative;background:none;border:none;font-size:18px}
.cart-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:var(--black);color:var(--white);border-radius:50%;font-size:9px;display:flex;align-items:center;justify-content:center;font-weight:500}

.page{display:none}
.page.active{display:block}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;padding-top:68px}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:80px 56px}
.hero-eyebrow{font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--gray);margin-bottom:32px;animation:fadeUp .7s ease both}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(80px,10vw,148px);line-height:.92;letter-spacing:2px;margin-bottom:40px;animation:fadeUp .7s .1s ease both}
.hero-title em{font-family:'Playfair Display',serif;font-style:italic;font-size:.55em;display:block;letter-spacing:1px;color:var(--gray)}
.hero-desc{max-width:340px;color:var(--gray);line-height:1.8;font-size:14px;margin-bottom:48px;animation:fadeUp .7s .2s ease both}
.hero-cta{display:flex;gap:16px;animation:fadeUp .7s .3s ease both;flex-wrap:wrap}
.btn-black{padding:16px 36px;background:var(--black);color:var(--white);border:none;font-family:'DM Sans',sans-serif;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;transition:opacity .2s}
.btn-black:hover{opacity:.75}
.btn-outline{padding:16px 36px;background:transparent;color:var(--black);border:1px solid var(--black);font-family:'DM Sans',sans-serif;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;transition:background .2s,color .2s}
.btn-outline:hover{background:var(--black);color:var(--white)}
.hero-right{background:var(--black);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;animation:fadeIn .8s .2s ease both}
.hero-visual{text-align:center;position:relative}
.hero-big-text{font-family:'Bebas Neue',sans-serif;font-size:clamp(120px,18vw,260px);color:rgba(255,255,255,0.08);line-height:1;user-select:none;letter-spacing:8px}
.hero-stats{position:absolute;bottom:48px;left:48px;right:48px;display:flex;justify-content:space-between}
.stat{text-align:center}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--white);display:block}
.stat-label{font-size:10px;letter-spacing:2px;color:rgba(255,255,255,0.35);text-transform:uppercase}

/* MARQUEE */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;background:var(--black)}
.marquee-track{display:flex;gap:48px;animation:marquee 20s linear infinite;width:max-content}
.m-item{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:4px;color:rgba(255,255,255,0.6);display:flex;align-items:center;gap:24px;white-space:nowrap}
.m-sep{width:5px;height:5px;background:rgba(255,255,255,0.2);border-radius:50%}

/* SERVICES */
.services{padding:120px 56px}
.sec-label{font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--gray);margin-bottom:16px}
.sec-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,6vw,80px);margin-bottom:64px;line-height:1}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line)}
.service-item{padding:40px 32px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden;transition:background .25s}
.service-item:nth-child(4n){border-right:none}
.service-item:nth-last-child(-n+3){border-bottom:none}
.service-item:hover{background:var(--black)}
.service-item:hover .srv-name,.service-item:hover .srv-price,.service-item:hover .srv-time{color:var(--white)}
.service-item:hover .srv-desc{color:rgba(255,255,255,0.5)}
.service-item:hover .srv-book-link{color:var(--white);border-color:rgba(255,255,255,0.3)}
.srv-num{font-family:'Bebas Neue',sans-serif;font-size:48px;color:var(--line);line-height:1;margin-bottom:24px;transition:color .25s}
.service-item:hover .srv-num{color:rgba(255,255,255,0.1)}
.srv-name{font-family:'Playfair Display',serif;font-size:22px;margin-bottom:12px;transition:color .25s;min-height:56px}
.srv-desc{font-size:13px;color:var(--gray);line-height:1.7;margin-bottom:24px;transition:color .25s}
.srv-footer{display:flex;justify-content:space-between;align-items:center}
.srv-price{font-family:'Bebas Neue',sans-serif;font-size:28px;transition:color .25s}
.srv-time{font-size:11px;color:var(--gray);letter-spacing:1px;transition:color .25s}
.srv-book-link{display:block;margin-top:20px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gray);text-decoration:none;border:none;border-bottom:1px solid var(--line);padding-bottom:4px;transition:all .25s;background:none;font-family:'DM Sans',sans-serif}

/* BARBERS */
.barbers{padding:0 56px 120px}
.barbers-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;flex-wrap:wrap;gap:24px}
.barbers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px}
.barber-card{position:relative;background:var(--light);overflow:hidden;aspect-ratio:3/4;display:block;text-decoration:none;color:inherit}
.barber-card:nth-child(2),.barber-card:nth-child(4){background:#1a1a1a}
.barber-bg{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .4s ease}
.barber-card:hover .barber-bg{transform:scale(1.04)}
.barber-monogram{font-family:'Bebas Neue',sans-serif;font-size:88px;line-height:1;letter-spacing:4px;color:var(--black);position:relative;z-index:2}
.barber-card:nth-child(2) .barber-monogram,.barber-card:nth-child(4) .barber-monogram{color:#fff}
.barber-initial{display:none}
.barber-info{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(transparent,rgba(0,0,0,0.7))}
.barber-name{font-family:'Playfair Display',serif;font-size:16px;color:#fff}
.barber-role{font-size:10px;letter-spacing:2px;color:rgba(255,255,255,0.5);text-transform:uppercase}

/* CONTACT */
.contact-strip{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.cs-item{padding:56px;border-right:1px solid var(--line)}
.cs-item:last-child{border-right:none}
.cs-icon{font-size:24px;margin-bottom:20px}
.cs-label{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gray);margin-bottom:8px}
.cs-val{font-family:'Playfair Display',serif;font-size:20px}
.cs-sub{font-size:13px;color:var(--gray);margin-top:4px}

/* FOOTER */
footer{background:var(--black);padding:80px 56px 40px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:64px}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:3px;color:var(--white);margin-bottom:20px;display:block}
.footer-tagline{color:rgba(255,255,255,0.3);font-size:13px;line-height:1.7;max-width:280px}
.footer-col h4{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:20px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{text-decoration:none;color:rgba(255,255,255,0.5);font-size:14px;transition:color .2s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{background:var(--black);border-top:1px solid rgba(255,255,255,0.07);padding:24px 56px;display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,0.2);letter-spacing:1px}

/* BOOKING PAGE */
.booking-page{padding-top:68px;min-height:100vh;background:var(--white)}
.booking-hero{background:var(--black);padding:80px 56px 60px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
.booking-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(60px,8vw,100px);color:var(--white);line-height:.95}
.booking-sub{color:rgba(255,255,255,0.35);font-size:14px;line-height:1.7;max-width:320px}
.bwnet-container{padding:48px 56px;min-height:600px}
.bwnet-wrapper{max-width:1100px;margin:0 auto;background:var(--white);border:1px solid var(--line)}
.bwnet-iframe{width:100%;height:900px;border:none;display:block;background:var(--white)}
.bwnet-fallback{padding:32px;text-align:center;border-top:1px solid var(--line);background:var(--light)}
.bwnet-fallback p{color:var(--gray);font-size:13px;margin-bottom:16px}
.bwnet-fallback .btn-black{display:inline-block;text-decoration:none;color:var(--white)}

.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--black);color:var(--white);padding:14px 28px;font-size:12px;letter-spacing:1px;z-index:500;opacity:0;transition:all .3s;border-left:3px solid rgba(255,255,255,0.3)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes rotate{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

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

/* PRIVACY PAGE */
.privacy-page{padding-top:68px;min-height:100vh;background:var(--white)}
.privacy-hero{background:var(--black);padding:80px 56px 60px}
.privacy-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(50px,7vw,90px);color:var(--white);line-height:.95;margin-bottom:16px}
.privacy-sub{color:rgba(255,255,255,0.35);font-size:13px;letter-spacing:2px;text-transform:uppercase}
.privacy-body{padding:64px 56px;max-width:880px;margin:0 auto}
.privacy-section{margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid var(--line)}
.privacy-section:last-of-type{border-bottom:none}
.privacy-section h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:400;margin-bottom:20px;line-height:1.3}
.privacy-section p{color:var(--mid,#3a3a3a);line-height:1.8;margin-bottom:16px;font-size:15px}
.privacy-section p em{font-style:italic;color:var(--gray);font-size:13px;display:block;padding:12px 16px;background:var(--light);border-left:3px solid var(--black);margin-top:12px}
.privacy-section ul{list-style:none;padding-left:0;margin-bottom:16px}
.privacy-section ul li{padding:10px 0 10px 24px;position:relative;line-height:1.7;font-size:14px;color:var(--mid,#3a3a3a)}
.privacy-section ul li::before{content:"—";position:absolute;left:0;color:var(--gray)}
.privacy-section ul li strong{color:var(--black)}
.privacy-footer{text-align:center;margin-top:32px;padding-top:32px}
.privacy-footer p{color:var(--gray);margin-bottom:24px}
@media(max-width:900px){
  .privacy-hero,.privacy-body{padding-left:24px;padding-right:24px}
  .privacy-body{padding-top:40px}
}

@media(max-width:900px){
  nav{padding:0 24px}
  nav ul{display:none}
  .hero{grid-template-columns:1fr}
  .hero-right{min-height:340px}
  .hero-left,.shop-body,.bwnet-container{padding-left:24px;padding-right:24px}
  .services,.barbers,.shop-preview{padding-left:24px;padding-right:24px}
  .booking-hero,.shop-hero{padding-left:24px;padding-right:24px}
  .services-grid,.barbers-grid,.products-row,.shop-grid{grid-template-columns:1fr 1fr}
  .services-grid .service-item:nth-child(even){border-right:none}
  .contact-strip{grid-template-columns:1fr}
  .cs-item{border-right:none;border-bottom:1px solid var(--line);padding:32px 24px}
  footer{grid-template-columns:1fr;padding:48px 24px;gap:32px}
  .footer-bottom{padding:20px 24px;flex-direction:column;gap:6px}
  .sp-header{grid-template-columns:1fr}
  .nav-book{display:none}
  .bwnet-iframe{height:700px}
}
@media(max-width:520px){
  .services-grid,.barbers-grid,.products-row,.shop-grid{grid-template-columns:1fr}
  .services-grid .service-item{border-right:none;border-bottom:1px solid var(--line)}
}
