    :root {
      --bg:         oklch(96.2% 0.018 86);
      --surface:    oklch(99.4% 0.006 86);
      --fg:         oklch(22% 0.055 74);
      --muted:      oklch(38% 0.045 76);
      --border:     oklch(78% 0.026 82);
      --green:      oklch(43% 0.105 78);
      --green-d:    oklch(28% 0.08 74);
      --green-soft: oklch(88% 0.05 84);
      --green-hero: oklch(35% 0.09 76);
      --sun:        oklch(69% 0.135 78);
      --sun-on:     oklch(18% 0.06 70);
      --sun-soft:   oklch(91% 0.062 86);
      --sky:        oklch(55% 0.07 84);
      --lilac:      oklch(57% 0.06 78);
      --red:        oklch(55% 0.18 28);
      --red-soft:   oklch(92% 0.04 28);
      --white:      oklch(100% 0 0);
      --font: 'Manrope', system-ui, sans-serif;
      --font-soft: 'Nunito', 'Manrope', system-ui, sans-serif;
      --r-sm: 10px; --r-md: 16px; --r-lg: 24px; --r-xl: 32px; --pill: 9999px;
      --wrap: 1080px; --gap: 32px;
      --sh:    0 12px 36px color-mix(in oklch, var(--fg) 12%, transparent);
      --sh-lg: 0 24px 80px color-mix(in oklch, var(--fg) 18%, transparent);
    }

    *, *::before, *::after { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
    html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
    body { margin: 0; background: var(--bg); color: var(--fg); font-family: var(--font); font-size: 16px; line-height: 1.55; -webkit-font-smoothing: antialiased; overflow-x: clip; cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' fill='none'%3E%3Ccircle cx='18' cy='18' r='16' stroke='%23354a2e' stroke-width='2.5'/%3E%3Cpath d='M18 11v14M11 18h14' stroke='%23354a2e' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E") 18 18, auto; }
    a, button, input, textarea, select, label, summary, .scroll-card, .cs-trigger, .cs-opt, [onclick] { cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' fill='none'%3E%3Ccircle cx='18' cy='18' r='16' fill='%23354a2e'/%3E%3Cpath d='M18 11v14M11 18h14' stroke='white' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E") 18 18, pointer !important; }
    @media (min-width: 1920px) { html { zoom: 1.25; } }
    img, svg { display: block; max-width: 100%; }
    a { color: inherit; text-decoration: none; -webkit-tap-highlight-color: transparent; }
    button { font: inherit; cursor: pointer; border: none; background: none; -webkit-tap-highlight-color: transparent; }
    input, textarea, select, summary, details { -webkit-tap-highlight-color: transparent; }
    .burger:focus-visible, .drawer-x:focus-visible, .drawer-cta:focus-visible, .modal-x:focus-visible, .mbtn:focus-visible, .h-cta:focus-visible, .h-tel:focus-visible, .cl-cta:focus-visible { outline: 3px solid color-mix(in oklch, var(--green) 44%, transparent); outline-offset: 4px; }
    p, h1, h2, h3 { margin: 0; text-wrap: pretty; }
    h1, h2, h3 { text-wrap: balance; }
    .wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gap); }

    /* ═══ ANIMATIONS */
    @keyframes fadeUp { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
    .anim { opacity: 0; transform: translateY(28px); transition: opacity .6s cubic-bezier(.22,.68,0,1), transform .6s cubic-bezier(.22,.68,0,1); }
    .anim.is-visible { opacity: 1; transform: translateY(0); }

    /* ═══ TOPBAR */
    .topbar { position: fixed; top: 0; left: 0; right: 0; z-index: 60; padding: 22px var(--gap); display: flex; align-items: center; justify-content: space-between; background: transparent; }
    .topbar-logo { display: grid; place-items: center; width: 75px; height: 75px; padding: 10px; background: var(--green); border: 2px solid var(--fg); border-radius: 18px; box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .topbar-logo img { display: block; width: 100%; height: 100%; object-fit: contain; filter: brightness(0) invert(1); }
    .burger { width: 75px; height: 75px; border-radius: 18px; background: var(--green); border: 2px solid var(--fg); display: grid; place-items: center; transition: transform 0.16s, box-shadow 0.16s, background 0.16s; box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .burger:hover { background: var(--green-d); transform: translate(-2px, -2px); box-shadow: 8px 8px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .burger:active { transform: translate(3px, 3px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .burger svg { width: 33px; height: 24px; }
    .burger svg line { stroke: var(--white); stroke-width: 2.4; stroke-linecap: round; }

    /* ═══ DRAWER */
    .drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 360px; background: var(--surface); z-index: 110; transform: translateX(110%); transition: transform 0.38s cubic-bezier(.22,.68,0,1.2); padding: 28px 36px 36px; display: flex; flex-direction: column; border-left: 2px solid var(--fg); box-shadow: -8px 0 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .drawer.open { transform: translateX(0); }
    @media (max-width: 580px) { .drawer { width: 100%; } }
    .drawer-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 44px; }
    .drawer-logo { font-family: var(--font-soft); font-size: 18px; font-weight: 800; color: var(--green-d); letter-spacing: -0.01em; }
    .drawer-x { width: 42px; height: 42px; border-radius: 14px; background: var(--surface); border: 2px solid var(--fg); box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); display: grid; place-items: center; font-size: 20px; font-weight: 900; color: var(--fg); transition: transform 0.16s, box-shadow 0.16s, background 0.16s; }
    .drawer-x:hover { background: var(--bg); transform: translate(-2px, -2px); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .drawer-nav { flex: 1; display: flex; flex-direction: column; gap: 2px; }
    .drawer-nav a { font-size: 24px; font-weight: 800; letter-spacing: -0.015em; padding: 13px 0; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; color: var(--fg); transition: color 0.15s; }
    .drawer-nav a .arr { font-size: 20px; color: var(--green); transition: transform 0.2s; }
    .drawer-nav a:hover { color: var(--green); }
    .drawer-nav a:hover .arr { transform: translateX(4px); }
    .drawer-bottom { margin-top: 36px; display: flex; flex-direction: column; gap: 12px; }
    .drawer-cta { padding: 15px 18px; border-radius: 16px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 17px; font-weight: 900; text-align: center; transition: transform 0.16s, box-shadow 0.16s, background 0.16s; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .drawer-cta:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .drawer-foot-row { display: flex; flex-direction: column; align-items: center; gap: 12px; }
    .drawer-tel { font-size: 16px; font-weight: 800; color: var(--green); }
    .drawer-tel:hover { color: var(--green-d); }
    .drawer-ig { color: var(--green); transition: color .15s; }
    .drawer-ig:hover { color: var(--green-d); }
    .drawer-ig svg { display: inline-block; }
    .scrim { position: fixed; inset: 0; z-index: 109; background: color-mix(in oklch, var(--fg) 44%, transparent); backdrop-filter: blur(3px); opacity: 0; pointer-events: none; transition: opacity 0.3s; }
    .scrim.open { opacity: 1; pointer-events: all; }

    /* ═══ MODAL */
    .modal { position: fixed; inset: 0; z-index: 200; display: none; align-items: center; justify-content: center; padding: 20px; }
    .modal.open { display: flex; }
    .modal-bg { position: absolute; inset: 0; background: color-mix(in oklch, var(--fg) 50%, transparent); backdrop-filter: blur(8px); }
    .modal-box { position: relative; z-index: 1; background: var(--surface); border: 2px solid var(--fg); border-radius: 20px; padding: 40px 36px; width: 100%; max-width: 480px; max-height: 92vh; overflow-y: auto; box-shadow: 8px 8px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .modal-head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 28px; gap: 12px; }
    .modal-h { font-size: 28px; font-weight: 900; letter-spacing: -0.025em; line-height: 1.1; }
    .modal-sub { font-size: 14px; color: var(--muted); margin-top: 6px; font-weight: 700; }
    .modal-x { width: 42px; height: 42px; flex-shrink: 0; border-radius: 14px; background: var(--surface); border: 2px solid var(--fg); box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); display: grid; place-items: center; font-size: 18px; font-weight: 900; color: var(--fg); transition: transform 0.16s, box-shadow 0.16s, background 0.16s; }
    .modal-x:hover { background: var(--bg); transform: translate(-2px, -2px); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .mform { display: flex; flex-direction: column; gap: 14px; }
    .mrow  { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
    .mf    { display: flex; flex-direction: column; gap: 5px; }
    .mf label { font-size: 12px; font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase; color: var(--muted); }
    .mi, .mt, .ms { width: 100%; padding: 13px 16px; border: 2px solid var(--fg); border-radius: 16px; background: var(--surface); color: var(--fg); font: inherit; font-size: 16px; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); transition: border-color 0.15s, background 0.15s, box-shadow 0.15s, transform 0.15s; }
    .mi:focus, .mt:focus, .ms:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 4px color-mix(in oklch, var(--green) 14%, transparent); }
    .mt { min-height: 72px; resize: vertical; line-height: 1.5; }
    /* Custom select */
    .cs { position: relative; }
    .cs-trigger { width: 100%; padding: 13px 16px; border: 2px solid var(--fg); border-radius: 16px; background: var(--surface); color: var(--fg); font: inherit; font-size: 16px; font-weight: 750; text-align: left; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); transition: border-color .15s, box-shadow .15s; display: flex; align-items: center; justify-content: space-between; gap: 8px; cursor: pointer; }
    .cs-trigger:hover { border-color: var(--green); }
    .cs.open .cs-trigger { border-color: var(--green); box-shadow: 0 0 0 4px color-mix(in oklch, var(--green) 14%, transparent); }
    .cs-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .cs-label.placeholder { color: var(--muted); font-weight: 650; }
    .cs-chevron { flex-shrink: 0; color: var(--green-d); transition: transform .25s; }
    .cs.open .cs-chevron { transform: rotate(180deg); }
    .cs-menu { position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 10; background: var(--surface); border: 2px solid var(--fg); border-radius: 16px; box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); padding: 6px; display: none; }
    .cs.open .cs-menu { display: block; }
    .cs-opt { width: 100%; padding: 12px 14px; border: none; border-radius: 12px; background: transparent; color: var(--fg); font: inherit; font-size: 15px; font-weight: 750; text-align: left; cursor: pointer; transition: background .12s, color .12s; }
    .cs-opt:hover { background: var(--green-soft); color: var(--green-d); }
    .cs-opt.selected { background: var(--green); color: var(--white); }
    .mbtn { padding: 15px 18px; border-radius: 16px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 17px; font-weight: 900; transition: transform 0.16s, box-shadow 0.16s, background 0.16s; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); display: inline-flex; align-items: center; justify-content: center; }
    .mbtn:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .mbtn:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .mbtn svg { display: inline-block; }
    .req { color: var(--red); font-weight: 900; }
    .mf-hint { display: none; font-size: 12px; font-weight: 800; color: var(--green-d); margin-top: 6px; padding: 8px 12px; background: var(--green-soft); border-radius: 10px; border: 1.5px solid var(--green); }
    .mf-hint.show { display: block; }
    .mf-err { display: none; font-size: 12px; font-weight: 800; color: var(--red); margin-top: 4px; }
    .mf-err.show { display: block; }
    .mi.is-invalid, .mt.is-invalid { border-color: var(--red); box-shadow: 0 0 0 3px color-mix(in oklch, var(--red) 16%, transparent); }
    .cs.is-invalid .cs-trigger { border-color: var(--red); box-shadow: 0 0 0 3px color-mix(in oklch, var(--red) 16%, transparent); }
    .m-status { text-align: center; font-size: 15px; font-weight: 700; padding: 12px 16px; border-radius: 14px; display: none; }
    .m-status.is-ok { display: block; background: var(--green-soft); color: var(--green-d); border: 2px solid var(--green); }
    .m-status.is-err { display: block; background: var(--red-soft); color: var(--red); border: 2px solid var(--red); }
    /* Thank-you screen */
    .ty { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 20px 0; gap: 16px; }
    .ty-icon { width: 80px; height: 80px; border-radius: 50%; background: var(--green-soft); color: var(--green-d); border: 2px solid var(--fg); box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 82%, transparent); display: grid; place-items: center; }
    .ty-h { font-family: var(--font-soft); font-size: clamp(24px, 4vw, 32px); font-weight: 800; letter-spacing: -0.025em; }
    .ty-p { color: var(--muted); font-size: 15px; font-weight: 700; line-height: 1.6; max-width: 340px; }
    .ty-tel { font-size: 18px; font-weight: 900; color: var(--green-d); padding: 12px 24px; border: 2px solid var(--fg); border-radius: 16px; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 82%, transparent); transition: transform .16s, box-shadow .16s; }
    .ty-tel:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .ty-close { margin-top: 8px; padding: 14px 28px; border-radius: 16px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 16px; font-weight: 900; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); transition: transform .16s, box-shadow .16s, background .16s; }
    .ty-close:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    @media (max-width: 480px) { .modal-box { padding: 28px 20px; border-radius: var(--r-lg); } .mrow { grid-template-columns: 1fr; } }

    /* ═══ HERO */
    .hero { background: linear-gradient(180deg, color-mix(in oklch, var(--green-soft) 64%, white) 0%, var(--bg) 100%); padding-top: calc(78px + clamp(48px, 8vw, 88px)); padding-bottom: clamp(56px, 9vw, 104px); text-align: left; position: relative; overflow: hidden; }
    .hero::before, .hero::after { display: none; }
    .hero-in { position: relative; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.72fr); gap: clamp(32px, 6vw, 72px); align-items: center; }
    .hero-copy { max-width: 650px; }
    .hero-badge { position: relative; display: inline-flex; align-items: center; color: var(--fg); border: 2px solid var(--fg); border-radius: 16px; padding: 10px 16px; background: var(--sun-soft); box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); font-family: var(--font-soft); font-size: clamp(14px, 1.6vw, 18px); font-weight: 800; letter-spacing: -0.01em; margin-bottom: 24px; transform: rotate(-1deg); text-transform: none; }
    .hero-badge::before { display: none; }
    .hero-badge span { position: relative; z-index: 1; padding: 0; border-radius: 0; background: transparent; box-shadow: none; white-space: nowrap; }
    .hero-h1 { font-family: var(--font-soft); font-size: clamp(40px, 6.5vw, 78px); font-weight: 800; line-height: 0.98; letter-spacing: -0.035em; color: var(--fg); margin-bottom: 20px; max-width: 14ch; }
    .hero-h1 .accent { color: var(--green-d); }
    .hero-p { font-size: clamp(16px, 1.5vw, 19px); color: var(--muted); line-height: 1.68; max-width: 50ch; margin: 0 0 28px; font-weight: 700; }
    .hero-cta-cluster { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; }
    .hero-btns { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-start; }
    .h-cta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 26px; border-radius: 16px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 16px; font-weight: 900; transition: transform 0.16s, box-shadow 0.16s, background 0.16s; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .h-cta:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .h-cta:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .h-tel { display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 16px 22px; border-radius: 16px; background: var(--surface); color: var(--fg); border: 2px solid var(--fg); font-size: 16px; font-weight: 900; transition: transform 0.16s, box-shadow 0.16s, background 0.16s; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .h-tel:hover { background: var(--bg); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .h-tel:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }

    .hero-card { background: var(--surface); border: 2px solid var(--fg); border-radius: 18px; padding: clamp(22px, 3vw, 30px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); transform: rotate(1deg); }
    .hero-card-top { display: flex; justify-content: space-between; gap: 18px; padding-bottom: 20px; border-bottom: 2px solid var(--fg); margin-bottom: 18px; }
    .hc-kicker { font-family: var(--font-soft); font-size: 16px; font-weight: 800; color: var(--green); margin-bottom: 5px; }
    .hc-name { font-family: var(--font-soft); font-size: 26px; font-weight: 900; letter-spacing: -0.02em; line-height: 1.05; }
    .hc-license { align-self: flex-start; border-radius: var(--pill); background: var(--sun); color: var(--sun-on); padding: 7px 10px; font-size: 12px; font-weight: 900; white-space: nowrap; border: 2px solid var(--fg); box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); transform: rotate(7deg); }
    .hero-facts { display: grid; gap: 12px; }
    .hero-fact { display: grid; grid-template-columns: 34px 1fr; gap: 12px; align-items: start; }
    .hero-fact .mark { width: 34px; height: 34px; border-radius: 12px; background: var(--green-soft); color: var(--green-d); display: grid; place-items: center; font-weight: 900; border: 2px solid var(--fg); box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); }
    .hero-fact .mark-2 { background: var(--surface); }
    .hero-fact .mark-3 { background: var(--sun-soft); }
    .hero-fact strong { display: block; font-size: 15px; line-height: 1.25; margin-bottom: 2px; }
    .hero-fact span { display: block; color: var(--muted); font-size: 13px; font-weight: 700; line-height: 1.45; }
    @media (max-width: 860px) { .hero-in { grid-template-columns: 1fr; } .hero-card { max-width: 560px; width: 100%; } }

    /* ═══ TRUST (under hero) */
    .trust { padding: clamp(20px, 3vw, 32px) 0; background: var(--green-d); border-top: 2px solid var(--fg); border-bottom: 2px solid var(--fg); }
    .trust-strip { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
    .trust-tag { display: inline-flex; align-items: center; gap: 8px; background: color-mix(in oklch, var(--white) 12%, transparent); color: var(--white); border: 1.5px solid color-mix(in oklch, var(--white) 28%, transparent); border-radius: var(--pill); padding: 9px 18px; font-size: 14px; font-weight: 800; letter-spacing: -0.01em; backdrop-filter: blur(4px); transition: background .2s; }
    .trust-tag:hover { background: color-mix(in oklch, var(--white) 20%, transparent); }

    /* ═══ MARQUEE */
    @keyframes marquee-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
    .marquee-wrap { background: var(--green-d); border-top: 2px solid var(--fg); border-bottom: 2px solid var(--fg); padding: 14px 0; transform: rotate(-1.2deg) scale(1.06); position: relative; z-index: 2; overflow: hidden; }
    .marquee-track { display: flex; width: max-content; animation: marquee-scroll 24s linear infinite; }
    .marquee-track:hover { animation-play-state: paused; }
    .marquee-item { color: var(--white); font-family: var(--font-soft); font-size: clamp(15px, 2vw, 20px); font-weight: 900; letter-spacing: 0.06em; white-space: nowrap; padding: 0 16px; }
    .marquee-dot { color: var(--sun); font-size: clamp(18px, 2.2vw, 24px); line-height: 1; padding: 0 8px; }

    /* ═══ DOCTOR INTRO */
    .how { padding-block: clamp(56px, 8vw, 96px); }
    .sec-cap { font-size: 12px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green); margin-bottom: 10px; }
    .sec-h { font-family: var(--font-soft); font-size: clamp(26px, 3.5vw, 42px); font-weight: 800; letter-spacing: -0.025em; line-height: 1.05; margin-bottom: 44px; }
    .doctor-intro { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr); gap: clamp(24px, 5vw, 56px); align-items: stretch; }
    .doctor-panel { background: var(--surface); border: 2px solid var(--fg); border-radius: 24px; padding: clamp(22px, 3vw, 34px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .doc-bio-card { background: var(--surface); border: 2px solid var(--fg); border-radius: 18px; padding: clamp(22px, 3vw, 30px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); transform: rotate(-.8deg); }
    .doc-bio-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; padding-bottom: 18px; border-bottom: 2px solid var(--fg); margin-bottom: 18px; }
    .doc-bio-kicker { font-family: var(--font-soft); font-size: 16px; font-weight: 800; color: var(--green); }
    .doc-bio-badge { flex-shrink: 0; border: 2px solid var(--fg); border-radius: var(--pill); background: var(--sun); color: var(--sun-on); padding: 7px 12px; font-size: 12px; font-weight: 900; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); transform: rotate(5deg); white-space: nowrap; }
    .doc-bio-facts { display: grid; gap: 14px; }
    .doc-bio-fact { display: grid; grid-template-columns: 52px 1fr; gap: 14px; align-items: start; }
    .doc-bio-mark { width: 52px; height: 52px; min-width: 52px; min-height: 52px; border-radius: 14px; background: var(--green-soft); color: var(--green-d); border: 2px solid var(--fg); box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); position: relative; }
    .doc-bio-mark svg { width: 26px; height: 26px; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
    .doc-bio-mark.mark-2 { background: var(--surface); }
    .doc-bio-mark.mark-3 { background: var(--sun-soft); }
    .doc-bio-mark svg { display: block; }
    .doc-bio-fact strong { display: block; font-size: 15px; font-weight: 800; line-height: 1.25; margin-bottom: 3px; }
    .doc-bio-fact span { display: block; color: var(--muted); font-size: 13px; font-weight: 700; line-height: 1.5; }
    @media (max-width: 780px) { .doctor-intro { grid-template-columns: 1fr; } }

    /* ═══ PRICE */
    .price { padding-block: clamp(60px, 8vw, 104px); background: color-mix(in oklch, var(--surface) 62%, var(--bg)); border-top: 2px solid var(--border); position: relative; overflow: hidden; }
    .price-head { text-align: center; max-width: 680px; margin: 0 auto 42px; }
    .price-tag { display: inline-block; font-family: var(--font-soft); color: var(--green); font-size: 20px; font-weight: 800; transform: rotate(-1.5deg); margin-bottom: 10px; }
    .price-head .sec-h { margin-bottom: 14px; }
    .price-note { max-width: 540px; margin: 0 auto; color: var(--muted); font-size: 15px; font-weight: 750; line-height: 1.65; }
    .price-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: stretch; }
    .price-row { position: relative; display: flex; flex-direction: column; padding: 24px; border: 2px solid var(--fg); border-radius: 18px; background: var(--surface); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); transition: transform .18s ease, box-shadow .18s ease; }
    .price-row:nth-child(1) { transform: rotate(-1deg); }
    .price-row:nth-child(2) { transform: rotate(1deg); }
    .price-row:nth-child(3) { transform: rotate(-1.6deg); }
    .price-row:hover { transform: translate(-3px, -3px) rotate(0deg); box-shadow: 10px 10px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .price-row.featured { background: var(--sun-soft); }
    .price-row.featured::after { content: 'найчастіше'; position: absolute; top: -14px; right: -10px; padding: 6px 12px; border: 2px solid var(--fg); border-radius: var(--pill); background: var(--sun); color: var(--sun-on); font-size: 12px; font-weight: 900; transform: rotate(7deg); }
    .price-ico { width: 52px; height: 52px; border-radius: var(--pill); display: grid; place-items: center; background: var(--green-soft); color: var(--green-d); border: 2px solid var(--fg); margin-bottom: 18px; }
    .price-ico svg { width: 25px; height: 25px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
    .price-name { font-family: var(--font-soft); font-size: clamp(22px, 2.4vw, 28px); font-weight: 800; letter-spacing: -0.025em; line-height: 1.05; margin-bottom: 8px; }
    .price-meta { color: var(--muted); font-size: 14px; font-weight: 750; line-height: 1.55; min-height: 66px; }
    .price-value { margin: 22px 0 20px; font-family: var(--font-soft); font-size: clamp(36px, 4.5vw, 54px); font-weight: 800; letter-spacing: -0.045em; color: var(--fg); white-space: nowrap; }
    .price-features { display: grid; gap: 10px; margin: 0 0 22px; padding: 0; list-style: none; }
    .price-features li { display: grid; grid-template-columns: 22px 1fr; gap: 10px; align-items: start; color: var(--fg); font-size: 14px; font-weight: 800; line-height: 1.4; }
    .price-features li::before { content: ''; width: 18px; height: 18px; border: 2px solid var(--fg); border-radius: var(--pill); background: var(--surface); box-shadow: inset 0 0 0 5px var(--green-soft); margin-top: 1px; }
    .price-row .cl-cta { margin-top: auto; width: 100%; padding: 13px 18px; font-size: 15px; }
    .price-row:not(.featured) .cl-cta { background: var(--surface); color: var(--fg); }
    .price-foot { margin-top: 30px; text-align: center; color: var(--muted); font-size: 13px; font-weight: 750; }
    @media (max-width: 760px) { .price-list { grid-template-columns: 1fr; gap: 18px; } .price-row, .price-row:nth-child(1), .price-row:nth-child(2), .price-row:nth-child(3) { transform: none; } .price-meta { min-height: 0; } }

    /* ═══ ALSO */
    .also { padding-block: clamp(32px, 4vw, 48px); border-top: 2px solid var(--fg); }
    .also-label { font-size: 12px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
    .also-row { display: flex; flex-wrap: wrap; gap: 10px; }
    .also-item { background: var(--surface); border: 2px solid var(--fg); border-radius: 16px; padding: 11px 18px; font-size: 15px; font-weight: 900; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 82%, transparent); }

    /* ═══ DOCTORS */
    .doctors { padding-block: clamp(56px, 8vw, 96px); background: var(--surface); border-top: 2px solid var(--fg); }
    .doctors-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 44px; }
    .doc-card { background: var(--surface); border-radius: 18px; overflow: hidden; border: 2px solid var(--fg); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); transition: transform .18s ease, box-shadow .18s ease; }
    .doc-card:nth-child(1) { transform: rotate(-.9deg); }
    .doc-card:nth-child(2) { transform: rotate(1deg); }
    .doc-card:hover { transform: translate(-3px, -3px) rotate(0deg); box-shadow: 10px 10px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .doc-photo { width: 100%; aspect-ratio: 3/4; background: color-mix(in oklch, var(--sun-soft) 62%, var(--surface)); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; position: relative; overflow: hidden; }
    .doc-badge { position: absolute; top: 14px; right: 14px; background: var(--sun); color: var(--sun-on); font-size: 12px; font-weight: 900; border: 2px solid var(--fg); border-radius: var(--pill); padding: 5px 12px; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); transform: rotate(7deg); }
    .doc-body { padding: 22px 22px 26px; }
    .doc-name { font-size: 19px; font-weight: 800; letter-spacing: -0.015em; line-height: 1.15; margin-bottom: 5px; }
    .doc-role { font-size: 13px; font-weight: 900; color: var(--green-d); margin-bottom: 12px; }
    .doc-bio  { font-size: 14px; color: var(--muted); line-height: 1.6; font-weight: 700; margin-bottom: 16px; }
    .doc-cta { display: inline-flex; align-items: center; justify-content: center; padding: 12px 22px; border-radius: 14px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 14px; font-weight: 900; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); transition: transform .16s, box-shadow .16s, background .16s; }
    .doc-cta:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .doc-cta:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    @media (max-width: 680px) { .doctors-grid { grid-template-columns: 1fr; } .doc-cta { width: 100%; text-align: center; } }

    /* ═══ GALLERY (infinite scroll) */
    @keyframes scroll-left { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
    @keyframes scroll-right { 0% { transform: translateX(-50%); } 100% { transform: translateX(0); } }
    .gallery { padding-block: clamp(56px, 8vw, 96px); background: var(--bg); border-top: 2px solid var(--fg); overflow: hidden; }
    .gallery .sec-cap { margin-bottom: 8px; }
    .gallery .sec-h { margin-bottom: 20px; }
    .gallery-sub { margin-top: clamp(36px, 5vw, 56px); }
    .scroll-strip { -webkit-mask: linear-gradient(90deg, transparent 0%, black 6%, black 94%, transparent 100%); mask: linear-gradient(90deg, transparent 0%, black 6%, black 94%, transparent 100%); overflow: hidden; padding-block: 8px; }
    .scroll-track { display: flex; gap: 16px; width: max-content; }
    .scroll-reviews { animation: scroll-left 28s linear infinite; }
    .scroll-certs { animation: scroll-right 32s linear infinite; }
    .scroll-track:hover { animation-play-state: paused; }
    .scroll-card { flex-shrink: 0; display: block; border: 2px solid var(--fg); border-radius: 16px; overflow: hidden; box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); transition: transform .2s ease, box-shadow .2s ease, filter .2s ease; cursor: pointer; }
    .scroll-card:hover { transform: scale(1.04); box-shadow: 8px 8px 0 color-mix(in oklch, var(--fg) 88%, transparent); filter: brightness(1.06); }
    .scroll-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .review-card-s { width: clamp(200px, 28vw, 280px); aspect-ratio: 3/4; }
    .cert-card-s { width: clamp(160px, 22vw, 220px); aspect-ratio: auto; background: var(--surface); }
    .cert-card-s img { object-fit: contain; padding: 8px; }

    /* ═══ LIGHTBOX */
    .lightbox { position: fixed; inset: 0; z-index: 300; background: color-mix(in oklch, var(--fg) 88%, transparent); backdrop-filter: blur(12px); display: none; align-items: center; justify-content: center; padding: 20px; }
    .lightbox.open { display: flex; }
    .lightbox-img { max-width: 90vw; max-height: 88vh; border-radius: 16px; box-shadow: 0 24px 80px rgba(0,0,0,.5); object-fit: contain; }
    .lightbox-close { position: absolute; top: 20px; right: 20px; width: 52px; height: 52px; border-radius: 16px; background: var(--surface); border: 2px solid var(--fg); box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); font-size: 22px; font-weight: 900; color: var(--fg); display: grid; place-items: center; transition: transform .16s, box-shadow .16s; z-index: 2; }
    .lightbox-close:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .lightbox-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 16px; background: var(--surface); border: 2px solid var(--fg); box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); font-size: 22px; font-weight: 900; color: var(--fg); display: grid; place-items: center; transition: transform .16s, box-shadow .16s; z-index: 2; }
    .lightbox-arrow:hover { transform: translateY(-50%) translate(-2px, -2px); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .lightbox-prev { left: 20px; }
    .lightbox-next { right: 20px; }

    /* ═══ FAQ */
    .faq { padding-block: clamp(56px, 8vw, 96px); background: color-mix(in oklch, var(--surface) 58%, var(--bg)); border-top: 2px solid var(--fg); }
    .faq .sec-cap { margin-bottom: 8px; }
    .faq .sec-h { margin-bottom: 28px; }
    .faq-list { display: grid; gap: 12px; max-width: 720px; margin-inline: auto; }
    .faq-item { border: 2px solid var(--fg); border-radius: 14px; background: var(--surface); box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); overflow: hidden; transition: box-shadow .18s; }
    .faq-item:hover { box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .faq-item[open] { box-shadow: 5px 5px 0 color-mix(in oklch, var(--green) 44%, transparent); border-color: var(--green); }
    .faq-item summary { padding: 14px 18px; font-size: 15px; font-weight: 800; cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 12px; transition: color .15s; -webkit-user-select: none; user-select: none; }
    .faq-item summary::-webkit-details-marker { display: none; }
    .faq-item summary::marker { display: none; content: ''; }
    .faq-item summary::after { content: '+'; font-size: 18px; font-weight: 900; color: var(--green); flex-shrink: 0; width: 28px; height: 28px; border-radius: 8px; background: var(--green-soft); display: flex; align-items: center; justify-content: center; line-height: 1; transition: transform .25s, background .15s; }
    .faq-item[open] summary::after { content: '\2212'; transform: rotate(180deg); background: var(--green); color: var(--white); }
    .faq-item summary:hover { color: var(--green-d); }
    .faq-item p { padding: 0 18px 16px; color: var(--muted); font-size: 14px; font-weight: 700; line-height: 1.6; max-width: 72ch; }
    .faq-cta { margin-top: 36px; padding: 28px 30px; border: 2px solid var(--fg); border-radius: 20px; background: var(--sun-soft); box-shadow: 6px 6px 0 color-mix(in oklch, var(--fg) 88%, transparent); text-align: center; max-width: 720px; margin-inline: auto; }
    .faq-cta-text { font-family: var(--font-soft); font-size: clamp(18px, 2.4vw, 24px); font-weight: 800; letter-spacing: -0.02em; margin-bottom: 20px; }

    /* ═══ CONTACT */
    .contact { padding-top: clamp(56px, 8vw, 96px); padding-bottom: 0; background: var(--surface); border-top: 2px solid var(--fg); overflow: hidden; position: relative; }
    .contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
    .cl-doctor { display: block; max-width: 364px; margin-top: 5px; margin-left: -20px; }
    .cl-h { font-family: var(--font-soft); font-size: clamp(26px, 3.5vw, 42px); font-weight: 800; letter-spacing: -0.025em; line-height: 1.05; margin-bottom: 14px; }
    .cl-p { font-size: 16px; color: var(--muted); font-weight: 700; line-height: 1.6; margin-bottom: 28px; }
    .cl-cta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 28px; border-radius: 16px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 17px; font-weight: 900; transition: transform 0.16s, box-shadow 0.16s, background 0.16s; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cl-cta:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cl-cta:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cl-cta svg { display: inline-block; }
    .cr { display: flex; flex-direction: column; gap: 14px; }
    .cr-item { display: flex; align-items: flex-start; gap: 14px; padding: 16px; background: var(--surface); border: 2px solid var(--fg); border-radius: 18px; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 82%, transparent); }
    .cr-item:nth-child(2n) { transform: rotate(.5deg); }
    .cr-icon { width: 42px; height: 42px; flex-shrink: 0; border-radius: var(--pill); background: var(--green-soft); border: 2px solid var(--fg); display: grid; place-items: center; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); }
    .cr-icon svg { width: 20px; height: 20px; stroke: var(--green); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
    .cr-label { font-size: 11px; font-weight: 900; letter-spacing: 0.07em; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
    .cr-val   { font-size: 17px; font-weight: 800; }
    .cr-note  { font-size: 13px; color: var(--muted); font-weight: 700; margin-top: 2px; }

    /* ═══ RESPONSIVE */
    @media (max-width: 680px) {
      .contact { padding-bottom: 40px; }
      .contact-layout { grid-template-columns: 1fr; gap: 0; }
      .contact-layout .cl-cta { display: flex; margin-inline: auto; }
      .cl-doctor { max-width: 240px; margin: 10px auto -10px; display: block; }
    }
    @media (max-width: 680px) {
      .hero { padding-top: 160px; padding-bottom: 80px; background: var(--bg); }
      .hero-in { gap: 28px; }
      .hero-badge { font-size: 13px; margin-bottom: 20px; padding: 8px 12px; transform: none; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
      .hero-h1 { font-size: clamp(32px, 9vw, 42px); max-width: 14ch; margin-bottom: 18px; }
      .hero-p { font-size: 14px; line-height: 1.7; max-width: 36ch; margin-bottom: 28px; }
      .hero-btns { gap: 14px; }
      .hero-card { display: none; }
    }
    @media (max-width: 480px) {
      .hero-cta-cluster { width: 100%; }
      .hero-btns { width: 100%; }
      .hero-card-top { flex-direction: column; }
      .h-cta, .h-tel, .cl-cta, .doc-cta, .mbtn, .faq-cta .cl-cta { width: 100%; text-align: center; justify-content: center; padding: 15px 20px; font-size: 15px; border-radius: 16px; }
    }

    /* ═══ FOOTER */
    .foot { padding-block: 30px; border-top: 1px solid var(--border); background: var(--bg); }
    .foot-i { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: 12px; color: var(--muted); font-weight: 700; }
    .foot-links { display: flex; gap: 20px; align-items: center; }
    .foot-links a:hover { color: var(--fg); }
    .foot-links svg { display: inline-block; }
    @media (max-width: 600px) { :root { --gap: 18px; } .burger { width: 66px; height: 66px; } .burger svg { width: 30px; height: 22px; } .topbar-logo { width: 66px; height: 66px; padding: 8px; } }

    /* ═══ CALLBACK WIDGET */
    .cb-widget { position: fixed; bottom: 28px; right: 28px; z-index: 90; }
    @keyframes cb-pulse { 0%,100% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--green) 40%, transparent), 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); } 50% { box-shadow: 0 0 0 12px color-mix(in oklch, var(--green) 0%, transparent), 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); } }
    .cb-top { width: 44px; height: 44px; border-radius: 14px; background: var(--surface); color: var(--fg); border: 2px solid var(--fg); box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); display: grid; place-items: center; margin: 0 auto 10px; opacity: 0; pointer-events: none; transition: opacity .3s, transform .16s, box-shadow .16s; }
    .cb-top.show { opacity: 1; pointer-events: all; }
    .cb-top:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cb-top svg { display: block; }
    .cb-fab { width: 62px; height: 62px; border-radius: 18px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); display: grid; place-items: center; transition: transform .16s, box-shadow .16s, background .16s; animation: cb-pulse 2.5s ease-in-out infinite; }
    .cb-fab:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 8px 8px 0 color-mix(in oklch, var(--fg) 88%, transparent); animation: none; }
    .cb-fab:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cb-fab.active { background: var(--fg); animation: none; transform: rotate(135deg); }
    .cb-fab svg { display: block; flex-shrink: 0; width: 26px; height: 26px; }
    .cb-popup { position: absolute; bottom: 74px; right: 0; width: 300px; background: var(--surface); border: 2px solid var(--fg); border-radius: 20px; padding: 22px; box-shadow: 8px 8px 0 color-mix(in oklch, var(--fg) 88%, transparent); display: none; transform-origin: bottom right; }
    .cb-popup.open { display: block; animation: fadeUp .25s ease; }
    .cb-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
    .cb-title { font-family: var(--font-soft); font-size: 18px; font-weight: 800; }
    .cb-x { width: 32px; height: 32px; border-radius: 10px; background: var(--surface); border: 2px solid var(--fg); box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); display: grid; place-items: center; font-size: 14px; font-weight: 900; color: var(--fg); transition: transform .16s, box-shadow .16s; }
    .cb-x:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cb-desc { font-size: 13px; color: var(--muted); font-weight: 700; line-height: 1.5; margin-bottom: 14px; }
    .cb-form { display: flex; flex-direction: column; gap: 10px; position: relative; }
    .cb-input { width: 100%; padding: 13px 16px; border: 2px solid var(--fg); border-radius: 14px; background: var(--surface); color: var(--fg); font: inherit; font-size: 16px; box-shadow: 3px 3px 0 color-mix(in oklch, var(--fg) 82%, transparent); transition: border-color .15s, box-shadow .15s; }
    .cb-input:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 4px color-mix(in oklch, var(--green) 14%, transparent); }
    .cb-btn { padding: 13px 18px; border-radius: 14px; background: var(--green-d); color: var(--white); border: 2px solid var(--fg); font-size: 15px; font-weight: 900; box-shadow: 4px 4px 0 color-mix(in oklch, var(--fg) 88%, transparent); transition: transform .16s, box-shadow .16s, background .16s; }
    .cb-btn:hover { background: var(--green); transform: translate(-3px, -3px); box-shadow: 7px 7px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cb-btn:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 color-mix(in oklch, var(--fg) 88%, transparent); }
    .cb-status { text-align: center; font-size: 14px; font-weight: 800; padding: 10px; border-radius: 12px; display: none; }
    .cb-status.is-ok { display: block; background: var(--green-soft); color: var(--green-d); border: 2px solid var(--green); }
    .cb-status.is-err { display: block; background: var(--red-soft); color: var(--red); border: 2px solid var(--red); }
    @media (max-width: 480px) { .cb-widget { bottom: 18px; right: 18px; } .cb-popup { width: calc(100vw - 36px); right: 0; } .cb-fab { width: 56px; height: 56px; } }
