:root {
    --bg-base:       #070d1a;
    --glass-bg:      rgba(255,255,255,0.05);
    --glass-border:  rgba(255,255,255,0.10);
    --blur:          blur(20px);
    --text-100: #f0f4ff;
    --text-200: #a8b8d8;
    --text-300: #6278a0;
    --accent-blue:   #3b82f6;
    --accent-teal:   #10b981;
    --accent-amber:  #f59e0b;
    --accent-purple: #8b5cf6;
    --shadow-glass: 0 8px 40px rgba(0,0,0,0.4);
    --radius-xl: 24px; --radius-lg: 16px; --radius-md: 10px; --radius-sm: 6px;
    --font: 'Inter', system-ui, sans-serif;
}
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--bg-base); color:var(--text-100); min-height:100vh; overflow-x:hidden; }

/* ── Background ── */
.bg-gradient { position:fixed;inset:0;z-index:-2; background:radial-gradient(ellipse at 20% 20%,#0d1f4a,var(--bg-base) 60%); }
.blob { position:fixed;border-radius:50%;filter:blur(90px);opacity:.3;z-index:-1; animation:floatBlob 14s ease-in-out infinite alternate;pointer-events:none; }
.blob-blue   { width:500px;height:500px;background:radial-gradient(circle,#1d4ed8,transparent);top:-15%;left:-10%; }
.blob-teal   { width:350px;height:350px;background:radial-gradient(circle,#065f46,transparent);bottom:10%;right:5%;animation-delay:-6s; }
.blob-purple { width:280px;height:280px;background:radial-gradient(circle,#4c1d95,transparent);top:50%;left:60%;animation-delay:-3s; }
@keyframes floatBlob { 0%{transform:translate(0,0) scale(1);}100%{transform:translate(25px,40px) scale(1.08);} }

/* ── Layout ── */
.app-wrapper { max-width:1100px;margin:0 auto;padding:2rem 1.5rem 4rem;display:flex;flex-direction:column;gap:1.5rem; }
.glass-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);
    backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);padding:2rem;box-shadow:var(--shadow-glass);display:flex;flex-direction:column;gap:1.5rem; }

/* ── Header ── */
.site-header { display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
    padding:1.5rem 2rem;background:var(--glass-bg);border:1px solid var(--glass-border);
    border-radius:var(--radius-xl);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur); }
.header-brand { display:flex;align-items:center;gap:1rem; }
.brand-logo { width:52px;height:52px;border-radius:var(--radius-md);
    background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));
    display:grid;place-items:center;font-size:1.5rem;box-shadow:0 4px 16px rgba(59,130,246,.35);flex-shrink:0; }
.site-header h1 { font-size:1.4rem;font-weight:700;letter-spacing:-.5px; }
.header-subtitle { font-size:.8rem;color:var(--text-300);margin-top:3px; }
.header-right { display:flex;align-items:center;gap:1rem;flex-wrap:wrap; }

/* UDI Live */
.udi-live-card { background:rgba(0,0,0,.25);border:1px solid var(--glass-border);border-radius:var(--radius-md);
    padding:.75rem 1.25rem;display:flex;align-items:center;gap:1rem;min-height:56px; }
.udi-live-loading { display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-300); }
.udi-live-content { display:flex;align-items:center;gap:1.5rem; }
.udi-live-value { display:flex;flex-direction:column; }
.udi-label { font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-300); }
.udi-amount { font-size:1.5rem;font-weight:700;color:var(--accent-teal);letter-spacing:-.5px; }
.udi-live-meta { display:flex;flex-direction:column; }
.udi-date { font-size:.8rem;font-weight:500; }
.udi-source { font-size:.7rem;color:var(--text-300); }
.badge { display:flex;align-items:center;gap:7px;padding:6px 14px;border-radius:999px;
    font-size:.78rem;font-weight:500;border:1px solid var(--glass-border);transition:all .4s; }
.badge-dot { width:7px;height:7px;border-radius:50%; }
.badge-loading .badge-dot { background:var(--accent-amber);animation:pulse 1.2s infinite; }
.badge-live    .badge-dot { background:var(--accent-teal); }
.badge-offline .badge-dot { background:var(--text-300); }
.badge-loading { color:var(--accent-amber);background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.2); }
.badge-live    { color:var(--accent-teal);background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.2); }
.badge-offline { color:var(--text-200);background:rgba(255,255,255,.04); }
@keyframes pulse { 0%,100%{opacity:1;}50%{opacity:.3;} }

/* ── KPI Cards ── */
.kpi-row { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem; }
.kpi-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);
    backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
    padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;transition:transform .2s; }
.kpi-card:hover { transform:translateY(-2px); }
.kpi-icon { width:40px;height:40px;border-radius:var(--radius-sm);display:grid;place-items:center;flex-shrink:0; }
.kpi-icon svg { width:18px;height:18px; }
.kpi-icon-blue   { background:rgba(59,130,246,.15);color:var(--accent-blue); }
.kpi-icon-teal   { background:rgba(16,185,129,.15);color:var(--accent-teal); }
.kpi-icon-amber  { background:rgba(245,158,11,.15);color:var(--accent-amber); }
.kpi-icon-purple { background:rgba(139,92,246,.15);color:var(--accent-purple); }
.kpi-body { display:flex;flex-direction:column;gap:3px;min-width:0; }
.kpi-label { font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-300);font-weight:500; }
.kpi-value { font-size:1.5rem;font-weight:700;color:var(--text-100);letter-spacing:-.5px;line-height:1.2; }
.kpi-sub   { font-size:.75rem;color:var(--text-300); }

/* ── Section header ── */
.section-header { display:flex;align-items:center;gap:.75rem; }
.section-icon { width:36px;height:36px;border-radius:var(--radius-sm);background:rgba(59,130,246,.12);
    border:1px solid rgba(59,130,246,.2);display:grid;place-items:center;flex-shrink:0;color:var(--accent-blue); }
.section-icon svg { width:16px;height:16px; }
.section-header h2 { font-size:1.05rem;font-weight:600;margin-bottom:2px; }
.section-header p  { font-size:.8rem;color:var(--text-300); }

/* ── Inputs ── */
.converter-row { display:flex;align-items:flex-end;gap:1rem; }
.converter-row .input-block { flex:1; }
.config-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem; }
.input-block { display:flex;flex-direction:column;gap:6px; }
.input-block label { font-size:.82rem;font-weight:500;color:var(--text-200); }
.input-field { display:flex;align-items:center;background:rgba(0,0,0,.25);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s,box-shadow .2s; }
.input-field:focus-within { border-color:var(--accent-blue);box-shadow:0 0 0 3px rgba(59,130,246,.15); }
.field-prefix,.field-suffix { padding:0 12px;font-size:.8rem;font-weight:600;color:var(--text-300);
    background:rgba(255,255,255,.03);white-space:nowrap; }
.field-prefix { border-right:1px solid var(--glass-border); }
.field-suffix  { border-left:1px solid var(--glass-border); }
input[type="number"] { flex:1;background:transparent;border:none;padding:.8rem 1rem;
    color:var(--text-100);font-size:1rem;font-weight:500;font-family:var(--font);outline:none;min-width:0;-moz-appearance:textfield;appearance:textfield; }
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance:none;appearance:none; }
.input-block > input[type="number"],
.input-block > select { background:rgba(0,0,0,.25);border:1px solid var(--glass-border);border-radius:var(--radius-md);
    padding:.8rem 1rem;color:var(--text-100);font-size:.9rem;font-family:var(--font);
    font-weight:500;outline:none;width:100%;transition:border-color .2s,box-shadow .2s;-moz-appearance:textfield;appearance:textfield; }
.input-block > input[type="number"]:focus,
.input-block > select:focus { border-color:var(--accent-blue);box-shadow:0 0 0 3px rgba(59,130,246,.15); }
.input-block > select { cursor:pointer;-webkit-appearance:none;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236278a0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;padding-right:2.5rem; }

/* Swap button */
.swap-btn { width:44px;height:44px;border-radius:50%;border:1px solid var(--glass-border);
    background:rgba(59,130,246,.15);color:var(--accent-blue);cursor:pointer;
    display:grid;place-items:center;flex-shrink:0;transition:all .2s;margin-bottom:1px; }
.swap-btn svg { width:18px;height:18px; }
.swap-btn:hover { background:rgba(59,130,246,.3);transform:rotate(180deg); }

/* ── Aport toggle — segmented pill control ── */
.aport-toggle {
    display: inline-flex;
    width: fit-content;
    background: rgba(0,0,0,0.25);
    border: 1px solid var(--glass-border);
    border-radius: 999px;
    padding: 4px;
    gap: 4px;
}

/* Hide the native radio — keep it in DOM for JS */
.toggle-opt input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.toggle-opt {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: 999px;
    font-size: .85rem;
    font-weight: 500;
    color: var(--text-300);
    cursor: pointer;
    user-select: none;
    transition: background .2s, color .2s, box-shadow .2s;
    white-space: nowrap;
}

.toggle-opt svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    transition: stroke .2s;
}

/* Active state: when the hidden radio is checked */
.toggle-opt:has(input:checked) {
    background: var(--accent-blue);
    color: #fff;
    box-shadow: 0 2px 10px rgba(59,130,246,.35);
}

.toggle-opt:not(:has(input:checked)):hover {
    background: rgba(255,255,255,.06);
    color: var(--text-200);
}

/* Mobile: full-width, larger tap target */
@media (max-width:700px) {
    .aport-toggle { width: 100%; }
    .toggle-opt   { flex: 1; justify-content: center; padding: 11px 12px; font-size: .82rem; }
}

/* ── Manual input table ── */
.hint-text { font-size:.82rem;color:var(--text-300); }
.manual-table-wrapper { overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--glass-border);max-height:280px;overflow-y:auto; }
.manual-table { width:100%;border-collapse:collapse;min-width:240px; }
.manual-table th { padding:10px 14px;text-align:left;font-size:.75rem;text-transform:uppercase;
    letter-spacing:.5px;color:var(--text-300);background:rgba(255,255,255,.04);
    border-bottom:1px solid var(--glass-border);position:sticky;top:0; }
.manual-table td { padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.04); }
.manual-table td:first-child { font-size:.85rem;font-weight:600;color:var(--text-200);padding-left:14px; }
.manual-table input { background:rgba(0,0,0,.3);border:1px solid var(--glass-border);border-radius:var(--radius-sm);
    padding:6px 10px;color:var(--text-100);font-family:var(--font);font-size:.9rem;width:130px;outline:none;transition:border-color .2s;-moz-appearance:textfield;appearance:textfield; }
.manual-table input:focus { border-color:var(--accent-blue); }
.manual-table input::-webkit-outer-spin-button,
.manual-table input::-webkit-inner-spin-button { -webkit-appearance:none;appearance:none; }

/* ── Calc button ── */
.calc-btn { align-self:flex-start;padding:.8rem 2rem;background:linear-gradient(135deg,var(--accent-blue),#2563eb);
    border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font);font-size:.95rem;
    font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(59,130,246,.3); }
.calc-btn:hover { transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,130,246,.4); }
.calc-btn:active { transform:translateY(0); }

/* ── Results ── */
.result-summary { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem; }
.rs-card { background:rgba(0,0,0,.25);border:1px solid var(--glass-border);border-radius:var(--radius-md);
    padding:1rem 1.25rem;display:flex;flex-direction:column;gap:4px; }
.rs-card.highlight { background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.2); }
.rs-label { font-size:.72rem;text-transform:uppercase;letter-spacing:.4px;color:var(--text-300);font-weight:500; }
.rs-value { font-size:1.3rem;font-weight:700;color:var(--text-100); }
.rs-card.highlight .rs-value { color:var(--accent-teal); }

.interpretation-box { background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.15);
    border-radius:var(--radius-md);padding:1rem 1.25rem;font-size:.88rem;color:var(--text-200);line-height:1.6; }

/* ── Result table ── */
/* ── Scroll hint (mobile only) ── */
.table-scroll-hint {
    display: none;
    align-items: center;
    gap: 6px;
    font-size: .75rem;
    color: var(--text-300);
    margin-bottom: .5rem;
    padding: 0 2px;
}
.table-scroll-hint svg { flex-shrink:0; }

/* ── Result table wrapper ── */
.table-wrapper {
    overflow-x: auto;
    border-radius: var(--radius-md);
    border: 1px solid var(--glass-border);
    -webkit-overflow-scrolling: touch;
}

.result-table { width:100%;border-collapse:collapse;font-size:.84rem;min-width:560px; }
.result-table thead tr { background:rgba(255,255,255,.04);border-bottom:1px solid var(--glass-border); }
.result-table th { padding:11px 14px;text-align:right;font-weight:600;font-size:.72rem;
    text-transform:uppercase;letter-spacing:.5px;color:var(--text-300);white-space:nowrap; }
.result-table th:first-child { text-align:left; }
.result-table tbody tr { border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s; }
.result-table tbody tr:hover { background:rgba(255,255,255,.03); }
.result-table tbody tr:nth-child(even) { background:rgba(255,255,255,.02); }
.result-table td { padding:10px 14px;text-align:right;color:var(--text-200);white-space:nowrap; }
.result-table td:first-child { text-align:left;font-weight:700;color:var(--text-100); }
.col-green { color:var(--accent-teal) !important;font-weight:700; }
.col-blue  { color:var(--accent-blue) !important; }
.col-amber { color:var(--accent-amber) !important; }

/* ── Inline editable input ── */
.inline-input {
    width: 90px;
    background: rgba(59,130,246,.12);
    border: 1px solid rgba(59,130,246,.3);
    border-radius: 6px;
    padding: 6px 8px;
    color: #f0f4ff;
    font-size: .85rem;
    font-family: inherit;
    text-align: right;
    outline: none;
    -moz-appearance: textfield;
    appearance: textfield;
    display: block;
    box-sizing: border-box;
}
.inline-input::-webkit-outer-spin-button,
.inline-input::-webkit-inner-spin-button { -webkit-appearance:none;appearance:none; }
.inline-input:focus { border-color:var(--accent-blue);background:rgba(59,130,246,.2); }

/* column that holds the editable input — give it a fixed width */
.result-table .td-editable { width: 110px; padding: 6px 10px; }

/* ── Mobile — secondary columns hidden to reduce scroll ── */
@media (max-width: 700px) {
    .table-scroll-hint { display: flex; }

    /* Hide less-critical columns: Aportación VP, UDIS Acumuladas */
    .result-table .col-hide-mobile { display: none; }

    /* Compact padding on mobile */
    .result-table th,
    .result-table td { padding: 9px 10px; font-size: .78rem; }

    /* Inline input adapts to mobile */
    .inline-input { width: 78px; font-size: .82rem; padding: 7px 6px; }
    .result-table .td-editable { width: 90px; padding: 5px 8px; }
}



/* ── Export ── */
.export-bar { display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:.25rem; }
.export-label { font-size:.82rem;color:var(--text-300); }
.export-btn { display:flex;align-items:center;gap:8px;padding:.6rem 1.1rem;border-radius:var(--radius-md);
    border:1px solid var(--glass-border);font-family:var(--font);font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s; }
.export-btn svg { width:15px;height:15px;flex-shrink:0; }
.btn-pdf   { background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.25);color:#fca5a5; }
.btn-pdf:hover { background:rgba(239,68,68,.2); }
.btn-excel { background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.25);color:#6ee7b7; }
.btn-excel:hover { background:rgba(16,185,129,.2); }

/* ── CTA ── */
.cta-section { background:linear-gradient(135deg,rgba(59,130,246,.09),rgba(139,92,246,.09));
    border:1px solid rgba(139,92,246,.18);border-radius:var(--radius-xl);
    backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);padding:2rem; }
.cta-content { display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap; }
.cta-badge { display:inline-block;background:rgba(139,92,246,.2);border:1px solid rgba(139,92,246,.3);
    color:#c4b5fd;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
    padding:4px 12px;border-radius:999px;margin-bottom:.75rem; }
.cta-text h3 { font-size:1.1rem;font-weight:700;margin-bottom:6px; }
.cta-text p  { font-size:.87rem;color:var(--text-200);max-width:480px;line-height:1.6; }
.cta-btn { display:flex;align-items:center;gap:10px;padding:.85rem 1.5rem;
    background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));
    border-radius:var(--radius-md);color:#fff;font-family:var(--font);font-size:.9rem;
    font-weight:600;text-decoration:none;box-shadow:0 4px 20px rgba(139,92,246,.35);
    transition:all .2s;white-space:nowrap;flex-shrink:0; }
.cta-btn svg { width:18px;height:18px; }
.cta-btn:hover { transform:translateY(-2px);box-shadow:0 6px 24px rgba(139,92,246,.45); }

/* ── Edu ── */
.edu-section { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);
    backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);overflow:hidden; }
.edu-summary { display:flex;align-items:center;gap:10px;padding:1.25rem 2rem;cursor:pointer;
    font-size:.95rem;font-weight:600;color:var(--text-200);list-style:none;transition:color .2s; }
.edu-summary:hover { color:var(--text-100); }
.edu-summary svg { width:18px;height:18px;flex-shrink:0;color:var(--accent-blue); }
.edu-summary::-webkit-details-marker { display:none; }
.edu-content { padding:0 2rem 2rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem; }
.edu-card { background:rgba(0,0,0,.2);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:1.25rem; }
.edu-card h4 { font-size:.88rem;font-weight:600;margin-bottom:8px;color:var(--accent-blue); }
.edu-card p  { font-size:.82rem;color:var(--text-200);line-height:1.65; }

/* ── Footer ── */
.site-footer { background:rgba(0,0,0,.2);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:1.5rem 2rem; }
.footer-top { display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap; }
.footer-brand { font-size:.95rem;font-weight:600;margin-bottom:4px; }
.footer-legal { font-size:.75rem;color:var(--text-300); }
.footer-legal a { color:var(--accent-blue);text-decoration:none; }
.footer-cta-link { color:var(--accent-purple);text-decoration:none;font-size:.85rem;font-weight:600;
    padding:.5rem 1rem;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-sm);transition:all .2s;white-space:nowrap; }
.footer-cta-link:hover { background:rgba(139,92,246,.1); }

/* ── Toast ── */
.toast { position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(80px);
    background:rgba(30,10,10,.9);border:1px solid rgba(239,68,68,.3);backdrop-filter:blur(12px);
    color:#fca5a5;padding:.75rem 1.25rem;border-radius:999px;font-size:.85rem;font-weight:500;
    display:flex;align-items:center;gap:8px;z-index:999;white-space:nowrap;
    transition:transform .4s cubic-bezier(.34,1.56,.64,1); }
.toast svg { width:16px;height:16px;flex-shrink:0; }
.toast.show { transform:translateX(-50%) translateY(0); }
.hidden { display:none !important; }
.mini-spinner { width:16px;height:16px;border:2px solid rgba(255,255,255,.1);
    border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Responsive ── */
@media (max-width:700px) {
    .app-wrapper { padding:1rem 1rem 3rem; }
    .site-header { flex-direction:column;align-items:flex-start;padding:1.25rem; }
    .header-right { width:100%;flex-direction:column;align-items:flex-start; }
    .udi-live-card { width:100%; }
    .glass-card { padding:1.25rem; }
    .converter-row { flex-direction:column; }
    .swap-btn { align-self:center; }
    .config-grid { grid-template-columns:1fr 1fr; }
    .calc-btn { width:100%;text-align:center;justify-content:center;display:flex; }
    .cta-content { flex-direction:column;align-items:flex-start; }
    .cta-btn { width:100%;justify-content:center; }
    .edu-content { grid-template-columns:1fr; }

    /* ── KPI: 2×2 compact grid on mobile ── */
    .kpi-row {
        grid-template-columns: 1fr 1fr;
        gap: .6rem;
    }
    .kpi-card {
        padding: .85rem .9rem;
        gap: .6rem;
        align-items: center;
    }
    .kpi-icon {
        width: 32px;
        height: 32px;
        flex-shrink: 0;
    }
    .kpi-icon svg { width: 14px; height: 14px; }
    .kpi-value { font-size: 1.15rem; }
    .kpi-label { font-size: .65rem; letter-spacing: .3px; }
    .kpi-sub   { font-size: .68rem; }

    /* ── Result summary: 2×2 compact grid on mobile ── */
    .result-summary {
        grid-template-columns: 1fr 1fr;
        gap: .5rem;
    }
    .rs-card { padding: .75rem 1rem; }
    .rs-value { font-size: 1.1rem; }
    .rs-label { font-size: .65rem; }
}


/* ═══════════════════════════════
   ── LEGION BANNER ──
═══════════════════════════════ */
:root {
    --legion-primary:  #534AB7;
    --legion-light:    #EEEDFE;
    --legion-mid:      #7F77DD;
    --legion-border:   #AFA9EC;
    --legion-dark:     #3C3489;
    --legion-danger:   #E24B4A;
    --legion-card-bg:  rgba(83,74,183,0.06);
    --legion-card-border: rgba(175,169,236,0.18);
}

/* ── Main Banner Card ── */
@keyframes legionGradientShift {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.legion-banner {
    position: relative;
    background: linear-gradient(135deg,
        rgba(83,74,183,.13) 0%,
        rgba(59,130,246,.07) 40%,
        rgba(16,185,129,.06) 70%,
        rgba(83,74,183,.11) 100%
    );
    background-size: 300% 300%;
    animation: legionGradientShift 9s ease infinite;
    border: 0.5px solid var(--legion-card-border);
    border-radius: 12px;
    backdrop-filter: var(--blur);
    -webkit-backdrop-filter: var(--blur);
    overflow: hidden;
    padding: 0 1.75rem 1.75rem;
    transition: border-color 0.3s;
}

.legion-banner:hover {
    border-color: rgba(175,169,236,0.35);
}

/* Mouse-reactive spotlight */
.legion-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(
        500px circle at var(--mx, 50%) var(--my, 50%),
        rgba(127,119,221,.13) 0%,
        transparent 65%
    );
    pointer-events: none;
    z-index: 0;
    transition: background 0.08s;
}

/* Ensure content sits above the pseudo-element */
.legion-top-bar, .legion-header, .legion-tabs, .legion-panel { position: relative; z-index: 1; }

@keyframes legionBarShimmer {
    0%   { background-position: -200% center; }
    100% { background-position: 200% center; }
}

.legion-top-bar {
    height: 5px;
    background: linear-gradient(90deg, #534AB7 0%, #7F77DD 25%, #3b82f6 50%, #10b981 70%, #534AB7 100%);
    background-size: 200%;
    animation: legionBarShimmer 3s linear infinite;
    margin: 0 -1.75rem 1.5rem;
}

/* ── Tabs ── */
.legion-tabs {
    display: flex;
    gap: 6px;
    margin-bottom: 1.25rem;
    background: rgba(0,0,0,0.2);
    border: 1px solid var(--legion-card-border);
    border-radius: 999px;
    padding: 4px;
    width: fit-content;
}

.legion-tab {
    padding: 6px 18px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: var(--text-300);
    font-family: var(--font);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.22s ease;
    white-space: nowrap;
}

.legion-tab:hover {
    color: var(--text-200);
}

.legion-tab.active {
    background: var(--legion-primary);
    color: #fff;
    box-shadow: 0 2px 10px rgba(83,74,183,0.4);
}

/* ── Panel ── */
.legion-panel {
    transition: opacity 0.22s ease;
}

.legion-panel.hidden {
    display: none !important;
}

.legion-panel-inner {
    display: flex;
    gap: 2rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.legion-copy {
    flex: 1;
    min-width: 260px;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

/* ── Wordmark ── */
.legion-header {
    margin-bottom: 1.1rem;
}

.legion-wordmark {
    display: inline-block;
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.05em;
    line-height: 1;
    background: linear-gradient(120deg, #7F77DD 0%, #b4afff 35%, #534AB7 65%, #3b82f6 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    /* Fallback for browsers that don't support gradient text */
    color: var(--legion-mid);
    user-select: none;
}

.legion-descriptor {
    margin-top: 6px;
    font-size: 0.8rem;
    color: var(--text-300);
    letter-spacing: 0.01em;
}

/* ── Typography ── */
.legion-eyebrow {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--legion-mid);
}

.legion-headline {
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--text-100);
    margin: 0;
}

.legion-headline-accent {
    color: var(--legion-primary);
    /* lighten slightly so it reads well on dark bg */
    color: #7F77DD;
}

.legion-subtext {
    font-size: 13px;
    font-weight: 400;
    line-height: 1.65;
    color: var(--text-200);
    max-width: 520px;
    margin: 0;
}

/* Emphasis inside subtext */
.legion-em {
    font-weight: 600;
    color: var(--text-100);
    font-style: normal;
}

/* ── Pain list ── */
.legion-pain-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 0;
    padding: 0;
}

.legion-pain-list li {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: 13px;
    color: var(--text-200);
    line-height: 1.5;
}

.legion-pain-list li svg {
    flex-shrink: 0;
    margin-top: 1px;
}

/* ── Feature chips ── */
.legion-chips {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
}

.legion-chip {
    display: inline-block;
    background: rgba(83,74,183,0.14);
    border: 1px solid var(--legion-card-border);
    color: var(--legion-mid);
    font-size: 12px;
    font-weight: 500;
    padding: 4px 12px;
    border-radius: 8px;
    white-space: nowrap;
}

/* ── CTAs ── */
.legion-ctas {
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex-shrink: 0;
    align-self: center;
    min-width: 180px;
}

@keyframes ctaGlow {
    0%, 100% { box-shadow: 0 4px 16px rgba(83,74,183,.35); }
    50%       { box-shadow: 0 4px 28px rgba(83,74,183,.65), 0 0 0 4px rgba(83,74,183,.12); }
}

.legion-cta-primary {
    display: block;
    text-align: center;
    padding: 0.75rem 1.6rem;
    background: var(--legion-primary);
    color: #fff;
    font-family: var(--font);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 8px;
    animation: ctaGlow 2.5s ease-in-out infinite;
    transition: background 0.2s, transform 0.2s;
    white-space: nowrap;
}

.legion-cta-primary:hover {
    background: var(--legion-dark);
    transform: translateY(-2px);
    animation: none;
    box-shadow: 0 8px 24px rgba(83,74,183,.55);
}

.legion-cta-secondary {
    display: block;
    text-align: center;
    padding: 0.65rem 1.4rem;
    background: transparent;
    color: var(--legion-mid);
    font-family: var(--font);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid var(--legion-card-border);
    border-radius: 8px;
    transition: all 0.2s;
    white-space: nowrap;
}

.legion-cta-secondary:hover {
    background: rgba(83,74,183,0.1);
    border-color: var(--legion-mid);
    color: #fff;
}

/* ── Sticky Banner ── */
.legion-sticky {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
    background: rgba(7,13,26,0.92);
    border-top: 1px solid var(--legion-card-border);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    transition: transform 0.35s cubic-bezier(.34,1.56,.64,1), opacity 0.3s ease;
}

.legion-sticky.hidden {
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
}

.legion-sticky-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 10px 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.legion-sticky-brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.legion-sticky-icon {
    width: 32px;
    height: 32px;
    border-radius: 7px;
    background: var(--legion-primary);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.legion-sticky-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.legion-sticky-title {
    font-size: 0.84rem;
    font-weight: 600;
    color: var(--text-100);
    white-space: nowrap;
}

.legion-sticky-sub {
    font-size: 0.74rem;
    color: var(--text-300);
    white-space: nowrap;
}

.legion-sticky-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.legion-sticky-btn {
    display: inline-block;
    padding: 7px 18px;
    background: var(--legion-primary);
    color: #fff;
    font-family: var(--font);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(83,74,183,0.35);
    transition: all 0.2s;
    white-space: nowrap;
}

.legion-sticky-btn:hover {
    background: var(--legion-dark);
    transform: translateY(-1px);
}

.legion-sticky-close {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--glass-border);
    background: rgba(255,255,255,0.06);
    color: var(--text-300);
    font-size: 1.1rem;
    cursor: pointer;
    display: grid;
    place-items: center;
    line-height: 1;
    transition: all 0.2s;
    flex-shrink: 0;
    font-family: var(--font);
}

.legion-sticky-close:hover {
    background: rgba(255,255,255,0.12);
    color: var(--text-100);
}

/* Body padding when sticky is visible */
body.legion-sticky-active {
    padding-bottom: 68px;
}

/* ── Legion Responsive ── */
@media (max-width:700px) {
    .legion-banner { padding: 0 1.25rem 1.25rem; }
    .legion-top-bar { margin: 0 -1.25rem 1.25rem; }
    .legion-panel-inner { flex-direction: column; gap: 1.25rem; }
    .legion-ctas { width: 100%; }
    .legion-cta-primary, .legion-cta-secondary { width: 100%; }
    .legion-sticky-inner { flex-wrap: wrap; gap: 8px; }
    .legion-sticky-sub { display: none; }
    .legion-sticky-title { font-size: 0.78rem; }
}

