/* =========================================================
   Gabinet Stomatologiczny Paweł Binda — Design System
   ========================================================= */
:root{
  /* Palette */
  --navy:#0e2a33;
  --navy-700:#123843;
  --teal:#2ec4b6;
  --teal-deep:#0d6e74;
  --mint:#7ee0c8;
  --mint-soft:#bff3e4;
  --gold:#c9a96a;
  --bg:#f5fbfa;
  --bg-2:#eef7f5;
  --white:#ffffff;
  --ink:#0e1b22;
  --muted:#5d7178;
  --line:rgba(14,42,51,.10);
  --glass:rgba(255,255,255,.65);

  /* Type */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Plus Jakarta Sans',system-ui,Arial,sans-serif;

  /* Shape */
  --r-sm:12px; --r:20px; --r-lg:32px; --r-xl:42px;
  --shadow:0 18px 50px -20px rgba(13,110,116,.35);
  --shadow-soft:0 12px 40px -18px rgba(14,42,51,.25);
  --container:1200px;
  --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
section{position:relative}

/* ---------- Layout ---------- */
.container{width:min(92%,var(--container));margin-inline:auto}
.section{padding:clamp(64px,9vw,130px) 0}
.center{text-align:center}
.grid{display:grid;gap:28px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--navy);letter-spacing:.2px}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:clamp(1.4rem,2.4vw,2rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--muted);max-width:60ch}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--teal-deep);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--teal);border-radius:2px}
.eyebrow.center{justify-content:center}
.serif-accent{font-family:var(--serif);font-style:italic;color:var(--teal-deep)}
.gradient-text{background:linear-gradient(110deg,var(--teal),var(--teal-deep));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--teal);
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:100px;font-weight:700;font-size:.95rem;
  background:var(--bg);color:#fff;border:1px solid transparent;cursor:pointer;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .3s;
  box-shadow:0 14px 30px -12px rgba(46,196,182,.7);position:relative;overflow:hidden;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 22px 44px -14px rgba(46,196,182,.8)}
.btn svg{width:18px;height:18px}
.btn--dark{--bg:var(--navy);box-shadow:0 14px 30px -14px rgba(14,42,51,.6)}
.btn--ghost{background:transparent;color:var(--navy);border:1.5px solid var(--line);box-shadow:none}
.btn--ghost:hover{border-color:var(--teal);color:var(--teal-deep)}
.btn--gold{--bg:var(--gold);box-shadow:0 14px 30px -14px rgba(201,169,106,.7)}
.btn--lg{padding:18px 38px;font-size:1.02rem}
.btn--white{background:#fff;color:var(--navy);box-shadow:0 14px 30px -16px rgba(0,0,0,.4)}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px clamp(20px,5vw,56px);
  transition:background .4s var(--ease),box-shadow .4s,padding .4s,backdrop-filter .4s;
}
.nav.scrolled{background:rgba(255,255,255,.82);backdrop-filter:blur(18px);box-shadow:0 8px 30px -18px rgba(14,42,51,.4);padding-top:12px;padding-bottom:12px}
.nav__logo img{height:46px;width:auto}
.nav__logo .w{display:block}.nav__logo .c{display:none}
.nav.scrolled .nav__logo .w{display:none}.nav.scrolled .nav__logo .c{display:block}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{
  font-weight:600;font-size:.93rem;color:rgba(255,255,255,.92);
  padding:9px 15px;border-radius:100px;transition:.25s;position:relative;
}
.nav.scrolled .nav__links a{color:var(--navy)}
.nav__links a:hover,.nav__links a.active{color:var(--teal-deep);background:rgba(46,196,182,.12)}
.nav.scrolled .nav__links a:hover,.nav.scrolled .nav__links a.active{background:rgba(46,196,182,.14)}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__phone{font-weight:700;color:#fff;display:flex;align-items:center;gap:8px;font-size:.95rem}
.nav.scrolled .nav__phone{color:var(--navy)}
.nav__phone svg{width:18px;height:18px;color:var(--teal)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:26px;height:2.5px;background:#fff;border-radius:3px;transition:.3s}
.nav.scrolled .nav__burger span{background:var(--navy)}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:1100;background:var(--navy);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;
  transform:translateY(-100%);transition:transform .55s var(--ease);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:var(--serif);font-size:2rem;color:#fff;padding:10px}
.mobile-menu a:hover{color:var(--mint)}
.mobile-menu .close{position:absolute;top:24px;right:28px;background:none;border:0;color:#fff;font-size:2rem;cursor:pointer}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;
  background:radial-gradient(120% 90% at 80% 0%,#16454f 0%,#0e2a33 55%,#091e25 100%)}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero__glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;z-index:0}
.hero__glow.a{width:560px;height:560px;background:#1f9e8f;top:-160px;right:-120px}
.hero__glow.b{width:460px;height:460px;background:#0d6e74;bottom:-180px;left:-140px}
.hero__inner{position:relative;z-index:3;padding-top:140px;padding-bottom:80px}
.hero h1{color:#fff}
.hero .lead{color:rgba(255,255,255,.8)}
.hero__badge{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);
  padding:9px 18px;border-radius:100px;color:#fff;font-size:.85rem;font-weight:600;margin-bottom:26px}
.hero__badge .stars{color:var(--gold);letter-spacing:2px}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:34px}
.hero__stats{display:flex;gap:38px;margin-top:54px;flex-wrap:wrap}
.hero__stat .n{font-family:var(--serif);font-size:2.6rem;color:#fff;font-weight:600;line-height:1}
.hero__stat .l{color:rgba(255,255,255,.65);font-size:.82rem;letter-spacing:.04em}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  color:rgba(255,255,255,.6);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll .mouse{width:24px;height:38px;border:2px solid rgba(255,255,255,.4);border-radius:14px;position:relative}
.hero__scroll .mouse::before{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:4px;height:7px;background:#fff;border-radius:3px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* ---------- Marquee / trust strip ---------- */
.strip{background:var(--navy);color:rgba(255,255,255,.85);padding:18px 0;overflow:hidden}
.strip__track{display:flex;gap:60px;white-space:nowrap;animation:marquee 28s linear infinite;width:max-content}
.strip__track span{display:inline-flex;align-items:center;gap:12px;font-family:var(--serif);font-size:1.3rem;font-style:italic}
.strip__track span::after{content:"✦";color:var(--teal);font-style:normal;margin-left:60px}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Cards / Services ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

.services{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.service-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:38px 32px;transition:transform .5s var(--ease),box-shadow .5s,border-color .5s;
  position:relative;overflow:hidden;
}
.service-card::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(46,196,182,.08),transparent 60%);opacity:0;transition:.5s}
.service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow);border-color:transparent}
.service-card:hover::after{opacity:1}
.service-card .ico{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--mint-soft),#fff);color:var(--teal-deep);margin-bottom:22px}
.service-card .ico svg{width:30px;height:30px}
.service-card h3{margin-bottom:10px}
.service-card p{color:var(--muted);font-size:.96rem}
.service-card .more{display:inline-flex;align-items:center;gap:7px;margin-top:18px;color:var(--teal-deep);font-weight:700;font-size:.9rem}
.service-card .more svg{width:16px;transition:transform .3s}
.service-card:hover .more svg{transform:translateX(5px)}

/* feature split */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.split.reverse{direction:rtl}.split.reverse>*{direction:ltr}
.media-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.media-frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.media-frame:hover img{transform:scale(1.05)}
.media-badge{position:absolute;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border-radius:var(--r);padding:18px 22px;box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:14px}
.media-badge.bl{bottom:24px;left:24px}.media-badge.tr{top:24px;right:24px}
.media-badge .big{font-family:var(--serif);font-size:2rem;color:var(--teal-deep);line-height:1}
.media-badge .sm{font-size:.78rem;color:var(--muted)}

.ticklist li{display:flex;gap:14px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line)}
.ticklist li:last-child{border-bottom:0}
.ticklist .ck{flex:0 0 26px;width:26px;height:26px;border-radius:50%;background:var(--mint-soft);color:var(--teal-deep);display:grid;place-items:center;margin-top:2px}
.ticklist .ck svg{width:14px}
.ticklist strong{display:block;color:var(--navy);font-family:var(--sans);font-size:1rem}
.ticklist span{color:var(--muted);font-size:.92rem}

/* ---------- Stats band ---------- */
.statband{background:linear-gradient(150deg,var(--navy),var(--teal-deep));color:#fff;border-radius:var(--r-xl);
  padding:clamp(40px,6vw,70px);display:grid;grid-template-columns:repeat(4,1fr);gap:30px;position:relative;overflow:hidden}
.statband::before{content:"";position:absolute;width:400px;height:400px;background:rgba(126,224,200,.18);border-radius:50%;filter:blur(80px);top:-150px;right:-80px}
.stat-item{text-align:center;position:relative;z-index:1}
.stat-item .n{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:600;line-height:1}
.stat-item .l{color:rgba(255,255,255,.7);font-size:.9rem;margin-top:6px}

/* ---------- Reviews ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;display:flex;flex-direction:column;gap:16px;transition:.5s var(--ease)}
.review-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft)}
.review-card .stars{color:var(--gold);letter-spacing:3px}
.review-card p{font-family:var(--serif);font-size:1.22rem;line-height:1.5;color:var(--navy)}
.review-card .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.review-card .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(150deg,var(--teal),var(--teal-deep));color:#fff;display:grid;place-items:center;font-weight:700}
.review-card .who b{display:block;font-size:.92rem}
.review-card .who small{color:var(--muted)}

/* rating summary */
.rating-row{display:flex;gap:18px;flex-wrap:wrap}
.rating-pill{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 22px}
.rating-pill .score{font-family:var(--serif);font-size:2.2rem;color:var(--teal-deep);line-height:1}
.rating-pill small{color:var(--muted);font-size:.82rem}
.rating-pill .stars{color:var(--gold);font-size:.85rem}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:clamp(46px,7vw,84px);
  background:linear-gradient(130deg,#0e2a33,#0d6e74);color:#fff;text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background:url('../img/klinika-wnetrze.png') center/cover;opacity:.14}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band .lead{color:rgba(255,255,255,.82);margin:18px auto 30px}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:rgba(255,255,255,.72);padding:80px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer__logo img{height:54px;margin-bottom:18px}
.footer p{font-size:.92rem;line-height:1.7}
.footer h4{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.footer a{display:block;padding:6px 0;font-size:.93rem;transition:.25s}
.footer a:hover{color:var(--mint);transform:translateX(4px)}
.footer__contact li{display:flex;gap:12px;padding:7px 0;font-size:.93rem}
.footer__contact svg{width:18px;color:var(--teal);flex:0 0 18px;margin-top:3px}
.footer__bottom{margin-top:54px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem}
.footer__social{display:flex;gap:12px}
.footer__social a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center}
.footer__social a:hover{background:var(--teal);border-color:var(--teal);transform:translateY(-3px)}
.footer__social svg{width:18px}

/* ---------- Page header (subpages) ---------- */
.pagehead{background:radial-gradient(120% 120% at 80% 0%,#16454f,#0e2a33);color:#fff;padding:170px 0 90px;position:relative;overflow:hidden}
.pagehead::before{content:"";position:absolute;width:500px;height:500px;background:rgba(46,196,182,.2);border-radius:50%;filter:blur(90px);top:-200px;right:-100px}
.pagehead h1{color:#fff;position:relative}
.pagehead .lead{color:rgba(255,255,255,.78);position:relative}
.breadcrumb{display:flex;gap:8px;align-items:center;color:rgba(255,255,255,.55);font-size:.85rem;margin-bottom:18px;position:relative}
.breadcrumb a:hover{color:var(--mint)}

/* ---------- Pricing ---------- */
.price-tabs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.price-tab{padding:11px 22px;border-radius:100px;border:1px solid var(--line);background:#fff;font-weight:600;cursor:pointer;transition:.3s;font-size:.92rem}
.price-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.price-table{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-soft)}
.price-row{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:20px 30px;border-bottom:1px solid var(--line);transition:background .25s}
.price-row:last-child{border-bottom:0}
.price-row:hover{background:var(--bg-2)}
.price-row .name{font-weight:600;color:var(--navy)}
.price-row .desc{color:var(--muted);font-size:.86rem}
.price-row .amt{font-family:var(--serif);font-size:1.5rem;color:var(--teal-deep);white-space:nowrap;font-weight:600}
.price-group{display:none}.price-group.active{display:block}

/* ---------- Gallery ---------- */
.gallery{columns:3;column-gap:20px}
.gallery figure{break-inside:avoid;margin-bottom:20px;border-radius:var(--r);overflow:hidden;position:relative;box-shadow:var(--shadow-soft)}
.gallery img{width:100%;transition:transform 1s var(--ease)}
.gallery figure:hover img{transform:scale(1.07)}
.gallery figcaption{position:absolute;inset:auto 0 0 0;padding:18px;background:linear-gradient(transparent,rgba(14,42,51,.85));color:#fff;font-size:.9rem;opacity:0;transition:.4s}
.gallery figure:hover figcaption{opacity:1}

/* before/after slider */
.ba{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/10;box-shadow:var(--shadow);user-select:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba .after{clip-path:inset(0 0 0 50%)}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;cursor:ew-resize;z-index:3}
.ba .handle::after{content:"⟷";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:#fff;border-radius:50%;display:grid;place-items:center;color:var(--teal-deep);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.ba .tag{position:absolute;top:14px;padding:5px 12px;border-radius:100px;font-size:.74rem;font-weight:700;color:#fff;background:rgba(14,42,51,.6);backdrop-filter:blur(6px);z-index:2}
.ba .tag.l{left:14px}.ba .tag.r{right:14px}

/* ---------- FAQ ---------- */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;overflow:hidden;transition:.3s}
.faq-item.open{box-shadow:var(--shadow-soft);border-color:transparent}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 26px;cursor:pointer;font-weight:600;color:var(--navy);font-size:1.05rem}
.faq-q .pl{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--mint-soft);color:var(--teal-deep);display:grid;place-items:center;transition:.3s;font-size:1.2rem}
.faq-item.open .pl{transform:rotate(45deg);background:var(--teal);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a p{padding:0 26px 24px;color:var(--muted)}

/* ---------- Team / About ---------- */
.doc-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line)}
.doc-card .ph{aspect-ratio:4/5;background:linear-gradient(160deg,var(--mint-soft),var(--bg-2));position:relative;overflow:hidden}
.doc-card .ph .initials{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-size:5rem;color:var(--teal-deep)}
.doc-card .info{padding:26px}
.doc-card .info h3{margin-bottom:4px}
.doc-card .info .role{color:var(--teal-deep);font-weight:600;font-size:.9rem}

.timeline{position:relative;padding-left:30px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline li{position:relative;padding:0 0 30px 24px}
.timeline li::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--teal)}
.timeline .yr{font-family:var(--serif);color:var(--teal-deep);font-size:1.2rem;font-weight:600}

/* ---------- Forms / Booking ---------- */
.form-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow);border:1px solid var(--line);padding:clamp(28px,4vw,50px)}
.steps{display:flex;gap:8px;margin-bottom:34px}
.step-dot{flex:1;display:flex;flex-direction:column;gap:8px}
.step-dot .bar{height:5px;border-radius:5px;background:var(--line);transition:.4s}
.step-dot.active .bar,.step-dot.done .bar{background:var(--teal)}
.step-dot small{font-size:.76rem;color:var(--muted);font-weight:600}
.step-dot.active small{color:var(--teal-deep)}
.fstep{display:none;animation:fade .5s var(--ease)}
.fstep.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:8px;color:var(--navy)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  font-family:inherit;font-size:.96rem;background:var(--bg);transition:.25s;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(46,196,182,.12)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.choice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.choice{border:1.5px solid var(--line);border-radius:var(--r-sm);padding:16px;cursor:pointer;transition:.25s;display:flex;gap:12px;align-items:center}
.choice:hover{border-color:var(--teal)}
.choice.sel{border-color:var(--teal);background:rgba(46,196,182,.08)}
.choice .ci{width:40px;height:40px;border-radius:12px;background:var(--mint-soft);color:var(--teal-deep);display:grid;place-items:center;flex:0 0 40px}
.choice .ci svg{width:20px}
.choice b{display:block;font-size:.94rem;color:var(--navy)}
.choice small{color:var(--muted);font-size:.8rem}
.slots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.slot{padding:12px;text-align:center;border:1.5px solid var(--line);border-radius:var(--r-sm);cursor:pointer;font-weight:600;font-size:.9rem;transition:.2s}
.slot:hover{border-color:var(--teal)}
.slot.sel{background:var(--navy);color:#fff;border-color:var(--navy)}
.form-nav{display:flex;justify-content:space-between;margin-top:28px;gap:14px}
.form-success{text-align:center;padding:20px}
.form-success .ok{width:80px;height:80px;border-radius:50%;background:var(--mint-soft);color:var(--teal-deep);display:grid;place-items:center;margin:0 auto 20px}
.form-success .ok svg{width:40px}

/* contact info cards */
.info-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;gap:16px;transition:.4s}
.info-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft)}
.info-card .ic{width:50px;height:50px;border-radius:14px;background:linear-gradient(150deg,var(--mint-soft),#fff);color:var(--teal-deep);display:grid;place-items:center;flex:0 0 50px}
.info-card .ic svg{width:24px}
.info-card b{display:block;color:var(--navy)}
.info-card span{color:var(--muted);font-size:.92rem}
.map-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line);min-height:340px}
.map-frame iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

/* hours table */
.hours-table{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.hours-table .hrow{display:flex;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--line);font-size:.95rem}
.hours-table .hrow:last-child{border-bottom:0}
.hours-table .hrow.today{background:rgba(46,196,182,.08);font-weight:700;color:var(--teal-deep)}
.hours-table .hrow .closed{color:#c0606a}

/* section heading helper */
.sec-head{max-width:680px}
.sec-head.center{margin-inline:auto}
.sec-head h2{margin:14px 0 16px}

/* pill chips */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 16px;font-size:.85rem;font-weight:600;color:var(--navy);display:inline-flex;align-items:center;gap:8px}
.chip svg{width:15px;color:var(--teal)}

/* floating book button (mobile) */
.fab{position:fixed;bottom:22px;right:22px;z-index:900;display:none}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .services,.reviews{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .gallery{columns:2}
}
@media(max-width:768px){
  .nav__links,.nav__phone{display:none}
  .nav__burger{display:flex}
  .services,.reviews,.info-cards,.choice-grid{grid-template-columns:1fr}
  .split,.split.reverse{grid-template-columns:1fr;direction:ltr}
  .split.reverse>*{direction:ltr}
  .field-row{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .gallery{columns:1}
  .slots{grid-template-columns:repeat(2,1fr)}
  .hero__stats{gap:22px}
  .fab{display:block}
  .statband{grid-template-columns:1fr 1fr;gap:24px}
}

/* ---------- Cal.com booking ---------- */
.cal-note{display:flex;gap:14px;align-items:flex-start;background:linear-gradient(150deg,var(--mint-soft),#fff);
  border:1px solid var(--line);border-radius:var(--r);padding:18px 22px;margin-bottom:24px;color:var(--navy);font-size:.95rem;line-height:1.55}
.cal-note svg{width:24px;flex:0 0 24px;color:var(--teal-deep);margin-top:2px}
.cal-note a{color:var(--teal-deep);font-weight:700}
.cal-embed{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-soft);
  overflow:hidden;min-height:640px;width:100%}
.cal-embed iframe{width:100%!important;min-height:640px}

/* ---------- Mobile polish ---------- */
@media(max-width:768px){
  :root{--r-lg:24px;--r-xl:28px}
  /* hero: keep 3D subtle so text stays readable */
  #hero-canvas{opacity:.5}
  .hero__inner{padding-top:120px;padding-bottom:64px}
  .hero h1{font-size:clamp(2.3rem,9vw,3rem)}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%;justify-content:center}
  .hero__stats{justify-content:space-between;width:100%}
  .hero__stat .n{font-size:2.1rem}
  .hero__badge{font-size:.78rem}
  .nav{padding:12px 18px}
  .nav.scrolled{padding:10px 18px}
  .nav__logo img{height:38px}
  /* tighten section rhythm */
  .section{padding:54px 0}
  .cta-band{padding:40px 22px}
  .cta-band .btn,.cta-band .btn--lg{width:100%;justify-content:center}
  .cta-band div[style*="display:flex"]{flex-direction:column}
  .price-row{flex-direction:column;align-items:flex-start;gap:8px}
  .price-row .amt{font-size:1.3rem}
  .price-tabs{gap:8px}
  .price-tab{padding:9px 16px;font-size:.85rem}
  .rating-row{justify-content:center}
  .media-badge.bl{left:14px;bottom:14px;padding:12px 16px}
  .media-badge.tr{right:14px;top:14px;padding:12px 16px}
  .media-badge .big{font-size:1.5rem}
  .cal-embed,.cal-embed iframe{min-height:560px}
  .strip__track span{font-size:1.05rem}
  .timeline{padding-left:24px}
}
@media(max-width:420px){
  .statband{grid-template-columns:1fr 1fr;gap:18px;padding:32px 20px}
  .hero__stat .n{font-size:1.9rem}
  h1{font-size:2.2rem}
}
