/* =============================================================================
   Shoptrak — Interactive Landing Page
   ============================================================================= */

/* --- Tokens --- */
:root {
    --blue:      #1A73E8;
    --blue-d:    #0D47A1;
    --blue-l:    #E8F0FE;
    --blue-m:    rgba(26,115,232,.12);
    --accent:    #00B0FF;
    --green:     #34A853;
    --green-l:   #E6F4EA;
    --amber:     #F9AB00;
    --amber-l:   #FEF7E0;
    --red:       #EA4335;
    --red-l:     #FCE8E6;
    --indigo:    #5E35B1;
    --indigo-l:  #EDE7F6;

    --bg:        #FFFFFF;
    --bg-alt:    #F0F4FF;
    --border:    rgba(255,255,255,0.55);
    --border-s:  #E8EAED;
    --text:      #202124;
    --text-m:    #5F6368;
    --text-l:    #9AA0A6;

    /* Glassmorphism */
    --glass-bg:      rgba(255,255,255,0.55);
    --glass-bg-alt:  rgba(255,255,255,0.38);
    --glass-border:  rgba(255,255,255,0.7);
    --glass-shadow:  0 8px 32px rgba(26,60,120,0.10), 0 1.5px 4px rgba(26,115,232,0.06);
    --glass-blur:    blur(18px);

    --font-b: 'Inter', system-ui, sans-serif;
    --font-h: 'Outfit', system-ui, sans-serif;

    --max-w: 1200px;
    --nav-h: 68px;
    --r-s: 8px;
    --r-m: 16px;
    --r-l: 24px;

    --sh-s: 0 1px 4px rgba(0,0,0,.06);
    --sh-m: 0 4px 20px rgba(0,0,0,.07);
    --sh-l: 0 12px 48px rgba(0,0,0,.09);
    --sh-b: 0 8px 24px rgba(26,115,232,.22);
}

/* --- Reset --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
    font-family: var(--font-b);
    color: var(--text);
    background-color: #EEF3FF;
    background-image:
        radial-gradient(ellipse 80% 60% at 10% 0%,   rgba(26,115,232,.13) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 90% 10%,  rgba(0,176,255,.10)  0%, transparent 55%),
        radial-gradient(ellipse 70% 60% at 50% 100%, rgba(94,53,177,.08)  0%, transparent 65%),
        radial-gradient(ellipse 50% 50% at 0%  80%,  rgba(52,168,83,.07)  0%, transparent 55%);
    background-attachment: fixed;
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4 { font-family: var(--font-h); font-weight: 700; line-height: 1.2; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; font-family: var(--font-b); border: none; background: none; }
input, select, textarea { font-family: var(--font-b); }

/* =============================================================================
   SCROLL PROGRESS
   ============================================================================= */
.scroll-progress {
    position: fixed;
    top: 0; left: 0;
    width: 0%;
    height: 3px;
    background: linear-gradient(90deg, var(--blue), var(--accent));
    z-index: 200;
    transition: width .1s linear;
}

/* =============================================================================
   LAYOUT
   ============================================================================= */
.container { width: 100%; max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
@media (min-width: 768px) { .container { padding: 0 2rem; } }
.section { padding: 56px 0; }
.section.bg-light {
    background: rgba(240,244,255,0.55);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-top: 1px solid var(--glass-border);
    border-bottom: 1px solid var(--glass-border);
}
.mt-8  { margin-top: 1.75rem; }
.mt-10 { margin-top: 2.5rem; }

/* =============================================================================
   TYPOGRAPHY HELPERS
   ============================================================================= */
.section-header { text-align: center; max-width: 660px; margin: 0 auto; }
.section-header h2 { font-size: clamp(1.875rem, 4vw, 2.625rem); margin-bottom: .625rem; }
.section-lead { color: var(--text-m); font-size: 1.0625rem; margin-top: .625rem; }
.eyebrow {
    display: inline-block;
    font-size: .75rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .09em;
    color: var(--blue); background: var(--blue-l);
    padding: .25rem .75rem; border-radius: 100px;
    margin-bottom: .875rem;
}
.eyebrow.white { background: rgba(255,255,255,.2); color: #fff; }

/* =============================================================================
   BUTTONS
   ============================================================================= */
.btn {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .75rem 1.5rem; border-radius: var(--r-s);
    font-weight: 600; font-size: .9375rem;
    transition: all .2s ease; border: 2px solid transparent;
    cursor: pointer; white-space: nowrap;
}
.btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.btn-primary { background: var(--blue); color: #fff; box-shadow: var(--sh-b); }
.btn-primary:hover { background: var(--blue-d); transform: translateY(-2px); box-shadow: 0 12px 32px rgba(26,115,232,.35); }
.btn-outline { background: transparent; color: var(--blue); border-color: var(--blue); }
.btn-outline:hover { background: var(--blue-l); transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--text-m); }
.btn-ghost:hover { background: var(--bg-alt); color: var(--text); }
.btn-full { width: 100%; justify-content: center; }
.btn-lg { padding: 1rem 2rem; font-size: 1rem; }
.btn-sm { padding: .5rem 1rem; font-size: .875rem; }

/* pulse ring */
.btn-pulse { position: relative; }
.btn-pulse::after {
    content: ''; position: absolute; inset: -4px;
    border-radius: calc(var(--r-s) + 4px);
    border: 2px solid var(--blue); opacity: 0;
    animation: pulse 2.5s ease-out infinite;
}
@keyframes pulse { 0%{transform:scale(1);opacity:.5} 100%{transform:scale(1.15);opacity:0} }

/* =============================================================================
   NAVBAR
   ============================================================================= */
.navbar {
    position: fixed; top: 0; left: 0; right: 0;
    height: var(--nav-h); z-index: 100;
    background: rgba(255,255,255,.60);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-bottom: 1px solid rgba(255,255,255,.75);
    transition: box-shadow .25s, background .25s;
}
.navbar.scrolled {
    background: rgba(255,255,255,.82);
    box-shadow: 0 4px 24px rgba(26,60,120,.10), 0 1px 4px rgba(26,115,232,.06);
}
.nav-container {
    max-width: var(--max-w); margin: 0 auto;
    padding: 0 1.5rem; height: 100%;
    display: flex; align-items: center; gap: 2rem;
}
.brand-logo { display: flex; align-items: center; gap: .625rem; font-family: var(--font-h); font-size: 1.375rem; font-weight: 800; color: var(--blue-d); flex-shrink: 0; }
.brand-icon-wrap { width: 34px; height: 34px; background: var(--blue); border-radius: var(--r-s); display: flex; align-items: center; justify-content: center; color: #fff; }
.brand-icon-wrap.small { width: 28px; height: 28px; }
.brand-text { font-family: var(--font-h); font-weight: 800; }
.nav-links { display: none; list-style: none; gap: 2rem; margin-left: auto; }
.nav-links a { font-size: .9rem; font-weight: 500; color: var(--text-m); transition: color .15s; }
.nav-links a:hover { color: var(--blue); }
.nav-actions { display: none; align-items: center; gap: .75rem; }
.mobile-toggle { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: var(--r-s); color: var(--text); margin-left: auto; transition: background .15s; }
.mobile-toggle:hover { background: var(--bg-alt); }
@media (min-width: 900px) {
    .nav-links { display: flex; }
    .nav-actions { display: flex; margin-left: 0; }
    .mobile-toggle { display: none; }
}
.mobile-drawer {
    display: none; flex-direction: column; gap: .125rem;
    position: absolute; top: var(--nav-h); left: 0; right: 0;
    background: #fff; border-bottom: 1px solid var(--border);
    padding: 1rem 1.5rem; box-shadow: var(--sh-l);
}
.mobile-drawer.open { display: flex; }
.mobile-drawer a { padding: .75rem .5rem; font-size: .9375rem; font-weight: 500; border-bottom: 1px solid var(--border); color: var(--text-m); transition: color .15s; }
.mobile-drawer a:last-child { border-bottom: none; }
.mobile-drawer a:hover { color: var(--blue); }

/* =============================================================================
   HERO
   ============================================================================= */
.hero {
    position: relative; overflow: hidden;
    padding: calc(var(--nav-h) + 48px) 0 48px;
    background: transparent;
}
.hero-blob {
    position: absolute; border-radius: 50%;
    filter: blur(90px); pointer-events: none;
}
.hero-blob-1 { top: -10%; left: -5%; width: 580px; height: 580px; background: rgba(232,240,254,.85); animation: bfloat 13s ease-in-out infinite alternate; }
.hero-blob-2 { bottom: -10%; right: -5%; width: 480px; height: 480px; background: rgba(0,176,255,.07); animation: bfloat 16s ease-in-out infinite alternate-reverse; }
@keyframes bfloat { from{transform:translate(0,0) scale(1)} to{transform:translate(40px,60px) scale(1.06)} }

.hero-grid { display: grid; gap: 3.5rem; align-items: center; }
@media (min-width: 900px) { .hero-grid { grid-template-columns: 1fr 1fr; } }

/* hero left */
.hero-badge {
    display: inline-flex; align-items: center; gap: .5rem;
    font-size: .8125rem; font-weight: 600; color: var(--blue-d);
    background: var(--blue-l); padding: .375rem 1rem;
    border-radius: 100px; margin-bottom: 1.25rem;
}
.hero-headline {
    font-size: clamp(2.125rem, 5vw, 3.5rem);
    line-height: 1.15; letter-spacing: -.02em;
    margin-bottom: 1.125rem;
}
.typewriter-wrap { white-space: nowrap; }
.typewriter-text { color: var(--blue); font-style: italic; }
.tw-cursor {
    display: inline-block; color: var(--blue);
    animation: blink .75s step-start infinite;
    font-weight: 300; margin-left: 2px;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

.hero-sub { font-size: 1.0625rem; color: var(--text-m); max-width: 500px; margin-bottom: 1.75rem; line-height: 1.7; }
.hero-sub strong { color: var(--text); }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.75rem; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.hero-trust span { display: flex; align-items: center; gap: .375rem; font-size: .8125rem; color: var(--text-m); }
.hero-trust svg { color: var(--green); flex-shrink: 0; }

/* hero dash window */
.hero-dash { position: relative; }
.dash-window {
    background: rgba(255,255,255,.68);
    backdrop-filter: blur(22px) saturate(160%);
    -webkit-backdrop-filter: blur(22px) saturate(160%);
    border: 1px solid rgba(255,255,255,.85);
    border-radius: var(--r-l);
    box-shadow: 0 20px 60px rgba(26,60,120,.13), 0 2px 12px rgba(26,115,232,.08);
    overflow: hidden;
    transform: perspective(1200px) rotateY(-5deg) rotateX(3deg);
    transition: transform .5s ease;
}
.dash-window:hover { transform: perspective(1200px) rotateY(0) rotateX(0); }
.dash-titlebar {
    display: flex; align-items: center; gap: .5rem;
    padding: .75rem 1.25rem;
    background: rgba(240,244,255,.7);
    border-bottom: 1px solid rgba(255,255,255,.6);
}
.dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.dot.red { background: var(--red); }
.dot.amber { background: var(--amber); }
.dot.green { background: var(--green); }
.dash-url { font-size: .75rem; color: var(--text-l); margin-left: .25rem; flex: 1; }
.dash-live-badge { display: flex; align-items: center; gap: .375rem; font-size: .75rem; font-weight: 600; color: var(--green); }

.dash-content { padding: 1.125rem; display: flex; flex-direction: column; gap: .875rem; }
.dash-row-kpis { display: grid; grid-template-columns: repeat(3,1fr); gap: .75rem; }
.kpi-box {
    background: rgba(240,244,255,.65);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.7);
    border-radius: var(--r-s); padding: .875rem;
}
.kpi-l { display: block; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--text-l); margin-bottom: .25rem; }
.kpi-v { display: block; font-family: var(--font-h); font-size: 1.5rem; font-weight: 800; margin-bottom: .375rem; }
.kpi-v.blue { color: var(--blue); }
.kpi-v.green { color: var(--green); }
.kpi-v.red { color: var(--red); }
.kpi-bar { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; }
.kpi-fill { height: 100%; background: var(--blue); border-radius: 2px; transition: width 1.2s ease; }
.kpi-fill.green { background: var(--green); }

.dash-part-table { border: 1px solid var(--border); border-radius: var(--r-s); overflow: hidden; }
.dpt-head, .dpt-row { display: grid; grid-template-columns: 2fr 1fr .8fr 1fr; gap: .5rem; padding: .5rem .875rem; font-size: .75rem; }
.dpt-head { background: var(--bg-alt); font-weight: 700; color: var(--text-l); text-transform: uppercase; letter-spacing: .04em; }
.dpt-row { border-top: 1px solid var(--border); animation: rowSlide .4s ease both; }
@keyframes rowSlide { from{opacity:0;transform:translateX(-8px)} to{opacity:1;transform:none} }
.status-pill { display: inline-block; padding: .125rem .5rem; border-radius: 100px; font-size: .7rem; font-weight: 700; }
.status-pill.green { background: var(--green-l); color: var(--green); }
.status-pill.amber { background: var(--amber-l); color: #9A6700; }
.status-pill.red   { background: var(--red-l);   color: var(--red);   }

.dash-alert {
    display: flex; align-items: center; gap: .5rem;
    background: var(--amber-l); border: 1px solid rgba(249,171,0,.3);
    border-radius: var(--r-s); padding: .625rem .875rem;
    font-size: .75rem; color: #7A5100;
    animation: alertPop .5s ease .8s both;
}
@keyframes alertPop { from{opacity:0;transform:scale(.95)} to{opacity:1;transform:scale(1)} }
.dash-alert svg { flex-shrink: 0; color: var(--amber); }

.ghost-excel {
    position: absolute; bottom: -16px; left: -16px;
    display: flex; align-items: center; gap: .625rem;
    background: rgba(255,255,255,.72);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255,255,255,.9);
    border-radius: var(--r-m); padding: .75rem 1rem;
    box-shadow: 0 8px 32px rgba(26,60,120,.12); font-size: .8125rem;
    opacity: .9; max-width: 260px;
    animation: ghostRise 1s ease .3s both;
}
@keyframes ghostRise { from{opacity:0;transform:translateY(12px)} to{opacity:.85;transform:none} }
.ghost-name { display: block; font-weight: 600; color: var(--text); font-size: .8rem; }
.ghost-sub  { display: block; color: var(--red); font-size: .7rem; font-weight: 500; }
.ghost-badge { flex-shrink: 0; background: var(--red-l); color: var(--red); font-size: .7rem; font-weight: 700; padding: .2rem .5rem; border-radius: 4px; }

/* =============================================================================
   STATS BAR
   ============================================================================= */
.stats-bar { background: var(--blue-d); padding: 2.5rem 0; }
.stats-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; }
.stat-item { display: flex; flex-direction: column; align-items: center; text-align: center; padding: .75rem 2.5rem; flex: 1; min-width: 140px; }
.stat-n { font-family: var(--font-h); font-size: 2rem; font-weight: 800; color: #fff; line-height: 1; }
.stat-d { font-size: .75rem; color: rgba(255,255,255,.6); margin-top: .375rem; max-width: 130px; line-height: 1.4; }
.stat-sep { width: 1px; height: 44px; background: rgba(255,255,255,.18); flex-shrink: 0; }
@media (max-width: 600px) { .stat-sep { display: none; } }

/* =============================================================================
   PROBLEM
   ============================================================================= */
.prob-cards { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .prob-cards { grid-template-columns: repeat(3,1fr); } }
.prob-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--r-m);
    padding: 2rem;
    box-shadow: var(--glass-shadow);
    transition: transform .25s, box-shadow .25s, background .25s;
}
.prob-card:hover {
    transform: translateY(-4px);
    background: rgba(255,255,255,.72);
    box-shadow: 0 20px 48px rgba(26,60,120,.13);
}
.prob-icon {
    width: 50px; height: 50px; border-radius: var(--r-s);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 1.125rem;
}
.prob-icon svg { width: 22px; height: 22px; }
.red-i   { background: var(--red-l);    color: var(--red);    }
.amber-i { background: var(--amber-l);  color: #9A6700;       }
.blue-i  { background: var(--blue-l);   color: var(--blue);   }
.prob-card h3 { font-size: 1.0625rem; margin-bottom: .5rem; }
.prob-card p  { color: var(--text-m); font-size: .9rem; line-height: 1.7; }
.prob-card p strong { color: var(--text); }

/* =============================================================================
   WORKFLOW
   ============================================================================= */
.workflow-wrap { position: relative; }

.wf-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto 1fr;
    align-items: center;
    gap: .5rem;
}
@media (max-width: 767px) {
    .wf-row { grid-template-columns: 1fr; gap: .75rem; }
    .wf-arrow { display: none; }
    .wf-vert-arrow { display: none; }
}

.wf-node {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1.5px solid var(--glass-border);
    border-radius: var(--r-m); padding: 1.5rem 1.25rem;
    text-align: center; cursor: pointer;
    transition: all .25s ease; position: relative;
    box-shadow: var(--glass-shadow);
    outline: none;
}
.wf-node:hover, .wf-node:focus-visible {
    border-color: rgba(26,115,232,.5);
    background: rgba(255,255,255,.72);
    box-shadow: 0 0 0 4px var(--blue-m), var(--glass-shadow);
    transform: translateY(-3px);
}
.wf-node.active {
    border-color: var(--blue);
    background: rgba(232,240,254,.75);
    box-shadow: var(--sh-b);
}
.wf-num {
    font-size: .7rem; font-weight: 800; letter-spacing: .08em;
    text-transform: uppercase; color: var(--text-l); margin-bottom: .625rem;
}
.wf-icon {
    width: 52px; height: 52px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto .875rem;
}
.wf-icon.blue   { background: var(--blue-l);   color: var(--blue);   }
.wf-icon.green  { background: var(--green-l);  color: var(--green);  }
.wf-icon.amber  { background: var(--amber-l);  color: #9A6700;       }
.wf-icon.indigo { background: var(--indigo-l); color: var(--indigo); }
.wf-icon svg { width: 26px; height: 26px; }
.wf-node h4 { font-size: .9375rem; margin-bottom: .25rem; }
.wf-node p  { font-size: .8rem; color: var(--text-m); }

/* Arrows */
.wf-arrow {
    display: flex; align-items: center;
    color: var(--text-l); flex-shrink: 0; position: relative;
    width: 60px;
}
.wf-arrow.right { flex-direction: row; }
.wf-arrow.left  { flex-direction: row-reverse; }
.wf-line {
    flex: 1; height: 2px; background: var(--border);
    position: relative; overflow: hidden;
}
.wf-dot-flow {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 8px; height: 8px; background: var(--blue);
    border-radius: 50%; left: -8px;
    animation: flowRight 2s linear infinite;
}
.wf-dot-flow.rev { animation: flowLeft 2s linear infinite; }
@keyframes flowRight { from{left:-8px} to{left:100%} }
@keyframes flowLeft  { from{right:-8px;left:auto} to{right:100%;left:auto} }

.arrow-head     { width: 14px; height: 14px; color: var(--blue-d); flex-shrink: 0; }
.arrow-head-rev { width: 14px; height: 14px; color: var(--blue-d); flex-shrink: 0; }

/* Vertical connectors */
.wf-vert-arrow {
    position: absolute; right: calc(16.66% - 30px);
    top: 50%; transform: translateY(-50%);
    display: flex; flex-direction: column;
    align-items: center; height: 60px; width: 20px;
    color: var(--blue-d);
}
.wf-vert-arrow.left {
    right: auto; left: calc(16.66% - 30px);
}
.wf-vline {
    flex: 1; width: 2px; background: var(--border);
    position: relative; overflow: hidden;
}
.wf-dot-flow.vertical {
    top: -8px; left: 50%; transform: translateX(-50%);
    animation: flowDown 2s linear infinite;
    animation-delay: .5s;
}
.wf-dot-flow.vertical.rev { animation: flowUp 2s linear infinite; animation-delay: .5s; }
@keyframes flowDown { from{top:-8px} to{top:100%} }
@keyframes flowUp   { from{bottom:-8px;top:auto} to{bottom:100%;top:auto} }
.arrow-head-down, .arrow-head-down-rev { width: 14px; height: 14px; flex-shrink: 0; }

.wf-row-top  { margin-bottom: 0; }
.wf-row-bottom { margin-top: 0; }

/* gap between the two rows (space for vertical arrows) */
.workflow-wrap .wf-row + .wf-vert-arrow + .wf-row,
.workflow-wrap .wf-row-bottom {
    margin-top: 48px;
}
.workflow-wrap { padding-bottom: 0; }

/* Detail panel */
.wf-detail {
    display: none; overflow: hidden;
    border: 1.5px solid rgba(26,115,232,.35); border-radius: var(--r-m);
    box-shadow: 0 8px 40px rgba(26,60,120,.14), 0 2px 8px rgba(26,115,232,.08);
    margin-top: 1.5rem;
    animation: panelDrop .3s ease;
}
.wf-detail.open { display: block; }
@keyframes panelDrop { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
.wf-detail-inner {
    padding: 2rem; display: grid; gap: 1.5rem; position: relative;
    background: rgba(255,255,255,.72);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
}
@media (min-width: 768px) { .wf-detail-inner { grid-template-columns: auto 1fr; } }
.wf-close {
    position: absolute; top: 1rem; right: 1rem;
    font-size: 1.25rem; color: var(--text-l); line-height: 1;
    transition: color .15s;
}
.wf-close:hover { color: var(--text); }
.wfd-icon {
    width: 64px; height: 64px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.wfd-icon svg { width: 30px; height: 30px; }
.wfd-body { min-width: 0; }
.wfd-eyebrow { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--blue); margin-bottom: .375rem; }
.wfd-body h3 { font-size: 1.25rem; margin-bottom: .5rem; }
.wfd-body p  { color: var(--text-m); font-size: .9rem; margin-bottom: 1rem; line-height: 1.7; }
.wfd-features { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1rem; }
.wfd-features li { display: flex; align-items: flex-start; gap: .625rem; font-size: .875rem; color: var(--text-m); }
.wfd-features li::before { content: '✓'; color: var(--green); font-weight: 700; flex-shrink: 0; margin-top: .05rem; }
.wfd-impact {
    background: var(--blue-l); border-radius: var(--r-s);
    padding: .875rem 1rem; font-size: .875rem; font-style: italic;
    color: var(--blue-d); line-height: 1.6;
}

/* =============================================================================
   TIMELINE
   ============================================================================= */
.timeline-wrap { }
.tl-nav {
    display: flex; align-items: center; justify-content: center;
    gap: 0; flex-wrap: nowrap; overflow-x: auto;
    padding-bottom: .5rem;
}
.tl-btn {
    display: flex; flex-direction: column; align-items: center; gap: .375rem;
    padding: .75rem 1.25rem; border-radius: var(--r-m);
    font-size: .8125rem; font-weight: 600; color: var(--text-m);
    transition: all .2s ease; cursor: pointer; white-space: nowrap;
    flex-shrink: 0; position: relative; z-index: 1;
}
.tl-btn:hover { color: var(--blue); background: var(--blue-l); }
.tl-btn.active { color: var(--blue-d); background: var(--blue-l); box-shadow: var(--sh-s); }
.tl-icon { font-size: 1.375rem; }
.tl-connector { flex: 1; height: 2px; background: var(--border); min-width: 20px; max-width: 80px; position: relative; }
.tl-connector::after {
    content: ''; position: absolute; top: 0; left: 0;
    height: 100%; width: 0%; background: var(--blue);
    transition: width .4s ease;
}
.tl-connector.passed::after { width: 100%; }

.tl-panels { margin-top: 1.5rem; }
.tl-panel { display: none; }
.tl-panel.active {
    display: grid; gap: 1.25rem;
    animation: panelFade .35s ease;
}
@media (min-width: 768px) { .tl-panel.active { grid-template-columns: 1fr 1fr; } }
@keyframes panelFade { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:none} }

.tl-before, .tl-after {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--r-m); padding: 1.75rem;
    box-shadow: var(--glass-shadow);
}
.tl-after {
    border-color: rgba(52,168,83,.35);
    background: rgba(230,244,234,.55);
}
.tl-label {
    display: inline-block; font-size: .8125rem; font-weight: 700;
    margin-bottom: .875rem; padding: .25rem .75rem;
    border-radius: 100px;
}
.tl-label.before { background: var(--red-l); color: var(--red); }
.tl-label.after  { background: var(--green-l); color: var(--green); }
.tl-before p, .tl-after p { color: var(--text-m); font-size: .9375rem; line-height: 1.7; margin-bottom: .875rem; }
.tl-before p strong, .tl-after p strong { color: var(--text); }
.tl-quote {
    font-style: italic; font-size: .875rem; color: var(--text-l);
    border-left: 3px solid var(--border); padding-left: .875rem;
}
.tl-chip-row { display: flex; flex-wrap: wrap; gap: .5rem; }
.tl-chip {
    font-size: .75rem; font-weight: 600; padding: .25rem .75rem;
    border-radius: 100px;
}
.tl-chip.blue   { background: var(--blue-l);   color: var(--blue-d); }
.tl-chip.green  { background: var(--green-l);  color: var(--green);  }
.tl-chip.amber  { background: var(--amber-l);  color: #9A6700;       }
.tl-chip.red    { background: var(--red-l);    color: var(--red);    }
.tl-chip.indigo { background: var(--indigo-l); color: var(--indigo); }

/* =============================================================================
   MODULE TABS
   ============================================================================= */
.tabs-wrap { }
.tab-nav {
    display: flex; gap: .25rem; flex-wrap: wrap;
    border-bottom: 2px solid var(--border); padding-bottom: 0;
    margin-bottom: -2px;
}
.tab-btn {
    padding: .75rem 1.125rem; font-size: .875rem; font-weight: 600;
    color: var(--text-m); border-bottom: 3px solid transparent;
    transition: all .2s; cursor: pointer; white-space: nowrap;
    margin-bottom: -2px;
}
.tab-btn:hover { color: var(--blue); }
.tab-btn.active { color: var(--blue); border-bottom-color: var(--blue); }

.tab-panels {
    border: 1px solid var(--glass-border);
    border-radius: 0 var(--r-m) var(--r-m) var(--r-m);
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    box-shadow: var(--glass-shadow);
}
.tab-panel { display: none; }
.tab-panel.active {
    display: grid; gap: 2.5rem;
    padding: 2.5rem; animation: tabFade .3s ease;
}
@media (min-width: 768px) { .tab-panel.active { grid-template-columns: 1fr 1fr; align-items: start; } }
@keyframes tabFade { from{opacity:0;transform:translateX(-6px)} to{opacity:1;transform:none} }

.tp-left {}
.tp-eyebrow { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--blue); margin-bottom: .75rem; }
.tp-left h3 { font-size: 1.375rem; margin-bottom: .875rem; }
.tp-left p  { color: var(--text-m); font-size: .9375rem; line-height: 1.7; margin-bottom: 1.25rem; }
.tp-features { display: flex; flex-direction: column; gap: .625rem; margin-bottom: 1.5rem; }
.tp-features li { display: flex; align-items: flex-start; gap: .75rem; font-size: .9rem; color: var(--text-m); line-height: 1.6; }
.check-icon { color: var(--green); font-weight: 700; flex-shrink: 0; margin-top: .05rem; }
.tp-impact {
    background: var(--blue-l); border-radius: var(--r-s);
    padding: 1rem 1.25rem; font-size: .875rem; font-style: italic;
    color: var(--blue-d); line-height: 1.6;
}
.tp-right {}
.tp-preview {
    background: var(--bg-alt); border: 1px solid var(--border);
    border-radius: var(--r-m); padding: 1.5rem; overflow: hidden;
}
.tpp-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 1rem; font-size: .875rem; font-weight: 600; color: var(--text);
}
.tpp-count { font-size: .8125rem; color: var(--text-l); }
.tpp-count.green { color: var(--green); }

/* Tab preview sub-components */
.tpp-table { }
.tppt-head, .tppt-row {
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: .5rem; padding: .5rem .625rem; font-size: .8125rem;
}
.tppt-head { font-weight: 700; color: var(--text-l); text-transform: uppercase; font-size: .7rem; letter-spacing: .05em; border-bottom: 1px solid var(--border); }
.tppt-row { border-top: 1px solid var(--border); color: var(--text-m); }

.tpp-kpi-row { display: grid; grid-template-columns: repeat(3,1fr); gap: .75rem; margin-bottom: 1rem; }
.tpp-kpi { background: #fff; border-radius: var(--r-s); padding: .75rem; border: 1px solid var(--border); }
.tpp-kl { display: block; font-size: .7rem; color: var(--text-l); font-weight: 600; text-transform: uppercase; margin-bottom: .25rem; }
.tpp-kv { font-family: var(--font-h); font-size: 1.125rem; font-weight: 700; }
.tpp-kv.blue { color: var(--blue); }
.tpp-bar-label { font-size: .75rem; font-weight: 600; color: var(--text-m); margin-bottom: .5rem; }
.tpp-bars { display: flex; flex-direction: column; gap: .5rem; }
.tpp-bar-item { display: flex; align-items: center; gap: .5rem; font-size: .75rem; color: var(--text-m); }
.tpp-bar-item > span:first-child { width: 20px; flex-shrink: 0; }
.tpp-bar-bg { flex: 1; height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; }
.tpp-bar-fill { height: 100%; background: var(--blue); border-radius: 3px; transition: width 1s ease; }
.tpp-bar-fill.amber { background: var(--amber); }
.tpp-bar-item > span:last-child { width: 32px; text-align: right; flex-shrink: 0; }
.amber-t { color: #9A6700; }

.tpp-log-entry { background: #fff; border: 1px solid var(--border); border-radius: var(--r-s); margin-bottom: .75rem; overflow: hidden; }
.tpp-le-row { display: flex; justify-content: space-between; padding: .5rem .875rem; font-size: .875rem; border-bottom: 1px solid var(--border); }
.tpp-le-row:last-child { border-bottom: none; }
.tpp-le-row.le-highlight { background: var(--red-l); }
.le-label { color: var(--text-l); font-weight: 500; }
.green-t { color: var(--green); font-weight: 600; }
.red-t   { color: var(--red);   font-weight: 600; }
.tpp-alert-row {
    display: flex; align-items: center; gap: .5rem;
    background: var(--amber-l); border-radius: var(--r-s);
    padding: .625rem .875rem; font-size: .8rem; color: #7A5100;
}
.alert-dot { width: 8px; height: 8px; background: var(--amber); border-radius: 50%; flex-shrink: 0; animation: blink 1.5s ease-in-out infinite; }

.tpp-matrix { }
.tpp-m-head, .tpp-m-row {
    display: grid; grid-template-columns: 1.5fr repeat(5,1fr);
    gap: .25rem; margin-bottom: .25rem; font-size: .75rem;
}
.tpp-m-head { font-weight: 700; color: var(--text-l); text-transform: uppercase; font-size: .65rem; letter-spacing: .04em; margin-bottom: .5rem; }
.tpp-m-row span:first-child { color: var(--text-m); font-weight: 500; }
.cell-ok, .cell-warn, .cell-bad {
    text-align: center; padding: .25rem .125rem;
    border-radius: 4px; font-weight: 600;
}
.cell-ok   { background: var(--green-l); color: var(--green); }
.cell-warn { background: var(--amber-l); color: #9A6700; }
.cell-bad  { background: var(--red-l);   color: var(--red);   }
.tpp-legend { display: flex; gap: 1rem; margin-top: .75rem; font-size: .75rem; }
.leg { display: flex; align-items: center; gap: .375rem; }
.leg::before { content: ''; width: 10px; height: 10px; border-radius: 2px; display: inline-block; }
.leg.on-plan::before { background: var(--green-l); border: 1px solid var(--green); }
.leg.lagging::before { background: var(--amber-l); border: 1px solid var(--amber); }
.leg.critical::before { background: var(--red-l); border: 1px solid var(--red); }

.idle-codes { display: flex; flex-direction: column; gap: .5rem; margin-bottom: .875rem; }
.ic-row { display: grid; grid-template-columns: auto 1fr auto auto; gap: .5rem; align-items: center; padding: .5rem .625rem; background: #fff; border: 1px solid var(--border); border-radius: var(--r-s); font-size: .8125rem; }
.ic-code { font-size: .7rem; font-weight: 700; padding: .2rem .5rem; border-radius: 4px; white-space: nowrap; }
.ic-code.c240 { background: var(--red-l); color: var(--red); }
.ic-code.c100 { background: var(--amber-l); color: #9A6700; }
.ic-code.c060 { background: var(--blue-l); color: var(--blue); }
.ic-code.c020 { background: var(--indigo-l); color: var(--indigo); }
.ic-desc { color: var(--text-m); }
.ic-hrs  { color: var(--text-l); font-size: .75rem; }
.ic-cost { font-weight: 600; font-size: .8125rem; }
.ic-total { font-size: .875rem; color: var(--text-m); text-align: right; }

.wip-table { display: flex; flex-direction: column; gap: .5rem; }
.wip-row { display: grid; grid-template-columns: 2fr 3fr auto; align-items: center; gap: .75rem; padding: .625rem .875rem; background: #fff; border: 1px solid var(--border); border-radius: var(--r-s); font-size: .8125rem; }
.wip-part { font-weight: 500; color: var(--text); }
.wip-progress { display: flex; align-items: center; gap: .5rem; }
.wip-bar-bg { flex: 1; height: 5px; background: var(--border); border-radius: 3px; overflow: hidden; }
.wip-bar-fill { height: 100%; background: var(--green); border-radius: 3px; transition: width 1s ease; }
.wip-bar-fill.amber { background: var(--amber); }
.wip-bar-fill.red   { background: var(--red);   }
.wip-progress span { font-size: .75rem; color: var(--text-l); flex-shrink: 0; width: 28px; text-align: right; }
.rag-badge { font-size: .7rem; font-weight: 700; padding: .2rem .5rem; border-radius: 4px; white-space: nowrap; }
.rag-badge.green { background: var(--green-l); color: var(--green); }
.rag-badge.amber { background: var(--amber-l); color: #9A6700; }
.rag-badge.red   { background: var(--red-l);   color: var(--red);   }

/* =============================================================================
   OEE CALCULATOR
   ============================================================================= */
.calc-wrap {
    display: grid; gap: 2.5rem;
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--r-l); padding: 2.5rem;
    box-shadow: var(--glass-shadow);
}
@media (min-width: 900px) { .calc-wrap { grid-template-columns: 1fr 1fr; align-items: start; } }

.calc-group-title { font-size: .875rem; font-weight: 700; color: var(--text); margin-bottom: 1.25rem; padding-bottom: .5rem; border-bottom: 1px solid var(--border); }
.calc-field { margin-bottom: 1.5rem; }
.calc-field label { display: block; font-size: .875rem; font-weight: 500; color: var(--text-m); margin-bottom: .5rem; }
.calc-field label strong { color: var(--blue); }

.calc-slider {
    width: 100%; -webkit-appearance: none; appearance: none;
    height: 5px; background: var(--border); border-radius: 3px; outline: none;
    cursor: pointer; transition: background .2s;
}
.calc-slider::-webkit-slider-thumb {
    -webkit-appearance: none; width: 20px; height: 20px;
    border-radius: 50%; background: var(--blue);
    box-shadow: 0 2px 8px rgba(26,115,232,.35); cursor: pointer;
    transition: transform .15s;
}
.calc-slider::-webkit-slider-thumb:hover { transform: scale(1.15); }
.calc-slider::-moz-range-thumb {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--blue); border: none; cursor: pointer;
}
.slider-ticks { display: flex; justify-content: space-between; margin-top: .25rem; }
.slider-ticks span { font-size: .7rem; color: var(--text-l); }

.btn-group { display: flex; gap: .375rem; flex-wrap: wrap; margin-top: .375rem; }
.seg-btn {
    padding: .5rem 1rem; border: 1.5px solid var(--border);
    border-radius: var(--r-s); font-size: .875rem; font-weight: 500;
    color: var(--text-m); background: #fff;
    transition: all .15s; cursor: pointer;
}
.seg-btn:hover { border-color: var(--blue); color: var(--blue); }
.seg-btn.active { background: var(--blue); border-color: var(--blue); color: #fff; }

/* Results */
.calc-results { display: flex; flex-direction: column; gap: 1.5rem; }
.result-oee { text-align: center; }
.result-label { display: block; font-size: .875rem; font-weight: 600; color: var(--text-m); margin-bottom: .75rem; }
.result-gauge { position: relative; width: 160px; margin: 0 auto; }
.gauge-svg { width: 100%; }
.gauge-val {
    position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
    font-family: var(--font-h); font-size: 2rem; font-weight: 800;
    color: var(--blue); line-height: 1;
}
.gauge-label { display: block; font-size: .75rem; color: var(--text-l); text-align: center; margin-top: .25rem; }
.oee-bench { font-size: .8125rem; color: var(--text-m); margin-top: .75rem; text-align: center; }
.bench-diff { display: inline-block; font-weight: 700; padding: .125rem .5rem; border-radius: 100px; margin-left: .375rem; font-size: .75rem; }

.result-costs { display: flex; flex-direction: column; gap: .75rem; }
.rc-item { display: flex; justify-content: space-between; align-items: center; padding: .875rem 1rem; background: var(--bg-alt); border-radius: var(--r-s); }
.rc-item.highlight { background: var(--green-l); }
.rc-label { font-size: .875rem; color: var(--text-m); }
.rc-val { font-family: var(--font-h); font-size: 1.25rem; font-weight: 700; }
.rc-val.red   { color: var(--red);   }
.rc-val.green { color: var(--green); }
.rc-val.blue  { color: var(--blue);  }

/* =============================================================================
   COMPARISON
   ============================================================================= */
.cost-strip {
    display: flex; flex-wrap: wrap; align-items: center;
    justify-content: center; gap: .875rem;
    background: var(--bg-alt); border: 1px solid var(--border);
    border-radius: var(--r-m); padding: 1.75rem;
}
.cs-item { display: flex; flex-direction: column; align-items: center; text-align: center; flex: 1; min-width: 120px; }
.cs-item.total { background: var(--red-l); padding: .875rem 1.25rem; border-radius: var(--r-s); }
.cs-item.shoptrak { background: var(--blue-l); padding: .875rem 1.25rem; border-radius: var(--r-s); }
.cs-l { font-size: .8rem; color: var(--text-m); margin-bottom: .25rem; }
.cs-v { font-family: var(--font-h); font-size: 1.25rem; font-weight: 800; }
.cs-v.red  { color: var(--red);  }
.cs-v.blue { color: var(--blue); }
.cs-op { font-family: var(--font-h); font-size: 1.25rem; font-weight: 700; color: var(--text-l); flex-shrink: 0; }
.cs-vs { background: var(--text-m); color: #fff; font-size: .75rem; font-weight: 700; padding: .25rem .625rem; border-radius: 100px; flex-shrink: 0; }

.compare-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--r-m); box-shadow: var(--sh-s); }
.compare-table { width: 100%; border-collapse: collapse; font-size: .9rem; min-width: 500px; }
.compare-table thead tr { background: var(--bg-alt); border-bottom: 2px solid var(--border); }
.compare-table th { padding: 1rem 1.25rem; text-align: left; font-weight: 700; font-size: .875rem; }
.col-excel    { color: #217346; background: #F0FFF4; }
.col-shoptrak { color: var(--blue-d); background: var(--blue-l); }
.compare-table td { padding: .8rem 1.25rem; border-bottom: 1px solid var(--border); vertical-align: middle; font-size: .875rem; }
.compare-table td:first-child { font-weight: 500; }
.compare-table tbody tr:last-child td { border-bottom: none; }
.compare-table tbody tr:hover td { background: var(--bg-alt); }
.compare-table td.good { color: var(--green); }
.compare-table td.bad  { color: var(--red-l);  color: #B71C1C; }

/* =============================================================================
   TESTIMONIALS
   ============================================================================= */
.testi-grid { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .testi-grid { grid-template-columns: repeat(3,1fr); } }
.testi-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--r-m);
    padding: 2rem; box-shadow: var(--glass-shadow);
    display: flex; flex-direction: column;
    gap: .875rem; transition: transform .25s, box-shadow .25s, background .25s;
}
.testi-card:hover {
    transform: translateY(-4px);
    background: rgba(255,255,255,.72);
    box-shadow: 0 20px 48px rgba(26,60,120,.13);
}
.testi-stars { color: var(--amber); font-size: 1rem; letter-spacing: .1em; }
.testi-card p { font-size: .9rem; color: var(--text-m); line-height: 1.7; font-style: italic; flex: 1; }
.testi-author { display: flex; align-items: center; gap: .875rem; padding-top: .875rem; border-top: 1px solid var(--border); }
.testi-av { width: 40px; height: 40px; border-radius: 50%; background: var(--blue); color: #fff; font-family: var(--font-h); font-weight: 700; font-size: .8rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.testi-author strong { display: block; font-size: .875rem; }
.testi-author span   { font-size: .8rem; color: var(--text-m); }

/* =============================================================================
   PRICING
   ============================================================================= */
.pricing-grid { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .pricing-grid { grid-template-columns: repeat(3,1fr); align-items: stretch; } }
.price-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--r-m);
    padding: 2rem; box-shadow: var(--glass-shadow); position: relative;
    display: flex; flex-direction: column; transition: box-shadow .25s, transform .25s, background .25s;
}
.price-card:hover {
    transform: translateY(-3px);
    background: rgba(255,255,255,.72);
    box-shadow: 0 20px 48px rgba(26,60,120,.13);
}
.price-card.featured {
    border-color: rgba(26,115,232,.5);
    background: rgba(232,240,254,.60);
    box-shadow: 0 8px 32px rgba(26,115,232,.15), var(--glass-shadow);
}
.price-badge {
    position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
    background: var(--blue); color: #fff; font-size: .7rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .05em;
    padding: .25rem 1rem; border-radius: 100px; white-space: nowrap;
}
.price-header { margin-bottom: 1.5rem; }
.plan-name { display: block; font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--text-l); margin-bottom: .75rem; }
.plan-price { display: flex; align-items: baseline; gap: .25rem; margin-bottom: .5rem; }
.currency { font-family: var(--font-h); font-size: 1.25rem; font-weight: 700; color: var(--text); margin-top: .25rem; }
.amount { font-family: var(--font-h); font-size: 2.5rem; font-weight: 800; color: var(--text); line-height: 1; }
.period { font-size: .875rem; color: var(--text-m); }
.plan-desc { font-size: .875rem; color: var(--text-m); }
.plan-features { list-style: none; margin-bottom: 1.75rem; flex: 1; display: flex; flex-direction: column; gap: .625rem; }
.plan-features li { font-size: .9rem; color: var(--text-m); }
.plan-features li.dim { color: var(--text-l); }
.price-includes {
    display: flex; flex-wrap: wrap; align-items: center; gap: 1rem;
    margin-top: 2rem;
    background: rgba(255,255,255,.55);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--r-m); padding: 1.25rem 1.5rem;
    box-shadow: var(--glass-shadow);
}
.pi-label { font-weight: 700; font-size: .875rem; flex-shrink: 0; }
.price-includes span { font-size: .8125rem; color: var(--text-m); }

/* =============================================================================
   DEMO SECTION
   ============================================================================= */
.demo-section {
    background: linear-gradient(135deg, var(--blue-d) 0%, var(--blue) 55%, #0093D0 100%);
    padding: 56px 0;
}
.demo-grid { display: grid; gap: 3rem; align-items: start; }
@media (min-width: 900px) { .demo-grid { grid-template-columns: 1fr 1fr; } }

.demo-h2 { font-size: clamp(1.75rem, 4vw, 2.375rem); color: #fff; margin-bottom: .75rem; }
.demo-sub { color: rgba(255,255,255,.8); font-size: 1rem; margin-bottom: 2rem; line-height: 1.7; }
.demo-trust { display: flex; flex-direction: column; gap: .875rem; }
.dt-item { display: flex; align-items: center; gap: .75rem; color: rgba(255,255,255,.9); font-size: .9375rem; }
.dt-icon { font-size: 1rem; flex-shrink: 0; }

.demo-form-card {
    background: rgba(255,255,255,.78);
    backdrop-filter: blur(24px) saturate(160%);
    -webkit-backdrop-filter: blur(24px) saturate(160%);
    border: 1px solid rgba(255,255,255,.9);
    border-radius: var(--r-l);
    padding: 2.25rem;
    box-shadow: 0 24px 80px rgba(0,0,0,.14), 0 2px 12px rgba(26,115,232,.08);
}
.demo-form-card form { display: flex; flex-direction: column; gap: 1.125rem; }
.form-row-2 { display: grid; gap: 1.125rem; }
@media (min-width: 600px) { .form-row-2 { grid-template-columns: 1fr 1fr; } }
.fg { display: flex; flex-direction: column; gap: .375rem; }
.fg label { font-size: .8125rem; font-weight: 600; color: var(--text); }
.fg input, .fg select {
    padding: .75rem 1rem; border: 1.5px solid var(--border);
    border-radius: var(--r-s); font-size: .9375rem; color: var(--text);
    background: #fff; outline: none; transition: border-color .15s, box-shadow .15s;
}
.fg input:focus, .fg select:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(26,115,232,.1); }
.fg input.err { border-color: var(--red); }
.fg input::placeholder { color: var(--text-l); }
.radio-row { display: flex; gap: 1.5rem; margin-top: .25rem; }
.radio-opt { display: flex; align-items: center; gap: .5rem; cursor: pointer; font-size: .9375rem; }
.radio-opt input { accent-color: var(--blue); }
.form-note { text-align: center; font-size: .8rem; color: var(--text-l); margin-top: -.375rem; }
.form-success { text-align: center; padding: 2.5rem 0; }
.fs-icon { font-size: 3rem; color: var(--green); margin-bottom: 1rem; }
.form-success h3 { font-size: 1.5rem; margin-bottom: .5rem; }
.form-success p { color: var(--text-m); }

/* =============================================================================
   FOOTER
   ============================================================================= */
.footer {
    background: rgba(255,255,255,.60);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-top: 1px solid var(--glass-border);
    padding: 40px 0 0;
}
.footer-grid { display: grid; gap: 3rem; }
@media (min-width: 768px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.footer-brand p { font-size: .875rem; color: var(--text-m); line-height: 1.7; max-width: 240px; margin: .875rem 0; }
.footer-tag { font-size: .8rem; font-weight: 700; color: var(--blue); letter-spacing: .03em; }
.footer-col h4 { font-size: .8125rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text); margin-bottom: 1.25rem; }
.footer-col ul { display: flex; flex-direction: column; gap: .75rem; }
.footer-col a { font-size: .9rem; color: var(--text-m); transition: color .15s; }
.footer-col a:hover { color: var(--blue); }
.footer-bottom { margin-top: 3rem; border-top: 1px solid var(--border); padding: 1.25rem 0; }
.footer-bottom-inner { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: .75rem; }
.footer-bottom-inner span { font-size: .8rem; color: var(--text-l); }

/* =============================================================================
   ANIMATIONS
   ============================================================================= */
.reveal-up {
    opacity: 0; transform: translateY(28px);
    transition: opacity .65s ease, transform .65s ease;
}
.reveal-up.in { opacity: 1; transform: none; }
.reveal-left {
    opacity: 0; transform: translateX(28px);
    transition: opacity .65s ease, transform .65s ease;
}
.reveal-left.in { opacity: 1; transform: none; }

/* Live dot */
.live-dot {
    display: inline-block; width: 8px; height: 8px;
    background: var(--green); border-radius: 50%;
    animation: blink 1.5s ease-in-out infinite;
}
.live-dot.small { width: 6px; height: 6px; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

/* Scrollbar */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg-alt); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-l); }
