/* =============================================================
   AXIOM TECHNOLOGY — premium beauty-tech landing
   v2 · pin-stack panels · stronger red accent · refined spacing
   ============================================================= */

/* ===== Tokens ===== */
:root {
    --ink:        #0F0F10;
    --ink-soft:   #1F1F22;
    --ink-mid:    #2C2C30;
    --steel:      #6E6E72;
    --mute:       #9C9CA1;
    --hair:       rgba(15, 15, 16, 0.08);
    --hair-2:     rgba(15, 15, 16, 0.04);
    --paper:      #F7F6F3;
    --paper-2:    #FBFAF7;
    --paper-3:    #EFEDE6;
    --white:      #FFFFFF;

    --red:        #C8102E;
    --red-deep:   #9B0E25;
    --red-light:  #E63946;
    --red-glow:   rgba(200, 16, 46, 0.20);
    --red-glow-strong: rgba(200, 16, 46, 0.32);
    --red-wash:   rgba(200, 16, 46, 0.06);
    --red-wash-2: rgba(200, 16, 46, 0.10);

    --shadow-sm:  0 1px 2px rgba(15,15,16,0.04), 0 4px 14px rgba(15,15,16,0.04);
    --shadow-md:  0 18px 40px -18px rgba(15,15,16,0.18), 0 4px 14px rgba(15,15,16,0.04);
    --shadow-lg:  0 30px 80px -30px rgba(15,15,16,0.24);
    --shadow-red: 0 24px 60px -22px rgba(200, 16, 46, 0.55);

    --radius-xs: 6px;
    --radius-sm: 10px;
    --radius-md: 18px;
    --radius-lg: 26px;
    --radius-xl: 36px;
    --radius-2xl: 44px;

    --ease:       cubic-bezier(0.32, 0.72, 0, 1);
    --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
    --ease-in:    cubic-bezier(0.7, 0, 0.84, 0);

    --container:  1320px;
    --container-narrow: 1080px;

    --font-sans:    'Geist', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-mono:    'Geist Mono', ui-monospace, 'SF Mono', Menlo, monospace;
    --font-display: 'Fraunces', 'Geist', serif;

    --pad-x: clamp(22px, 4vw, 56px);
}

/* ===== Reset ===== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body {
    font-family: var(--font-sans);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.55;
    color: var(--ink);
    background: var(--paper);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    min-height: 100dvh;
}
img, svg { display: block; max-width: 100%; height: auto; }
img { -webkit-user-drag: none; user-select: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; padding: 0; }
a { color: inherit; text-decoration: none; }
ul, ol, dl, dt, dd, h1, h2, h3, h4, h5, h6, p, figure { margin: 0; padding: 0; }
ul, ol { list-style: none; }
input, select, textarea { font: inherit; color: inherit; }
::selection { background: var(--ink); color: var(--paper); }

@media (prefers-reduced-motion: reduce) {
    * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; animation-iteration-count: 1 !important; }
}

/* ===== A11y ===== */
.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.skip-link {
    position: absolute; top: -100px; left: 12px; z-index: 999;
    background: var(--ink); color: var(--paper); padding: 10px 14px; border-radius: 8px; font-size: 14px;
}
.skip-link:focus { top: 12px; }

/* ============================================================
   PRELOADER
   ============================================================ */
body.is-loading { overflow: hidden; }

.preloader {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: var(--paper);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.preloader.is-leaving {
    animation: preloaderLeave 0.85s var(--ease) forwards;
    pointer-events: none;
}
@keyframes preloaderLeave {
    0%   { clip-path: inset(0 0 0 0);     opacity: 1; }
    100% { clip-path: inset(0 0 100% 0);  opacity: 0; }
}

.preloader-grid {
    position: absolute; inset: 0;
    pointer-events: none;
    opacity: 0;
    animation: preGridIn 1s var(--ease) 0.05s forwards;
}
.preloader-grid span {
    position: absolute;
    background: var(--hair);
}
.preloader-grid span:nth-child(1) { top: 0; left: 0; height: 100%; width: 1px; transform: translateX(14vw); }
.preloader-grid span:nth-child(2) { top: 0; right: 0; height: 100%; width: 1px; transform: translateX(-14vw); }
.preloader-grid span:nth-child(3) { left: 0; top: 0; width: 100%; height: 1px; transform: translateY(18vh); }
.preloader-grid span:nth-child(4) { left: 0; bottom: 0; width: 100%; height: 1px; transform: translateY(-18vh); }
.preloader-grid span:nth-child(5) { left: 50%; top: 0; height: 100%; width: 1px; transform: translateX(-50%); opacity: 0.5; }
.preloader-grid span:nth-child(6) { left: 50%; top: 50%; width: 22px; height: 1px; transform: translate(-50%, -50%); background: var(--red); }
.preloader-grid span:nth-child(7) { left: 50%; top: 50%; height: 22px; width: 1px; transform: translate(-50%, -50%); background: var(--red); }
.preloader-grid span:nth-child(8) { display: none; }
@keyframes preGridIn { to { opacity: 1; } }

.preloader-inner {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
    z-index: 2;
}

.preloader-mark {
    position: relative;
    width: clamp(120px, 14vw, 168px);
    height: clamp(120px, 14vw, 168px);
    display: flex;
    align-items: center;
    justify-content: center;
}
.preloader-glow {
    position: absolute;
    width: 220%; height: 220%;
    background: radial-gradient(circle, var(--red-glow-strong) 0%, var(--red-glow) 30%, transparent 65%);
    filter: blur(36px);
    opacity: 0;
    transform: scale(0.6);
    animation: preGlow 2.4s var(--ease) 0.3s forwards;
}
@keyframes preGlow {
    0%   { opacity: 0; transform: scale(0.6); }
    50%  { opacity: 1; transform: scale(1.1); }
    100% { opacity: 0.85; transform: scale(1); }
}
.preloader-logo {
    position: relative;
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: 0;
    transform: scale(0.95);
    filter: blur(10px);
    animation: preLogoIn 1.6s var(--ease) 0.15s forwards;
}
@keyframes preLogoIn {
    0%   { opacity: 0; transform: scale(0.95); filter: blur(10px); }
    35%  { opacity: 0.5; filter: blur(2px); }
    100% { opacity: 1; transform: scale(1); filter: blur(0); }
}

.preloader-line {
    position: relative;
    width: clamp(220px, 26vw, 320px);
    height: 1px;
    background: var(--hair);
    overflow: visible;
    border-radius: 999px;
}
.preloader-line-fill {
    position: absolute;
    top: 0; left: 0; bottom: 0;
    width: 100%;
    background: linear-gradient(90deg, var(--red), var(--red-light));
    transform: scaleX(0);
    transform-origin: left center;
    border-radius: 999px;
    animation: preFill 1.7s var(--ease) 0.45s forwards;
}
@keyframes preFill { to { transform: scaleX(1); } }
.preloader-line-pulse {
    position: absolute;
    top: -2px;
    left: -30px;
    width: 60px; height: 5px;
    background: linear-gradient(90deg, transparent 0%, var(--red) 50%, var(--red-light) 75%, transparent 100%);
    border-radius: 999px;
    filter: blur(2px);
    opacity: 0;
    animation: prePulse 1.8s var(--ease) 0.45s forwards;
}
@keyframes prePulse {
    0%   { opacity: 0; left: -30px; }
    15%  { opacity: 1; }
    85%  { opacity: 1; }
    100% { opacity: 0; left: calc(100% + 30px); }
}

.preloader-text {
    display: flex;
    gap: 4px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--steel);
}
.preloader-text span {
    display: inline-block;
    opacity: 0;
    transform: translateY(8px);
    animation: preChar 0.6s var(--ease) forwards;
}
.preloader-text span:nth-child(1)  { animation-delay: 1.40s; }
.preloader-text span:nth-child(2)  { animation-delay: 1.46s; }
.preloader-text span:nth-child(3)  { animation-delay: 1.52s; }
.preloader-text span:nth-child(4)  { animation-delay: 1.58s; }
.preloader-text span:nth-child(5)  { animation-delay: 1.64s; }
.preloader-text span:nth-child(6)  { animation-delay: 1.70s; }
.preloader-text span:nth-child(7)  { animation-delay: 1.76s; }
.preloader-text span:nth-child(8)  { animation-delay: 1.82s; }
.preloader-text span:nth-child(9)  { animation-delay: 1.88s; }
.preloader-text span:nth-child(10) { animation-delay: 1.94s; }
.preloader-text span:nth-child(11) { animation-delay: 2.00s; }
.preloader-text span:nth-child(12) { animation-delay: 2.06s; }
.preloader-text span:nth-child(13) { animation-delay: 2.12s; }
.preloader-text span:nth-child(14) { animation-delay: 2.18s; }
.preloader-text span:nth-child(15) { animation-delay: 2.24s; }
.preloader-text span:nth-child(16) { animation-delay: 2.30s; }
.preloader-dot {
    background: var(--red);
    width: 4px; height: 4px;
    border-radius: 50%;
    align-self: center;
    margin: 0 4px;
}
@keyframes preChar { to { opacity: 1; transform: translateY(0); } }

@media (prefers-reduced-motion: reduce) {
    .preloader-grid, .preloader-glow, .preloader-logo,
    .preloader-line-fill, .preloader-line-pulse, .preloader-text span {
        animation: none !important;
        opacity: 1;
        transform: none;
        filter: none;
    }
    .preloader.is-leaving { animation: none; opacity: 0; transition: opacity 0.2s linear; }
}


/* ===== Page atmosphere ===== */
.page-grain {
    position: fixed; inset: 0; pointer-events: none; z-index: 1;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.4 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    opacity: 0.04;
    mix-blend-mode: multiply;
}

/* ===== Custom cursor — removed; using native cursor ===== */

/* ===== Icons ===== */
.ic { display: inline-block; vertical-align: -0.16em; flex: 0 0 auto; }
.ic-row { display: inline-flex; align-items: center; gap: 8px; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    --btn-bg: var(--ink);
    --btn-fg: var(--paper);
    --btn-bd: var(--ink);
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 16px 22px;
    border-radius: 999px;
    background: var(--btn-bg);
    color: var(--btn-fg);
    border: 1px solid var(--btn-bd);
    font-weight: 500;
    font-size: 15px;
    letter-spacing: -0.005em;
    line-height: 1;
    white-space: nowrap;
    transition: transform 0.45s var(--ease), background 0.4s var(--ease), color 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s;
    will-change: transform;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0) scale(0.985); }

.btn--primary { --btn-bg: var(--ink); --btn-fg: var(--paper); --btn-bd: var(--ink); }
.btn--primary:hover {
    --btn-bg: var(--red);
    --btn-bd: var(--red);
    box-shadow: var(--shadow-red);
}

.btn--red { --btn-bg: var(--red); --btn-fg: var(--paper); --btn-bd: var(--red); }
.btn--red:hover { --btn-bg: var(--red-deep); --btn-bd: var(--red-deep); box-shadow: var(--shadow-red); }

.btn--ghost {
    --btn-bg: transparent;
    --btn-fg: var(--ink);
    --btn-bd: var(--hair);
}
.btn--ghost:hover {
    --btn-bg: var(--ink);
    --btn-fg: var(--paper);
    --btn-bd: var(--ink);
}

.btn--lg { padding: 18px 26px; font-size: 16px; gap: 16px; }
.btn--xl { padding: 22px 30px; font-size: 17px; gap: 18px; }
.btn--compact { padding: 12px 18px; font-size: 14px; gap: 10px; }
.btn--full { width: 100%; justify-content: center; }

.btn-arrow {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 26px; height: 26px;
    border-radius: 999px;
    background: rgba(255,255,255,0.14);
    transition: transform 0.4s var(--ease), background 0.4s var(--ease);
}
.btn--ghost .btn-arrow { background: rgba(15,15,16,0.06); }
.btn--ghost:hover .btn-arrow { background: rgba(255,255,255,0.14); }
.btn:hover .btn-arrow { transform: translateX(3px); }

/* ============================================================
   EYEBROW + SECTION TITLES
   ============================================================ */
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--steel);
}
.eyebrow--inverse { color: rgba(247,246,243,0.7); }
.eyebrow-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--red);
    box-shadow: 0 0 0 4px var(--red-wash);
    animation: dotPulse 2.6s ease-in-out infinite;
}
@keyframes dotPulse {
    0%, 100% { box-shadow: 0 0 0 4px var(--red-wash); }
    50%      { box-shadow: 0 0 0 7px rgba(200,16,46,0.04); }
}
.eyebrow--inverse .eyebrow-dot { background: var(--red-light); box-shadow: 0 0 0 4px rgba(230,57,70,0.18); }

.section-head {
    max-width: var(--container);
    margin: 0 auto clamp(40px, 4.5vw, 60px);
    padding: 0 var(--pad-x);
    display: flex; flex-direction: column; align-items: flex-start; gap: 16px;
}
.section-head--centered { align-items: center; text-align: center; }
.section-title {
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: clamp(34px, 4.8vw, 64px);
    line-height: 1.02;
    letter-spacing: -0.032em;
    color: var(--ink);
    text-wrap: balance;
    max-width: 18ch;
}
.section-title--lg { font-size: clamp(38px, 5.6vw, 76px); max-width: 16ch; }
.section-title--inverse { color: var(--paper); }
.section-title em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    font-feature-settings: "ss01", "calt";
    color: var(--red);
}
.section-title--inverse em { color: var(--red-light); }
.section-sub {
    font-size: clamp(15px, 1.3vw, 17px);
    line-height: 1.55;
    color: var(--steel);
    max-width: 56ch;
    text-wrap: pretty;
}
.section-sub--inverse { color: rgba(247,246,243,0.65); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    padding: clamp(12px, 1.6vw, 18px) var(--pad-x);
    transition: padding 0.5s var(--ease);
}
.site-header::before {
    content: '';
    position: absolute; inset: 0;
    background: rgba(247, 246, 243, 0.78);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    border-bottom: 1px solid var(--hair-2);
    opacity: 0;
    transition: opacity 0.5s var(--ease);
    pointer-events: none;
}
.site-header.is-scrolled::before { opacity: 1; }
.site-header.is-scrolled { padding-top: 8px; padding-bottom: 8px; }

.header-inner {
    position: relative;
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: clamp(20px, 4vw, 48px);
}
.brand { display: inline-flex; align-items: center; }
.brand-logo { height: clamp(34px, 3.6vw, 46px); width: auto; transition: opacity 0.4s; }
.brand-logo--light { display: none; }

.nav-main { display: flex; gap: clamp(24px, 3vw, 38px); justify-content: center; }
.nav-link {
    font-size: 14px;
    color: var(--steel);
    transition: color 0.3s var(--ease);
    position: relative;
    padding: 4px 0;
}
.nav-link::after {
    content: '';
    position: absolute; left: 0; bottom: 0;
    width: 100%; height: 1px;
    background: var(--ink);
    transform: scaleX(0); transform-origin: right center;
    transition: transform 0.5s var(--ease);
}
.nav-link:hover { color: var(--ink); }
.nav-link:hover::after { transform: scaleX(1); transform-origin: left center; }

.header-actions { display: flex; align-items: center; gap: 12px; }
.lang-switch {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid var(--hair);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em;
    transition: background 0.3s var(--ease), color 0.3s var(--ease), transform 0.4s var(--ease);
}
.lang-switch:hover { background: var(--ink); color: var(--paper); transform: rotate(-15deg) scale(1.05); }

.nav-toggle { display: none; width: 38px; height: 38px; border-radius: 999px; border: 1px solid var(--hair); position: relative; }
.nav-toggle span { position: absolute; left: 11px; right: 11px; height: 1.4px; background: var(--ink); transition: transform 0.5s var(--ease); }
.nav-toggle span:nth-child(1) { top: 15px; }
.nav-toggle span:nth-child(2) { top: 21px; }
.nav-toggle.is-open span:nth-child(1) { top: 18px; transform: rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { top: 18px; transform: rotate(-45deg); }

.nav-mobile {
    position: fixed;
    inset: 0;
    background: rgba(247, 246, 243, 0.97);
    backdrop-filter: blur(24px);
    z-index: 95;
    opacity: 0; visibility: hidden;
    transition: opacity 0.5s var(--ease), visibility 0.5s;
    padding: 110px var(--pad-x) 40px;
}
.nav-mobile.is-open { opacity: 1; visibility: visible; }
.nav-mobile-inner { max-width: 600px; margin: 0 auto; display: flex; flex-direction: column; gap: 4px; }
.nav-mobile-link {
    display: flex; align-items: center; gap: 18px;
    padding: 18px 4px;
    font-size: clamp(28px, 6vw, 40px);
    font-weight: 500;
    letter-spacing: -0.02em;
    border-bottom: 1px solid var(--hair-2);
    transform: translateY(20px); opacity: 0;
    transition: transform 0.7s var(--ease), opacity 0.7s var(--ease);
}
.nav-mobile.is-open .nav-mobile-link { transform: translateY(0); opacity: 1; }
.nav-mobile.is-open .nav-mobile-link:nth-child(1) { transition-delay: 0.05s; }
.nav-mobile.is-open .nav-mobile-link:nth-child(2) { transition-delay: 0.10s; }
.nav-mobile.is-open .nav-mobile-link:nth-child(3) { transition-delay: 0.15s; }
.nav-mobile.is-open .nav-mobile-link:nth-child(4) { transition-delay: 0.20s; }
.nav-mobile.is-open .nav-mobile-link:nth-child(5) { transition-delay: 0.25s; }
.nav-mobile.is-open .btn { transition-delay: 0.30s; transform: translateY(0); opacity: 1; }
.nav-mobile .btn { transform: translateY(20px); opacity: 0; transition: transform 0.7s var(--ease), opacity 0.7s var(--ease); margin-top: 22px; }
.nm-num { font-family: var(--font-mono); font-size: 13px; color: var(--steel); letter-spacing: 0.06em; }


/* ============================================================
   PIN-STACK PANEL SYSTEM
   ============================================================ */
.main { padding-top: 0; }

.slides-wrapper {
    position: relative;
    z-index: 2;
}

.panel {
    position: relative;
    width: 100%;
    min-height: 100dvh;
    background: var(--paper);
    overflow: hidden;
    box-sizing: border-box;
    will-change: transform, opacity;
}

/* Each panel is a flex container vertically centering its content (when small) */
.panel-content {
    width: 100%;
    min-height: 100dvh;
    padding: clamp(120px, 14vh, 160px) 0 clamp(60px, 8vh, 100px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-sizing: border-box;
    position: relative;
}

/* Panel-specific backgrounds */
.panel--hero { background: var(--paper); }
.panel--pillars { background: var(--paper-2); }
.panel--products { background: var(--paper); }
.panel--salons { background: var(--paper-2); }
.panel--income { background: var(--ink); color: var(--paper); }
.panel--calc { background: var(--paper); }
.panel--consult { background: var(--paper-2); }
.panel--advantages { background: var(--paper); }
.panel--testimonials { background: var(--paper-2); }
.panel--faq { background: var(--paper); }

.panel-bg-glow {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    background: radial-gradient(circle, var(--red-glow), transparent 65%);
    filter: blur(20px);
}
.panel-bg-glow--tl { top: -10%; left: -10%; width: 50%; height: 60%; }
.panel-bg-glow--br { bottom: -10%; right: -10%; width: 50%; height: 60%; }

.panel > * { position: relative; z-index: 1; }


/* ============================================================
   HERO (smaller, more refined)
   ============================================================ */
.panel--hero .panel-content { padding-top: clamp(120px, 15vh, 170px); padding-bottom: clamp(28px, 4vh, 52px); }

.hero-grid {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0;
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(36px, 4.5vw, 70px);
    align-items: center;
    flex: 1;
}
.hero-content { position: relative; z-index: 2; display: flex; flex-direction: column; gap: 22px; }
.hero-title {
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: clamp(30px, 3.9vw, 52px);
    line-height: 1.04;
    letter-spacing: -0.028em;
    color: var(--ink);
    margin: 4px 0 4px;
    overflow-wrap: normal;
    word-break: keep-all;
    hyphens: none;
    -webkit-hyphens: none;
    max-width: 26ch;
}
.hero-line { display: block; padding-top: 0.04em; padding-bottom: 0.08em; padding-right: 0.08em; word-break: keep-all; overflow-wrap: normal; hyphens: none; }
.hero-line--em { position: relative; }
.hero-line em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    color: var(--red);
}
.hero-mark {
    position: absolute;
    left: 0;
    bottom: 0;
    height: 4px;
    width: 38%;
    background: linear-gradient(90deg, var(--red), var(--red-light) 60%, transparent);
    transform: scaleX(0); transform-origin: left center;
    animation: heroMark 1.4s 1.6s var(--ease) forwards;
    border-radius: 2px;
}
@keyframes heroMark { to { transform: scaleX(1); } }

.hero-sub {
    font-size: clamp(15.5px, 1.3vw, 18px);
    line-height: 1.55;
    color: var(--ink-mid);
    max-width: 50ch;
    text-wrap: pretty;
}

.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }

.hero-trust {
    display: flex; flex-wrap: wrap;
    gap: 10px 22px;
    margin-top: 8px;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.02em;
    color: var(--steel);
}
.hero-trust li { display: inline-flex; align-items: center; gap: 8px; }
.trust-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 24px; height: 24px;
    border-radius: 50%;
    border: 1px solid var(--hair);
    color: var(--ink);
    background: var(--white);
}

/* Hero visual */
.hero-visual {
    position: relative;
    aspect-ratio: 1 / 1.02;
    min-height: 420px;
    max-height: 70vh;
    display: flex; align-items: center; justify-content: center;
}
.hero-glow {
    position: absolute;
    inset: 6%;
    background: radial-gradient(circle at 50% 55%, var(--red-glow-strong) 0%, var(--red-glow) 30%, transparent 65%);
    filter: blur(38px);
    border-radius: 50%;
    animation: heroGlow 7s ease-in-out infinite;
}
@keyframes heroGlow {
    0%, 100% { transform: scale(1); opacity: 1; }
    50%      { transform: scale(1.08); opacity: 0.78; }
}
.hero-grid-lines {
    position: absolute; inset: 0;
    pointer-events: none;
}
.hero-grid-lines span { position: absolute; background: var(--hair); }
.hero-grid-lines span:nth-child(1) { left: 0; top: 18%; width: 100%; height: 1px; }
.hero-grid-lines span:nth-child(2) { left: 0; top: 82%; width: 100%; height: 1px; }
.hero-grid-lines span:nth-child(3) { top: 0; left: 14%; height: 100%; width: 1px; }
.hero-grid-lines span:nth-child(4) { top: 0; left: 86%; height: 100%; width: 1px; }

.hero-product {
    position: relative;
    width: 84%;
    aspect-ratio: 1;
    z-index: 2;
}
.hero-product-frame {
    position: relative;
    width: 100%; height: 100%;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    background: linear-gradient(140deg, #FBFAF7 0%, #EAE8E1 100%);
    box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,0.85);
}
.hero-product-frame::before {
    content: '';
    position: absolute; inset: 0;
    background:
        radial-gradient(120% 80% at 30% 10%, rgba(255,255,255,0.55), transparent 50%),
        radial-gradient(70% 50% at 80% 90%, var(--red-glow), transparent 60%);
    pointer-events: none;
}
.hero-product-img {
    width: 100%; height: 100%;
    object-fit: contain;
    object-position: center;
    padding: 8%;
    filter: drop-shadow(0 30px 40px rgba(15,15,16,0.20));
    position: relative;
    z-index: 2;
}
.hero-product-floor {
    position: absolute;
    left: 12%; right: 12%;
    bottom: 8%;
    height: 12px;
    border-radius: 50%;
    background: radial-gradient(ellipse at center, rgba(15,15,16,0.28), transparent 70%);
    filter: blur(6px);
    z-index: 1;
}

/* Floating chips */
.chip {
    position: absolute;
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: 18px;
    padding: 12px 16px;
    box-shadow: var(--shadow-md);
    display: flex; align-items: center; gap: 12px;
    backdrop-filter: blur(10px);
    z-index: 4;
    will-change: transform;
}
.chip-icon {
    flex: 0 0 auto;
    width: 30px; height: 30px;
    border-radius: 999px;
    background: var(--paper);
    color: var(--ink);
    display: inline-flex; align-items: center; justify-content: center;
}
.chip--1 .chip-icon { background: var(--red); color: var(--paper); }
.chip-body { display: flex; flex-direction: column; gap: 2px; }
.chip-v {
    font-family: var(--font-mono);
    font-size: 16px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--ink);
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
}
.chip-u { font-size: 11px; color: var(--steel); letter-spacing: 0.02em; }

.chip--1 { top: 4%;   left: -8%;  }
.chip--2 { bottom: 14%; right: -8%; }
.chip--3 { bottom: -2%;  left: 14%; }
.chip--1 .chip-v { color: var(--red); font-size: 17px; }

/* Hero marquee — лежить на нижній границі hero панелі */
.hero-marquee {
    margin-top: clamp(40px, 4vw, 60px);
    overflow: hidden;
    border-top: 1px solid var(--hair);
    border-bottom: 1px solid var(--hair);
    padding: 16px 0;
    width: 100%;
    flex-shrink: 0;
}
.marquee-track {
    display: flex; gap: 24px;
    align-items: center;
    font-family: var(--font-mono);
    font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--steel);
    white-space: nowrap;
    animation: marquee 38s linear infinite;
    will-change: transform;
}
.marquee-track > span { flex: 0 0 auto; }
.m-dot { display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: var(--red); }
@keyframes marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}


/* ============================================================
   TECH SHOWCASE — interactive tabs + image stage
   ============================================================ */
.tech-showcase {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-x);
    display: grid;
    grid-template-columns: minmax(300px, 380px) 1fr;
    gap: clamp(28px, 3.5vw, 56px);
    align-items: stretch;
}

.tech-tabs {
    display: flex; flex-direction: column;
    gap: 1px;
    background: var(--hair);
    border: 1px solid var(--hair);
    border-radius: var(--radius-xl);
    overflow: hidden;
    align-self: start;
}
.tech-tab {
    background: var(--white);
    padding: clamp(20px, 2.4vw, 26px) clamp(20px, 2.4vw, 26px);
    display: grid;
    grid-template-columns: 36px 32px 1fr 18px;
    gap: 14px;
    align-items: center;
    cursor: pointer;
    position: relative;
    transition: background 0.5s var(--ease), color 0.5s var(--ease), padding 0.5s var(--ease);
    overflow: hidden;
}
.tech-tab:hover { background: var(--paper-2); }
.tech-tab.is-active {
    background: var(--ink);
    color: var(--paper);
    padding-left: clamp(28px, 3vw, 36px);
}
.tech-tab.is-active::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--red);
}
.tech-tab-num {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--steel);
    letter-spacing: 0.06em;
    transition: color 0.4s;
}
.tech-tab.is-active .tech-tab-num { color: rgba(247,246,243,0.5); }
.tech-tab-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    border-radius: 10px;
    background: var(--red-wash);
    color: var(--red);
    transition: background 0.4s, color 0.4s;
}
.tech-tab.is-active .tech-tab-icon {
    background: var(--red);
    color: var(--paper);
}
.tech-tab-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.tech-tab-tag {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--steel);
    transition: color 0.4s;
}
.tech-tab.is-active .tech-tab-tag { color: rgba(247,246,243,0.55); }
.tech-tab-title {
    font-size: clamp(15px, 1.4vw, 17px);
    font-weight: 500;
    letter-spacing: -0.012em;
    line-height: 1.2;
    color: var(--ink);
    transition: color 0.4s;
}
.tech-tab.is-active .tech-tab-title { color: var(--paper); }
.tech-tab-arrow {
    color: var(--steel);
    opacity: 0;
    transform: translateX(-6px);
    transition: opacity 0.4s var(--ease), transform 0.4s var(--ease), color 0.4s;
}
.tech-tab.is-active .tech-tab-arrow {
    opacity: 1;
    transform: translateX(0);
    color: var(--red-light);
}
.tech-tab-progress {
    position: absolute; bottom: 0; left: 0;
    height: 1.5px;
    width: 0;
    background: var(--red);
    transition: width 0s linear;
}
.tech-tab.is-active .tech-tab-progress {
    width: 100%;
    transition: width var(--tech-rotate, 5s) linear;
}

/* Stage */
.tech-stage {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 18px;
}
.tech-stage-images {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 11;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    background: linear-gradient(160deg, #F4F2EC 0%, #E5E2D9 100%);
}
.tech-image {
    position: absolute; inset: 0;
    clip-path: inset(100% 0 0 0);
    transition: clip-path 1.05s var(--ease);
    display: flex; align-items: center; justify-content: center;
    will-change: clip-path;
}
.tech-image.is-active {
    clip-path: inset(0 0 0 0);
    z-index: 2;
}
.tech-image-bg {
    position: absolute; inset: 0;
    background: linear-gradient(160deg, #F4F2EC 0%, #E0DDD4 100%);
}
.tech-image.t-warm .tech-image-bg {
    background: linear-gradient(160deg, #F7EBE8 0%, #E5D6D0 100%);
}
.tech-image.t-spotlight .tech-image-bg {
    background: radial-gradient(circle at 50% 40%, #FAF8F4 0%, #DCD8CD 80%);
}
.tech-image-glow {
    position: absolute;
    width: 50%; height: 60%;
    top: 18%; left: 25%;
    background: radial-gradient(circle, var(--red-glow), transparent 65%);
    filter: blur(34px);
    z-index: 1;
}
.tech-image.t-warm .tech-image-glow { background: radial-gradient(circle, rgba(200,16,46,0.32), transparent 65%); }
.tech-image.t-spotlight .tech-image-glow { background: radial-gradient(circle, rgba(255,255,255,0.6), transparent 70%); filter: blur(20px); }

.tech-image img {
    width: 70%; height: 85%;
    object-fit: contain;
    position: relative;
    z-index: 2;
    filter: drop-shadow(0 30px 50px rgba(15,15,16,0.22));
}
.tech-image.t-spotlight img { filter: drop-shadow(0 35px 50px rgba(15,15,16,0.28)) brightness(1.04); }
.tech-image-floor {
    position: absolute;
    left: 22%; right: 22%; bottom: 8%;
    height: 14px;
    background: radial-gradient(ellipse at center, rgba(15,15,16,0.30), transparent 70%);
    filter: blur(7px);
    z-index: 1;
}
.tech-image-meta {
    position: absolute;
    top: clamp(18px, 2vw, 26px);
    left: clamp(18px, 2vw, 26px);
    right: clamp(18px, 2vw, 26px);
    z-index: 3;
    display: flex; justify-content: space-between; align-items: center;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink);
    pointer-events: none;
}
.tech-image-meta-label {
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(6px);
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid var(--hair);
}
.tech-image-meta-num { color: var(--steel); }

/* Card */
.tech-stage-cards {
    position: relative;
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: var(--radius-xl);
    padding: clamp(22px, 2.6vw, 32px) clamp(22px, 2.6vw, 36px);
    overflow: hidden;
}
.tech-stage-cards::before {
    content: '';
    position: absolute;
    top: -30%; right: -10%;
    width: 50%; height: 60%;
    background: radial-gradient(circle, var(--red-wash-2), transparent 70%);
    pointer-events: none;
}
.tech-card {
    position: relative;
    z-index: 1;
    display: none;
    flex-direction: column;
    gap: 14px;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
}
.tech-card.is-active {
    display: flex;
    opacity: 1;
    transform: translateY(0);
}
.tech-card-head { display: flex; flex-direction: column; gap: 6px; }
.tech-card-tag {
    align-self: start;
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--red);
    background: var(--red-wash);
    padding: 6px 10px;
    border-radius: 999px;
}
.tech-card-title {
    font-size: clamp(22px, 2.2vw, 28px);
    font-weight: 500;
    letter-spacing: -0.018em;
    line-height: 1.1;
    color: var(--ink);
}
.tech-card-subtitle {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    font-size: clamp(15px, 1.4vw, 18px);
    line-height: 1.3;
    color: var(--ink-mid);
    max-width: 38ch;
}
.tech-card-body {
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--steel);
    max-width: 52ch;
}
.tech-card-specs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--hair);
    border-top: 1px solid var(--hair);
    border-bottom: 1px solid var(--hair);
    margin-top: 6px;
}
.tech-spec {
    background: var(--white);
    padding: 12px 14px 12px 0;
    display: flex; flex-direction: column;
    gap: 4px;
}
.tech-spec dt {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--steel);
}
.tech-spec dd {
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--ink);
    font-feature-settings: "tnum";
    letter-spacing: -0.005em;
}
.tech-card-cta {
    align-self: start;
    display: inline-flex; align-items: center; gap: 12px;
    padding: 12px 18px;
    border-radius: 999px;
    border: 1px solid var(--hair);
    background: var(--paper-2);
    font-size: 14px;
    font-weight: 500;
    transition: background 0.4s, color 0.4s, border-color 0.4s, transform 0.4s;
    margin-top: 4px;
}
.tech-card-cta:hover {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
    transform: translateY(-1px);
}
.tech-card-cta .btn-arrow {
    width: 22px; height: 22px;
    background: rgba(15,15,16,0.06);
}
.tech-card-cta:hover .btn-arrow {
    background: var(--red);
    color: var(--paper);
}


/* ============================================================
   PRODUCTS
   ============================================================ */
.wave-strip {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--font-mono); font-size: 12px;
    color: var(--ink-mid);
    letter-spacing: 0.04em;
    background: var(--white);
    border: 1px solid var(--hair);
    padding: 9px 16px;
    border-radius: 999px;
    margin-top: 6px;
}
.wave-strip svg { color: var(--red); }

.products-grid {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-x);
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(20px, 2.4vw, 32px);
}

.product-card {
    position: relative;
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: var(--radius-2xl);
    padding: clamp(24px, 2.8vw, 36px);
    overflow: hidden;
    display: grid;
    grid-template-rows: auto auto 1fr;
    gap: 18px;
    transition: transform 0.6s var(--ease), border-color 0.4s, box-shadow 0.6s;
}
.product-card:hover {
    transform: translateY(-2px);
    border-color: rgba(15,15,16,0.14);
    box-shadow: var(--shadow-md);
}
.product-card--featured { background: linear-gradient(170deg, #FFFFFF 0%, #F9F8F4 100%); }
.product-card-glow {
    position: absolute;
    top: -10%; right: -10%;
    width: 60%; height: 60%;
    background: radial-gradient(circle, var(--red-glow), transparent 60%);
    pointer-events: none;
    filter: blur(8px);
}

.product-tag {
    display: inline-flex; align-self: start; align-items: center; gap: 8px;
    background: var(--ink);
    color: var(--paper);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    padding: 8px 14px;
    border-radius: 999px;
    position: relative;
    z-index: 2;
}
.product-tag-dot {
    width: 5px; height: 5px; border-radius: 50%;
    background: var(--red);
    box-shadow: 0 0 0 3px rgba(200,16,46,0.3);
    animation: dotPulse 2.6s ease-in-out infinite;
}
.product-tag--muted {
    background: transparent; color: var(--ink); border: 1px solid var(--hair);
}
.product-tag--muted .product-tag-dot { background: var(--ink); box-shadow: none; }

.product-image {
    position: relative;
    aspect-ratio: 16/10;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: linear-gradient(160deg, #F4F2EC 0%, #E5E2D9 100%);
    display: flex; align-items: center; justify-content: center;
}
.product-image img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.7s var(--ease);
    position: relative;
    z-index: 2;
}
.product-card:hover .product-image img { transform: scale(1.045) translateY(-3px); }
.product-image-glow {
    position: absolute;
    width: 70%; height: 70%;
    background: radial-gradient(circle, var(--red-glow-strong), transparent 65%);
    filter: blur(34px);
    border-radius: 50%;
    animation: glowPulse 6s ease-in-out infinite;
}
.product-image-glow--soft {
    background: radial-gradient(circle, rgba(15,15,16,0.10), transparent 65%);
}
.product-image-floor {
    position: absolute;
    left: 18%; right: 18%; bottom: 8%;
    height: 10px;
    background: radial-gradient(ellipse at center, rgba(15,15,16,0.22), transparent 70%);
    filter: blur(5px);
    z-index: 1;
}
@keyframes glowPulse {
    0%, 100% { transform: scale(1); opacity: 0.9; }
    50%      { transform: scale(1.08); opacity: 0.6; }
}

.product-body { display: flex; flex-direction: column; gap: 16px; }
.product-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
}
.product-name {
    font-size: clamp(24px, 2.2vw, 30px);
    font-weight: 500;
    letter-spacing: -0.018em;
    line-height: 1.05;
}
.product-price {
    flex: 0 0 auto;
    font-size: clamp(20px, 1.8vw, 24px);
    font-weight: 500;
    letter-spacing: -0.01em;
    line-height: 1.05;
    white-space: nowrap;
    font-feature-settings: "tnum";
}
.product-card--featured .product-price { color: var(--red); }
.product-desc {
    font-size: 14.5px;
    color: var(--steel);
    line-height: 1.55;
    max-width: 50ch;
}

.product-feats {
    display: flex; flex-direction: column; gap: 10px;
    padding: 16px 0 4px;
    border-top: 1px solid var(--hair);
}
.product-feats li {
    display: flex; align-items: flex-start; gap: 10px;
    font-size: 14px;
    color: var(--ink-mid);
    line-height: 1.4;
}
.feat-icon {
    flex: 0 0 auto;
    width: 18px; height: 18px;
    border-radius: 50%;
    background: var(--ink);
    color: var(--paper);
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 2px;
}
.product-card--featured .feat-icon { background: var(--red); }

.product-specs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 24px;
    padding-top: 16px;
    border-top: 1px solid var(--hair);
    font-family: var(--font-mono);
    font-size: 12px;
}
.spec { display: flex; justify-content: space-between; gap: 12px; align-items: baseline; }
.spec dt { color: var(--steel); letter-spacing: 0.04em; }
.spec dd { color: var(--ink); text-align: right; font-feature-settings: "tnum"; }

.finance-line {
    max-width: var(--container);
    margin: clamp(28px, 3vw, 40px) auto 0;
    padding: 0 var(--pad-x);
    font-size: 14.5px;
    color: var(--ink-mid);
    display: flex; align-items: center; gap: 14px;
}
.finance-mark {
    flex: 0 0 auto;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--red);
    color: var(--paper);
    display: inline-flex; align-items: center; justify-content: center;
}


/* ============================================================
   SALONS
   ============================================================ */
.salons-grid {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-x);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(28px, 4vw, 56px);
}
.salons-text {
    font-size: clamp(15.5px, 1.3vw, 18px);
    line-height: 1.6;
    color: var(--ink-mid);
    max-width: 52ch;
}
.salons-stats {
    max-width: var(--container);
    margin: clamp(36px, 5vw, 56px) auto 0;
    padding: 0 var(--pad-x);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--hair);
    border-top: 1px solid var(--hair);
    border-bottom: 1px solid var(--hair);
}
.salons-stats li {
    background: var(--paper-2);
    padding: clamp(20px, 2.4vw, 28px);
    display: flex; flex-direction: column; gap: 6px;
}
.ss-v {
    font-family: var(--font-mono);
    font-size: clamp(28px, 3vw, 38px);
    font-weight: 500;
    color: var(--ink);
    letter-spacing: -0.01em;
    font-variant-numeric: tabular-nums;
}
.ss-u {
    font-size: 12px;
    color: var(--steel);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    font-family: var(--font-mono);
}


/* ============================================================
   INCOME
   ============================================================ */
.panel--income .panel-content {
    padding-top: clamp(110px, 14vh, 140px);
    padding-bottom: clamp(60px, 8vh, 100px);
}
.income-bg-glow {
    position: absolute;
    top: -10%; right: -10%;
    width: 65%; height: 65%;
    background: radial-gradient(circle, var(--red-glow-strong), transparent 60%);
    pointer-events: none;
    z-index: 0;
}

.panel--income .section-head { padding-left: var(--pad-x); padding-right: var(--pad-x); margin-bottom: clamp(36px, 4vw, 50px); }

.big-number {
    position: relative;
    text-align: center;
    margin: clamp(24px, 4vw, 50px) 0;
    z-index: 2;
}
.big-number-pre {
    display: block;
    font-family: var(--font-mono);
    font-size: 13px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(247,246,243,0.55);
    margin-bottom: 12px;
}
.big-number-v {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    font-size: clamp(60px, 13vw, 200px);
    line-height: 0.92;
    letter-spacing: -0.04em;
    color: var(--paper);
    display: inline-block;
}
.bn-mask { display: inline-block; overflow: hidden; padding-bottom: 0.06em; padding-top: 0.04em; }
.bn-text {
    display: inline-block;
    background: linear-gradient(180deg, #FFFFFF 0%, #FFFFFF 60%, var(--red-light) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.big-number-u {
    display: block;
    font-size: clamp(15px, 1.3vw, 18px);
    color: rgba(247,246,243,0.65);
    margin-top: 18px;
    letter-spacing: 0.01em;
}

.income-rows {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 var(--pad-x);
    position: relative;
    z-index: 2;
}
.income-row {
    display: grid;
    grid-template-columns: 36px 1fr auto;
    align-items: baseline;
    gap: 18px;
    padding: 22px 0;
    border-top: 1px solid rgba(247,246,243,0.10);
}
.income-row:last-child { border-bottom: 1px solid rgba(247,246,243,0.10); }
.income-row-icon {
    color: var(--red-light);
    align-self: center;
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px;
    border-radius: 50%;
    background: rgba(230,57,70,0.12);
}
.income-row-label {
    font-size: clamp(15px, 1.4vw, 18px);
    color: var(--paper);
    letter-spacing: -0.005em;
}
.income-row-value {
    font-family: var(--font-mono);
    font-size: clamp(18px, 2vw, 26px);
    color: var(--paper);
    font-feature-settings: "tnum";
    letter-spacing: -0.005em;
}
.income-row-unit { color: rgba(247,246,243,0.5); font-size: 0.7em; }
.income-row:last-child .income-row-value { color: var(--red-light); font-weight: 500; }

.income-cta {
    margin-top: clamp(32px, 4vw, 48px);
    text-align: center;
    position: relative; z-index: 2;
    padding: 0 var(--pad-x);
}
.income-note {
    font-size: 14px;
    color: rgba(247,246,243,0.65);
    margin-bottom: 20px;
    max-width: 56ch;
    margin-left: auto; margin-right: auto;
    display: inline-flex; align-items: center; gap: 8px;
}
.income-note svg { color: var(--red-light); }


/* ============================================================
   CALCULATOR
   ============================================================ */
.calc-card {
    position: relative;
    max-width: var(--container);
    margin: 0 auto;
    padding: clamp(24px, 3.5vw, 50px);
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: clamp(24px, 3vw, 40px);
    box-shadow: var(--shadow-md);
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: clamp(28px, 4vw, 56px);
    overflow: hidden;
}
.calc-grain {
    position: absolute; inset: 0; pointer-events: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence baseFrequency='1.4' numOctaves='1'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.3 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    opacity: 0.03; mix-blend-mode: multiply;
}
.calc-bg-glow {
    position: absolute;
    top: -20%; left: -10%;
    width: 50%; height: 60%;
    background: radial-gradient(circle, var(--red-wash-2), transparent 70%);
    pointer-events: none;
}

.calc-controls { display: flex; flex-direction: column; gap: 28px; position: relative; z-index: 2; }
.calc-field { display: flex; flex-direction: column; gap: 12px; }
.calc-field-head { display: flex; align-items: baseline; flex-wrap: wrap; gap: 8px 10px; }
.calc-label {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--steel);
    margin-right: auto;
}
.calc-label svg { color: var(--red); }
.calc-value {
    font-family: var(--font-mono);
    font-size: clamp(26px, 3.2vw, 38px);
    font-weight: 500;
    color: var(--ink);
    letter-spacing: -0.015em;
    font-feature-settings: "tnum";
    line-height: 1;
}
.calc-unit { font-family: var(--font-mono); font-size: 13px; color: var(--steel); }

.calc-slider {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 4px;
    background: var(--hair);
    border-radius: 999px;
    outline: none;
    cursor: pointer;
    background-image: linear-gradient(to right, var(--red), var(--red-light));
    background-size: var(--fill, 50%) 100%;
    background-repeat: no-repeat;
}
.calc-slider::-webkit-slider-runnable-track { height: 4px; background: transparent; }
.calc-slider::-moz-range-track { height: 4px; background: var(--hair); border-radius: 999px; }
.calc-slider::-moz-range-progress { height: 4px; background: var(--red); border-radius: 999px; }
.calc-slider::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--ink);
    border: 3px solid var(--white);
    box-shadow: 0 4px 14px rgba(15,15,16,0.18), 0 0 0 1px var(--hair);
    margin-top: -9px;
    cursor: grab;
    transition: transform 0.2s var(--ease), background 0.3s, box-shadow 0.3s;
}
.calc-slider:hover::-webkit-slider-thumb,
.calc-slider:focus-visible::-webkit-slider-thumb {
    background: var(--red);
    box-shadow: 0 0 0 4px var(--red-wash), 0 4px 14px rgba(200,16,46,0.3);
    transform: scale(1.12);
}
.calc-slider::-moz-range-thumb {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--ink);
    border: 3px solid var(--white);
    box-shadow: 0 4px 14px rgba(15,15,16,0.18);
    cursor: grab;
}

.calc-scale {
    display: flex; justify-content: space-between;
    font-family: var(--font-mono); font-size: 11px; color: var(--mute);
    letter-spacing: 0.04em;
}

.calc-results {
    position: relative; z-index: 2;
    display: flex; flex-direction: column; gap: 10px;
}
.calc-result {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    align-items: baseline;
    gap: 4px 16px;
    padding: 16px 20px;
    border: 1px solid var(--hair);
    border-radius: var(--radius-md);
    background: var(--paper-2);
}
.calc-result-label {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--steel);
    grid-column: 1;
}
.calc-result-value {
    font-family: var(--font-mono);
    font-size: clamp(22px, 2.4vw, 28px);
    font-weight: 500;
    color: var(--ink);
    font-feature-settings: "tnum";
    letter-spacing: -0.012em;
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
}
.calc-result-unit {
    font-family: var(--font-mono); font-size: 11px; color: var(--mute);
    letter-spacing: 0.04em;
}

.calc-result--accent {
    position: relative;
    background: linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%);
    border-color: var(--ink);
    color: var(--paper);
    padding: 22px 24px;
    margin-top: 6px;
    overflow: hidden;
}
.calc-result--accent .calc-result-label { color: rgba(247,246,243,0.7); }
.calc-result--accent .calc-result-label svg { color: var(--red-light); }
.calc-result--accent .calc-result-value { color: var(--paper); }
.calc-result--accent .calc-result-unit { color: rgba(247,246,243,0.55); }
.calc-result-value--xl { font-size: clamp(32px, 3.6vw, 46px); }
.calc-result-glow {
    position: absolute;
    bottom: -50%; right: -10%;
    width: 60%; height: 200%;
    background: radial-gradient(circle, var(--red-glow-strong), transparent 60%);
    pointer-events: none;
    transition: opacity 0.6s var(--ease);
}
.calc-result--accent.is-pulsing .calc-result-glow { opacity: 1.6; }


/* ============================================================
   CONSULT
   ============================================================ */
.consult-grid {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-x);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(36px, 4.5vw, 70px);
    align-items: start;
}
.consult-head { display: flex; flex-direction: column; gap: 16px; }
.consult-bullets { display: flex; flex-direction: column; gap: 0; margin-top: 14px; }
.consult-bullets li {
    display: grid; grid-template-columns: 36px 1fr;
    gap: 14px; align-items: center;
    padding: 14px 0;
    border-top: 1px solid var(--hair);
    font-size: 15.5px;
    color: var(--ink-mid);
}
.consult-bullets li:last-child { border-bottom: 1px solid var(--hair); }
.consult-bullets svg {
    color: var(--red);
    background: var(--red-wash);
    border-radius: 50%;
    padding: 7px;
    box-sizing: content-box;
    width: 16px; height: 16px;
}

.consult-form {
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: var(--radius-2xl);
    padding: clamp(26px, 3.5vw, 42px);
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
}
.consult-form::before {
    content: '';
    position: absolute;
    top: -30%; right: -20%;
    width: 60%; height: 60%;
    background: radial-gradient(circle, var(--red-wash-2), transparent 70%);
    pointer-events: none;
}


/* ============================================================
   FORM FIELDS
   ============================================================ */
.lead-form { display: flex; flex-direction: column; gap: 20px; position: relative; }
.form-row { display: grid; gap: 18px; }
.form-row--split { grid-template-columns: 1fr 1fr; }

.field { display: flex; flex-direction: column; gap: 6px; position: relative; }
.field-label {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--steel);
}
.field-input {
    width: 100%;
    border: 0;
    border-bottom: 1px solid var(--hair);
    background: transparent;
    padding: 12px 0 14px;
    font-size: 16px;
    color: var(--ink);
    outline: none;
    border-radius: 0;
    transition: color 0.3s;
}
.field-input::placeholder { color: var(--mute); }
.field-input:focus + .field-line,
.field-input:not(:placeholder-shown) + .field-line { transform: scaleX(1); }
.field-line {
    display: block;
    height: 1.5px;
    background: var(--ink);
    transform: scaleX(0); transform-origin: left center;
    transition: transform 0.5s var(--ease);
}
.select-wrap { position: relative; }
.field-select { appearance: none; -webkit-appearance: none; padding-right: 28px; }
.select-caret { position: absolute; right: 4px; top: 50%; transform: translateY(-50%); color: var(--steel); pointer-events: none; }

.checkbox {
    display: flex; align-items: flex-start; gap: 10px;
    cursor: pointer; font-size: 13px; color: var(--steel); line-height: 1.45;
    user-select: none;
}
.checkbox input { position: absolute; opacity: 0; pointer-events: none; }
.checkbox-box {
    flex: 0 0 auto;
    width: 18px; height: 18px;
    border: 1px solid var(--hair);
    border-radius: 5px;
    display: inline-flex; align-items: center; justify-content: center;
    color: transparent;
    transition: background 0.3s, border-color 0.3s, color 0.3s;
    margin-top: 1px;
}
.checkbox input:checked ~ .checkbox-box {
    background: var(--red);
    border-color: var(--red);
    color: var(--paper);
}
.checkbox input:focus-visible ~ .checkbox-box { box-shadow: 0 0 0 3px var(--red-wash); }

.hp-field {
    position: absolute !important;
    left: -9999px !important; top: -9999px !important;
    width: 1px !important; height: 1px !important;
    opacity: 0 !important; pointer-events: none !important;
}

.form-submit { margin-top: 4px; }
.form-submit.is-busy { opacity: 0.7; pointer-events: none; }

.form-error {
    font-size: 13px;
    color: var(--red);
    background: var(--red-wash);
    padding: 10px 14px;
    border-radius: 10px;
    margin-top: -6px;
}
.form-error[hidden] { display: none; }

.form-success {
    position: absolute;
    inset: -10px;
    background: var(--white);
    border-radius: inherit;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center;
    padding: 40px 24px;
    opacity: 0; visibility: hidden;
    transition: opacity 0.5s var(--ease), visibility 0.5s;
    z-index: 5;
}
.form-success.is-active { opacity: 1; visibility: visible; }
.form-success-mark {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: var(--red);
    color: var(--paper);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 18px;
    transform: scale(0.6); opacity: 0;
    transition: transform 0.7s var(--ease), opacity 0.5s;
}
.form-success.is-active .form-success-mark { transform: scale(1); opacity: 1; }
.form-success-mark .success-ring,
.form-success-mark .success-check {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset 0.8s var(--ease) 0.2s;
}
.form-success.is-active .success-ring { stroke-dashoffset: 0; }
.form-success.is-active .success-check { stroke-dashoffset: 0; transition-delay: 0.5s; }
.form-success-title { font-size: 22px; font-weight: 500; letter-spacing: -0.015em; margin-bottom: 8px; }
.form-success-sub { font-size: 14px; color: var(--steel); max-width: 36ch; }


/* ============================================================
   ADVANTAGES
   ============================================================ */
.advantage-grid {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-x);
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 1px;
    background: var(--hair);
    border: 1px solid var(--hair);
    border-radius: var(--radius-2xl);
    overflow: hidden;
}
.adv-card {
    grid-column: span 2;
    background: var(--white);
    padding: clamp(24px, 3vw, 36px);
    display: flex; flex-direction: column; gap: 12px;
    position: relative;
    overflow: hidden;
    transition: background 0.5s var(--ease);
}
.adv-card:nth-child(4) { grid-column: span 3; }
.adv-card:nth-child(5) { grid-column: span 3; }
.adv-card:nth-child(6) { grid-column: span 6; }
.adv-card:hover { background: var(--paper-2); }
.adv-card:hover .adv-line { transform: scaleX(1); }
.adv-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--red-wash) 0%, transparent 100%);
    color: var(--red);
    margin-bottom: 4px;
}
.adv-num {
    position: absolute; top: clamp(20px, 2.6vw, 30px); right: clamp(20px, 2.6vw, 30px);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    color: var(--mute);
}
.adv-title {
    font-size: clamp(19px, 1.9vw, 24px);
    font-weight: 500;
    letter-spacing: -0.014em;
    line-height: 1.15;
}
.adv-body { font-size: 14px; line-height: 1.55; color: var(--steel); max-width: 50ch; }
.adv-line {
    position: absolute;
    left: 0; top: 0;
    width: 100%; height: 2px;
    background: var(--red);
    transform: scaleX(0); transform-origin: left center;
    transition: transform 0.7s var(--ease);
}


/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonial-rail { position: relative; overflow: hidden; padding-left: var(--pad-x); }
.testimonial-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(340px, 420px);
    gap: 18px;
    overflow-x: auto;
    padding: 6px 0 24px;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-right: var(--pad-x);
    cursor: grab;
}
.testimonial-track:active { cursor: grabbing; }
.testimonial-track::-webkit-scrollbar { display: none; }
.testimonial {
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: var(--radius-lg);
    padding: clamp(22px, 2.6vw, 32px);
    display: flex; flex-direction: column; gap: 18px;
    scroll-snap-align: start;
    transition: transform 0.5s var(--ease), border-color 0.4s, box-shadow 0.5s;
}
.testimonial:hover {
    transform: translateY(-2px);
    border-color: rgba(15,15,16,0.14);
    box-shadow: var(--shadow-md);
}
.t-head {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 14px;
}
.t-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: var(--paper);
}
.t-avatar--rose  { background: linear-gradient(135deg, #C8102E 0%, #8B0A20 100%); }
.t-avatar--stone { background: linear-gradient(135deg, #2C2C30 0%, #0F0F10 100%); }
.t-avatar--olive { background: linear-gradient(135deg, #5C5A4F 0%, #2E2C25 100%); }
.t-avatar--taupe { background: linear-gradient(135deg, #8B7E6E 0%, #4A4135 100%); }
.t-meta-top { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.t-name { font-size: 14.5px; font-weight: 500; letter-spacing: -0.005em; }
.t-role { font-size: 12.5px; color: var(--steel); }
.t-stars { display: inline-flex; gap: 2px; color: var(--red); }
.star-filled { fill: var(--red); }

.t-text {
    font-family: var(--font-sans);
    font-weight: 400;
    font-size: clamp(15.5px, 1.4vw, 17.5px);
    line-height: 1.55;
    letter-spacing: -0.005em;
    color: var(--ink-mid);
    flex: 1;
    text-wrap: pretty;
}
.t-text::first-letter { color: var(--red); font-weight: 500; }
.t-foot {
    display: inline-flex; align-items: center; gap: 8px;
    padding-top: 14px;
    border-top: 1px solid var(--hair);
    font-size: 12.5px; color: var(--steel);
}
.t-foot svg { color: var(--red); }

.rail-controls {
    max-width: var(--container);
    margin: 18px auto 0;
    padding: 0 var(--pad-x);
    display: flex; gap: 8px; justify-content: flex-end;
}
.rail-btn {
    width: 44px; height: 44px;
    border-radius: 50%;
    border: 1px solid var(--hair);
    color: var(--ink);
    background: var(--white);
    transition: background 0.4s var(--ease), color 0.4s, transform 0.4s, border-color 0.4s;
}
.rail-btn:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); transform: translateY(-2px); }


/* ============================================================
   FAQ
   ============================================================ */
.faq-list { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--pad-x); }
.faq-item { border-top: 1px solid var(--hair); }
.faq-item:last-child { border-bottom: 1px solid var(--hair); }
.faq-q {
    width: 100%;
    display: grid;
    grid-template-columns: 50px 1fr 28px;
    align-items: baseline;
    gap: 16px;
    padding: 22px 4px;
    text-align: left;
    transition: padding 0.4s var(--ease);
}
.faq-q:hover { padding-left: 14px; }
.faq-num {
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.06em;
    color: var(--red);
    align-self: start;
    padding-top: 4px;
}
.faq-q-text {
    font-size: clamp(16.5px, 1.4vw, 20px);
    font-weight: 500;
    letter-spacing: -0.012em;
    line-height: 1.3;
    color: var(--ink);
}
.faq-icon {
    position: relative;
    width: 22px; height: 22px;
    align-self: center;
}
.faq-icon span {
    position: absolute;
    left: 50%; top: 50%;
    background: var(--ink);
    border-radius: 999px;
    transition: transform 0.5s var(--ease), background 0.3s;
}
.faq-item:hover .faq-icon span { background: var(--red); }
.faq-icon span:nth-child(1) { width: 13px; height: 1.5px; transform: translate(-50%, -50%); }
.faq-icon span:nth-child(2) { width: 1.5px; height: 13px; transform: translate(-50%, -50%); }
.faq-item.is-open .faq-icon span:nth-child(2) { transform: translate(-50%, -50%) rotate(90deg) scaleX(0); }
.faq-item.is-open .faq-icon span { background: var(--red); }

.faq-a { overflow: hidden; height: 0; transition: height 0.6s var(--ease); }
.faq-a-inner {
    padding: 0 4px 24px 66px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--ink-mid);
    max-width: 64ch;
}
.faq-a-inner strong { color: var(--ink); font-weight: 500; }


/* ============================================================
   FINAL CTA
   ============================================================ */
.final {
    position: relative;
    z-index: 10;
    background: var(--ink);
    color: var(--paper);
    padding: clamp(80px, 11vw, 130px) var(--pad-x);
    overflow: hidden;
    text-align: center;
}
.final-glow {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 80%; height: 100%;
    background: radial-gradient(ellipse at center, var(--red-glow-strong), transparent 60%);
    pointer-events: none;
    filter: blur(30px);
}
.final-glow--2 {
    top: 80%; left: 20%;
    width: 40%; height: 40%;
    background: radial-gradient(circle, var(--red-glow), transparent 70%);
    transform: translate(-50%, -50%);
}
.final-inner {
    position: relative;
    max-width: 880px;
    margin: 0 auto;
    display: flex; flex-direction: column; align-items: center; gap: 22px;
}
.final-title {
    font-size: clamp(40px, 6.4vw, 88px);
    font-weight: 500;
    letter-spacing: -0.038em;
    line-height: 0.98;
    text-wrap: balance;
    color: var(--paper);
}
.final-title em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    background: linear-gradient(180deg, var(--red-light) 0%, var(--red) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.final-sub {
    font-size: clamp(15px, 1.3vw, 18px);
    color: rgba(247,246,243,0.7);
    max-width: 50ch;
    text-wrap: pretty;
}
.final-trust {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 14px;
    margin-top: 18px;
    font-size: 13px;
    color: rgba(247,246,243,0.7);
}
.final-trust span { display: inline-flex; align-items: center; gap: 8px; }
.final-trust svg { color: var(--red-light); }
.final-trust-sep { width: 4px; height: 4px; border-radius: 50%; background: rgba(247,246,243,0.25); }


/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    position: relative;
    z-index: 11;
    background: var(--ink);
    color: var(--paper);
    padding: clamp(60px, 7vw, 90px) var(--pad-x) 28px;
    overflow: hidden;
    border-top: 1px solid rgba(247,246,243,0.06);
}
.footer-grain {
    position: absolute; inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    opacity: 0.03; pointer-events: none; mix-blend-mode: screen;
}
.footer-inner {
    position: relative;
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1.4fr 1fr;
    gap: clamp(28px, 4vw, 56px);
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(247,246,243,0.10);
}
.footer-logo { height: 42px; width: auto; margin-bottom: 18px; }
.footer-about { font-size: 13.5px; line-height: 1.6; color: rgba(247,246,243,0.6); max-width: 36ch; }
.footer-title {
    display: block;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(247,246,243,0.5);
    margin-bottom: 14px;
}
.footer-col { display: flex; flex-direction: column; gap: 9px; }
.footer-link {
    font-size: 14px;
    color: var(--paper);
    transition: color 0.3s, transform 0.4s;
    display: inline-block;
    line-height: 1.4;
}
.footer-link:hover { color: var(--red-light); transform: translateX(3px); }
.footer-link.is-active { color: var(--red-light); }
.footer-link--muted { color: rgba(247,246,243,0.55); font-size: 12.5px; }
.footer-line { display: flex; flex-direction: column; gap: 2px; }
.footer-label {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(247,246,243,0.5);
}
.footer-value { font-size: 14px; color: var(--paper); }
.footer-value--link:hover { color: var(--red-light); }
.footer-social {
    display: inline-flex; align-items: center; gap: 8px;
    margin-top: 12px;
    padding: 9px 14px;
    border: 1px solid rgba(247,246,243,0.16);
    border-radius: 999px;
    align-self: flex-start;
    font-size: 13px;
    transition: background 0.3s, border-color 0.3s, color 0.3s;
}
.footer-social:hover { background: var(--red); color: var(--paper); border-color: var(--red); }
.footer-meta {
    position: relative;
    max-width: var(--container);
    margin: 22px auto 0;
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px;
    color: rgba(247,246,243,0.5);
    flex-wrap: wrap;
    gap: 12px;
}


/* ============================================================
   STICKY MOBILE CTA + FLOATING WIDGET
   ============================================================ */
.sticky-mobile-cta {
    position: fixed;
    left: 12px; right: 12px; bottom: 12px;
    z-index: 80;
    display: none;
    align-items: center; justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    background: var(--ink);
    color: var(--paper);
    border-radius: 999px;
    box-shadow: var(--shadow-lg), 0 0 0 4px rgba(200,16,46,0.10);
    font-size: 15px; font-weight: 500;
    transform: translateY(120%);
    transition: transform 0.6s var(--ease);
}
.sticky-mobile-cta.is-visible { transform: translateY(0); }
.smc-arrow {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--red);
}
@media (max-width: 768px) { .sticky-mobile-cta { display: flex; } }

.floating-widget {
    position: fixed;
    bottom: 20px; right: 20px;
    z-index: 80;
    display: inline-flex; align-items: center; gap: 10px;
    padding: 12px 18px 12px 12px;
    background: var(--white);
    border: 1px solid var(--hair);
    border-radius: 999px;
    box-shadow: var(--shadow-md);
    font-size: 14px;
    transform: translateY(150%);
    transition: transform 0.6s var(--ease), background 0.4s, color 0.4s;
}
.floating-widget.is-visible { transform: translateY(0); }
.floating-widget:hover { background: var(--ink); color: var(--paper); }
.floating-widget:hover .fw-icon { background: var(--red); color: var(--paper); }
.fw-icon {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--paper);
    display: inline-flex; align-items: center; justify-content: center;
    transition: background 0.4s, color 0.4s;
    color: var(--red);
}
@media (max-width: 768px) { .floating-widget { display: none; } }


/* ============================================================
   POPUP
   ============================================================ */
.popup {
    position: fixed; inset: 0; z-index: 200;
    opacity: 0; visibility: hidden;
    transition: opacity 0.5s var(--ease), visibility 0.5s;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
}
.popup.is-open { opacity: 1; visibility: visible; }
.popup-backdrop {
    position: absolute; inset: 0;
    background: rgba(15,15,16,0.55);
    backdrop-filter: blur(8px);
}
.popup-card {
    position: relative;
    background: var(--white);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-lg);
    padding: clamp(28px, 4vw, 44px);
    width: 100%;
    max-width: 540px;
    max-height: calc(100dvh - 40px);
    overflow-y: auto;
    transform: translateY(20px) scale(0.96);
    transition: transform 0.5s var(--ease);
}
.popup.is-open .popup-card { transform: translateY(0) scale(1); }
.popup-card::after {
    content: '';
    position: absolute;
    top: -20%; right: -20%;
    width: 60%; height: 60%;
    background: radial-gradient(circle, var(--red-wash-2), transparent 70%);
    pointer-events: none;
    border-radius: inherit;
}
.popup-grain {
    position: absolute; inset: 0; pointer-events: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence baseFrequency='1.4' numOctaves='1'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.4 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    opacity: 0.04; mix-blend-mode: multiply; border-radius: inherit;
}
.popup-close {
    position: absolute;
    top: 18px; right: 18px;
    width: 38px; height: 38px;
    border-radius: 50%;
    border: 1px solid var(--hair);
    color: var(--ink);
    display: inline-flex; align-items: center; justify-content: center;
    transition: background 0.3s, color 0.3s, transform 0.4s;
    z-index: 4;
}
.popup-close:hover { background: var(--red); color: var(--paper); border-color: var(--red); transform: rotate(90deg); }
.popup-head { position: relative; z-index: 2; margin-bottom: 24px; display: flex; flex-direction: column; gap: 10px; }
.popup-title {
    font-size: clamp(26px, 2.8vw, 34px);
    font-weight: 500;
    letter-spacing: -0.02em;
    line-height: 1.05;
}
.popup-title em { font-family: var(--font-display); font-style: italic; font-weight: 300; }
.popup-sub { font-size: 14.5px; color: var(--steel); line-height: 1.55; }


/* ============================================================
   ANIMATION INITIAL STATES
   ============================================================ */
[data-anim="fade-up"] { opacity: 0; transform: translateY(20px); }
.is-revealed[data-anim="fade-up"],
[data-anim="fade-up"].is-revealed { opacity: 1; transform: translateY(0); transition: opacity 0.85s var(--ease), transform 0.85s var(--ease); }

[data-anim="hero-visual"] { opacity: 0; transform: translateY(30px) scale(0.97); }
[data-anim="hero-visual"].is-revealed { opacity: 1; transform: translateY(0) scale(1); transition: opacity 1.2s var(--ease), transform 1.2s var(--ease); }

/* Word containers prevent mid-word breaks. Chars animate inside. */
[data-split] .split-word {
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    padding-bottom: 0.06em;
    padding-top: 0.04em;
    vertical-align: top;
}
[data-split] .split-char { display: inline-block; transform: translateY(110%); opacity: 0; }
[data-split-lines] .split-line { display: inline-block; overflow: hidden; padding-bottom: 0.06em; padding-top: 0.04em; max-width: 100%; }
[data-split-lines] .split-line-inner { display: inline-block; transform: translateY(110%); }
[data-split-lines].is-revealed .split-line-inner {
    transform: translateY(0);
    transition: transform 1.05s var(--ease);
}

[data-pillar],
[data-product],
[data-adv-card],
[data-income-row] {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.9s var(--ease), transform 0.9s var(--ease);
}
[data-pillar].is-revealed,
[data-product].is-revealed,
[data-adv-card].is-revealed,
[data-income-row].is-revealed {
    opacity: 1; transform: translateY(0);
}

.bn-mask .bn-text { transform: translateY(110%); }
[data-big-number].is-revealed .bn-text {
    transform: translateY(0);
    transition: transform 1.4s var(--ease);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
    .hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .hero-visual { aspect-ratio: 1.1/1; min-height: 380px; max-width: 540px; margin: 0 auto; }
    .salons-stats { grid-template-columns: repeat(2, 1fr); }
    .tech-showcase { grid-template-columns: 1fr; gap: 24px; }
    .tech-tabs {
        flex-direction: row;
        overflow-x: auto;
        scrollbar-width: none;
        border-radius: var(--radius-lg);
    }
    .tech-tabs::-webkit-scrollbar { display: none; }
    .tech-tab {
        flex: 0 0 auto;
        min-width: 240px;
        grid-template-columns: 32px 28px 1fr;
    }
    .tech-tab-arrow { display: none; }
    .tech-stage-images { aspect-ratio: 16/10; }
    .tech-card-specs { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 1024px) {
    .products-grid { grid-template-columns: 1fr; }
    .product-specs { grid-template-columns: 1fr 1fr; }
    .calc-card { grid-template-columns: 1fr; }
    .salons-grid { grid-template-columns: 1fr; }
    .consult-grid { grid-template-columns: 1fr; }
    .footer-inner { grid-template-columns: 1fr 1fr; }
    .advantage-grid { grid-template-columns: repeat(2, 1fr); }
    .adv-card,
    .adv-card:nth-child(4),
    .adv-card:nth-child(5),
    .adv-card:nth-child(6) { grid-column: span 1; }
    .panel { min-height: auto; }
    .panel-content { min-height: auto; padding-top: 100px; padding-bottom: 80px; }
    .panel--hero .panel-content { min-height: 100dvh; }
}

@media (max-width: 768px) {
    body { padding-bottom: 80px; }
    .nav-main { display: none; }
    .nav-toggle { display: inline-flex; }
    .header-actions .btn--compact { display: none; }
    .panel-content { padding-top: 90px; padding-bottom: 70px; }
    .panel--hero .panel-content { padding-top: 110px; }
    .hero-visual { min-height: 320px; }
    .chip { padding: 10px 12px; gap: 8px; }
    .chip-icon { width: 26px; height: 26px; }
    .chip-v { font-size: 13px; }
    .chip-u { font-size: 10px; }
    .chip--1 { left: -2%; }
    .chip--2 { right: -2%; }
    .form-row--split { grid-template-columns: 1fr; }
    .footer-inner { grid-template-columns: 1fr; gap: 28px; }
    .income-row { grid-template-columns: 30px 1fr; row-gap: 4px; }
    .income-row-value { grid-column: 2; font-size: 20px; }
    .calc-result { grid-template-columns: 1fr; }
    .calc-result-value { grid-column: 1; grid-row: auto; font-size: 26px; }
    .calc-result-value--xl { font-size: 30px; }
    .product-specs { grid-template-columns: 1fr; gap: 8px; }
    .pillars-grid { grid-template-columns: 1fr; }
    .salons-stats { grid-template-columns: 1fr 1fr; }
    .faq-q { grid-template-columns: 38px 1fr 26px; gap: 12px; padding: 20px 0; }
    .faq-q:hover { padding-left: 0; }
    .faq-a-inner { padding-left: 50px; padding-right: 0; }
    .advantage-grid { grid-template-columns: 1fr; }
    .testimonial-track { grid-auto-columns: 78%; }
    .floating-widget { display: none; }
    .footer-meta { justify-content: flex-start; }
    /* Mobile container breathing room — desktop keeps hero-grid edge-aligned */
    .hero-grid { padding: 0 var(--pad-x); }
    .product-card { padding: clamp(22px, 5.5vw, 32px) !important; }
    /* Stack label/value in product specs so long values do not overflow the card */
    .spec { flex-direction: column; align-items: flex-start; gap: 2px; }
    .spec dd { text-align: left; }
    /* Stack label and value+unit in calculator so the big numeric value gets its own row */
    .calc-field-head { flex-direction: column; align-items: flex-start; gap: 6px; }
    .calc-label { margin-right: 0; }
    /* Drop CSS grid on cards so children cannot blow them out via min-width: auto */
    .calc-card, .product-card { display: block !important; }
    .calc-card > *, .product-card > * { min-width: 0; max-width: 100%; }
}

@media (max-width: 480px) {
    .btn--xl { padding: 18px 24px; font-size: 15px; }
    .hero-cta { width: 100%; }
    .hero-cta .btn { flex: 1; justify-content: center; }
    .hero-trust { font-size: 11px; gap: 8px 14px; }
    .popup { padding: 8px; }
    .popup-card { border-radius: 24px; padding: 26px 20px; max-height: calc(100dvh - 16px); }
}

/* ============================================================
   v4 OVERRIDES — hero polish, faq grid, footer marquee,
   salons rebuild, big-number fix, pin-stack disable
   ============================================================ */

/* ----- Hero image: drop the boxy frame entirely ----- */
.hero-product-frame {
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    border-radius: 0 !important;
}
.hero-product-frame::before { content: none !important; }
.hero-product-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
    padding: 4% !important;
    filter: drop-shadow(0 25px 35px rgba(15,15,16,0.18)) drop-shadow(0 50px 60px rgba(200,16,46,0.10));
}
.hero-product { width: 92% !important; }
.hero-product-floor {
    bottom: 4% !important;
    height: 18px !important;
    background: radial-gradient(ellipse at center, rgba(15,15,16,0.32), transparent 70%) !important;
    filter: blur(8px) !important;
}
.hero-glow {
    inset: 8% !important;
    background: radial-gradient(ellipse 75% 65% at 50% 60%, var(--red-glow-strong) 0%, var(--red-glow) 35%, transparent 70%) !important;
    filter: blur(48px) !important;
}
/* Atmospheric backdrop that takes the SHAPE of the visual area */
.hero-visual::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 32% 8% 32% 8% / 8% 32% 8% 32%;
    background:
        radial-gradient(120% 70% at 30% 0%, rgba(255,255,255,0.6), transparent 55%),
        linear-gradient(160deg, #FBFAF7 0%, #F0EDE5 60%, #E5E1D6 100%);
    z-index: 0;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), 0 30px 80px -30px rgba(15,15,16,0.18);
    transition: border-radius 1.4s var(--ease);
}
.hero-visual { isolation: isolate; }
.hero-glow, .hero-grid-lines, .hero-product { z-index: 1; }
.chip { z-index: 5; }

/* ----- Hero CTA primary acts as red ----- */
.hero-cta .btn--primary { --btn-bg: var(--red); --btn-fg: var(--paper); --btn-bd: var(--red); }
.hero-cta .btn--primary:hover { --btn-bg: var(--red-deep); --btn-bd: var(--red-deep); }


/* ----- Big number: prevent cut-off, scale safely ----- */
.big-number-v {
    font-size: clamp(50px, 10.5vw, 156px) !important;
    line-height: 1 !important;
    padding: 0 0.04em !important;
}
.bn-mask {
    overflow: hidden;
    padding: 0.06em 0.04em 0.12em 0.04em !important;
    line-height: 1;
}
.big-number {
    padding: 0 var(--pad-x);
    overflow: visible;
}


/* ----- FAQ: 2 cols + grid-rows trick (no JS animation) ----- */
.faq-list {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 0 clamp(20px, 3vw, 56px);
    align-items: start;
    max-width: var(--container) !important;
}
.faq-a {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.5s var(--ease);
    height: auto !important;
    overflow: hidden;
}
.faq-a-inner {
    overflow: hidden;
    min-height: 0;
}
.faq-item.is-open .faq-a {
    grid-template-rows: 1fr;
}
.faq-item.is-open .faq-q { color: var(--ink); }
@media (max-width: 900px) {
    .faq-list { grid-template-columns: 1fr; }
}


/* ----- Footer marquee ----- */
.footer-marquee {
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid rgba(247,246,243,0.08);
    margin-bottom: clamp(36px, 5vw, 60px);
    padding: clamp(28px, 4vw, 48px) 0;
}
.footer-marquee::before,
.footer-marquee::after {
    content: '';
    position: absolute; top: 0; bottom: 0;
    width: 80px;
    z-index: 2;
    pointer-events: none;
}
.footer-marquee::before { left: 0;  background: linear-gradient(90deg, var(--ink), transparent); }
.footer-marquee::after  { right: 0; background: linear-gradient(-90deg, var(--ink), transparent); }
.fm-track {
    display: flex; align-items: center;
    gap: clamp(24px, 3vw, 48px);
    white-space: nowrap;
    animation: fmScroll 42s linear infinite;
    will-change: transform;
}
.fm-text {
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: clamp(56px, 11vw, 156px);
    line-height: 0.95;
    letter-spacing: -0.04em;
    color: var(--paper);
}
.fm-text--italic {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
}
.fm-text--italic em {
    background: linear-gradient(180deg, var(--paper) 0%, var(--red-light) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    font-style: italic;
}
.fm-logo {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: clamp(60px, 8vw, 110px);
    height: clamp(60px, 8vw, 110px);
    border-radius: 50%;
    background: var(--red);
    flex: 0 0 auto;
}
.fm-logo img {
    width: 70%; height: 70%;
    object-fit: contain;
    filter: brightness(0) invert(1);
}
.fm-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--red);
    flex: 0 0 auto;
}
@keyframes fmScroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-25%); }
}


/* ----- Salons rebuild ----- */
.panel--salons .panel-content { gap: clamp(40px, 5vw, 70px); }
.salons-stage {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-x);
    display: flex;
    flex-direction: column;
    gap: clamp(50px, 7vw, 90px);
}
.salons-quote {
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: clamp(22px, 2.6vw, 36px);
    line-height: 1.3;
    letter-spacing: -0.02em;
    color: var(--ink);
    text-wrap: balance;
    max-width: 22ch;
    text-align: center;
    margin: 0 auto;
}
.sw-word {
    display: inline-block;
    margin-right: 0.28em;
    opacity: 0.18;
    transition: opacity 0.4s var(--ease);
}
.sw-word.is-on { opacity: 1; }
.salons-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--hair);
    border-top: 1px solid var(--hair);
    border-bottom: 1px solid var(--hair);
    padding: 0;
    margin: 0;
}
.salons-stats li {
    background: var(--paper);
    padding: clamp(24px, 3vw, 36px) clamp(20px, 2.4vw, 28px);
    display: flex; flex-direction: column;
    gap: 8px;
    position: relative;
}
.salons-stats li::before {
    content: '';
    position: absolute; left: 0; top: 0;
    width: 0; height: 2px;
    background: var(--red);
    transition: width 0.7s var(--ease);
}
.salons-stats li.is-on::before { width: 100%; }
.ss-v {
    font-family: var(--font-mono);
    font-weight: 500;
    font-size: clamp(36px, 4vw, 54px);
    color: var(--ink);
    letter-spacing: -0.02em;
    font-feature-settings: "tnum";
    line-height: 1;
}
.ss-u {
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--steel);
}
.salons-tail {
    font-size: clamp(15px, 1.3vw, 17px);
    line-height: 1.6;
    color: var(--steel);
    max-width: 60ch;
    margin: 0 auto;
    text-align: center;
}
@media (max-width: 768px) {
    .salons-stats { grid-template-columns: 1fr 1fr; }
    .salons-quote { font-size: clamp(20px, 5.5vw, 28px); }
}


/* ----- Tech showcase: stabilize hover (no jitter) ----- */
.tech-tab { transition: background 0.4s var(--ease), color 0.4s var(--ease); padding-left: clamp(20px, 2.4vw, 26px) !important; }
.tech-tab.is-active { padding-left: clamp(20px, 2.4vw, 26px) !important; }
.tech-stage-cards {
    min-height: 320px;
}
.tech-card {
    position: absolute !important;
    inset: clamp(22px, 2.6vw, 32px) clamp(22px, 2.6vw, 36px) !important;
    display: flex !important;
    pointer-events: none;
    will-change: opacity, transform;
}
.tech-card.is-active {
    pointer-events: auto;
}
.tech-card:not(.is-active) {
    opacity: 0;
    transform: translateY(8px);
}
.tech-stage-cards { position: relative; }


/* ----- Pin-stack neutralisation: keep panels in normal flow ----- */
.panel { min-height: auto !important; }
.panel-content { min-height: auto !important; padding-top: clamp(80px, 10vh, 120px) !important; padding-bottom: clamp(60px, 7vh, 90px) !important; }
.panel--hero { min-height: 100dvh !important; }
.panel--hero .panel-content { min-height: calc(100dvh - 0px) !important; }
.slides-wrapper { display: block; }


/* ----- Section spacing rationalisation ----- */
.section-head { margin-bottom: clamp(32px, 4vw, 50px) !important; }

/* ============================================================
   v5 OVERRIDES — hero grid global, marquee, tech verbs,
   section-head full-width, products align, pin-stack restore,
   advantage borders off
   ============================================================ */

/* ---------- 7. Advantage-grid: drop outer border ---------- */
.advantage-grid {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
}
.adv-card {
    background: var(--white);
    border-bottom: 1px solid var(--hair);
    border-right: 1px solid var(--hair);
}
/* remove right border on rightmost cards per row */
.adv-card:nth-child(3n) { border-right: 0; }
@media (max-width: 1024px) {
    .adv-card:nth-child(3n) { border-right: 1px solid var(--hair); }
    .adv-card:nth-child(2n) { border-right: 0; }
}
@media (max-width: 768px) {
    .adv-card:nth-child(2n) { border-right: 1px solid var(--hair); }
    .adv-card { border-right: 0 !important; }
}


/* ---------- 1. Hero grid as global animated background ---------- */
.panel--hero {
    position: relative;
    overflow: hidden;
}
.panel--hero::before {
    content: '';
    position: absolute;
    inset: -10%;
    z-index: 0;
    --grid-line: rgba(15, 15, 16, 0.05);
    --grid-size: 64px;
    background-image:
        linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
        linear-gradient(0deg,  var(--grid-line) 1px, transparent 1px);
    background-size: var(--grid-size) var(--grid-size);
    mask: radial-gradient(ellipse 110% 90% at 50% 40%, #000 30%, transparent 80%);
    -webkit-mask: radial-gradient(ellipse 110% 90% at 50% 40%, #000 30%, transparent 80%);
    animation: heroGridDrift 40s linear infinite;
    pointer-events: none;
    will-change: transform;
}
@keyframes heroGridDrift {
    from { transform: translate3d(0, 0, 0); }
    to   { transform: translate3d(-64px, -64px, 0); }
}
.panel--hero > * { position: relative; z-index: 2; }
/* Remove the per-visual grid lines (now global) */
.hero-grid-lines { display: none !important; }


/* ---------- 1b. Hero image full container width ---------- */
.hero-product { width: 100% !important; height: 100% !important; }
.hero-product-img { padding: 2% !important; }
.hero-visual::before {
    border-radius: 30% 6% 30% 6% / 6% 30% 6% 30% !important;
}


/* ---------- 2. Hero marquee seamless loop ---------- */
.hero-marquee {
    position: relative;
    overflow: hidden;
}
.hero-marquee::before, .hero-marquee::after {
    content: '';
    position: absolute; top: 0; bottom: 0;
    width: 60px;
    z-index: 2;
    pointer-events: none;
}
.hero-marquee::before { left: 0;  background: linear-gradient(90deg,  var(--paper), transparent); }
.hero-marquee::after  { right: 0; background: linear-gradient(-90deg, var(--paper), transparent); }
.marquee-track {
    display: flex; flex-wrap: nowrap;
    gap: 24px;
    width: max-content;
    animation: heroMarq 36s linear infinite;
    will-change: transform;
}
.marquee-track > * { flex: 0 0 auto; }
@keyframes heroMarq {
    from { transform: translate3d(0, 0, 0); }
    to   { transform: translate3d(-25%, 0, 0); }
}


/* ---------- 4. Section head full-width left-aligned ---------- */
.section-head:not(.section-head--centered) {
    max-width: none !important;
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
    align-items: flex-start !important;
}
.section-title {
    max-width: none !important;
    padding-right: 0.1em;
}
[data-split-lines] .split-line {
    overflow: hidden;
    padding-bottom: 0.18em !important;
    padding-top: 0.04em !important;
    padding-right: 0.18em !important;
    max-width: none !important;
}
[data-split-lines] .split-line-inner {
    padding-right: 0.06em;
}


/* ---------- 5. Product card alignment ---------- */
.product-body {
    display: flex !important;
    flex-direction: column;
    height: 100%;
}
.product-feats {
    margin-top: 0;
    min-height: 130px;
    align-content: start;
}
.product-specs {
    margin-top: 0;
    min-height: 110px;
}
.product-card .btn {
    margin-top: auto !important;
}
.product-card { display: grid !important; grid-template-rows: auto auto 1fr !important; }

/* Mobile: drop grid so long content cannot blow the card via min-width: auto */
@media (max-width: 768px) {
    .product-card { display: block !important; }
    .product-card > * { min-width: 0; max-width: 100%; }
}


/* ---------- 3. Tech verbs section (CodePen aidenwood pattern) ---------- */
.panel--tech-verbs {
    background: var(--paper);
    color: var(--ink);
    position: relative;
    --tech-fluid: clamp(2.8rem, 8vw, 8rem);
}
.tech-header {
    min-height: 100svh;
    display: flex;
    align-items: center;
    padding: 0 clamp(1.5rem, 5vw, 5rem);
}
.tech-header .eyebrow { position: absolute; top: clamp(80px, 12vh, 120px); }
.tech-h1 {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--tech-fluid);
    line-height: 0.92;
    letter-spacing: -0.04em;
    color: var(--ink);
    margin: 0;
    text-wrap: balance;
    max-width: 16ch;
}
.tech-h1 em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    background: linear-gradient(180deg, var(--red) 0%, var(--red-deep) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.tech-main { width: 100%; }

.tech-content {
    display: flex;
    width: 100%;
    padding-left: clamp(1.5rem, 5vw, 5rem);
    line-height: 1.18;
    font-size: var(--tech-fluid);
}
.tech-content h3 {
    position: sticky;
    top: calc(50% - 0.5lh);
    font-size: inherit;
    font-weight: 600;
    line-height: 1.18;
    margin: 0;
    display: inline-block;
    height: fit-content;
    white-space: nowrap;
    color: var(--ink);
    background: linear-gradient(var(--ink) 50%, var(--mute));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.tech-verbs {
    list-style: none;
    padding: 0; margin: 0;
    font-weight: 600;
    font-size: inherit;
    line-height: 1.18;
}
.tech-verbs li {
    color: var(--mute);
    opacity: 0.2;
    transition: color 0.25s ease;
}
.tech-verbs li:last-of-type {
    background: linear-gradient(var(--red) 30%, var(--red-deep));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.tech-verbs li.is-active {
    color: var(--ink);
}
.tech-fin {
    min-height: 100svh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 22px;
    padding: 0 var(--pad-x);
}
.tech-fin-title {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--tech-fluid);
    line-height: 0.92;
    letter-spacing: -0.04em;
    margin: 0;
}
.tech-fin-title em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    background: linear-gradient(180deg, var(--red) 0%, var(--red-deep) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

@media (max-width: 768px) {
    .tech-header, .tech-content { padding-left: 1.25rem; }
    .tech-content h3 { white-space: normal; }
}


/* ---------- 6. Pin-stack restore (codepen exact) ---------- */
/* Re-enable per-panel min-height for proper pin geometry */
.panel { min-height: 100dvh !important; }
.panel-content { min-height: auto !important; padding-top: clamp(80px, 10vh, 120px) !important; padding-bottom: clamp(60px, 7vh, 90px) !important; display: flex; flex-direction: column; justify-content: center; }
.panel--hero, .panel--hero .panel-content { min-height: 100dvh !important; }
.panel--tech-verbs { min-height: auto !important; } /* tech runs its own scroll */

/* ============================================================
   v6 — INSIDE AXIOM (cinematic 5-frame pin-scroll)
   Replaces tech-verbs section. Premium editorial showcase.
   ============================================================ */

.panel--inside {
    background: var(--paper-2);
    color: var(--ink);
    overflow: visible;
    position: relative;
    min-height: auto !important;
}

.inside-intro {
    max-width: var(--container);
    margin: 0 auto;
    padding: clamp(80px, 12vh, 140px) var(--pad-x) clamp(40px, 5vw, 60px);
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: flex-start;
}

/* Pinned stage */
.inside-pin {
    position: relative;
    width: 100%;
    height: 100svh;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 0;
    background: var(--ink);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.inside-stage {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background: linear-gradient(160deg, #1A1A1D 0%, #0F0F10 100%);
}

.inside-frame {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.7s var(--ease);
    pointer-events: none;
    will-change: opacity;
}
.inside-frame.is-active {
    opacity: 1;
    pointer-events: auto;
}

/* Photo crop layer */
.inside-photo {
    position: absolute;
    inset: 0;
    overflow: hidden;
}
.inside-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: var(--crop-pos, 50% 50%);
    transform: scale(var(--crop-scale, 1.3));
    filter: saturate(1.05) contrast(1.04);
    transition: transform 1.4s var(--ease);
    will-change: transform;
}
.inside-frame.is-active .inside-photo img {
    transform: scale(calc(var(--crop-scale, 1.3) * 0.94));
}

/* Photo grade — cinematic dark vignette */
.inside-photo-grade {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 60% at 50% 40%, transparent 0%, rgba(15,15,16,0.45) 75%, rgba(15,15,16,0.85) 100%),
        linear-gradient(180deg, rgba(15,15,16,0.05) 0%, rgba(15,15,16,0.55) 100%);
    pointer-events: none;
    mix-blend-mode: multiply;
}
/* Soft red ambient glow */
.inside-photo-glow {
    position: absolute;
    bottom: -10%; right: -10%;
    width: 60%; height: 60%;
    background: radial-gradient(circle, var(--red-glow-strong), transparent 65%);
    filter: blur(60px);
    pointer-events: none;
    opacity: 0.7;
}

/* Right-column overlay */
.inside-overlay {
    position: relative;
    height: 100%;
    background: linear-gradient(180deg, #1A1A1D 0%, #0F0F10 100%);
    color: var(--paper);
    padding: clamp(50px, 7vh, 90px) clamp(30px, 4vw, 70px) clamp(60px, 7vh, 90px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 22px;
    overflow: hidden;
    z-index: 2;
}
.inside-overlay::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 1px; height: 100%;
    background: linear-gradient(180deg, transparent, rgba(247,246,243,0.08) 50%, transparent);
}
.inside-overlay::after {
    content: '';
    position: absolute;
    top: -10%; left: -20%;
    width: 60%; height: 60%;
    background: radial-gradient(circle, var(--red-glow), transparent 70%);
    filter: blur(50px);
    pointer-events: none;
}

.inside-frame:not(.is-active) .inside-overlay > * {
    opacity: 0;
    transform: translateY(20px);
}
.inside-frame.is-active .inside-overlay > * {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.7s var(--ease) 0.15s, transform 0.7s var(--ease) 0.15s;
}
.inside-frame.is-active .inside-overlay .inside-tag        { transition-delay: 0.10s; }
.inside-frame.is-active .inside-overlay .inside-stat       { transition-delay: 0.18s; }
.inside-frame.is-active .inside-overlay .inside-frame-title { transition-delay: 0.26s; }
.inside-frame.is-active .inside-overlay .inside-body       { transition-delay: 0.34s; }

/* Tag pill */
.inside-tag {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    align-self: flex-start;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--paper);
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid rgba(247,246,243,0.16);
    background: rgba(255,255,255,0.04);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.inside-tag-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--red-light);
    box-shadow: 0 0 0 4px rgba(230,57,70,0.18);
    animation: dotPulse 2.6s ease-in-out infinite;
}

/* Mega stat */
.inside-stat {
    display: flex;
    align-items: baseline;
    gap: 14px;
    flex-wrap: wrap;
    margin: 4px 0 -8px;
}
.inside-stat-v {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    font-size: clamp(72px, 11vw, 168px);
    line-height: 0.86;
    letter-spacing: -0.04em;
    background: linear-gradient(180deg, var(--paper) 0%, var(--paper) 55%, var(--red-light) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    padding-bottom: 0.06em;
}
.inside-stat-u {
    font-family: var(--font-mono);
    font-size: clamp(13px, 1.1vw, 16px);
    color: rgba(247,246,243,0.65);
    letter-spacing: 0.04em;
    max-width: 18ch;
    line-height: 1.3;
}

.inside-frame-title {
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: clamp(26px, 2.6vw, 38px);
    line-height: 1.08;
    letter-spacing: -0.022em;
    color: var(--paper);
    text-wrap: balance;
    max-width: 14ch;
}
.inside-frame-title em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    background: linear-gradient(180deg, var(--red-light) 0%, var(--red) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.inside-body {
    font-size: clamp(14.5px, 1.2vw, 16.5px);
    line-height: 1.6;
    color: rgba(247,246,243,0.7);
    max-width: 42ch;
    text-wrap: pretty;
}

/* Right rail */
.inside-rail {
    position: absolute;
    bottom: clamp(28px, 4vh, 44px);
    left: clamp(24px, 3vw, 50px);
    right: clamp(24px, 3vw, 50px);
    z-index: 5;
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: clamp(20px, 3vw, 36px);
    align-items: center;
}
.inside-rail-progress {
    position: relative;
    height: 1px;
    background: rgba(247,246,243,0.14);
    overflow: hidden;
}
.inside-rail-progress-fill {
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: var(--p, 0%);
    background: linear-gradient(90deg, var(--red), var(--red-light));
    transition: width 0.5s var(--ease);
}
.inside-rail-tabs {
    display: flex;
    gap: 4px;
}
.inside-rail-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid transparent;
    background: transparent;
    color: rgba(247,246,243,0.45);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: color 0.4s var(--ease), border-color 0.4s, background 0.4s, transform 0.4s;
}
.inside-rail-tab:hover {
    color: var(--paper);
    transform: translateY(-1px);
}
.inside-rail-tab.is-active {
    color: var(--paper);
    border-color: var(--red);
    background: rgba(200,16,46,0.18);
}
.inside-rail-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px 10px 16px;
    border-radius: 999px;
    background: var(--red);
    color: var(--paper);
    font-family: var(--font-sans);
    font-size: 13px;
    font-weight: 500;
    transition: background 0.4s var(--ease), transform 0.4s;
}
.inside-rail-cta:hover {
    background: var(--red-deep);
    transform: translateY(-1px);
}
.inside-rail-cta .btn-arrow {
    width: 22px; height: 22px;
    background: rgba(255,255,255,0.16);
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
}

/* Mobile fallback — stacked frames, no pin */
@media (max-width: 1024px) {
    .inside-pin {
        height: auto;
        grid-template-columns: 1fr;
    }
    .inside-stage {
        position: static;
        height: auto;
    }
    .inside-frame {
        position: static;
        opacity: 1;
        pointer-events: auto;
        display: grid;
        grid-template-rows: 56svh auto;
        border-bottom: 1px solid rgba(247,246,243,0.06);
    }
    .inside-frame:last-child { border-bottom: 0; }
    .inside-photo { position: relative; height: 56svh; }
    .inside-overlay {
        padding: clamp(36px, 6vw, 60px) clamp(24px, 5vw, 40px);
    }
    .inside-frame .inside-overlay > * {
        opacity: 1 !important;
        transform: none !important;
    }
    .inside-rail {
        position: static;
        margin: clamp(24px, 4vw, 40px) clamp(20px, 4vw, 40px);
        grid-template-columns: 1fr auto;
    }
    .inside-rail-tabs { display: none; }
    .inside-rail-progress { display: none; }
}

/* ============================================================
   v7 OVERRIDES — FAQ fix, hero img cover, padding consistency,
   Inside sticky-track (no GSAP pin)
   ============================================================ */

/* ---------- 1. FAQ open behaviour (grid-rows trick, clean) ---------- */
.faq-a {
    display: grid !important;
    grid-template-rows: 0fr !important;
    transition: grid-template-rows 0.55s var(--ease) !important;
    overflow: hidden;
    height: auto !important;
    margin: 0;
    padding: 0;
}
.faq-a > .faq-a-inner {
    overflow: hidden;
    min-height: 0;
}
.faq-item.is-open .faq-a {
    grid-template-rows: 1fr !important;
}
/* Fallback for browsers that can't animate grid-template-rows */
@supports not (grid-template-rows: 0fr) {
    .faq-a { display: block !important; grid-template-rows: none !important; max-height: 0; transition: max-height 0.55s var(--ease) !important; }
    .faq-item.is-open .faq-a { max-height: 1200px; }
}


/* ---------- 2. Hero product image: cover, full bleed in shape ---------- */
.hero-product-frame {
    border-radius: var(--radius-2xl) !important;
    overflow: hidden !important;
    background: linear-gradient(140deg, #FBFAF7 0%, #EAE8E1 100%) !important;
    box-shadow: var(--shadow-lg) !important;
}
.hero-product-frame::before {
    content: '' !important;
    position: absolute; inset: 0;
    background:
        radial-gradient(120% 80% at 30% 10%, rgba(255,255,255,0.35), transparent 55%),
        radial-gradient(70% 50% at 80% 90%, var(--red-glow), transparent 65%);
    pointer-events: none;
    z-index: 2;
}
.hero-product-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    padding: 0 !important;
    border-radius: 0 !important;
    filter: saturate(1.04) contrast(1.04) !important;
    position: relative;
    z-index: 1;
}
.hero-visual::before {
    border-radius: var(--radius-2xl) !important;
}
.hero-product-floor { display: none !important; }


/* ---------- 3. Padding consistency across all sections ---------- */
.panel { padding: 0 !important; }

/* All inner content rails use the same container + pad-x */
.section-head:not(.section-head--centered),
.section-head.section-head--centered,
.products-grid,
.salons-grid,
.salons-stage,
.advantage-grid,
.consult-grid,
.faq-list,
.testimonial-rail,
.income-rows,
.income-cta,
.calc-card,
.finance-line,
.salons-stats {
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
    box-sizing: border-box;
}

/* income panel as full-bleed dark band, content respects pad-x */
.panel--income {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: var(--ink) !important;
}
.panel--income .panel-content {
    max-width: none !important;
    width: 100%;
}
.panel--income .big-number {
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
}

/* Final + footer — consistent pad-x */
.final, .site-footer {
    padding-left: var(--pad-x) !important;
    padding-right: var(--pad-x) !important;
}

/* Inside intro */
.inside-intro {
    padding-left: var(--pad-x) !important;
    padding-right: var(--pad-x) !important;
}

/* testimonial-rail — was padding-left only; restore symmetry */
.testimonial-track {
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
}
.testimonial-rail { padding-left: 0 !important; padding-right: 0 !important; }


/* ---------- 4. INSIDE: sticky-track replacement (no GSAP pin) ---------- */
.inside-track {
    position: relative;
    width: 100%;
    /* total height = N frames × 100vh */
    --inside-frame-vh: 95svh;
    height: calc(var(--inside-frames, 5) * var(--inside-frame-vh));
}
.inside-sticky {
    position: sticky;
    top: 0;
    width: 100%;
    height: 100svh;
    z-index: 1;
    overflow: hidden;
}
.inside-sticky .inside-pin {
    position: relative;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    background: var(--ink);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
}

/* Markers — invisible 1px slabs (one per frame) used by IntersectionObserver */
.inside-markers {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    pointer-events: none;
    z-index: 0;
}
.inside-marker {
    flex: 0 0 var(--inside-frame-vh, 95svh);
    width: 100%;
}

/* Mobile: drop sticky/track height — just stack frames vertically */
@media (max-width: 1024px) {
    .inside-track { height: auto !important; }
    .inside-sticky { position: static !important; height: auto !important; overflow: visible !important; }
    .inside-sticky .inside-pin {
        display: block !important;
        height: auto !important;
        background: var(--ink);
        box-shadow: none !important;
    }
    .inside-markers { display: none !important; }
    .inside-stage { position: static !important; height: auto !important; }
    .inside-frame {
        position: static !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        display: grid !important;
        grid-template-rows: 56svh auto;
    }
    .inside-frame .inside-overlay > * {
        opacity: 1 !important;
        transform: none !important;
    }
    .inside-photo {
        position: relative !important;
        height: 56svh !important;
    }
    .inside-rail {
        position: static !important;
        margin: clamp(20px, 4vw, 36px) clamp(20px, 4vw, 40px) !important;
        grid-template-columns: 1fr auto !important;
    }
    .inside-rail-tabs, .inside-rail-progress { display: none !important; }
}

/* ============================================================
   v8 OVERRIDES — FAQ max-height (JS), padding bottom-clip fix,
   desktop padless rails, floating widget hide on Inside,
   testimonial controls realignment
   ============================================================ */

/* ---------- 1. FAQ open via JS-controlled max-height ---------- */
.faq-a {
    display: block !important;
    grid-template-rows: none !important;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.55s var(--ease) !important;
    height: auto !important;
}
.faq-a > .faq-a-inner {
    overflow: hidden;
    min-height: 0;
}
.faq-item.is-open .faq-a {
    /* JS sets explicit max-height in px; this is just a safety ceiling */
    max-height: 1200px;
}


/* ---------- 2. Padding-right for clipped italic descenders ---------- */
.bn-mask {
    padding-right: 8px !important;
    padding-bottom: 0.2em !important;
    padding-left: 4px !important;
}
.bn-mask .bn-text {
    padding-right: 5px;
    padding-bottom: 0.06em;
}
[data-split-lines] .split-line {
    padding-right: 0.22em !important;
    padding-bottom: 0.18em !important;
}
[data-split-lines] .split-line-inner {
    padding-right: 0.1em;
}
.inside-stat-v {
    padding-right: 8px;
    padding-bottom: 0.08em;
}
.section-title em,
.hero-line em,
.tech-fin-title em,
.final-title em,
.t-text::first-letter {
    /* gradient text-clip — descenders/swashes need breathing room */
    padding-right: 0.04em;
}


/* ---------- 4. Desktop ≥ container — drop pad-x on inner rails ---------- */
@media (min-width: 1380px) {
    .section-head:not(.section-head--centered),
    .section-head.section-head--centered,
    .products-grid,
    .salons-grid,
    .salons-stage,
    .advantage-grid,
    .consult-grid,
    .faq-list,
    .income-rows,
    .income-cta,
    .calc-card,
    .finance-line,
    .salons-stats,
    .inside-intro {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    /* Income big-number still needs a bit so the gradient text-clip
       doesn't kiss the canvas edge on ultra-wide */
    .panel--income .big-number { padding-left: 0; padding-right: 0; }
}


/* ---------- 5. Testimonial controls re-align ---------- */
.testimonial-rail {
    position: relative;
    overflow: hidden;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.testimonial-track {
    padding-left: var(--pad-x) !important;
    padding-right: var(--pad-x) !important;
}
.rail-controls {
    max-width: var(--container) !important;
    margin: clamp(16px, 2vw, 24px) auto 0 !important;
    padding-left: var(--pad-x) !important;
    padding-right: var(--pad-x) !important;
    display: flex !important;
    gap: 8px !important;
    justify-content: flex-end !important;
}
@media (min-width: 1380px) {
    .testimonial-track,
    .rail-controls {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    .testimonial-track,
    .rail-controls {
        max-width: var(--container);
        margin-left: auto;
        margin-right: auto;
    }
}


/* ---------- 6. Floating widget hide on Inside section ---------- */
body.inside-active .floating-widget {
    transform: translateY(150%) !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* ============================================================
   v9 OVERRIDES — calc card external/internal split,
   section-head padding hardening
   ============================================================ */

/* ---------- 1. .calc-card has its OWN internal padding ----------
   Mistake in v7/v8: .calc-card was added to the inner-rail rule that
   sets padding-left/right: var(--pad-x). But that's a CARD with its
   own internal padding (clamp 24-50px). The result: on viewport
   ≥1380px we wiped its internal padding to 0, sliders kissed the
   border. Fix: keep internal padding always, drive external spacing
   via margin. */
.calc-card {
    padding: clamp(24px, 3.5vw, 50px) !important;
    margin-left: var(--pad-x);
    margin-right: var(--pad-x);
}
@media (min-width: 1380px) {
    .calc-card {
        margin-left: auto !important;
        margin-right: auto !important;
    }
}


/* ---------- 2. Section-head padding hardening ----------
   Cache plugins / CDNs sometimes drop !important padding overrides
   merged from media queries. Lock pad-x explicitly with the same
   priority as v7 rule, plus reset on ≥1380px. */
.section-head {
    max-width: var(--container);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--pad-x) !important;
    padding-right: var(--pad-x) !important;
    box-sizing: border-box;
}
.section-head--centered { align-items: center; }
@media (min-width: 1380px) {
    .section-head {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}

/* Same for inside-intro and the marquee/rails so they stay aligned
   to the same container as section-head on every viewport */
.inside-intro {
    max-width: var(--container);
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   v10 — Testimonials edge alignment (with section-head)
   ============================================================ */

/* Universal "edge gutter" — aligns content to container edges on
   desktop, falls back to pad-x on smaller screens. Used wherever
   we want elements to land exactly on the same vertical line as
   .section-head (max-width + margin auto). */
:root {
    --edge-gutter: max(var(--pad-x), calc((100vw - var(--container)) / 2));
}

/* Testimonials: rail flush, track + controls use edge-gutter so
   first/last card and arrow buttons line up with section-head. */
.panel--testimonials .testimonial-rail {
    max-width: 100% !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    overflow: hidden;
}
.panel--testimonials .testimonial-track {
    padding-left: var(--edge-gutter) !important;
    padding-right: var(--edge-gutter) !important;
    max-width: none !important;
    margin: 0 !important;
}
.panel--testimonials .rail-controls {
    max-width: none !important;
    margin: clamp(16px, 2vw, 24px) 0 0 !important;
    padding-left: var(--edge-gutter) !important;
    padding-right: var(--edge-gutter) !important;
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

/* Cancel v8/v9 desktop overrides for these specific selectors */
@media (min-width: 1380px) {
    .panel--testimonials .testimonial-track,
    .panel--testimonials .rail-controls {
        padding-left: var(--edge-gutter) !important;
        padding-right: var(--edge-gutter) !important;
        max-width: none !important;
    }
}

/* ============================================================
   v11 — TESTIMONIALS section-head + rail-controls hardlocked
   to edge-gutter on every viewport. Highest specificity.
   ============================================================ */

.panel--testimonials .section-head {
    max-width: 100% !important;
    margin: 0 0 clamp(36px, 4vw, 56px) 0 !important;
    padding-left: var(--edge-gutter) !important;
    padding-right: var(--edge-gutter) !important;
    box-sizing: border-box !important;
    align-items: flex-start !important;
}

.panel--testimonials .rail-controls {
    max-width: 100% !important;
    margin: clamp(20px, 2.4vw, 32px) 0 0 0 !important;
    padding-left: var(--edge-gutter) !important;
    padding-right: var(--edge-gutter) !important;
    display: flex !important;
    gap: 10px !important;
    justify-content: flex-end !important;
    box-sizing: border-box !important;
}

/* Override any inherited media-query reset */
@media (min-width: 1380px) {
    .panel--testimonials .section-head,
    .panel--testimonials .rail-controls {
        padding-left: var(--edge-gutter) !important;
        padding-right: var(--edge-gutter) !important;
    }
}


/* ============================================================
   v13 — Scroll-to-top, Inside desktop photo, Hero mobile order,
   mobile overflow audit, testimonial arrows + centering
   ============================================================ */

/* ---------- 1. Scroll-to-top floating arrow (left) ---------- */
.scroll-top {
    position: fixed;
    left: clamp(14px, 2vw, 24px);
    bottom: clamp(20px, 3vh, 32px);
    z-index: 70;
    width: 46px; height: 46px;
    border-radius: 50%;
    border: 1px solid var(--hair);
    background: var(--white);
    color: var(--ink);
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-md, 0 10px 30px -12px rgba(15,15,16,0.18));
    cursor: pointer;
    opacity: 0;
    transform: translateY(12px) scale(0.92);
    pointer-events: none;
    transition: opacity 0.4s var(--ease), transform 0.5s var(--ease), background 0.3s, color 0.3s, border-color 0.3s;
}
.scroll-top.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}
.scroll-top:hover {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
    transform: translateY(-2px) scale(1);
}
@media (max-width: 768px) {
    .scroll-top {
        bottom: 88px; /* sit above sticky-mobile-cta */
        width: 42px; height: 42px;
    }
}

/* ---------- 2. INSIDE Axiom — show photo on desktop (2-col frame) ---------- */
@media (min-width: 1025px) {
    .inside-sticky .inside-pin {
        grid-template-columns: 1fr !important;
    }
    .inside-stage {
        grid-column: 1 / -1;
    }
    .inside-frame {
        display: grid !important;
        grid-template-columns: 1.15fr 1fr;
        align-items: stretch;
    }
    .inside-photo {
        position: relative !important;
        inset: auto !important;
        width: 100%;
        height: 100%;
        overflow: hidden;
    }
    .inside-photo img {
        position: absolute;
        inset: 0;
    }
    .inside-overlay {
        position: relative;
        z-index: 2;
    }
}

/* ---------- 3. Hero — mobile: image FIRST, content SECOND, no overflow ---------- */
.panel--hero { overflow: hidden; }
@media (max-width: 1100px) {
    .hero-grid {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 28px !important;
    }
    .hero-visual {
        order: -1;
        grid-row: 1;
        max-width: 460px;
        width: 100%;
        margin: 0 auto;
        min-height: 320px;
    }
    .hero-content {
        order: 1;
        grid-row: 2;
    }
    /* Tame chips on small viewports so they don't push horizontal overflow */
    .chip--1 { left: 4% !important; }
    .chip--2 { right: 4% !important; }
    .chip--3 { right: 4% !important; }
}
@media (max-width: 768px) {
    .hero-visual {
        max-width: 380px;
        min-height: 280px;
        aspect-ratio: 1 / 1;
    }
    .hero-title { font-size: clamp(30px, 9vw, 44px); max-width: 100%; }
    .hero-sub { font-size: 15px; }
    /* Drop chips on phones — they crowd the photo and cause clipping */
    .chip { display: none !important; }
}

/* ---------- 4. Mobile audit: panel min-height, paddings, btns full-width ---------- */
@media (max-width: 768px) {
    /* Kill 100dvh per panel — it creates huge bottom voids on phones */
    .panel { min-height: auto !important; }
    .panel--hero, .panel--hero .panel-content { min-height: auto !important; }
    .panel-content {
        padding-top: clamp(56px, 9vw, 80px) !important;
        padding-bottom: clamp(48px, 8vw, 72px) !important;
        justify-content: flex-start !important;
    }
    .panel--hero .panel-content {
        padding-top: 96px !important;
        padding-bottom: clamp(40px, 7vw, 60px) !important;
    }
    /* Buttons spilling: clamp lg/xl, force wrap, full-width row */
    .btn--lg, .btn--xl {
        padding: 14px 20px !important;
        font-size: 14.5px !important;
    }
    .hero-cta { flex-direction: column !important; gap: 10px !important; width: 100%; }
    .hero-cta .btn { width: 100%; justify-content: center; }
    /* Calc card adapt: kill internal heavy padding, slim controls */
    .calc-card {
        padding: 22px 18px !important;
        margin-left: var(--pad-x) !important;
        margin-right: var(--pad-x) !important;
    }
    .calc-grid, .calc-result, .calc-rows, .calc-controls {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }
    .calc-card .btn { width: 100%; justify-content: center; }
    /* Income panel CTA */
    .income-cta .btn { width: 100%; justify-content: center; }
    /* Salons / products: trim huge bottom padding */
    .panel--salons .panel-content,
    .panel--products .panel-content {
        padding-bottom: clamp(40px, 8vw, 60px) !important;
    }
    /* Section heads: tighter top */
    .section-head { gap: 10px; margin-bottom: clamp(20px, 5vw, 32px); }
    /* Prevent any element causing horizontal overflow */
    html, body { overflow-x: hidden !important; }
    /* Big number protection */
    .big-number { padding-left: var(--pad-x) !important; padding-right: var(--pad-x) !important; }
    .big-number-v { font-size: clamp(44px, 14vw, 80px) !important; }
}

/* ---------- 5. Testimonials — center cards on mobile, bigger arrows ---------- */
.rail-btn {
    width: 46px !important;
    height: 46px !important;
}
.rail-btn svg { width: 16px; height: 16px; }
.panel--testimonials .rail-controls {
    justify-content: center !important;
    gap: 14px !important;
}
@media (max-width: 768px) {
    .panel--testimonials .testimonial-track {
        grid-auto-columns: 88% !important;
        scroll-snap-type: x mandatory;
        scroll-padding-left: var(--edge-gutter) !important;
        scroll-padding-right: var(--edge-gutter) !important;
        gap: 14px !important;
    }
    .panel--testimonials .testimonial { scroll-snap-align: center; }
    .panel--testimonials .rail-controls {
        margin-top: 18px !important;
    }
}
/* Replace caret-style arrows with cleaner chevrons via overlay glyph */
.rail-btn[data-rail-prev] svg path,
.rail-btn[data-rail-next] svg path {
    stroke-width: 1.5;
}


/* ============================================================
   v14 — Inside Axiom desktop split, mobile overflow nuke,
   testimonials card+arrows refinement, hero mobile order
   ============================================================ */

/* ---------- 1. INSIDE Axiom desktop: photo LEFT / text RIGHT split ---------- */
/* Keep the original pin geometry (sticky + grid) intact. Only override
   the frame's internal layout so photo and overlay are side-by-side
   inside each absolutely-positioned frame. */
@media (min-width: 1025px) {
    /* Stage takes full width — drop the 1.2fr/1fr split (rail is absolute anyway) */
    .inside-sticky .inside-pin {
        grid-template-columns: 1fr !important;
    }
    /* Each frame splits internally: photo (left) + overlay (right) */
    .inside-frame {
        display: grid !important;
        grid-template-columns: 1.15fr 1fr !important;
        align-items: stretch;
    }
    /* Photo cell — stop being absolute, let grid place it */
    .inside-photo {
        position: relative !important;
        inset: auto !important;
        width: 100% !important;
        height: 100% !important;
        grid-column: 1 !important;
        overflow: hidden;
    }
    .inside-photo img {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }
    /* Overlay cell — natural height in grid */
    .inside-overlay {
        position: relative !important;
        height: auto !important;
        grid-column: 2 !important;
        z-index: 2;
    }
    /* Rail stays as absolute overlay on the bottom of the pin */
    .inside-rail {
        position: absolute !important;
        z-index: 5;
    }
}

/* ---------- 2. Mobile overflow NUKE — kill horizontal scroll ---------- */
/* CRITICAL: overflow-x:hidden on <html>/<body> establishes a scroll
   container and BREAKS position:sticky (kills Inside Axiom pin).
   Use overflow-x:clip which contains overflow without becoming a
   scroll container. */
html { overflow-x: clip; }
body { overflow-x: clip; }
@supports not (overflow: clip) {
    body { overflow-x: hidden; }
}
img, video { max-width: 100%; height: auto; }
/* NOTE: do NOT add max-width:100% or min-width:0 globally — both break
   intentional max-widths (e.g. .products-grid max-width: var(--container))
   AND collapse flex marquees. Mobile overflow is handled per-element
   via media-query rules below. */

/* ---------- 3. Testimonials: cleaner arrows, mobile-safe card width ---------- */
.rail-btn {
    width: 48px !important;
    height: 48px !important;
    border-radius: 50% !important;
    border: 1px solid var(--hair) !important;
    background: var(--white) !important;
    color: var(--ink) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.35s var(--ease), color 0.35s, border-color 0.35s, transform 0.35s !important;
}
.rail-btn:hover {
    background: var(--ink) !important;
    color: var(--paper) !important;
    border-color: var(--ink) !important;
    transform: translateY(-2px);
}
.panel--testimonials .rail-controls {
    justify-content: center !important;
    gap: 12px !important;
}

@media (max-width: 768px) {
    /* Card width clamp: never wider than 86vw, never under 240px */
    .panel--testimonials .testimonial-track {
        grid-auto-columns: min(86vw, 340px) !important;
        gap: 12px !important;
        scroll-snap-type: x mandatory;
        scroll-padding-left: var(--edge-gutter) !important;
        scroll-padding-right: var(--edge-gutter) !important;
    }
    .panel--testimonials .testimonial { scroll-snap-align: center; }
    .rail-btn { width: 44px !important; height: 44px !important; }
}

/* ---------- 4. HERO mobile: photo first, content second, no overflow ---------- */
@media (max-width: 1100px) {
    .hero-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 24px !important;
    }
    .hero-visual {
        order: -1 !important;
        width: 100% !important;
        max-width: 460px !important;
        margin: 0 auto !important;
        min-height: 300px;
        aspect-ratio: 1 / 1;
    }
    .hero-content {
        order: 1 !important;
        width: 100% !important;
        align-items: flex-start;
    }
    .hero-title { max-width: 100% !important; }
    .hero-sub { max-width: 100% !important; }
}

@media (max-width: 768px) {
    .hero-visual { max-width: 360px !important; min-height: 260px; }
    .hero-title { font-size: clamp(28px, 8.5vw, 40px) !important; }
    .chip { display: none !important; }
    /* Buttons & trust full-width */
    .hero-cta {
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
    }
    .hero-cta .btn { width: 100% !important; justify-content: center !important; }
    .hero-trust { font-size: 11.5px; gap: 8px 14px; }
}

/* ---------- 5. Calculator mobile rebuild ---------- */
@media (max-width: 768px) {
    .calc-card {
        grid-template-columns: 1fr !important;
        gap: 22px !important;
        padding: 20px 16px !important;
        border-radius: 22px !important;
        margin-left: var(--pad-x) !important;
        margin-right: var(--pad-x) !important;
        max-width: calc(100vw - 2 * var(--pad-x)) !important;
    }
    .calc-controls { gap: 18px !important; }
    .calc-field-head { gap: 4px 8px; }
    .calc-value { font-size: clamp(22px, 7vw, 28px) !important; }
    .calc-result {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto !important;
        gap: 4px 0 !important;
        padding: 14px 16px !important;
    }
    .calc-result-value {
        grid-column: 1 !important;
        grid-row: auto !important;
        font-size: clamp(22px, 6.5vw, 28px) !important;
    }
    .calc-result-value--xl { font-size: clamp(28px, 8vw, 36px) !important; }
}

/* ---------- 6. Mobile: trim huge bottom voids on products + salons ---------- */
@media (max-width: 768px) {
    .panel { min-height: auto !important; }
    .panel--hero, .panel--hero .panel-content { min-height: auto !important; }
    .panel-content {
        padding-top: clamp(56px, 9vw, 80px) !important;
        padding-bottom: clamp(40px, 7vw, 56px) !important;
        justify-content: flex-start !important;
        gap: clamp(20px, 5vw, 32px) !important;
    }
    .panel--hero .panel-content {
        padding-top: 92px !important;
        padding-bottom: clamp(36px, 6vw, 52px) !important;
        min-height: auto !important;
    }
    .panel--products .panel-content,
    .panel--salons .panel-content {
        padding-bottom: clamp(36px, 6vw, 52px) !important;
        gap: clamp(24px, 5vw, 36px) !important;
    }
    .panel--salons .salons-stage { gap: clamp(24px, 6vw, 40px) !important; }
    /* Inside Axiom mobile: lower frame photo height so 5 frames don't kill scroll */
    .inside-frame { grid-template-rows: 44svh auto !important; }
    .inside-photo { height: 44svh !important; }
    .inside-overlay { padding: 28px 20px !important; gap: 14px !important; }
    .inside-stat-v { font-size: clamp(54px, 16vw, 88px) !important; }
    .inside-frame-title { font-size: clamp(22px, 6vw, 28px) !important; }
}

/* ---------- 7. Mobile: section heads + buttons full-fit ---------- */
@media (max-width: 768px) {
    .btn--lg, .btn--xl {
        padding: 14px 18px !important;
        font-size: 14.5px !important;
    }
    .btn--full { width: 100% !important; }
    .income-cta {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 14px !important;
    }
    .income-cta .btn { width: 100% !important; justify-content: center !important; }
    .income-row { grid-template-columns: 30px 1fr !important; row-gap: 4px !important; }
    .income-row-value { grid-column: 2 !important; font-size: 18px !important; }
    /* Big number doesn't smash edges */
    .big-number { padding-left: var(--pad-x) !important; padding-right: var(--pad-x) !important; }
    .big-number-v { font-size: clamp(44px, 13vw, 80px) !important; }
    /* Section title scale safeguard */
    .section-title { font-size: clamp(28px, 8vw, 42px) !important; }
    .section-title--lg { font-size: clamp(32px, 9.5vw, 50px) !important; }
}

/* ---------- 8. Scroll-to-top z-order vs sticky CTA ---------- */
.scroll-top { z-index: 75; }
@media (max-width: 768px) {
    .scroll-top { left: 14px; bottom: 90px; }
}


/* ============================================================
   v15 — Footer marquee fix, side gutters restoration,
   mobile header rebuild
   ============================================================ */

/* ---------- 1. Footer marquee — kill overlap, speed up ---------- */
/* Without width:max-content, flex items shrink and overlap. Force
   intrinsic width so each glyph keeps its space. Speed: 42s → 26s. */
.fm-track {
    width: max-content !important;
    flex-wrap: nowrap !important;
    animation: fmScroll 26s linear infinite !important;
}
.fm-track > * { flex: 0 0 auto !important; }


/* ---------- 2. Mobile header rebuild — richer, more premium ---------- */
@media (max-width: 768px) {
    .site-header {
        padding: 10px 14px !important;
    }
    .header-inner {
        grid-template-columns: auto 1fr auto !important;
        gap: 12px !important;
        align-items: center;
    }
    /* Bigger logo on mobile for presence */
    .brand-logo { height: 38px !important; }
    /* Lang switch: pill with current language code, not a tiny dot */
    .lang-switch {
        width: auto !important;
        height: 36px !important;
        padding: 0 14px !important;
        border-radius: 999px !important;
        font-size: 12px !important;
        font-weight: 500 !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        background: transparent;
        color: var(--ink);
    }
    /* Compact phone CTA injected via header-actions */
    .header-actions {
        gap: 8px !important;
    }
    .header-actions .header-call {
        display: inline-flex !important;
        align-items: center; justify-content: center;
        width: 36px; height: 36px;
        border-radius: 50%;
        background: var(--red);
        color: var(--paper);
        flex: 0 0 auto;
        transition: background 0.3s var(--ease), transform 0.3s;
    }
    .header-actions .header-call:hover { background: var(--red-deep); transform: scale(1.05); }
    /* Burger: bigger, friendlier */
    .nav-toggle {
        width: 42px !important;
        height: 42px !important;
        border-radius: 999px !important;
        border: 1px solid var(--hair) !important;
        background: var(--white);
        position: relative;
    }
    .nav-toggle span {
        position: absolute !important;
        left: 12px !important;
        right: 12px !important;
        height: 1.6px !important;
        background: var(--ink);
        border-radius: 2px;
    }
    .nav-toggle span:nth-child(1) { top: 16px !important; }
    .nav-toggle span:nth-child(2) { top: 24px !important; }
    .nav-toggle.is-open span:nth-child(1) { top: 20px !important; transform: rotate(45deg); }
    .nav-toggle.is-open span:nth-child(2) { top: 20px !important; transform: rotate(-45deg); }
    /* Scrolled header: solid white pill across the full strip */
    .site-header.is-scrolled { padding-top: 6px !important; padding-bottom: 6px !important; }
}

/* Hide header-call on desktop — keep mobile-only */
.header-call { display: none; }


/* ---------- 3. Mobile: ensure consult+products keep side gutters ---------- */
/* These were victims of v14's max-width:100% override (now removed),
   but we still want a hard floor of 14px on extra-narrow phones. */
@media (max-width: 480px) {
    .panel-content {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}
