/* =====================================================================
   Staffono Studio — early access landing
   Self-contained styles (scoped under .studio-body) — LIGHT theme
   ===================================================================== */

.studio-body {
    --bg: #f6f3fc;
    --bg-2: #ffffff;
    --bg-soft: #efeaf9;
    --card: #ffffff;
    --line: rgba(124, 58, 237, 0.12);
    --line-soft: rgba(24, 18, 37, 0.08);
    --text: #181225;
    --muted: #5d5570;
    --muted-2: #948da6;
    --primary: #8b5cf6;
    --primary-2: #7c3aed;
    --magenta: #d946ef;
    --grad: linear-gradient(120deg, #7c3aed 0%, #a855f7 45%, #d946ef 100%);
    --shadow-card: 0 24px 60px -34px rgba(91, 45, 168, 0.40);
    --shadow-soft: 0 12px 30px -18px rgba(91, 45, 168, 0.30);
    --radius: 18px;
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

.studio-body * { box-sizing: border-box; }

.studio-body #smooth-wrapper,
.studio-body #smooth-content { width: 100%; }

.studio-body main { display: block; }

.studio-body img { max-width: 100%; display: block; }

.st-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

h1, h2, h3 {
    font-family: 'Sora', 'Inter', sans-serif;
    font-weight: 700;
    line-height: 1.08;
    letter-spacing: -0.02em;
    margin: 0;
    color: var(--text);
}

a { color: inherit; text-decoration: none; }

/* ---------- Buttons ---------- */
.st-btn {
    --pad-y: 15px;
    --pad-x: 26px;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: var(--pad-y) var(--pad-x);
    border-radius: 999px;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, border-color .25s;
    white-space: nowrap;
}
.st-btn--sm { --pad-y: 10px; --pad-x: 18px; font-size: 14px; }
.st-btn--block { width: 100%; }
.st-btn--solid {
    background: var(--grad);
    color: #fff;
    box-shadow: 0 12px 30px -10px rgba(168, 85, 247, 0.6);
}
.st-btn--solid:hover { transform: translateY(-2px); box-shadow: 0 20px 44px -12px rgba(168, 85, 247, 0.75); }
.st-btn--ghost {
    background: #fff;
    border-color: var(--line);
    color: var(--text);
    box-shadow: var(--shadow-soft);
}
.st-btn--ghost:hover { border-color: rgba(124,58,237,0.5); transform: translateY(-2px); }

.st-btn__spinner {
    width: 16px; height: 16px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.45);
    border-top-color: #fff;
    display: none;
    animation: st-spin .7s linear infinite;
}
.st-btn.is-loading { pointer-events: none; opacity: .85; }
.st-btn.is-loading .st-btn__spinner { display: inline-block; }
@keyframes st-spin { to { transform: rotate(360deg); } }

/* ---------- Nav ---------- */
.st-nav {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 6px 32px;
    transition: background .35s, backdrop-filter .35s, padding .35s, border-color .35s, box-shadow .35s;
    border-bottom: 1px solid transparent;
}
.st-nav.is-stuck {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(14px);
    border-bottom-color: var(--line);
    box-shadow: 0 8px 30px -20px rgba(91, 45, 168, 0.5);
    padding: 4px 32px;
}
.st-nav__brand img { height: 160px; width: auto; display: block; }
.st-nav.is-stuck .st-nav__brand img { height: 120px; }
.st-nav__links { display: flex; gap: 30px; }
.st-nav__links a { color: var(--muted); font-size: 15px; font-weight: 500; transition: color .2s; }
.st-nav__links a:hover { color: var(--primary-2); }

/* ---------- Hero ---------- */
.st-hero {
    position: relative;
    padding: 210px 0 90px;
    overflow: hidden;
    background:
        radial-gradient(1200px 600px at 72% 0%, rgba(168,85,247,0.20), transparent 60%),
        radial-gradient(900px 520px at 8% 18%, rgba(217,70,239,0.14), transparent 55%),
        linear-gradient(180deg, #efeafb 0%, var(--bg) 70%);
}
.st-hero__grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(124,58,237,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(124,58,237,0.06) 1px, transparent 1px);
    background-size: 64px 64px;
    mask-image: radial-gradient(900px 600px at 60% 0%, #000 30%, transparent 75%);
    -webkit-mask-image: radial-gradient(900px 600px at 60% 0%, #000 30%, transparent 75%);
    pointer-events: none;
}
.st-hero__glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    opacity: .5;
    pointer-events: none;
    will-change: transform;
}
.st-hero__glow--1 { width: 520px; height: 520px; top: -120px; right: -60px; background: rgba(168,85,247,0.45); }
.st-hero__glow--2 { width: 420px; height: 420px; bottom: -160px; left: -80px; background: rgba(217,70,239,0.30); }

.st-hero__inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 50px;
    align-items: center;
}
.st-hero__title {
    font-size: clamp(2.4rem, 5vw, 4rem);
    margin: 22px 0 20px;
    max-width: 16ch;
}
.st-hero__sub {
    color: var(--muted);
    font-size: clamp(1rem, 1.4vw, 1.18rem);
    max-width: 46ch;
    margin-bottom: 30px;
}
.st-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }
.st-hero__meta { display: flex; align-items: center; gap: 14px; margin-top: 30px; }
.st-hero__meta p { margin: 0; color: var(--muted); font-size: 14px; }
.st-avatars { display: flex; }
.st-avatars span {
    width: 34px; height: 34px; border-radius: 50%;
    margin-left: -10px; border: 2px solid #fff;
    background: var(--grad);
    box-shadow: 0 4px 10px -4px rgba(91,45,168,0.5);
}
.st-avatars span:first-child { margin-left: 0; }
.st-avatars span:nth-child(2) { background: linear-gradient(120deg,#22d3ee,#7c3aed); }
.st-avatars span:nth-child(3) { background: linear-gradient(120deg,#f59e0b,#d946ef); }
.st-avatars span:nth-child(4) { background: linear-gradient(120deg,#34d399,#8b5cf6); }

/* Pill */
.st-pill {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 7px 14px; border-radius: 999px;
    background: rgba(139,92,246,0.10);
    border: 1px solid rgba(139,92,246,0.30);
    color: #6d28d9; font-size: 13px; font-weight: 600;
}
.st-pill__dot {
    width: 8px; height: 8px; border-radius: 50%; background: #10b981;
    box-shadow: 0 0 0 0 rgba(16,185,129,0.5);
    animation: st-ping 1.8s infinite;
}
@keyframes st-ping {
    0% { box-shadow: 0 0 0 0 rgba(16,185,129,0.5); }
    70% { box-shadow: 0 0 0 8px rgba(16,185,129,0); }
    100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); }
}

/* Hero visual / screenshots */
.st-hero__visual { position: relative; min-height: 420px; }
.st-shot {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.7);
    box-shadow: 0 40px 80px -34px rgba(40,18,80,0.55);
    background: #0f1117;
}
.st-shot--main { transform: rotate(-1.5deg); }
.st-shot--float { position: absolute; width: 60%; border-radius: 14px; }
.st-shot--a { right: -6%; bottom: -10%; box-shadow: 0 30px 60px -22px rgba(124,58,237,0.5); }
.st-shot--b { left: -10%; top: -8%; width: 46%; }

/* Scroll cue */
.st-scrollcue {
    position: absolute; left: 50%; bottom: 26px; transform: translateX(-50%);
    z-index: 3; color: var(--muted-2); font-size: 12px; letter-spacing: .18em;
    text-transform: uppercase; display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.st-scrollcue span {
    width: 24px; height: 38px; border: 2px solid rgba(124,58,237,0.3); border-radius: 14px; position: relative;
}
.st-scrollcue span::after {
    content: ''; position: absolute; left: 50%; top: 7px; transform: translateX(-50%);
    width: 4px; height: 7px; border-radius: 3px; background: var(--primary);
    animation: st-scroll 1.6s infinite;
}
@keyframes st-scroll { 0% { opacity: 0; top: 7px; } 40% { opacity: 1; } 100% { opacity: 0; top: 20px; } }

/* ---------- Marquee ---------- */
.st-marquee {
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 18px 0;
    overflow: hidden;
    background: #fff;
}
.st-marquee__track {
    display: flex; align-items: center; gap: 26px; width: max-content;
    animation: st-marquee 28s linear infinite;
    color: #b3a9c6; font-family: 'Sora', sans-serif; font-weight: 600;
    font-size: clamp(1.1rem, 2vw, 1.6rem); text-transform: uppercase; letter-spacing: .04em;
}
.st-marquee__track i { color: var(--primary); font-style: normal; }
@keyframes st-marquee { to { transform: translateX(-50%); } }

/* ---------- Sections ---------- */
.st-section { padding: 110px 0; position: relative; }
.st-head { max-width: 760px; margin: 0 auto 56px; text-align: center; }
.st-eyebrow {
    display: inline-block; color: var(--primary-2); font-weight: 600; font-size: 13px;
    letter-spacing: .16em; text-transform: uppercase; margin-bottom: 16px;
}
.st-title { font-size: clamp(1.8rem, 3.4vw, 2.8rem); }

/* Features */
.st-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.st-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 30px;
    box-shadow: var(--shadow-soft);
    transition: transform .4s cubic-bezier(.2,.8,.2,1), border-color .4s, box-shadow .4s;
}
.st-card:hover {
    transform: translateY(-6px);
    border-color: rgba(124,58,237,0.35);
    box-shadow: var(--shadow-card);
}
.st-card__icon {
    width: 52px; height: 52px; border-radius: 14px; margin-bottom: 20px;
    background: rgba(139,92,246,0.12); border: 1px solid rgba(139,92,246,0.25);
    position: relative;
}
.st-card__icon::after {
    content: ''; position: absolute; inset: 0; margin: auto;
    width: 24px; height: 24px;
    background: var(--grad);
    -webkit-mask: center / contain no-repeat;
    mask: center / contain no-repeat;
}
.st-card__icon[data-icon="calendar"]::after { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='3' y1='9' x2='21' y2='9'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='3' y1='9' x2='21' y2='9'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3C/svg%3E"); }
.st-card__icon[data-icon="users"]::after { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E"); }
.st-card__icon[data-icon="sparkles"]::after { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2l1.8 5.5L19 9l-5.2 1.5L12 16l-1.8-5.5L5 9l5.2-1.5z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2l1.8 5.5L19 9l-5.2 1.5L12 16l-1.8-5.5L5 9l5.2-1.5z'/%3E%3C/svg%3E"); }
.st-card__icon[data-icon="link"]::after { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'/%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'/%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'/%3E%3C/svg%3E"); }
.st-card__icon[data-icon="robot"]::after { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='4' y='8' width='16' height='12' rx='2'/%3E%3Ccircle cx='9' cy='14' r='1.4' fill='black' stroke='none'/%3E%3Ccircle cx='15' cy='14' r='1.4' fill='black' stroke='none'/%3E%3Cline x1='12' y1='4' x2='12' y2='8'/%3E%3Ccircle cx='12' cy='3' r='1.4' fill='black' stroke='none'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='4' y='8' width='16' height='12' rx='2'/%3E%3Ccircle cx='9' cy='14' r='1.4' fill='black' stroke='none'/%3E%3Ccircle cx='15' cy='14' r='1.4' fill='black' stroke='none'/%3E%3Cline x1='12' y1='4' x2='12' y2='8'/%3E%3Ccircle cx='12' cy='3' r='1.4' fill='black' stroke='none'/%3E%3C/svg%3E"); }
.st-card__icon[data-icon="chart"]::after { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cline x1='4' y1='20' x2='4' y2='12'/%3E%3Cline x1='10' y1='20' x2='10' y2='5'/%3E%3Cline x1='16' y1='20' x2='16' y2='9'/%3E%3Cline x1='22' y1='20' x2='2' y2='20'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cline x1='4' y1='20' x2='4' y2='12'/%3E%3Cline x1='10' y1='20' x2='10' y2='5'/%3E%3Cline x1='16' y1='20' x2='16' y2='9'/%3E%3Cline x1='22' y1='20' x2='2' y2='20'/%3E%3C/svg%3E"); }
.st-card h3 { font-size: 1.2rem; margin-bottom: 10px; }
.st-card p { color: var(--muted); margin: 0; font-size: 15px; }

/* ---------- Showcase (pinned) ---------- */
.st-showcase { padding: 60px 0 120px; position: relative; background: linear-gradient(180deg, var(--bg) 0%, #efeafb 100%); }
.st-showcase__inner {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 60px;
    align-items: start;
}
.st-showcase__text {
    position: sticky;
    top: 120px;
}
.st-showcase__text p { color: var(--muted); margin: 18px 0 24px; }
.st-checklist { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.st-checklist li { position: relative; padding-left: 30px; color: var(--text); font-weight: 500; }
.st-checklist li::before {
    content: '✓'; position: absolute; left: 0; top: 0;
    width: 20px; height: 20px; border-radius: 50%;
    background: rgba(124,58,237,0.14); color: var(--primary-2);
    display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700;
}
.st-showcase__media { display: grid; gap: 28px; }
.st-frame {
    margin: 0; border-radius: 16px; overflow: hidden;
    border: 1px solid rgba(255,255,255,0.7);
    box-shadow: 0 40px 80px -36px rgba(40,18,80,0.5);
    background: #0f1117;
    will-change: transform;
}
.st-frame:nth-child(2) { margin-left: 8%; }
.st-frame:nth-child(3) { margin-right: 6%; }

/* ---------- Steps ---------- */
.st-how { background: #fff; }
.st-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.st-step {
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 34px 30px;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-soft);
}
.st-step::before {
    content: ''; position: absolute; inset: auto auto -40% -10%;
    width: 60%; height: 80%; background: radial-gradient(circle, rgba(139,92,246,0.14), transparent 70%);
}
.st-step__n {
    font-family: 'Sora', sans-serif; font-weight: 800; font-size: 2.4rem;
    background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
    display: block; margin-bottom: 12px;
}
.st-step h3 { font-size: 1.25rem; margin-bottom: 8px; }
.st-step p { color: var(--muted); margin: 0; }

/* ---------- Waitlist ---------- */
.st-waitlist { position: relative; padding: 40px 0 120px; overflow: hidden; background: linear-gradient(180deg, #efeafb 0%, var(--bg) 100%); }
.st-waitlist__glow {
    position: absolute; width: 700px; height: 700px; border-radius: 50%;
    top: -200px; left: 50%; transform: translateX(-50%);
    background: radial-gradient(circle, rgba(168,85,247,0.22), transparent 65%);
    filter: blur(40px); pointer-events: none;
}
.st-waitlist__card {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 28px;
    padding: 54px;
    box-shadow: 0 50px 120px -54px rgba(91, 45, 168, 0.55);
}
.st-waitlist__left h2 { margin: 16px 0 14px; }
.st-waitlist__left > p { color: var(--muted); margin-bottom: 24px; }
.st-badge {
    display: inline-block; padding: 8px 16px; border-radius: 999px;
    background: var(--grad); color: #fff; font-weight: 700; font-size: 13px;
    letter-spacing: .03em; box-shadow: 0 10px 24px -10px rgba(168,85,247,0.7);
}

/* Form */
.st-form { display: grid; gap: 16px; }
.st-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.st-field { display: grid; gap: 7px; }
.st-field label { font-size: 13px; font-weight: 600; color: var(--muted); }
.st-field input,
.st-field select {
    width: 100%;
    padding: 14px 16px;
    background: #faf8ff;
    border: 1px solid var(--line);
    border-radius: 12px;
    color: var(--text);
    font-size: 15px;
    font-family: inherit;
    transition: border-color .2s, box-shadow .2s, background .2s;
    appearance: none;
}
.st-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237c3aed' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 40px;
    cursor: pointer;
}
.st-field select option { background: #fff; color: var(--text); }
.st-field input::placeholder { color: #a9a1bb; }
.st-field input:focus,
.st-field select:focus {
    outline: none;
    border-color: rgba(124,58,237,0.6);
    box-shadow: 0 0 0 3px rgba(124,58,237,0.14);
    background: #fff;
}
.st-field.has-error input,
.st-field.has-error select { border-color: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,0.12); }

.st-form__note { color: var(--muted-2); font-size: 12.5px; margin: 4px 0 0; text-align: center; }
.st-form__msg { margin: 0; font-size: 14px; text-align: center; min-height: 1px; }
.st-form__msg.is-error { color: #dc2626; }
.st-form__msg.is-ok { color: #059669; }

.st-form__success { text-align: center; padding: 20px 0; }
.st-form__check {
    width: 70px; height: 70px; margin: 0 auto 18px; border-radius: 50%;
    background: var(--grad); color: #fff; font-size: 34px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 16px 40px -12px rgba(168,85,247,0.7);
    animation: st-pop .5s cubic-bezier(.2,1.4,.4,1) both;
}
@keyframes st-pop { from { transform: scale(0); } to { transform: scale(1); } }
.st-form__success h3 { font-size: 1.5rem; margin-bottom: 8px; }
.st-form__success-text { color: var(--muted); margin: 0; }

/* ---------- Footer ---------- */
.st-footer { border-top: 1px solid var(--line); padding: 40px 0; background: #fff; }
.st-footer__inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.st-footer__logo { height: 34px; width: auto; }
.st-footer p { color: var(--muted); margin: 0; font-size: 14px; }
.st-footer__links { display: flex; gap: 22px; }
.st-footer__links a { color: var(--muted); font-size: 14px; transition: color .2s; }
.st-footer__links a:hover { color: var(--primary-2); }

/* ---------- Reveal animation base ---------- */
.st-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); transition-delay: var(--d, 0s); }
.st-reveal.is-in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
    .st-hero__inner { grid-template-columns: 1fr; }
    .st-hero__visual { min-height: 340px; margin-top: 20px; }
    .st-features { grid-template-columns: repeat(2, 1fr); }
    .st-showcase__inner { grid-template-columns: 1fr; gap: 30px; }
    .st-showcase__text { position: static; }
    .st-steps { grid-template-columns: 1fr; }
    .st-waitlist__card { grid-template-columns: 1fr; padding: 36px; }
    .st-nav__links { display: none; }
}
@media (max-width: 600px) {
    .st-hero { padding: 180px 0 70px; }
    .st-features { grid-template-columns: 1fr; }
    .st-field-row { grid-template-columns: 1fr; }
    .st-nav { padding: 4px 18px; }
    .st-nav__brand img { height: 120px; }
    .st-nav.is-stuck .st-nav__brand img { height: 96px; }
    .st-waitlist__card { padding: 26px; }
    .st-section { padding: 80px 0; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .st-reveal { opacity: 1 !important; transform: none !important; }
    .st-marquee__track, .st-scrollcue span::after, .st-pill__dot { animation: none !important; }
}

/* ---------- Content pages ---------- */
.st-page-hero {
    padding: 140px 0 48px;
    background: linear-gradient(180deg, #efeafb 0%, var(--bg) 100%);
    text-align: center;
}
.st-page-hero__title { font-size: clamp(2rem, 4vw, 3rem); max-width: 18ch; margin: 0 auto 16px; }
.st-page-hero__sub { color: var(--muted); font-size: 1.1rem; max-width: 52ch; margin: 0 auto; }

.st-breadcrumbs { padding: 16px 0 0; background: var(--bg); }
.st-breadcrumbs__list {
    display: flex; flex-wrap: wrap; gap: 8px; list-style: none; margin: 0; padding: 0;
    font-size: 13px; color: var(--muted);
}
.st-breadcrumbs__item:not(:last-child)::after { content: '/'; margin-left: 8px; opacity: .5; }
.st-breadcrumbs__item a { color: var(--primary-2); }
.st-breadcrumbs__item a:hover { text-decoration: underline; }

.st-prose-section { padding-top: 48px; }
.st-prose { max-width: 720px; margin: 0 auto; color: var(--muted); line-height: 1.75; }
.st-prose h2 { color: var(--text); font-size: 1.45rem; margin: 2rem 0 .75rem; }
.st-prose h3 { color: var(--text); font-size: 1.15rem; margin: 1.5rem 0 .5rem; }
.st-prose p { margin: 0 0 1rem; }
.st-prose ul { margin: 0 0 1.25rem; padding-left: 1.25rem; }
.st-prose a { color: var(--primary-2); font-weight: 500; }
.st-prose a:hover { text-decoration: underline; }
.st-prose strong { color: var(--text); }

.st-section-link { text-align: center; margin-top: 28px; }
.st-section-link a { color: var(--primary-2); font-weight: 600; }

.st-faq__inner { max-width: 720px; margin: 0 auto; }
.st-faq__list { display: grid; gap: 12px; margin-top: 28px; }
.st-faq__item {
    background: #fff; border: 1px solid var(--line); border-radius: 12px;
    padding: 0 18px; box-shadow: var(--shadow-soft);
}
.st-faq__item summary {
    cursor: pointer; font-weight: 600; color: var(--text);
    padding: 16px 0; list-style: none;
}
.st-faq__item summary::-webkit-details-marker { display: none; }
.st-faq__item summary::after { content: '+'; float: right; color: var(--primary); }
.st-faq__item[open] summary::after { content: '−'; }
.st-faq__item p { margin: 0 0 16px; color: var(--muted); font-size: 15px; }

.st-cta-band { padding: 64px 0; background: linear-gradient(135deg, #7c3aed 0%, #a855f7 50%, #d946ef 100%); }
.st-cta-band__inner {
    display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.st-cta-band h2 { color: #fff; font-size: clamp(1.5rem, 3vw, 2rem); margin: 12px 0 8px; }
.st-cta-band p { color: rgba(255,255,255,0.88); margin: 0; max-width: 42ch; }
.st-cta-band .st-btn--solid { background: #fff; color: var(--primary-2); box-shadow: none; }

.st-pricing-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-bottom: 48px; }
.st-pricing-card {
    background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
    padding: 32px; box-shadow: var(--shadow-soft);
}
.st-pricing-card--featured { border-color: rgba(124,58,237,0.35); box-shadow: var(--shadow-card); }
.st-pricing-card h2 { font-size: 1.35rem; margin: 12px 0; }
.st-pricing-card__price { font-size: 1.5rem; margin: 0 0 8px; color: var(--text); }
.st-pricing-card__note { color: var(--muted); font-size: 14px; margin-bottom: 20px; }

.st-compare-wrap { margin: 32px auto 0; overflow-x: auto; }
.st-compare { width: 100%; border-collapse: collapse; font-size: 14px; background: #fff; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-soft); }
.st-compare th, .st-compare td { padding: 14px 16px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.st-compare thead th { background: var(--bg-soft); color: var(--text); font-weight: 600; }
.st-compare tbody th { font-weight: 500; color: var(--text); width: 28%; }
.st-compare__note { font-size: 12px; color: var(--muted-2); margin-top: 12px; text-align: center; }

.st-alt-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; margin-top: 24px; }
.st-alt-card {
    display: block; background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
    padding: 24px; box-shadow: var(--shadow-soft); transition: transform .25s, box-shadow .25s, border-color .25s;
    color: inherit; text-decoration: none;
}
.st-alt-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); border-color: rgba(124,58,237,0.35); }
.st-alt-card h3 { font-size: 1.1rem; margin: 0 0 10px; }
.st-alt-card h3 a { color: var(--primary-2); }
.st-alt-card p { margin: 0; color: var(--muted); font-size: 14px; }

.st-links-band { background: #fff; padding-top: 64px; }
.st-links-band .st-alt-card { text-align: center; font-weight: 600; color: var(--primary-2); }

.st-footer__links { flex-wrap: wrap; justify-content: center; }

@media (max-width: 980px) {
    .st-page-hero { padding: 120px 0 36px; }
    .st-pricing-grid { grid-template-columns: 1fr; }
    .st-cta-band__inner { flex-direction: column; text-align: center; }
}
