/* ==========================================================================
   Диана Богданова-Николова · психолог · София  —  V4 "Modern Playful"
   Art direction cloned from thepracticetherapy.com:
   warm grey + pale lime + periwinkle blocks, high-contrast serif display
   with italic accents, layered window-frame imagery, dark pill buttons.
   Type: Spectral (serif display + italics) · Onest (sans body).
   NOTE: class names are unchanged from V3 so all 4 pages + booking modal work.
   ========================================================================== */
:root{
  /* core palette */
  --ink:#1b1b15;            /* near-black */
  --ink-2:#3d3d33;          /* body text */
  --muted:#7c7c70;
  --paper:#e7e6dd;          /* warm grey page bg */
  --cream:#f3f1e7;
  --white:#ffffff;
  --lime:#dde58c;           /* chartreuse pop */
  --lime-soft:#edf2c2;
  --lime-deep:#cdd766;
  --peri:#a9bcdb;           /* periwinkle */
  --peri-soft:#cfdaee;
  --peri-deep:#5f7bb3;      /* highlight / links */
  --gold:#bd8c3a;           /* stars only */

  /* ---- aliases kept so existing inline style="var(--green…)" still resolves ---- */
  --bg:var(--paper); --bg2:var(--peri-soft); --surface:var(--white); --surface2:#efeee5;
  --green-900:var(--ink); --green-700:#3d3d33; --green:var(--peri-deep); --green-600:#283a66;
  --green-300:#b9c7e2; --sage-100:var(--peri-soft);
  --text:var(--ink-2);
  --accent:var(--peri-deep); --accent-soft:var(--peri-soft);

  --line:rgba(27,27,21,.12); --line-2:rgba(27,27,21,.2);
  --shadow-sm:0 2px 10px rgba(27,27,21,.06);
  --shadow:0 14px 40px rgba(27,27,21,.12);
  --shadow-lg:0 34px 80px rgba(27,27,21,.18);
  --r:16px; --r-lg:28px; --maxw:1180px;
  --font:'Onest',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --serif:'Spectral',Georgia,'Times New Roman',serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--paper);color:var(--ink-2);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;letter-spacing:-.005em}
img{max-width:100%;display:block}
a{color:var(--peri-deep);text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);font-weight:600;line-height:1.08;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:760px;margin:0 auto}

/* type scale — serif display with italic accents */
.h1{font-family:var(--serif);font-size:clamp(44px,6.2vw,76px);font-weight:600;line-height:1.0;letter-spacing:-.015em}
.h1 span,.h2 span{font-style:italic;font-weight:500}
.h2{font-family:var(--serif);font-size:clamp(32px,4.2vw,50px);font-weight:600}
.lead{font-size:clamp(17px,2vw,20px);color:var(--ink-2);line-height:1.6}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--peri-deep);font-family:var(--font);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:'';width:26px;height:8px;border-radius:100px;background:var(--lime);flex-shrink:0}
.sec-head.center .eyebrow{justify-content:center}

/* buttons — dark pill, lime accent */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:15px 30px;border:none;border-radius:100px;font-family:inherit;
  font-size:15px;font-weight:600;cursor:pointer;transition:.18s;white-space:nowrap;
  background:var(--ink);color:#f3f1e7;letter-spacing:.005em}
.btn:hover{background:#000;transform:translateY(-2px);box-shadow:0 14px 30px rgba(27,27,21,.28);color:#f3f1e7}
.btn.lg{padding:17px 36px;font-size:16px}
.btn.accent{background:var(--lime);color:var(--ink)}
.btn.accent:hover{background:var(--lime-deep);box-shadow:0 14px 30px rgba(205,215,102,.5)}
.btn.ghost{background:transparent;color:var(--ink);border:1.6px solid var(--ink);box-shadow:none}
.btn.ghost:hover{background:var(--ink);color:#f3f1e7;transform:translateY(-2px)}
.btn svg{width:18px;height:18px}

/* nav */
.nav{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:20px;min-height:80px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mk{width:42px;height:42px;border-radius:12px;background:var(--lime);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;letter-spacing:-.02em;font-family:var(--serif)}
.brand .tx{display:flex;flex-direction:column;line-height:1.05}
.brand .nm{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--ink);letter-spacing:-.01em}
.brand .rl{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:2px;font-family:var(--font)}
.nav-spacer{flex:1}
.nav-links{display:flex;gap:4px}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--ink-2);padding:8px 15px;border-radius:100px;transition:.15s;font-family:var(--font)}
.nav-links a:hover{color:var(--ink);background:rgba(27,27,21,.06)}
.nav-links a.active{color:var(--ink);background:var(--lime)}
.nav-phone{font-size:14.5px;font-weight:700;color:var(--ink);white-space:nowrap;font-family:var(--font)}
.nav .btn{padding:11px 22px;font-size:14px}
@media(max-width:960px){.nav-links{display:none}}
@media(max-width:620px){
  .nav-phone{display:none}
  .nav .wrap{min-height:64px;gap:12px}
  .brand .mk{width:36px;height:36px;font-size:14px}
  .brand .nm{font-size:15px}
  .brand .rl{display:none}
  .nav .btn{padding:10px 18px;font-size:13.5px}
}

/* sections */
.section{padding:104px 0}
.section.sm{padding:64px 0}
.section.bg2{background:var(--peri-soft)}
.section.white{background:var(--cream)}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:18px}
.sec-head p{margin-top:16px;font-size:18px}
@media(max-width:600px){.section{padding:72px 0}}

/* hero */
.hero{padding:70px 0 86px;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;top:-120px;right:-120px;width:380px;height:380px;
  border-radius:50%;background:radial-gradient(circle,var(--lime-soft),transparent 70%);opacity:.7;z-index:0}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;position:relative;z-index:1}
.rating-pill{display:inline-flex;align-items:center;gap:10px;background:var(--white);
  border:1px solid var(--line);border-radius:100px;padding:9px 17px;font-size:13.5px;font-weight:600;
  color:var(--ink);box-shadow:var(--shadow-sm);margin-bottom:26px;font-family:var(--font)}
.rating-pill .st{color:var(--gold);letter-spacing:1px}
.hero h1{margin-bottom:24px}
.hero .lead{max-width:500px;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* hero — layered window-frame */
.hero-figure{position:relative;isolation:isolate}
.hero-figure>img{position:relative;z-index:1;width:100%;border-radius:18px;aspect-ratio:4/5;
  object-fit:cover;box-shadow:var(--shadow-lg)}            /* fallback for un-framed img */
.frame{position:relative;z-index:1;background:var(--white);border-radius:22px;padding:12px;
  box-shadow:var(--shadow-lg)}
.frame-bar{display:flex;gap:7px;padding:6px 6px 12px}
.frame-bar span{width:11px;height:11px;border-radius:50%;background:#d9d8cf}
.frame-bar span:nth-child(1){background:var(--lime-deep)}
.frame-bar span:nth-child(2){background:var(--peri)}
.frame img{width:100%;border-radius:14px;aspect-ratio:4/5;object-fit:cover}
.hero-figure::before{content:'';position:absolute;inset:34px -28px -28px 34px;
  background:var(--peri);border-radius:30px;z-index:0}
.float-card{position:absolute;z-index:2;border-radius:16px;box-shadow:var(--shadow-lg);
  padding:14px 18px;display:flex;align-items:center;gap:13px}
.float-card.tl{top:34px;left:-28px;background:var(--lime)}
.float-card.br{bottom:30px;right:-26px;background:var(--white)}
.float-card .big{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--ink);letter-spacing:-.02em;line-height:1}
.float-card .cap{font-size:12px;color:var(--ink-2);line-height:1.35;max-width:120px;font-weight:500}
.float-card .avs{display:flex}
.float-card .avs span{width:30px;height:30px;border-radius:50%;border:2px solid #fff;margin-left:-9px;
  background:var(--peri-deep);display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-weight:700}
.float-card .avs span:first-child{margin-left:0}
@media(max-width:880px){
  .hero{padding:48px 0 64px}
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .hero-figure{max-width:460px}
  /* stop overlay cards from covering the photo — stack them below the frame */
  .float-card{position:static;width:fit-content;max-width:100%;box-shadow:var(--shadow)}
  .float-card.tl{margin:16px 0 0}
  .float-card.br{margin:16px 0 0}
  .hero-chat{position:static;left:auto;bottom:auto;max-width:none;margin-top:14px}
}

/* trust bar */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:14px 30px;align-items:center;justify-content:center;padding:24px 28px}
.trust .lbl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700}
.trust .chip{font-size:14px;font-weight:600;color:var(--ink)}
.trust .dot{width:5px;height:5px;border-radius:50%;background:var(--peri)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.split.flip .media{order:2}
.media{position:relative}
.media img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}
.media.tall img{aspect-ratio:3/4}
.media::before{content:'';position:absolute;inset:auto -18px -18px auto;width:64%;height:64%;
  background:var(--lime);border-radius:var(--r-lg);z-index:-1}
.split.flip .media::before{inset:auto auto -18px -18px}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:46px}.split.flip .media{order:0}}

/* issue chips */
.issues{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.issue{display:flex;gap:12px;align-items:flex-start;background:var(--white);border:1px solid var(--line);
  border-radius:14px;padding:15px 18px;font-size:15px;color:var(--ink);font-weight:500;transition:.15s}
.issue:hover{border-color:var(--peri);transform:translateY(-2px)}
.issue svg{width:20px;height:20px;color:var(--peri-deep);flex-shrink:0;margin-top:1px}
@media(max-width:560px){.issues{grid-template-columns:1fr}}

/* quote band — big lime panel, serif italic */
.band{background:var(--lime);color:var(--ink);text-align:center;position:relative;overflow:hidden}
.band .wrap{position:relative;z-index:1}
.band::before{content:'\201C';position:absolute;top:-40px;left:50%;transform:translateX(-50%);
  font-family:var(--serif);font-size:300px;line-height:1;color:rgba(27,27,21,.07);z-index:0}
.band .q{font-family:var(--serif);font-style:italic;font-size:clamp(26px,3.4vw,40px);font-weight:500;
  line-height:1.3;max-width:900px;margin:0 auto;letter-spacing:-.01em;color:var(--ink)}
.band .q b{font-weight:600;font-style:normal}
.band .by{margin-top:26px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#5a5f2a;font-weight:700;font-family:var(--font)}

/* services — colorful shape badges */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;transition:.2s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.card .ic svg{width:27px;height:27px;color:var(--ink);stroke-width:1.6}
.cards .card:nth-child(1) .ic{background:var(--lime)}
.cards .card:nth-child(2) .ic{background:var(--peri)}
.cards .card:nth-child(3) .ic{background:var(--lime-soft)}
.card h4{font-size:23px;margin-bottom:10px;letter-spacing:-.01em}
.card p{font-size:15px;color:var(--ink-2)}
@media(max-width:860px){.cards{grid-template-columns:1fr}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{position:relative;padding-top:22px;border-top:2px solid var(--ink)}
.step .n{position:absolute;top:-17px;left:0;width:34px;height:34px;border-radius:50%;background:var(--lime);
  color:var(--ink);font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--serif)}
.step h4{font-size:19px;margin:8px 0 8px}
.step p{font-size:14px;color:var(--ink-2)}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:460px){.steps{grid-template-columns:1fr}}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{text-align:center;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:30px 12px}
.stat .n{font-family:var(--serif);font-size:46px;font-weight:600;color:var(--peri-deep);letter-spacing:-.02em;line-height:1}
.stat .l{font-size:13px;color:var(--ink-2);margin-top:10px}
@media(max-width:560px){.stats{grid-template-columns:1fr 1fr}}

/* quals */
.quals{list-style:none}
.quals li{display:flex;gap:13px;padding:14px 0;border-top:1px solid var(--line);font-size:15.5px;color:var(--ink)}
.quals li:first-child{border-top:none}
.quals li svg{width:20px;height:20px;color:var(--peri-deep);flex-shrink:0;margin-top:2px}

/* testimonials */
.tests{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.test{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;position:relative}
.test .st{color:var(--gold);letter-spacing:2px;font-size:14px;margin-bottom:18px}
.test p{font-family:var(--serif);font-size:18px;color:var(--ink);line-height:1.55;font-weight:500;margin-bottom:24px}
.test .who{display:flex;align-items:center;gap:12px}
.test .av{width:44px;height:44px;border-radius:50%;background:var(--peri);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:var(--serif)}
.test .nm{font-weight:700;color:var(--ink);font-size:14.5px}
.test .mt{font-size:12.5px;color:var(--muted)}
@media(max-width:860px){.tests{grid-template-columns:1fr}}

/* whom */
.whom-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:920px;margin:0 auto}
.whom{border-radius:var(--r-lg);padding:36px}
.whom.yes{background:var(--ink);color:#e9e8df}
.whom.yes h4{color:#fff}
.whom.no{background:var(--white);border:1px solid var(--line)}
.whom h4{font-size:24px;margin-bottom:20px}
.whom ul{list-style:none}
.whom li{display:flex;gap:11px;padding:9px 0;font-size:15px;align-items:flex-start}
.whom li svg{width:19px;height:19px;flex-shrink:0;margin-top:2px}
.whom.yes li svg{color:var(--lime)}
.whom.no li{color:var(--ink)}.whom.no li svg{color:var(--muted)}
@media(max-width:640px){.whom-grid{grid-template-columns:1fr}}

/* faq */
.faq{max-width:820px;margin:0 auto}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:16px;margin-bottom:12px;padding:4px 26px}
.faq summary{cursor:pointer;list-style:none;font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink);
  padding:22px 0;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{width:24px;height:24px;flex-shrink:0;position:relative}
.faq summary .pm::before,.faq summary .pm::after{content:'';position:absolute;background:var(--peri-deep);border-radius:2px;
  top:50%;left:50%;transform:translate(-50%,-50%)}
.faq summary .pm::before{width:14px;height:2px}.faq summary .pm::after{width:2px;height:14px;transition:.2s}
.faq details[open] summary .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq p{font-size:15.5px;color:var(--ink-2);padding:0 0 22px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.cc{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow-sm)}
.crow{display:flex;gap:16px;padding:16px 0;border-top:1px solid var(--line);align-items:flex-start}
.crow:first-child{border-top:none}
.crow .ic{width:42px;height:42px;border-radius:12px;background:var(--lime);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.crow .ic svg{width:19px;height:19px;color:var(--ink)}
.crow .k{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:3px}
.crow .v{font-size:15.5px;color:var(--ink)}
.crow .v a{color:var(--ink);font-weight:600}
.directions img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow);aspect-ratio:3/4;object-fit:cover}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr;gap:32px}}

/* final cta — dark drama with lime button */
.final{background:var(--ink);color:#e9e8df;text-align:center}
.final h2{color:#fff;margin-bottom:20px}
.final h2 span{color:var(--lime)}
.final p{color:#bdbcb1;max-width:560px;margin:0 auto 34px;font-size:18px}
.final .reassure{margin-top:26px;display:flex;gap:10px 22px;justify-content:center;flex-wrap:wrap;font-size:13.5px;color:#9a998e}

/* footer */
.footer{background:var(--ink);color:#9a998e;padding:64px 0 32px}
.footer .cols{display:flex;flex-wrap:wrap;gap:34px 60px;justify-content:space-between}
.footer .brand .nm{color:#fff}.footer .brand .rl{color:#7c7b70}
.footer .brand .mk{background:var(--lime);color:var(--ink)}
.footer h5{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--lime);margin-bottom:16px;font-family:var(--font)}
.footer a,.footer .fl{display:block;font-size:14.5px;color:#9a998e;padding:5px 0}
.footer a:hover{color:#fff}
.footer .copy{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:24px;text-align:center;font-size:12.5px;color:#6f6e64}

/* ==========================================================================
   V4.1 — DISTINCTIVE HOMEPAGE (editorial / asymmetric / custom shapes)
   ========================================================================== */

/* full-bleed helper */
.bleed{width:100%}

/* decorative organic blobs */
.blob{position:absolute;z-index:0;pointer-events:none}
.blob.lime{color:var(--lime)} .blob.peri{color:var(--peri)} .blob.soft{color:var(--lime-soft)}

/* signature hero overlay card ("Нека поговорим") */
.hero-chat{position:absolute;z-index:3;left:-34px;bottom:54px;max-width:262px;
  background:var(--lime);border-radius:22px;padding:22px 24px;box-shadow:var(--shadow-lg)}
.hero-chat .t{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--ink);line-height:1.15;margin-bottom:8px}
.hero-chat .d{font-size:13px;color:#4a4e22;line-height:1.45;margin-bottom:16px}
.hero-chat a{display:inline-flex;align-items:center;gap:8px;font-family:var(--font);font-weight:700;
  font-size:13.5px;color:var(--ink);letter-spacing:.02em}
.hero-chat a svg{width:18px;height:18px;transition:.18s}
.hero-chat:hover a svg{transform:translateX(4px)}
/* mobile: drop the overlay card below the photo (must come AFTER base rules to win) */
@media(max-width:880px){
  .hero-chat{position:static;left:auto;bottom:auto;max-width:none;margin-top:14px}
  .hero-figure::before{display:none}   /* desktop depth panel — off on mobile */
  .hero-figure .blob{display:none}     /* decorative blob — off on mobile */
}

/* marquee strip of specialties */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;white-space:nowrap;padding:18px 0;display:flex}
.marquee .track{display:inline-flex;align-items:center;gap:34px;padding-right:34px;
  animation:marq 32s linear infinite;flex-shrink:0}
.marquee b{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(20px,2.4vw,28px);color:var(--cream)}
.marquee i{width:9px;height:9px;border-radius:50%;background:var(--lime);flex-shrink:0}
@keyframes marq{to{transform:translateX(-50%)}}

/* asymmetric editorial section head: big outlined number + heading */
.ed-head{display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:start;margin-bottom:56px}
.bignum{font-family:var(--serif);font-size:clamp(78px,11vw,168px);font-weight:600;line-height:.74;
  -webkit-text-stroke:1.6px rgba(27,27,21,.2);color:transparent;letter-spacing:-.04em;margin-top:-6px}
.ed-head.onlime .bignum{-webkit-text-stroke-color:rgba(27,27,21,.28)}
.ed-head .ht{max-width:640px}
.ed-head .ht .eyebrow{margin-bottom:16px}
.ed-head .ht p{margin-top:16px;font-size:18px}
@media(max-width:680px){.ed-head{grid-template-columns:1fr;gap:8px}.bignum{font-size:72px}}

/* staggered issue list (anti-grid) */
.issues.stagger .issue:nth-child(even){transform:translateY(20px)}
@media(max-width:560px){.issues.stagger .issue:nth-child(even){transform:none}}

/* BENTO services — breaks the equal 3-grid */
.bento{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.b{position:relative;overflow:hidden;border-radius:28px;padding:38px 34px;transition:.22s;min-height:230px;
  display:flex;flex-direction:column;justify-content:flex-end;border:1px solid transparent}
.b:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.b .glyph{position:absolute;top:26px;right:26px;width:64px;height:64px;z-index:1}
.b h4{font-family:var(--serif);font-size:25px;font-weight:600;color:var(--ink);margin-bottom:10px;letter-spacing:-.01em;position:relative;z-index:1}
.b p{font-size:15px;color:var(--ink-2);position:relative;z-index:1;max-width:340px}
.b.feature{grid-column:span 2;min-height:200px}
.b.lime{background:var(--lime)} .b.peri{background:var(--peri)}
.b.cream{background:var(--cream);border-color:var(--line)} .b.paper{background:var(--white);border-color:var(--line)}
.b.feature h4{font-size:30px}
@media(max-width:760px){.bento{grid-template-columns:1fr}.b.feature{grid-column:span 1}}

/* bold stat band */
.statband{background:var(--ink);color:var(--cream)}
.statband .row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.statband .s{padding:8px 6px}
.statband .s .n{font-family:var(--serif);font-size:clamp(44px,5.5vw,68px);font-weight:600;color:var(--lime);line-height:1;letter-spacing:-.02em}
.statband .s .l{font-size:13.5px;color:#bdbcb1;margin-top:12px}
.statband .s:nth-child(2) .n,.statband .s:nth-child(4) .n{color:var(--peri)}
@media(max-width:620px){.statband .row{grid-template-columns:1fr 1fr;gap:34px}}

/* staggered testimonials */
.tests.stagger .test:nth-child(2){transform:translateY(28px)}
@media(max-width:860px){.tests.stagger .test:nth-child(2){transform:none}}

/* ==========================================================================
   BOOKING CALENDAR MODAL  (re-skinned to ink + lime)
   ========================================================================== */
.bk-overlay{position:fixed;inset:0;z-index:200;background:rgba(20,20,16,.55);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s}
.bk-overlay.open{display:flex;opacity:1}
.bk-modal{background:var(--cream);border-radius:26px;box-shadow:var(--shadow-lg);width:100%;max-width:880px;
  max-height:92vh;overflow:hidden;display:grid;grid-template-columns:300px 1fr;transform:translateY(12px);transition:.25s}
.bk-overlay.open .bk-modal{transform:none}
.bk-aside{background:var(--ink);color:#dcdbd1;padding:36px 30px;display:flex;flex-direction:column}
.bk-aside .who{display:flex;align-items:center;gap:13px;margin-bottom:26px}
.bk-aside .who img{width:52px;height:52px;border-radius:50%;object-fit:cover}
.bk-aside .who .nm{color:#fff;font-weight:600;font-size:15px;font-family:var(--serif)}
.bk-aside .who .rl{font-size:12px;color:#9a998e}
.bk-aside h3{color:#fff;font-size:25px;margin-bottom:10px;letter-spacing:-.01em;font-family:var(--serif);font-weight:600}
.bk-aside .desc{font-size:14px;color:#bdbcb1;line-height:1.55}
.bk-aside .meta{margin-top:auto;padding-top:26px;display:flex;flex-direction:column;gap:12px}
.bk-aside .meta div{display:flex;gap:10px;align-items:center;font-size:13.5px;color:#cdccc2}
.bk-aside .meta svg{width:17px;height:17px;color:var(--lime);flex-shrink:0}
.bk-main{padding:32px;overflow-y:auto}
.bk-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.bk-top h4{font-size:21px;color:var(--ink);font-family:var(--serif);font-weight:600}
.bk-close{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:var(--white);
  cursor:pointer;font-size:18px;color:var(--ink-2);display:flex;align-items:center;justify-content:center;transition:.15s}
.bk-close:hover{background:var(--paper)}
.bk-steps{display:flex;gap:6px;margin-bottom:24px}
.bk-steps span{flex:1;height:4px;border-radius:3px;background:var(--line-2)}
.bk-steps span.on{background:var(--ink)}
.bk-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.bk-cal-head .mo{font-weight:600;color:var(--ink);font-size:17px;text-transform:capitalize;font-family:var(--serif)}
.bk-nav{display:flex;gap:8px}
.bk-nav button{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:var(--white);cursor:pointer;color:var(--ink);font-size:15px;transition:.15s}
.bk-nav button:hover:not(:disabled){background:var(--paper)}
.bk-nav button:disabled{opacity:.35;cursor:not-allowed}
.bk-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.bk-dow span{text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase}
.bk-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.bk-day{aspect-ratio:1;border:none;background:transparent;border-radius:10px;cursor:pointer;font-family:inherit;
  font-size:14.5px;font-weight:600;color:var(--ink);transition:.12s;display:flex;align-items:center;justify-content:center}
.bk-day:hover:not(:disabled){background:var(--paper)}
.bk-day.has{background:var(--white);border:1px solid var(--line)}
.bk-day.has:hover{border-color:var(--ink);background:var(--lime-soft)}
.bk-day.sel{background:var(--ink);color:#fff}
.bk-day:disabled{color:var(--muted);opacity:.45;cursor:default}
.bk-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:6px}
.bk-slot{padding:13px 8px;border:1px solid var(--line);background:var(--white);border-radius:12px;cursor:pointer;
  font-family:inherit;font-size:15px;font-weight:600;color:var(--ink);transition:.15s}
.bk-slot:hover{border-color:var(--ink);background:var(--lime-soft)}
.bk-slot.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.bk-hint{font-size:13px;color:var(--muted);margin-top:16px;text-align:center}
.bk-field{margin-bottom:14px}
.bk-field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.bk-field input,.bk-field textarea{width:100%;padding:13px 15px;border:1px solid var(--line-2);border-radius:12px;
  font-family:inherit;font-size:15px;color:var(--ink);background:var(--white);transition:.15s}
.bk-field input:focus,.bk-field textarea:focus{outline:none;border-color:var(--peri-deep);box-shadow:0 0 0 3px rgba(95,123,179,.18)}
.bk-toggle{display:flex;gap:10px;margin-bottom:18px}
.bk-toggle button{flex:1;padding:12px;border:1px solid var(--line-2);background:var(--white);border-radius:12px;
  cursor:pointer;font-family:inherit;font-weight:600;font-size:14px;color:var(--ink);transition:.15s}
.bk-toggle button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.bk-summary{background:var(--white);border:1px solid var(--line);border-radius:13px;padding:14px 16px;margin-bottom:18px;
  font-size:14px;color:var(--ink-2);display:flex;gap:10px;align-items:center}
.bk-summary svg{width:18px;height:18px;color:var(--peri-deep)}
.bk-summary b{color:var(--ink)}
.bk-back{background:none;border:none;color:var(--muted);font-family:inherit;font-weight:600;cursor:pointer;font-size:14px;padding:8px 0}
.bk-back:hover{color:var(--ink)}
.bk-actions{display:flex;gap:12px;align-items:center;margin-top:18px}
.bk-success{text-align:center;padding:30px 10px}
.bk-success .ok{width:74px;height:74px;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.bk-success .ok svg{width:36px;height:36px;color:var(--ink)}
.bk-success h4{font-size:26px;margin-bottom:12px;font-family:var(--serif);font-weight:600;color:var(--ink)}
.bk-success p{font-size:15.5px;color:var(--ink-2);max-width:380px;margin:0 auto 8px}
.bk-success .det{margin-top:18px;font-weight:600;color:var(--ink)}
@media(max-width:680px){
  .bk-modal{grid-template-columns:1fr;max-height:94vh}
  .bk-aside{display:none}
  .bk-slots{grid-template-columns:repeat(2,1fr)}
}
