/* ============================================
   STUART HOLLINGER LANDING PAGE
   Modern, Dark Theme with Gradients
   ============================================ */

/* CSS Variables */
:root {
    /* Colors */
    --bg-primary: #0a0a0f;
    --bg-secondary: #12121a;
    --bg-tertiary: #1a1a25;
    --bg-card: rgba(255, 255, 255, 0.03);
    --bg-card-hover: rgba(255, 255, 255, 0.06);

    --text-primary: #ffffff;
    --text-secondary: rgba(255, 255, 255, 0.7);
    --text-tertiary: rgba(255, 255, 255, 0.5);

    --accent-primary: #6366f1;
    --accent-secondary: #8b5cf6;
    --accent-tertiary: #a855f7;
    --accent-gradient: linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #ec4899 100%);

    --success: #22c55e;
    --warning: #f59e0b;

    --border-color: rgba(255, 255, 255, 0.08);
    --border-hover: rgba(255, 255, 255, 0.15);

    /* Spacing */
    --section-padding: 120px;
    --container-width: 1200px;

    /* Typography */
    --font-main: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Effects */
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 20px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 8px 40px rgba(0, 0, 0, 0.5);
    --shadow-glow: 0 0 60px rgba(99, 102, 241, 0.3);

    --transition-fast: 0.15s ease;
    --transition-normal: 0.3s ease;
    --transition-slow: 0.5s ease;
}

/* Reset */
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    /* scroll-behavior removed - instant navigation */
}

body {
    font-family: var(--font-main);
    background: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.6;
    overflow-x: hidden;
}

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

ul {
    list-style: none;
}

img {
    max-width: 100%;
    height: auto;
}

/* Utility Classes */
.gradient-text {
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.section-container {
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 48px;
}

@media (min-width: 1400px) {
    .section-container {
        padding: 0 64px;
    }
}

/* ============================================
   NAVIGATION
   ============================================ */
.nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    padding: 16px 24px;
    background: rgba(10, 10, 15, 0.8);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border-color);
}

.nav-container {
    max-width: var(--container-width);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.nav-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: 1.1rem;
}

.logo-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--accent-gradient);
    border-radius: 8px;
    font-size: 0.9rem;
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 32px;
}

.nav-links a {
    font-size: 0.9rem;
    color: var(--text-secondary);
    transition: color var(--transition-fast);
}

.nav-links a:hover {
    color: var(--text-primary);
}

.nav-cta {
    padding: 10px 20px;
    background: var(--accent-gradient);
    border-radius: 8px;
    font-weight: 600;
    color: white !important;
}

/* Special Wallet Nav Link - Treasury Portal Style */
.nav-wallet {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1), rgba(16, 185, 129, 0.05));
    border: 1px solid rgba(34, 197, 94, 0.4);
    border-radius: 20px;
    color: #22c55e !important;
    font-weight: 600;
    font-size: 0.85rem;
    transition: all 0.3s ease;
    position: relative;
}

.nav-wallet::before {
    content: '◆';
    font-size: 0.7rem;
    color: #22c55e;
}

.nav-wallet:hover {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2), rgba(16, 185, 129, 0.1));
    border-color: #22c55e;
    box-shadow: 0 0 20px rgba(34, 197, 94, 0.3);
    transform: translateY(-1px);
    color: #4ade80 !important;
}

.mobile-menu-btn {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    background: none;
    border: none;
    cursor: pointer;
}

.mobile-menu-btn span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--text-primary);
    border-radius: 2px;
}

/* ============================================
   HERO SECTION
   ============================================ */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 120px 24px 80px;
    overflow: hidden;
}

.hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-gradient {
    position: absolute;
    top: -50%;
    right: -20%;
    width: 80%;
    height: 150%;
    background: radial-gradient(ellipse at center, rgba(99, 102, 241, 0.15) 0%, transparent 60%);
    pointer-events: none;
}

.hero-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
    background-size: 60px 60px;
    mask-image: radial-gradient(ellipse at center, black 0%, transparent 70%);
}

.hero-content {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 60px;
}

.hero-text {
    max-width: 600px;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 100px;
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 24px;
}

.badge-dot {
    width: 8px;
    height: 8px;
    background: var(--success);
    border-radius: 50%;
    animation: pulse 2s infinite;
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

.hero-title {
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin-bottom: 24px;
}

.title-line {
    display: block;
}

.hero-subtitle {
    font-size: 1.2rem;
    color: var(--text-secondary);
    max-width: 550px;
    margin-bottom: 32px;
    line-height: 1.7;
}

.token-highlight {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-family: monospace;
    font-weight: 600;
    color: var(--accent-primary);
}

.hero-cta {
    display: flex;
    gap: 16px;
    margin-bottom: 48px;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 28px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 12px;
    border: none;
    cursor: pointer;
    transition: all var(--transition-normal);
}

.btn-primary {
    background: var(--accent-gradient);
    color: white;
    box-shadow: var(--shadow-glow);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 80px rgba(99, 102, 241, 0.4);
}

.btn-secondary {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.btn-secondary:hover {
    background: var(--bg-card-hover);
    border-color: var(--border-hover);
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.btn-outline:hover {
    background: var(--bg-card);
    border-color: var(--border-hover);
}

.hero-stats {
    display: flex;
    align-items: center;
    gap: 32px;
}

.stat {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.stat-number {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.stat-label {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.stat-divider {
    width: 1px;
    height: 40px;
    background: var(--border-color);
}

/* Floating Cards */
.hero-visual {
    position: relative;
    width: 100%;
    height: 450px;
}

.floating-cards {
    position: relative;
    width: 100%;
    height: 100%;
}

.app-card {
    position: absolute;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    box-shadow: var(--shadow-lg);
    animation: float 6s ease-in-out infinite;
}

.app-icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border-radius: 12px;
    font-size: 1.4rem;
}

.app-card span {
    font-weight: 600;
    font-size: 0.95rem;
}

.card-1 {
    top: 10%;
    left: 0;
    animation-delay: 0s;
}

.card-2 {
    top: 30%;
    right: 0;
    animation-delay: -1s;
}

.card-3 {
    top: 50%;
    left: 10%;
    animation-delay: -2s;
}

.card-4 {
    top: 70%;
    right: 10%;
    animation-delay: -3s;
}

.card-5 {
    bottom: 5%;
    left: 20%;
    animation-delay: -4s;
}

.card-6 {
    top: 5%;
    right: 15%;
    animation-delay: -0.5s;
}

.card-7 {
    top: 20%;
    left: 40%;
    animation-delay: -2.5s;
}

.card-8 {
    top: 60%;
    right: 25%;
    animation-delay: -3.5s;
}

.card-9 {
    bottom: 15%;
    right: 5%;
    animation-delay: -1.5s;
}

.card-10 {
    top: 40%;
    left: 5%;
    animation-delay: -4.5s;
}

.card-11 {
    bottom: 25%;
    left: 45%;
    animation-delay: -5s;
}

@keyframes float {

    0%,
    100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-20px);
    }
}

/* ============================================
   APPS SECTION
   ============================================ */
.apps-section {
    padding: var(--section-padding) 0;
    background: var(--bg-secondary);
}

.section-header {
    text-align: center;
    max-width: 600px;
    margin: 0 auto 64px;
}

.section-tag {
    display: inline-block;
    padding: 6px 14px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 100px;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--accent-primary);
    margin-bottom: 16px;
}

.section-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 16px;
}

.section-subtitle {
    font-size: 1.1rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

.apps-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
}

.app-category {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
    padding: 32px;
    transition: all var(--transition-normal);
}

.app-category:hover {
    border-color: var(--border-hover);
    box-shadow: var(--shadow-md);
}

.category-title {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 24px;
}

.category-icon {
    font-size: 1.4rem;
}

.category-apps {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.app-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 16px;
    transition: all var(--transition-fast);
}

.app-item:hover {
    background: var(--bg-tertiary);
}

.app-item-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border-radius: 12px;
    font-size: 1.4rem;
    flex-shrink: 0;
}

.app-item-info {
    flex: 1;
    min-width: 0;
}

.app-item-info h4 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 4px;
}

.app-item-info p {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    line-height: 1.4;
}

.app-status {
    padding: 6px 12px;
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    flex-shrink: 0;
}

.app-status.live {
    background: rgba(34, 197, 94, 0.15);
    color: var(--success);
}

.app-status.building {
    background: rgba(245, 158, 11, 0.15);
    color: var(--warning);
}

/* ============================================
   TOKEN SECTION
   ============================================ */
.token-section {
    padding: var(--section-padding) 0;
    background: var(--bg-primary);
}

.token-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
}

.token-info {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.token-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    padding: 20px;
}

.token-card.main-card {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border-color: rgba(99, 102, 241, 0.3);
}

.token-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}

.token-logo {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 12px;
    font-size: 1.2rem;
    font-weight: 700;
}

.token-header h3 {
    font-size: 1.2rem;
    font-weight: 700;
}

.token-header span {
    font-size: 0.9rem;
    color: var(--text-tertiary);
}

.token-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

.token-stat {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.token-stat-label {
    font-size: 0.65rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.token-stat-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.how-it-works h3 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 24px;
}

.steps {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.step {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.step-number {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 50%;
    font-weight: 700;
    font-size: 0.9rem;
    flex-shrink: 0;
}

.step-content h4 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 4px;
}

.step-content p {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

/* Staking Benefits */
.staking-benefits {
    margin-top: 20px;
    padding: 16px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 16px;
    text-align: center;
}

.staking-benefits h3 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.staking-subtitle {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 12px;
}

.staking-perks {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.staking-perk {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: var(--bg-secondary);
    border-radius: 8px;
    font-size: 0.8rem;
}

.perk-icon {
    font-size: 1rem;
}

/* ============================================
   DISCUSSION BOARD PAGE
   ============================================ */
.discuss-hero {
    padding: 120px 24px 40px;
    text-align: center;
}

.discuss-hero h1 {
    font-size: 2rem;
    font-weight: 800;
    margin-bottom: 8px;
}

.discuss-subtitle {
    font-size: 1rem;
    color: var(--text-secondary);
    margin-bottom: 24px;
}

.staker-info {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.staker-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--accent-gradient);
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}

.staker-note {
    font-size: 0.8rem;
    color: var(--text-tertiary);
}

/* App Tabs */
.discuss-content {
    padding: 0 24px 80px;
}

.app-tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 16px;
    margin-bottom: 24px;
}

.app-tab {
    padding: 8px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    font-size: 0.8rem;
    color: var(--text-secondary);
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--transition-fast);
}

.app-tab:hover {
    border-color: var(--accent-primary);
}

.app-tab.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

/* Submit Idea Box */
.submit-idea-box {
    padding: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    margin-bottom: 24px;
}

.submit-idea-box h3 {
    font-size: 1rem;
    margin-bottom: 12px;
}

.idea-form {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 12px;
}

.idea-app,
.idea-title,
.idea-desc {
    padding: 10px 14px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.9rem;
}

.idea-desc {
    grid-column: span 2;
}

.idea-form .btn {
    grid-column: span 2;
}

/* Feature Cards */
.feature-cards {
    display: grid;
    gap: 16px;
}

.feature-card {
    display: flex;
    gap: 16px;
    padding: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    transition: all var(--transition-normal);
}

.feature-card:hover {
    border-color: var(--border-hover);
}

.card-votes {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    min-width: 50px;
}

.upvote-btn {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-size: 1rem;
    color: var(--text-tertiary);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.upvote-btn:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}

.upvote-btn.voted {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

.vote-count {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.card-content {
    flex: 1;
}

.card-app {
    font-size: 0.7rem;
    color: var(--accent-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 4px;
}

.card-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 6px;
}

.card-desc {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 10px;
}

.card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.75rem;
}

.card-author {
    color: var(--text-tertiary);
}

.card-status {
    padding: 4px 10px;
    border-radius: 12px;
    font-weight: 500;
}

.status-new {
    background: rgba(255, 255, 255, 0.1);
}

.status-review {
    background: rgba(99, 102, 241, 0.2);
    color: #818cf8;
}

.status-planned {
    background: rgba(245, 158, 11, 0.2);
    color: #fbbf24;
}

.status-building {
    background: rgba(34, 197, 94, 0.2);
    color: #4ade80;
}

/* Emission Timeline */
.emission-timeline {
    margin-top: 16px;
    padding: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
}

.timeline-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.timeline-header h4 {
    font-size: 0.85rem;
    font-weight: 700;
    margin: 0;
}

.timeline-status {
    font-size: 0.65rem;
    padding: 3px 8px;
    background: var(--accent-gradient);
    border-radius: 20px;
    font-weight: 600;
}

.timeline-desc {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    margin-bottom: 12px;
}

.emission-explainer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px;
    background: var(--bg-secondary);
    border-radius: 10px;
    margin-bottom: 10px;
}

.explainer-stat {
    text-align: center;
    padding: 6px 10px;
}

.explainer-stat.highlight {
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 10px;
}

.explainer-num {
    display: block;
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--text-primary);
}

.explainer-stat.highlight .explainer-num {
    color: var(--success);
}

.explainer-label {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-tertiary);
}

.explainer-arrow {
    font-size: 1.2rem;
    color: var(--accent-primary);
    font-weight: 700;
}

.month-buttons {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 4px;
    margin-bottom: 12px;
}

.month-btn {
    width: 100%;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    font-weight: 600;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-secondary);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.month-btn:hover:not(.past):not(.current) {
    border-color: var(--accent-primary);
    background: rgba(99, 102, 241, 0.1);
}

.month-btn.past {
    background: var(--bg-tertiary);
    color: var(--text-tertiary);
    opacity: 0.4;
    cursor: not-allowed;
    text-decoration: line-through;
}

.month-btn.current {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
    animation: currentPulse 2s infinite;
}

@keyframes currentPulse {

    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(99, 102, 241, 0.4);
    }

    50% {
        box-shadow: 0 0 0 4px rgba(99, 102, 241, 0);
    }
}

.month-btn.future {
    background: rgba(34, 197, 94, 0.1);
    border-color: rgba(34, 197, 94, 0.3);
    color: var(--success);
}

.timeline-progress {
    margin-top: 8px;
}

.progress-bar {
    height: 6px;
    background: var(--bg-tertiary);
    border-radius: 3px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background: var(--accent-gradient);
    border-radius: 3px;
    transition: width 0.3s ease;
}

.progress-labels {
    display: flex;
    justify-content: space-between;
    margin-top: 4px;
    font-size: 0.65rem;
    color: var(--text-tertiary);
}

#progressPercent {
    color: var(--accent-primary);
    font-weight: 600;
}

.inline-link {
    color: var(--accent-primary);
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 2px;
}

.inline-link:hover {
    color: var(--accent-secondary);
}

/* ============================================
   STAKING SECTION
   ============================================ */
.staking-section {
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    margin-top: 24px;
}

.staking-section h3 {
    font-size: 1.1rem;
    margin-bottom: 4px;
}

.staking-subtitle {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin-bottom: 20px;
}

.staking-calculator {
    padding: 20px;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 20px;
}

.stake-input-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.stake-input-row label {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.stake-input-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

.stake-input-group input {
    width: 100px;
    padding: 8px 12px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.9rem;
    text-align: right;
}

.stake-suffix {
    font-size: 0.8rem;
    color: var(--text-tertiary);
}

.payout-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.toggle-label {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.toggle-buttons {
    display: flex;
    gap: 8px;
}

.toggle-btn {
    padding: 8px 16px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    font-size: 0.8rem;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.toggle-btn:hover {
    border-color: var(--accent-primary);
}

.toggle-btn.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

.stake-results {
    padding: 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    margin-bottom: 12px;
}

.stake-result-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
}

.stake-result-row.highlight {
    background: rgba(99, 102, 241, 0.1);
    margin: 0 -8px;
    padding: 10px 8px;
    border-radius: 6px;
}

.result-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.result-value {
    font-size: 0.9rem;
    font-weight: 700;
}

.stake-assumption {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    text-align: center;
}

.stake-assumption select {
    padding: 4px 8px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.75rem;
}

.staking-perks {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.staking-perk {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: var(--bg-secondary);
    border-radius: 8px;
    font-size: 0.8rem;
}

.perk-icon {
    font-size: 1rem;
}

.perk-text {
    color: var(--text-secondary);
}

/* Flywheel Visual */
.flywheel-visual {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
    padding: 32px;
    text-align: center;
}

.flywheel-visual h3 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 32px;
}

.flywheel {
    position: relative;
    width: 300px;
    height: 300px;
    margin: 0 auto 24px;
}

.flywheel-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 50%;
    font-weight: 700;
    font-size: 0.9rem;
    z-index: 2;
    box-shadow: var(--shadow-glow);
}

.flywheel-items {
    position: absolute;
    inset: 0;
}

.flywheel-item {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.flywheel-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 1.2rem;
}

.flywheel-item.item-1 {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.flywheel-item.item-2 {
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}

.flywheel-item.item-3 {
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

.flywheel-item.item-4 {
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}

.flywheel-arrows {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.arrow-path {
    fill: none;
    stroke: var(--accent-primary);
    stroke-width: 2;
    stroke-dasharray: 8 4;
    opacity: 0.5;
}

.flywheel-caption {
    font-size: 0.9rem;
    color: var(--text-tertiary);
    max-width: 280px;
    margin: 0 auto;
    line-height: 1.5;
}

.flywheel-section {
    margin-top: 48px;
    display: flex;
    justify-content: center;
}

/* ============================================
   LIVE STATS BAR
   ============================================ */
.live-stats-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 48px;
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
}

.live-stat {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 16px;
    position: relative;
}

.live-stat-icon {
    font-size: 1.5rem;
}

.live-stat-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.live-stat-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.live-stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
}

.live-badge {
    position: absolute;
    top: 8px;
    right: 8px;
    padding: 3px 8px;
    background: rgba(34, 197, 94, 0.2);
    color: var(--success);
    border-radius: 6px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    animation: livePulse 2s infinite;
}

@keyframes livePulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.6;
    }
}

/* ============================================
   TOKEN CALCULATOR
   ============================================ */
.token-calculator {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(99, 102, 241, 0.1) 100%);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 20px;
    padding: 20px;
}

.token-calculator h3 {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.calc-subtitle {
    color: var(--text-secondary);
    margin-bottom: 16px;
    font-size: 0.85rem;
}

.calc-slider-container {
    margin-bottom: 16px;
}

.calc-slider-container label {
    display: block;
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 12px;
    color: var(--text-secondary);
}

.calc-slider {
    width: 100%;
    height: 8px;
    border-radius: 4px;
    background: var(--bg-tertiary);
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
}

.calc-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--accent-gradient);
    cursor: grab;
    box-shadow: 0 0 20px rgba(99, 102, 241, 0.5);
    transition: transform 0.2s;
}

.calc-slider::-webkit-slider-thumb:hover {
    transform: scale(1.1);
}

.calc-slider::-webkit-slider-thumb:active {
    cursor: grabbing;
    transform: scale(0.95);
}

.slider-value {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 8px;
    padding: 6px 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--accent-primary);
}

.price-mcap-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.current-indicator {
    margin-top: 8px;
    padding: 6px 12px;
    background: rgba(99, 102, 241, 0.15);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.current-label {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-tertiary);
}

.current-value {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--accent-primary);
}

.mcap-display {
    margin-top: 12px;
    padding: 8px 16px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(34, 197, 94, 0.05) 100%);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 10px;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.mcap-display span {
    font-weight: 700;
    color: var(--success);
}

.mcap-display-large {
    margin-top: 8px;
    padding: 10px 16px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(34, 197, 94, 0.05) 100%);
    border: 2px solid rgba(34, 197, 94, 0.4);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    transition: all 0.2s ease;
}

.mcap-display-large:hover {
    border-color: rgba(34, 197, 94, 0.6);
    transform: scale(1.02);
}

.mcap-label {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-tertiary);
}

.mcap-value {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--success);
}

/* Pay vs Get Comparison */
.pay-vs-get {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 16px;
    background: var(--bg-secondary);
    border: 2px solid var(--border-color);
    border-radius: 16px;
    margin-bottom: 16px;
    transition: all 0.3s ease;
}

.pay-vs-get.profit {
    border-color: rgba(34, 197, 94, 0.5);
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(34, 197, 94, 0.05) 100%);
}

.pay-vs-get.break-even {
    border-color: rgba(245, 158, 11, 0.5);
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.1) 0%, rgba(245, 158, 11, 0.05) 100%);
}

.pay-side,
.get-side {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 12px 20px;
    border-radius: 12px;
}

.pay-side {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.get-side {
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.pvg-label {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-tertiary);
}

.pvg-value {
    font-size: 1.5rem;
    font-weight: 800;
}

.pay-side .pvg-value {
    color: #ef4444;
}

.get-side .pvg-value {
    color: var(--success);
}

.pvg-detail {
    font-size: 0.7rem;
    color: var(--text-tertiary);
}

.pvg-arrow {
    font-size: 1.5rem;
    color: var(--accent-primary);
    animation: arrowPulse 1.5s infinite;
}

@keyframes arrowPulse {

    0%,
    100% {
        opacity: 1;
        transform: translateX(0);
    }

    50% {
        opacity: 0.5;
        transform: translateX(4px);
    }
}

.pvg-verdict {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
}

.verdict-icon {
    font-size: 1rem;
}

.verdict-text {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.calc-results {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-bottom: 16px;
}

.calc-result {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 10px;
    background: var(--bg-secondary);
    border-radius: 10px;
}

.calc-result.highlight {
    grid-column: span 2;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.2) 0%, rgba(168, 85, 247, 0.2) 100%);
    border: 1px solid rgba(99, 102, 241, 0.3);
    padding: 12px;
}

.calc-label {
    font-size: 0.7rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.calc-value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.calc-result.highlight .calc-value {
    font-size: 1.4rem;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.calc-unit {
    font-size: 0.9rem;
    color: var(--text-secondary);
    font-weight: 600;
}

.early-advantage {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(34, 197, 94, 0.05) 100%);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 16px;
}

.advantage-icon {
    font-size: 2rem;
}

.early-advantage strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 4px;
    color: var(--success);
}

.early-advantage p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin: 0;
}

/* ROI Highlight Card */
.roi-card {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(34, 197, 94, 0.05) 100%);
    border: 2px solid var(--success);
    border-radius: 20px;
    padding: 24px;
    text-align: center;
    margin-top: 24px;
}

.roi-title {
    font-size: 0.85rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 8px;
}

.roi-value {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--success);
    margin-bottom: 8px;
}

.roi-subtitle {
    font-size: 0.95rem;
    color: var(--text-secondary);
}

/* ============================================
   REVENUE FLOW VISUALIZATION
   ============================================ */
.revenue-flow-section {
    margin-top: 64px;
    padding: 40px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
}

.revenue-flow-section h3 {
    font-size: 1.5rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 8px;
}

.flow-subtitle {
    text-align: center;
    color: var(--text-secondary);
    margin-bottom: 40px;
    font-size: 0.95rem;
}

.revenue-flow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    overflow-x: auto;
    padding: 20px 0;
}

.flow-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 20px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    min-width: 140px;
    text-align: center;
    transition: all var(--transition-normal);
}

.flow-step:hover {
    border-color: var(--border-hover);
    transform: translateY(-2px);
}

.flow-step.highlight-step {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.15) 0%, rgba(168, 85, 247, 0.1) 100%);
    border-color: rgba(99, 102, 241, 0.3);
}

.flow-step.final-step {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(34, 197, 94, 0.05) 100%);
    border-color: rgba(34, 197, 94, 0.3);
}

.flow-icon {
    font-size: 2rem;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border-radius: 16px;
}

.flow-icon.token-icon {
    background: var(--accent-gradient);
    color: white;
    font-weight: 700;
}

.flow-icon.distribute-icon {
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
}

.flow-content {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.flow-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.flow-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.flow-detail {
    font-size: 0.8rem;
    color: var(--text-tertiary);
}

.success-text {
    color: var(--success);
}

/* Flow Arrows */
.flow-arrow {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0 4px;
}

.arrow-line {
    width: 30px;
    height: 3px;
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));
    border-radius: 2px;
}

.arrow-line.animated {
    position: relative;
    overflow: hidden;
}

.arrow-line.animated::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent);
    animation: flowPulse 2s infinite;
}

@keyframes flowPulse {
    0% {
        left: -100%;
    }

    100% {
        left: 100%;
    }
}

.arrow-head {
    font-size: 1.2rem;
    color: var(--accent-primary);
    font-weight: 700;
}

/* Split Step */
.flow-step.split-step {
    padding: 16px;
    min-width: 200px;
}

.split-container {
    display: flex;
    gap: 8px;
}

.split-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 12px 8px;
    border-radius: 12px;
    flex: 1;
}

.split-item.stuart {
    background: rgba(99, 102, 241, 0.1);
}

.split-item.ops {
    background: rgba(245, 158, 11, 0.1);
}

.split-item.buyback {
    background: rgba(34, 197, 94, 0.15);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.split-percent {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-primary);
}

.split-label {
    font-size: 0.65rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.split-value {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary);
}

/* Flow Summary */
.flow-summary {
    margin-top: 32px;
}

.summary-box {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(99, 102, 241, 0.1) 100%);
    border: 1px solid rgba(34, 197, 94, 0.2);
    border-radius: 16px;
}

.summary-icon {
    font-size: 2rem;
}

.summary-box strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 4px;
}

.summary-box p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin: 0;
}

/* ============================================
   PRICING SECTION
   ============================================ */
.pricing-section {
    padding: var(--section-padding) 0;
    background: var(--bg-secondary);
}

.pricing-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1000px;
    margin: 0 auto;
}

.pricing-card {
    position: relative;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    transition: all var(--transition-normal);
}

.pricing-card:hover {
    border-color: var(--border-hover);
    transform: translateY(-4px);
}

.pricing-card.featured {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.15) 0%, rgba(168, 85, 247, 0.1) 100%);
    border-color: var(--accent-primary);
    transform: scale(1.05);
}

.pricing-card.featured:hover {
    transform: scale(1.05) translateY(-4px);
}

.featured-badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    padding: 6px 16px;
    background: var(--accent-gradient);
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.feature-highlight {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    padding: 6px 16px;
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.payment-methods {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 8px;
}

.payment-methods .btn {
    font-size: 0.85rem;
    padding: 10px 16px;
}

/* Custom Subscription Tier */
.custom-tier {
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(99, 102, 241, 0.05) 100%);
}

.custom-slider-section {
    margin-bottom: 20px;
}

.custom-slider-section input[type="range"] {
    width: 100%;
    height: 8px;
    -webkit-appearance: none;
    background: var(--bg-tertiary);
    border-radius: 4px;
    outline: none;
}

.custom-slider-section input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 24px;
    height: 24px;
    background: var(--accent-gradient);
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.4);
}

.slider-labels {
    display: flex;
    justify-content: space-between;
    margin-top: 8px;
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.custom-rewards {
    padding: 16px;
    background: var(--bg-tertiary);
    border-radius: 12px;
    margin-bottom: 16px;
}

.reward-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
}

.reward-row.highlight {
    background: rgba(99, 102, 241, 0.1);
    margin: 0 -12px;
    padding: 10px 12px;
    border-radius: 8px;
}

.reward-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.reward-value {
    font-size: 0.9rem;
    font-weight: 700;
}

.tier-badge {
    padding: 4px 10px;
    background: var(--accent-gradient);
    border-radius: 12px;
    font-size: 0.75rem;
}

.pricing-features.compact {
    margin-bottom: 16px;
}

.pricing-features.compact li {
    padding: 6px 0;
    font-size: 0.85rem;
}

.sub-assumption {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 12px;
    font-size: 0.8rem;
}

.assumption-label {
    color: var(--text-tertiary);
}

.sub-assumption select {
    padding: 6px 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.8rem;
    cursor: pointer;
}

.pricing-header {
    text-align: center;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.pricing-header h3 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.pricing-amount {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 4px;
}

.price {
    font-size: 2.5rem;
    font-weight: 800;
}

.period {
    font-size: 0.9rem;
    color: var(--text-tertiary);
}

.pricing-features {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 32px;
}

.pricing-features li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.pricing-features li.disabled {
    color: var(--text-tertiary);
    opacity: 0.6;
}

.pricing-features .check,
.pricing-features .x {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
}

.pricing-features .check {
    color: var(--success);
}

.pricing-features .x {
    color: var(--text-tertiary);
}

.pricing-card .btn {
    width: 100%;
}

/* ============================================
   SUBSCRIBE SECTION
   ============================================ */
.subscribe-section {
    padding: var(--section-padding) 0;
    background: var(--bg-primary);
}

.subscribe-content {
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

.subscribe-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 16px;
}

.subscribe-subtitle {
    font-size: 1.1rem;
    color: var(--text-secondary);
    margin-bottom: 32px;
}

/* ============================================
   ABOUT SECTION
   ============================================ */
.about-section {
    padding: 80px 24px;
    background: var(--bg-secondary);
}

.about-content {
    display: flex;
    align-items: center;
    gap: 48px;
    max-width: 900px;
    margin: 0 auto;
}

.about-image {
    flex-shrink: 0;
}

.about-photo-placeholder {
    width: 180px;
    height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 50%;
    font-size: 4rem;
}

.about-text h2 {
    font-size: 2rem;
    font-weight: 800;
    margin-bottom: 8px;
}

.about-tagline {
    font-size: 1.1rem;
    color: var(--accent-primary);
    margin-bottom: 20px;
}

.about-bio {
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 16px;
}

.about-social {
    display: flex;
    gap: 12px;
    margin-top: 24px;
}

.social-link {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 1.2rem;
    transition: all var(--transition-fast);
}

.social-link:hover {
    border-color: var(--accent-primary);
    background: rgba(99, 102, 241, 0.1);
}

@media (max-width: 768px) {
    .about-content {
        flex-direction: column;
        text-align: center;
    }

    .about-social {
        justify-content: center;
    }
}

.early-alert {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(34, 197, 94, 0.05) 100%);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 16px;
    margin-bottom: 32px;
    text-align: left;
}

.alert-icon {
    font-size: 2rem;
}

.alert-content strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 4px;
}

.alert-content p {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.subscribe-form {
    margin-bottom: 32px;
}

.form-group {
    display: flex;
    gap: 12px;
}

.form-group input {
    flex: 1;
    padding: 16px 20px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 1rem;
    color: var(--text-primary);
    outline: none;
    transition: all var(--transition-fast);
}

.form-group input::placeholder {
    color: var(--text-tertiary);
}

.form-group input:focus {
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}

.form-note {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin-top: 12px;
}

.social-proof {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.proof-avatars {
    display: flex;
}

.avatar {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border: 2px solid var(--bg-primary);
    border-radius: 50%;
    font-weight: 600;
    font-size: 0.85rem;
    margin-right: -8px;
}

.avatar:last-child {
    margin-right: 0;
    background: var(--bg-tertiary);
}

/* ============================================
   FOOTER
   ============================================ */
.footer {
    padding: 80px 24px 40px;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
}

.footer-container {
    max-width: var(--container-width);
    margin: 0 auto;
}

.footer-main {
    display: grid;
    grid-template-columns: 1.5fr 2fr;
    gap: 64px;
    margin-bottom: 48px;
}

.footer-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 16px;
}

.footer-brand p {
    color: var(--text-secondary);
    font-size: 0.95rem;
    margin-bottom: 24px;
    max-width: 300px;
}

.footer-social {
    display: flex;
    gap: 12px;
}

.footer-social a {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    transition: all var(--transition-fast);
}

.footer-social a:hover {
    background: var(--bg-card-hover);
    border-color: var(--border-hover);
}

.footer-social svg {
    width: 18px;
    height: 18px;
}

.footer-links {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

.footer-column h4 {
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-tertiary);
    margin-bottom: 16px;
}

.footer-column a {
    display: block;
    font-size: 0.9rem;
    color: var(--text-secondary);
    padding: 6px 0;
    transition: color var(--transition-fast);
}

.footer-column a:hover {
    color: var(--text-primary);
}

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 32px;
    border-top: 1px solid var(--border-color);
}

.footer-bottom p {
    font-size: 0.9rem;
    color: var(--text-tertiary);
}

.footer-legal {
    display: flex;
    gap: 24px;
}

.footer-legal a {
    font-size: 0.9rem;
    color: var(--text-tertiary);
    transition: color var(--transition-fast);
}

.footer-legal a:hover {
    color: var(--text-primary);
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */
@media (max-width: 1024px) {
    .hero-content {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .hero-text {
        max-width: 100%;
    }

    .hero-visual {
        display: none;
    }

    .hero-cta {
        justify-content: center;
    }

    .hero-stats {
        justify-content: center;
    }

    .live-stats-bar {
        grid-template-columns: repeat(2, 1fr);
    }

    .apps-grid {
        grid-template-columns: 1fr;
    }

    .token-content {
        grid-template-columns: 1fr;
    }

    .calc-results {
        grid-template-columns: 1fr;
    }

    .calc-result.highlight {
        grid-column: span 1;
    }

    .pricing-cards {
        grid-template-columns: 1fr;
        max-width: 400px;
    }

    .pricing-card.featured {
        transform: none;
        order: -1;
    }

    .pricing-card.featured:hover {
        transform: translateY(-4px);
    }
}

@media (max-width: 768px) {
    :root {
        --section-padding: 80px;
    }

    .nav-links {
        display: none;
    }

    .mobile-menu-btn {
        display: flex;
    }

    .hero {
        padding: 100px 24px 60px;
    }

    .hero-cta {
        flex-direction: column;
    }

    .hero-stats {
        flex-wrap: wrap;
        gap: 24px;
    }

    .stat-divider {
        display: none;
    }

    .section-header {
        margin-bottom: 48px;
    }

    .app-item {
        flex-wrap: wrap;
    }

    .app-status {
        width: 100%;
        text-align: center;
        margin-top: 8px;
    }

    .form-group {
        flex-direction: column;
    }

    .footer-main {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .footer-links {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-bottom {
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }
}

@media (max-width: 480px) {
    .footer-links {
        grid-template-columns: 1fr;
    }

    .flywheel {
        transform: scale(0.85);
    }
}

/* ============================================
   APP MODAL
   ============================================ */
.app-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 24px;
}

.app-modal.active {
    display: flex;
}

.modal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(8px);
}

.modal-content {
    position: relative;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 24px;
    padding: 32px;
    max-width: 500px;
    width: 100%;
    animation: modalSlideIn 0.3s ease;
}

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.95);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 1.2rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.modal-close:hover {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.5);
    color: #ef4444;
}

.modal-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
}

.modal-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 16px;
    font-size: 2rem;
}

.modal-title-area h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.modal-category {
    font-size: 0.8rem;
    color: var(--accent-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.modal-desc {
    color: var(--text-secondary);
    margin-bottom: 20px;
    line-height: 1.6;
}

.modal-features h4 {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 12px;
}

.modal-features ul {
    list-style: none;
    padding: 0;
    margin: 0 0 24px 0;
}

.modal-features li {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.modal-features li::before {
    content: '✓';
    color: var(--success);
    font-weight: 700;
}

.modal-actions {
    display: flex;
    gap: 12px;
}

.modal-actions .btn {
    flex: 1;
    text-align: center;
}

/* Modal Pricing Options */
.modal-pricing {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 16px;
}

.pricing-option {
    padding: 16px;
    border-radius: 12px;
    text-align: center;
    position: relative;
}

.suite-option {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.15) 0%, rgba(168, 85, 247, 0.15) 100%);
    border: 2px solid rgba(99, 102, 241, 0.4);
}

.single-option {
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
}

.option-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    padding: 4px 10px;
    background: var(--success);
    border-radius: 12px;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: #0a0a0f;
}

.option-price {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.option-price span {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-tertiary);
}

.option-name {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 2px;
}

.option-desc {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    margin-bottom: 12px;
}

.pricing-option .btn {
    width: 100%;
}

.modal-trial {
    text-align: center;
    padding: 10px;
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 8px;
    font-size: 0.8rem;
    color: var(--success);
    margin-bottom: 16px;
}

.store-buttons {
    display: flex;
    gap: 8px;
}

.store-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.75rem;
    font-weight: 600;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.store-btn:hover {
    border-color: var(--accent-primary);
    background: rgba(99, 102, 241, 0.1);
}

.store-icon {
    font-size: 1rem;
}

.modal-learn-more {
    display: block;
    text-align: center;
    color: var(--text-tertiary);
    font-size: 0.85rem;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.modal-learn-more:hover {
    color: var(--accent-primary);
}

/* Make app items clickable */
.app-item {
    cursor: pointer;
    transition: all var(--transition-normal);
}

.app-item:hover {
    transform: translateX(4px);
    border-color: var(--accent-primary);
}

/* ============================================
   APP LANDING PAGES
   ============================================ */
.app-hero {
    padding: 140px 24px 60px;
    text-align: center;
    background: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
}

.app-hero-content {
    max-width: 600px;
    margin: 0 auto;
}

.app-hero-badge {
    display: inline-block;
    padding: 6px 16px;
    background: var(--accent-gradient);
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    margin-bottom: 16px;
}

.app-hero-icon {
    font-size: 4rem;
    margin-bottom: 16px;
}

.app-hero h1 {
    font-size: 2.5rem;
    font-weight: 800;
    margin-bottom: 16px;
}

.app-hero-desc {
    font-size: 1.1rem;
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 32px;
}

.app-hero-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.app-hero-price {
    font-size: 0.9rem;
    color: var(--text-tertiary);
}

/* App Features */
.app-features {
    padding: 80px 24px;
}

.app-features h2 {
    text-align: center;
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 48px;
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 24px;
    max-width: 900px;
    margin: 0 auto;
}

.feature-item {
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    text-align: center;
    transition: all var(--transition-normal);
}

.feature-item:hover {
    border-color: var(--accent-primary);
    transform: translateY(-4px);
}

.feature-icon {
    font-size: 2rem;
    margin-bottom: 12px;
}

.feature-item h3 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 8px;
}

.feature-item p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

/* How It Works */
.app-how-it-works {
    padding: 80px 24px;
    background: var(--bg-secondary);
}

.app-how-it-works h2 {
    text-align: center;
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 48px;
}

.hiw-steps {
    display: flex;
    justify-content: center;
    gap: 32px;
    flex-wrap: wrap;
    max-width: 900px;
    margin: 0 auto;
}

.hiw-step {
    flex: 1;
    min-width: 200px;
    max-width: 280px;
    text-align: center;
}

.hiw-number {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 50%;
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 auto 16px;
}

.hiw-step h3 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 8px;
}

.hiw-step p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

/* App CTA */
.app-cta {
    padding: 80px 24px;
}

.cta-box {
    max-width: 600px;
    margin: 0 auto;
    padding: 48px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 24px;
    text-align: center;
}

.cta-box h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.cta-box p {
    color: var(--text-secondary);
    margin-bottom: 24px;
}

.btn-lg {
    padding: 16px 32px;
    font-size: 1.1rem;
}

/* ============================================
   SUITE TOKEN PAGE
   ============================================ */
.suite-hero {
    padding: 140px 24px 80px;
    text-align: center;
    background: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
}

.suite-hero-content {
    max-width: 700px;
    margin: 0 auto;
}

.suite-logo {
    font-size: 4rem;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 16px;
}

.suite-hero h1 {
    font-size: 3rem;
    font-weight: 800;
    margin-bottom: 12px;
}

.suite-tagline {
    font-size: 1.3rem;
    color: var(--accent-primary);
    margin-bottom: 16px;
}

.suite-desc {
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 32px;
}

.suite-stats-row {
    display: flex;
    justify-content: center;
    gap: 48px;
}

.suite-stat {
    text-align: center;
}

.suite-stat .stat-value {
    display: block;
    font-size: 2rem;
    font-weight: 800;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.suite-stat .stat-label {
    font-size: 0.85rem;
    color: var(--text-tertiary);
}

.suite-tokenomics,
.suite-how-it-works,
.suite-staking,
.suite-revenue {
    padding: 80px 24px;
}

.suite-tokenomics {
    background: var(--bg-secondary);
}

.suite-tokenomics h2,
.suite-how-it-works h2,
.suite-staking h2,
.suite-revenue h2 {
    text-align: center;
    font-size: 2rem;
    margin-bottom: 40px;
}

.allocation-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    max-width: 900px;
    margin: 0 auto;
}

.allocation-item {
    text-align: center;
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.alloc-percent {
    font-size: 2.5rem;
    font-weight: 800;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.alloc-name {
    font-weight: 600;
    margin: 8px 0 4px;
}

.alloc-detail {
    font-size: 0.85rem;
    color: var(--text-tertiary);
}

.hiw-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    max-width: 1000px;
    margin: 0 auto;
}

.hiw-step {
    text-align: center;
    padding: 24px;
}

.hiw-number {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-gradient);
    border-radius: 50%;
    font-weight: 800;
    margin: 0 auto 16px;
}

.hiw-step h3 {
    font-size: 1.1rem;
    margin-bottom: 8px;
}

.hiw-step p {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.suite-staking {
    background: var(--bg-secondary);
}

.staking-calculator-large {
    max-width: 800px;
    margin: 0 auto 40px;
    padding: 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
}

.calc-inputs {
    display: flex;
    gap: 24px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.calc-input-group {
    flex: 1;
    min-width: 150px;
}

.calc-input-group label {
    display: block;
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.input-with-suffix {
    display: flex;
    align-items: center;
    gap: 8px;
}

.input-with-suffix input {
    width: 100px;
    padding: 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
}

.calc-input-group select {
    width: 100%;
    padding: 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
}

.calc-outputs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.calc-output {
    text-align: center;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 12px;
}

.calc-output.highlight {
    background: rgba(99, 102, 241, 0.1);
}

.output-label {
    display: block;
    font-size: 0.8rem;
    color: var(--text-tertiary);
    margin-bottom: 4px;
}

.output-value {
    font-size: 1.5rem;
    font-weight: 800;
}

.staking-benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 900px;
    margin: 0 auto;
}

.benefit-card {
    text-align: center;
    padding: 32px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.benefit-icon {
    font-size: 2.5rem;
    margin-bottom: 16px;
    display: block;
}

.benefit-card h4 {
    font-size: 1.1rem;
    margin-bottom: 8px;
}

.benefit-card p {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.revenue-breakdown {
    display: flex;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
    max-width: 800px;
    margin: 0 auto;
}

.revenue-item {
    text-align: center;
    padding: 24px 32px;
    border-radius: 16px;
    min-width: 150px;
}

.revenue-item.stuart {
    background: rgba(99, 102, 241, 0.1);
}

.revenue-item.buyback {
    background: rgba(168, 85, 247, 0.1);
}

.revenue-item.staker {
    background: rgba(34, 197, 94, 0.1);
}

.revenue-item.ops {
    background: rgba(250, 204, 21, 0.1);
}

.rev-percent {
    display: block;
    font-size: 2rem;
    font-weight: 800;
}

.revenue-item.stuart .rev-percent {
    color: var(--accent-primary);
}

.revenue-item.buyback .rev-percent {
    color: var(--accent-secondary);
}

.revenue-item.staker .rev-percent {
    color: var(--success);
}

.revenue-item.ops .rev-percent {
    color: #facc15;
}

.rev-label {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.discuss-section {
    padding: 80px 24px;
    background: var(--bg-secondary);
}

.discuss-section h2 {
    text-align: center;
    font-size: 2rem;
    margin-bottom: 8px;
}

.suite-cta {
    padding: 80px 24px;
}

@media (max-width: 768px) {

    .allocation-grid,
    .hiw-steps,
    .staking-benefits-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .calc-outputs {
        grid-template-columns: 1fr;
    }

    .suite-stats-row {
        gap: 24px;
    }

    .revenue-breakdown {
        flex-direction: column;
        align-items: center;
    }
}

/* ============================================
   TOKEN TEASER SECTION (Main Page)
   ============================================ */
.token-teaser-section {
    padding: 80px 24px;
    background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-primary) 100%);
}

.token-teaser {
    display: flex;
    align-items: flex-start;
    gap: 32px;
    max-width: 800px;
    margin: 0 auto;
    padding: 48px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
}

.teaser-icon {
    font-size: 4rem;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    flex-shrink: 0;
}

.teaser-content {
    flex: 1;
}

.teaser-content h2 {
    font-size: 2rem;
    font-weight: 800;
    margin: 12px 0 16px;
}

.teaser-content p {
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 24px;
}

.teaser-stats {
    display: flex;
    gap: 32px;
    margin-bottom: 24px;
}

.teaser-stat {
    text-align: center;
    padding: 16px 24px;
    background: var(--bg-secondary);
    border-radius: 12px;
    min-width: 100px;
}

.tstat-value {
    display: block;
    font-size: 1.5rem;
    font-weight: 800;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 4px;
}

.tstat-label {
    font-size: 0.8rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

@media (max-width: 768px) {
    .token-teaser {
        flex-direction: column;
        padding: 32px 24px;
        text-align: center;
    }

    .teaser-icon {
        margin: 0 auto;
    }

    .teaser-stats {
        flex-wrap: wrap;
        justify-content: center;
        gap: 16px;
    }

    .teaser-stat {
        min-width: 80px;
        padding: 12px 16px;
    }
}

/* ============================================
   CONTAINER AND PAYOUT TOGGLE (Suite Page)
   ============================================ */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.payout-toggle {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.payout-toggle label {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.toggle-buttons {
    display: flex;
    gap: 8px;
}

.toggle-btn {
    padding: 10px 16px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.85rem;
}

.toggle-btn:hover {
    border-color: var(--accent-primary);
}

.toggle-btn.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

/* Suite page h2 centering */
.suite-staking h2,
.suite-revenue h2,
.discuss-section h2 {
    text-align: center;
}

.suite-staking .section-subtitle,
.discuss-section .section-subtitle {
    text-align: center;
    color: var(--text-secondary);
    margin-bottom: 40px;
}

/* Staker info badge for discuss section */
.staker-info {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 24px;
    background: rgba(99, 102, 241, 0.1);
    border: 1px solid var(--accent-primary);
    border-radius: 12px;
    margin-bottom: 24px;
}

.staker-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--accent-gradient);
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
}

.staker-note {
    color: var(--text-secondary);
    font-size: 0.9rem;
}

/* App tabs for discussion */
.app-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.app-tab {
    padding: 10px 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.app-tab:hover {
    border-color: var(--accent-primary);
}

.app-tab.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

/* Submit idea box */
.submit-idea-box {
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    margin-bottom: 32px;
}

.submit-idea-box h3 {
    margin-bottom: 16px;
}

.idea-form {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 16px;
}

.idea-form select,
.idea-form input,
.idea-form textarea {
    padding: 12px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.9rem;
}

.idea-form textarea {
    grid-column: 1 / -1;
}

.idea-form button {
    justify-self: start;
}

/* Feature cards */
.feature-cards {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.feature-card {
    display: flex;
    gap: 20px;
    padding: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
}

.card-votes {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.upvote-btn {
    width: 40px;
    height: 40px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.upvote-btn:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}

.upvote-btn.voted {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

.vote-count {
    font-weight: 700;
    color: var(--text-primary);
}

.card-content {
    flex: 1;
}

.card-app {
    font-size: 0.75rem;
    color: var(--accent-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.card-title {
    font-size: 1rem;
    margin-bottom: 8px;
}

.card-desc {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 12px;
}

.card-meta {
    display: flex;
    gap: 16px;
    font-size: 0.8rem;
}

.card-author {
    color: var(--text-tertiary);
}

.card-status {
    font-weight: 500;
}

/* CTA Box */
.cta-box {
    text-align: center;
    padding: 48px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 24px;
}

.cta-box h2 {
    margin-bottom: 12px;
}

.cta-box p {
    color: var(--text-secondary);
    margin-bottom: 24px;
}

/* ============================================
   MEMBERSHIP TIER CALCULATOR (Suite Page)
   ============================================ */
.membership-tier-row {
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border-color);
}

.membership-tier-row label {
    display: block;
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 12px;
}

.tier-buttons {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.tier-btn {
    padding: 12px 20px;
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: 10px;
    color: var(--text-secondary);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.tier-btn:hover {
    border-color: var(--accent-primary);
    color: var(--text-primary);
}

.tier-btn.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
    transform: scale(1.05);
}

/* Token Rewards Box */
.token-rewards-box,
.staking-revenue-box {
    padding: 24px;
    background: var(--bg-secondary);
    border-radius: 16px;
    margin-bottom: 16px;
}

.token-rewards-box {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border: 1px solid rgba(99, 102, 241, 0.3);
}

.reward-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.reward-icon {
    font-size: 1.5rem;
}

.reward-title {
    font-weight: 700;
    font-size: 1.1rem;
}

.reward-tier {
    margin-left: auto;
    padding: 6px 12px;
    background: var(--accent-gradient);
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}

.reward-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.reward-stat {
    text-align: center;
    padding: 16px;
    background: var(--bg-card);
    border-radius: 12px;
}

.reward-stat.highlight {
    background: rgba(99, 102, 241, 0.15);
}

.rstat-value {
    display: block;
    font-size: 1.5rem;
    font-weight: 800;
    margin-bottom: 4px;
}

.rstat-label {
    font-size: 0.8rem;
    color: var(--text-tertiary);
}

/* Total Earnings Box */
.total-earnings-box {
    text-align: center;
    padding: 24px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(99, 102, 241, 0.1) 100%);
    border: 2px solid var(--success);
    border-radius: 16px;
}

.total-label {
    font-size: 1rem;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.total-value {
    font-size: 2.5rem;
    font-weight: 800;
    background: linear-gradient(135deg, var(--success) 0%, var(--accent-primary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.total-desc {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin-top: 4px;
}

@media (max-width: 768px) {
    .tier-buttons {
        justify-content: center;
    }

    .tier-btn {
        padding: 10px 14px;
        font-size: 0.85rem;
    }

    .reward-stats {
        grid-template-columns: 1fr;
    }

    .reward-header {
        flex-wrap: wrap;
    }

    .reward-tier {
        margin-left: 0;
        margin-top: 8px;
    }
}

/* ============================================
   MARKET ASSUMPTIONS SECTION
   ============================================ */
.assumptions-section {
    margin-bottom: 24px;
    padding: 20px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed var(--border-color);
    border-radius: 12px;
}

.assumptions-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.assumptions-icon {
    font-size: 1.2rem;
}

.assumptions-title {
    font-weight: 700;
    font-size: 1rem;
}

.assumptions-note {
    font-size: 0.8rem;
    color: var(--text-tertiary);
    font-style: italic;
}

.assumptions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.assumption-item label {
    display: block;
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.assumption-item select {
    width: 100%;
    padding: 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.9rem;
}

.price-slider-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.price-slider {
    flex: 1;
    height: 6px;
    background: var(--bg-tertiary);
    border-radius: 3px;
    -webkit-appearance: none;
    appearance: none;
}

.price-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    background: var(--accent-gradient);
    border-radius: 50%;
    cursor: pointer;
}

.price-display {
    font-weight: 700;
    font-size: 1.1rem;
    min-width: 70px;
    text-align: right;
    color: var(--accent-primary);
}

.mcap-display {
    margin-top: 8px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.mcap-display span {
    font-weight: 600;
    color: var(--text-primary);
}

@media (max-width: 768px) {
    .assumptions-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   COMPACT STAKING CALCULATOR
   ============================================ */
.staking-calculator-compact {
    max-width: 900px;
    margin: 0 auto;
    padding: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.calc-row {
    margin-bottom: 12px;
}

/* Row 1: Inputs */
.inputs-row {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.input-col {
    flex: 1;
    min-width: 140px;
}

.input-col label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.tier-buttons-compact {
    display: flex;
    gap: 4px;
}

.tier-btn-sm {
    padding: 6px 10px;
    font-size: 0.75rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.15s ease;
}

.tier-btn-sm:hover {
    border-color: var(--accent-primary);
}

.tier-btn-sm.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

.stake-input-inline {
    display: flex;
    align-items: center;
    gap: 6px;
}

.stake-input-inline input {
    width: 80px;
    padding: 6px 8px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.85rem;
}

.stake-input-inline span {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.stake-value-display {
    margin-top: 4px;
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.stake-value-display span {
    color: var(--success);
    font-weight: 600;
}

.input-col select {
    width: 100%;
    padding: 6px 8px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.85rem;
}

/* Row 2: Assumptions */
.assumptions-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 10px 14px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px dashed var(--border-color);
    border-radius: 8px;
    flex-wrap: wrap;
}

.assumption-inline {
    display: flex;
    align-items: center;
    gap: 8px;
}

.assume-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.mini-slider {
    width: 80px;
    height: 4px;
    -webkit-appearance: none;
    appearance: none;
    background: var(--bg-tertiary);
    border-radius: 2px;
}

.mini-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 12px;
    height: 12px;
    background: var(--accent-primary);
    border-radius: 50%;
    cursor: pointer;
}

.assume-value {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--accent-primary);
    min-width: 50px;
}

.assume-mcap {
    font-size: 0.7rem;
    color: var(--text-tertiary);
}

.mini-select {
    padding: 4px 8px;
    font-size: 0.75rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    color: var(--text-primary);
}

.toggle-inline {
    display: flex;
    gap: 4px;
    margin-left: auto;
}

.toggle-btn-sm {
    padding: 4px 10px;
    font-size: 0.7rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    color: var(--text-secondary);
    cursor: pointer;
}

.toggle-btn-sm.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

/* Row 3: Results */
.results-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.result-box {
    padding: 14px;
    background: var(--bg-secondary);
    border-radius: 10px;
}

.token-box {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.08) 0%, rgba(168, 85, 247, 0.08) 100%);
    border: 1px solid rgba(99, 102, 241, 0.2);
}

.result-header {
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.result-tier {
    margin-left: auto;
    font-size: 0.7rem;
    padding: 3px 8px;
    background: var(--accent-gradient);
    border-radius: 10px;
}

.result-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}

.result-item {
    text-align: center;
    padding: 8px;
    background: var(--bg-card);
    border-radius: 6px;
}

.result-item.highlight {
    background: rgba(99, 102, 241, 0.1);
}

.result-value {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 2px;
}

.result-label {
    font-size: 0.65rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
}

/* Row 4: Total */
.total-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 14px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(99, 102, 241, 0.1) 100%);
    border: 1px solid var(--success);
    border-radius: 10px;
    margin-top: 4px;
}

.total-row .total-icon {
    font-size: 1.2rem;
}

.total-row .total-label {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.total-row .total-value {
    font-size: 1.4rem;
    font-weight: 800;
    background: linear-gradient(135deg, var(--success) 0%, var(--accent-primary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

@media (max-width: 768px) {
    .inputs-row {
        flex-direction: column;
    }

    .tier-buttons-compact {
        flex-wrap: wrap;
    }

    .assumptions-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .toggle-inline {
        margin-left: 0;
    }

    .results-row {
        grid-template-columns: 1fr;
    }

    .result-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ============================================
   FLEXIBLE PRICING SLIDER
   ============================================ */
.flex-pricing-box {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px;
    background: var(--bg-card);
    border: 2px solid var(--border-color);
    border-radius: 24px;
}

.flex-price-display {
    text-align: center;
    margin-bottom: 24px;
}

.flex-currency {
    font-size: 2rem;
    color: var(--text-secondary);
    vertical-align: super;
}

.flex-amount {
    font-size: 5rem;
    font-weight: 800;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.flex-period {
    font-size: 1.2rem;
    color: var(--text-tertiary);
}

.flex-slider-container {
    position: relative;
    margin-bottom: 48px;
    padding: 0 10px;
}

.flex-slider {
    width: 100%;
    height: 8px;
    -webkit-appearance: none;
    appearance: none;
    background: linear-gradient(90deg, var(--bg-tertiary) 0%, var(--accent-primary) 4%, var(--accent-secondary) 100%);
    border-radius: 4px;
    outline: none;
}

.flex-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 28px;
    height: 28px;
    background: var(--accent-gradient);
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4);
}

.slider-milestones {
    position: absolute;
    top: 20px;
    left: 10px;
    right: 10px;
    pointer-events: none;
}

.milestone {
    position: absolute;
    transform: translateX(-50%);
}

.m-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.milestone-main .m-label {
    font-weight: 700;
    color: var(--accent-primary);
}

.unlock-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 24px;
    transition: all 0.3s ease;
}

.unlock-banner.unlocked {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(99, 102, 241, 0.15) 100%);
    border: 1px solid var(--success);
}

.unlock-icon {
    font-size: 1.5rem;
}

.unlock-text {
    font-size: 1rem;
    font-weight: 600;
}

.flex-benefits {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
}

.benefit-col {
    padding: 20px;
    background: var(--bg-secondary);
    border-radius: 12px;
}

.benefit-col h4 {
    font-size: 0.9rem;
    margin-bottom: 12px;
    color: var(--text-secondary);
}

.app-unlock-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}

.app-chip {
    padding: 6px 10px;
    font-size: 0.75rem;
    background: var(--bg-tertiary);
    border-radius: 16px;
    color: var(--text-tertiary);
    opacity: 0.5;
    transition: all 0.2s ease;
}

.app-chip.unlocked {
    opacity: 1;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(99, 102, 241, 0.2) 100%);
    color: var(--text-primary);
    border: 1px solid var(--success);
}

.apps-counter {
    font-size: 0.85rem;
    color: var(--text-tertiary);
}

.tokens-col {
    text-align: center;
}

.token-big {
    font-size: 2.5rem;
    font-weight: 800;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.token-label {
    font-size: 0.8rem;
    color: var(--text-tertiary);
    margin-bottom: 8px;
}

.token-value {
    font-size: 0.9rem;
    color: var(--success);
    font-weight: 600;
}

.perks-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.perk {
    padding: 6px 0;
    font-size: 0.85rem;
    color: var(--text-tertiary);
    opacity: 0.5;
    transition: all 0.2s ease;
}

.perk::before {
    content: "○";
    margin-right: 8px;
}

.perk.unlocked {
    opacity: 1;
    color: var(--text-primary);
}

.perk.unlocked::before {
    content: "✓";
    color: var(--success);
}

.flex-cta {
    text-align: center;
}

.flex-cta-note {
    margin-top: 12px;
    font-size: 0.85rem;
    color: var(--text-tertiary);
}

@media (max-width: 768px) {
    .flex-pricing-box {
        padding: 24px;
    }

    .flex-amount {
        font-size: 3.5rem;
    }

    .flex-benefits {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   $SUITE INFO TOOLTIP
   ============================================ */
.suite-info-trigger {
    position: relative;
    cursor: help;
    font-size: 0.8rem;
    opacity: 0.7;
    transition: opacity 0.2s;
}

.suite-info-trigger:hover {
    opacity: 1;
}

.suite-tooltip {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: 280px;
    padding: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 100;
    text-align: left;
    margin-bottom: 8px;
}

.suite-info-trigger:hover .suite-tooltip {
    opacity: 1;
    visibility: visible;
}

.tooltip-header {
    font-weight: 700;
    font-size: 1rem;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.suite-tooltip p {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin: 0 0 12px 0;
    line-height: 1.4;
}

.tooltip-section {
    margin-bottom: 12px;
}

.tooltip-section strong {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.tooltip-section p {
    margin: 0;
    font-size: 0.8rem;
}

.tooltip-link {
    display: inline-block;
    padding: 8px 16px;
    background: var(--accent-gradient);
    color: white;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    transition: transform 0.2s;
}

.tooltip-link:hover {
    transform: translateY(-1px);
}

/* Arrow */
.suite-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 8px solid transparent;
    border-top-color: var(--bg-card);
}

/* ============================================
   SVG ICON SYSTEM
   ============================================ */
.icon {
    width: 18px;
    height: 18px;
    vertical-align: middle;
    margin-right: 6px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.icon-sm {
    width: 14px;
    height: 14px;
    vertical-align: middle;
    margin-right: 4px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.info-icon {
    width: 14px;
    height: 14px;
    vertical-align: middle;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    opacity: 0.6;
}

.info-icon:hover {
    opacity: 1;
}

.lock-svg,
.unlock-svg {
    width: 16px;
    height: 16px;
    vertical-align: middle;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.unlock-svg {
    stroke: var(--success);
}

.unlock-icon .lock-svg {
    width: 20px;
    height: 20px;
}

.unlock-banner.unlocked .lock-svg {
    stroke: var(--success);
}

/* ============================================
   APPS PAGE
   ============================================ */
.apps-page {
    padding-top: 80px;
}

.apps-hero {
    text-align: center;
    padding: 60px 0 40px;
}

.apps-hero h1 {
    font-size: 3rem;
    margin-bottom: 16px;
}

.apps-subtitle {
    font-size: 1.2rem;
    color: var(--text-secondary);
}

.apps-grid-section {
    padding: 40px 0 80px;
}

.app-filters {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}

.filter-btn {
    padding: 10px 20px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    color: var(--text-secondary);
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.2s;
}

.filter-btn:hover {
    border-color: var(--accent-primary);
    color: var(--text-primary);
}

.filter-btn.active {
    background: var(--accent-gradient);
    border-color: transparent;
    color: white;
}

.apps-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
}

.app-list-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 24px;
    transition: all 0.3s ease;
}

.app-list-card:hover {
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.app-list-card-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 12px;
}

.app-list-card-icon {
    width: 48px;
    height: 48px;
    background: var(--bg-tertiary);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.app-list-card-icon svg {
    width: 24px;
    height: 24px;
    stroke: var(--accent-primary);
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.app-list-card-title {
    flex: 1;
}

.app-list-card-title h3 {
    font-size: 1.2rem;
    margin-bottom: 4px;
}

.app-status {
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 10px;
    background: var(--bg-tertiary);
    color: var(--text-tertiary);
}

.app-status.coming-soon {
    background: rgba(251, 191, 36, 0.15);
    color: #fbbf24;
}

.app-status.live {
    background: rgba(34, 197, 94, 0.15);
    color: var(--success);
}

.expand-btn {
    width: 32px;
    height: 32px;
    background: var(--bg-tertiary);
    border: none;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.expand-btn svg {
    width: 16px;
    height: 16px;
    stroke: var(--text-secondary);
    stroke-width: 2;
    fill: none;
    transition: transform 0.2s;
}

.app-list-card.expanded .expand-btn svg {
    transform: rotate(180deg);
}

.app-tagline {
    color: var(--text-secondary);
    font-size: 0.95rem;
    margin-bottom: 0;
}

.app-list-card-details {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.app-list-card.expanded .app-list-card-details {
    max-height: 300px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.app-features h4 {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.app-features ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.app-features li {
    padding: 6px 0;
    font-size: 0.9rem;
    color: var(--text-secondary);
    padding-left: 20px;
    position: relative;
}

.app-features li::before {
    content: "→";
    position: absolute;
    left: 0;
    color: var(--accent-primary);
}

.apps-cta {
    text-align: center;
    margin-top: 60px;
    padding: 48px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
}

.apps-cta h2 {
    font-size: 1.8rem;
    margin-bottom: 12px;
}

.apps-cta p {
    color: var(--text-secondary);
    margin-bottom: 24px;
}

@media (max-width: 768px) {
    .apps-hero h1 {
        font-size: 2rem;
    }

    .apps-card-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   PAY PER USE PRICING
   ============================================ */
.pay-per-use-container {
    max-width: 800px;
    margin: 0 auto;
}

.how-it-works {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-bottom: 50px;
    flex-wrap: wrap;
}

.step {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    max-width: 200px;
}

.step-num {
    width: 40px;
    height: 40px;
    background: var(--accent-gradient);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.step-content h4 {
    font-size: 1rem;
    margin-bottom: 4px;
}

.step-content p {
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.4;
}

.credit-packages {
    text-align: center;
    margin-bottom: 50px;
}

.credit-packages h3 {
    font-size: 1.3rem;
    margin-bottom: 24px;
}

.packages-grid {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.package {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 28px 36px;
    text-align: center;
    min-width: 140px;
    transition: all 0.25s ease;
    position: relative;
}

.package:hover {
    border-color: var(--accent-primary);
    transform: translateY(-4px);
}

.package.popular {
    border-color: var(--accent-primary);
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.1), rgba(236, 72, 153, 0.05));
}

.package-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--accent-gradient);
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
}

.package-amount {
    font-size: 2rem;
    font-weight: 700;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.package-label {
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin-bottom: 12px;
}

.package-price {
    font-size: 1.3rem;
    font-weight: 600;
}

.example-costs {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 28px;
    margin-bottom: 32px;
}

.example-costs h3 {
    font-size: 1.1rem;
    margin-bottom: 20px;
    text-align: center;
}

.costs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
}

.cost-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: var(--bg-tertiary);
    border-radius: 10px;
}

.cost-action {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.cost-amount {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--accent-primary);
}

.token-info-box {
    display: flex;
    align-items: center;
    gap: 20px;
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.1), rgba(236, 72, 153, 0.05));
    border: 1px solid rgba(168, 85, 247, 0.3);
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 32px;
}

.token-info-icon {
    width: 56px;
    height: 56px;
    background: var(--bg-tertiary);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.token-info-icon svg {
    width: 28px;
    height: 28px;
    stroke: var(--accent-primary);
    stroke-width: 2;
    fill: none;
}

.token-info-content h4 {
    font-size: 1.1rem;
    margin-bottom: 6px;
}

.token-info-content p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.token-link {
    font-size: 0.9rem;
    color: var(--accent-primary);
    font-weight: 500;
}

.token-link:hover {
    text-decoration: underline;
}

@media (max-width: 768px) {
    .how-it-works {
        flex-direction: column;
        align-items: center;
    }

    .step {
        max-width: 280px;
    }

    .packages-grid {
        flex-direction: column;
        align-items: center;
    }

    .package {
        width: 100%;
        max-width: 200px;
    }

    .token-info-box {
        flex-direction: column;
        text-align: center;
    }
}

/* ============================================
   TREASURY SECTION
   ============================================ */
.treasury-section {
    padding: 100px 0;
    background: var(--bg-secondary);
}

.treasury-content {
    max-width: 900px;
    margin: 0 auto;
}

.treasury-phases {
    margin-bottom: 60px;
}

.treasury-phases h3,
.treasury-actions h3 {
    text-align: center;
    font-size: 1.2rem;
    margin-bottom: 30px;
    color: var(--text-secondary);
}

.phases-track {
    display: flex;
    align-items: stretch;
    justify-content: center;
    gap: 0;
}

.phase {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 28px;
    max-width: 300px;
    transition: all 0.3s;
}

.phase.active {
    border-color: var(--accent-primary);
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.08), rgba(236, 72, 153, 0.04));
}

.phase-connector {
    width: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.phase-connector::before {
    content: "→";
    font-size: 1.5rem;
    color: var(--text-tertiary);
}

.phase-marker {
    width: 36px;
    height: 36px;
    background: var(--bg-tertiary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    margin-bottom: 16px;
}

.phase.active .phase-marker {
    background: var(--accent-gradient);
}

.phase-info h4 {
    font-size: 1.1rem;
    margin-bottom: 6px;
}

.phase-range {
    font-size: 0.9rem;
    color: var(--accent-primary);
    font-weight: 600;
    margin-bottom: 12px;
}

.phase-split {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.split-item {
    font-size: 0.75rem;
    padding: 4px 10px;
    border-radius: 12px;
    font-weight: 500;
}

.split-item.reinvest {
    background: rgba(34, 197, 94, 0.15);
    color: var(--success);
}

.split-item.giving {
    background: rgba(168, 85, 247, 0.15);
    color: var(--accent-primary);
}

.phase-desc {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.treasury-actions {
    margin-bottom: 50px;
}

.actions-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.action-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 28px;
    text-align: center;
    transition: all 0.25s;
}

.action-card:hover {
    border-color: var(--accent-primary);
    transform: translateY(-4px);
}

.action-icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.15), rgba(236, 72, 153, 0.1));
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
}

.action-icon svg {
    width: 26px;
    height: 26px;
    stroke: var(--accent-primary);
    stroke-width: 2;
    fill: none;
}

.action-card h4 {
    font-size: 1rem;
    margin-bottom: 8px;
}

.action-card p {
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.treasury-stats {
    display: flex;
    justify-content: center;
    gap: 24px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}

.stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 24px 40px;
    text-align: center;
    min-width: 150px;
}

.stat-label {
    font-size: 0.8rem;
    color: var(--text-tertiary);
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.stat-value {
    font-size: 1.8rem;
    font-weight: 700;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 4px;
}

.stat-note {
    font-size: 0.8rem;
    color: var(--text-tertiary);
}

.treasury-cta {
    text-align: center;
    padding: 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.treasury-cta p {
    font-size: 1.1rem;
    margin-bottom: 20px;
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    .phases-track {
        flex-direction: column;
        align-items: center;
    }

    .phase-connector {
        width: auto;
        height: 40px;
    }

    .phase-connector::before {
        content: "↓";
    }

    .actions-grid {
        grid-template-columns: 1fr;
    }

    .stat-card {
        padding: 20px 30px;
    }
}

/* ============================================
   ECOSYSTEM FLOW DIAGRAM - HORIZONTAL LAYOUT
   ============================================ */
.ecosystem-overview {
    padding: 80px 0;
    background: var(--bg-secondary);
}

.ecosystem-overview .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.ecosystem-overview h2 {
    text-align: center;
    font-size: 2rem;
    margin-bottom: 12px;
}

.ecosystem-overview .section-subtitle {
    text-align: center;
    margin-bottom: 48px;
    color: var(--text-secondary);
}

.value-flow {
    max-width: 1000px;
    margin: 0 auto 40px;
    padding: 40px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.05) 0%, rgba(168, 85, 247, 0.05) 100%);
    border: 1px solid var(--border-color);
    border-radius: 24px;
}

/* Main horizontal flow - force flex row */
.flow-main,
.flow-outputs {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px;
    flex-wrap: nowrap;
}

.flow-node {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 16px 20px;
    min-width: 100px;
}

.flow-node.primary {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.15) 0%, rgba(168, 85, 247, 0.15) 100%);
    border: 1px solid var(--accent-primary);
    border-radius: 16px;
    padding: 24px 32px;
}

.flow-node.burn-node .node-circle {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.4);
    color: #ef4444;
}

.node-circle {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-card);
    border: 2px solid var(--border-color);
    border-radius: 50%;
    margin-bottom: 12px;
    color: var(--accent-primary);
    transition: all 0.3s ease;
}

.node-circle.large {
    width: 72px;
    height: 72px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.2) 0%, rgba(168, 85, 247, 0.2) 100%);
    border-color: var(--accent-primary);
}

.flow-node:hover .node-circle {
    transform: scale(1.1);
    box-shadow: 0 0 20px rgba(99, 102, 241, 0.3);
}

.node-label {
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 4px;
}

.node-sub {
    font-size: 0.8rem;
    color: var(--text-tertiary);
}

.node-value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--accent-primary);
}

/* Connectors */
.flow-connector {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    min-width: 60px;
}

.connector-line {
    width: 40px;
    height: 2px;
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));
    position: relative;
}

.connector-line::after {
    content: '→';
    position: absolute;
    right: -8px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--accent-primary);
    font-size: 1rem;
}

.connector-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.flow-connector.burn .connector-line {
    background: linear-gradient(90deg, var(--accent-primary), #ef4444);
}

.flow-connector.burn .connector-label {
    color: #ef4444;
    font-weight: 600;
}

/* Return paths */
.flow-returns {
    display: flex;
    justify-content: space-around;
    padding: 24px 80px;
}

.return-path {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text-secondary);
    font-size: 0.85rem;
}

.return-path svg {
    color: var(--accent-primary);
}

.return-path.left {
    margin-left: 60px;
}

.return-path.right {
    margin-right: 60px;
}

/* Side options */
.flow-options {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 24px;
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--border-color);
    flex-wrap: wrap;
}

.option-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    transition: all 0.3s ease;
}

.option-card:hover {
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.option-card svg {
    color: var(--accent-primary);
    flex-shrink: 0;
}

.option-title {
    display: block;
    font-weight: 600;
    font-size: 0.9rem;
}

.option-sub {
    display: block;
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

/* Key points */
.key-points {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    max-width: 800px;
    margin: 0 auto;
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.key-point {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.95rem;
}

.point-check {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(34, 197, 94, 0.15);
    border-radius: 50%;
    flex-shrink: 0;
}

.point-check svg {
    color: var(--success);
}

@media (max-width: 900px) {

    .flow-main,
    .flow-outputs {
        flex-wrap: wrap;
        gap: 16px;
    }

    .flow-connector {
        display: none;
    }

    .flow-returns {
        padding: 16px;
        flex-direction: column;
        gap: 12px;
    }

    .return-path.left,
    .return-path.right {
        margin: 0;
        justify-content: center;
    }

    .flow-options {
        flex-direction: column;
        align-items: center;
    }

    .key-points {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   INTERACTIVE SIMULATOR
   ============================================ */
.simulator-section {
    margin-top: 48px;
    padding: 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
}

.sim-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

.sim-header h3 {
    font-size: 1.4rem;
    font-weight: 700;
}

.sim-reset-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
}

.sim-reset-btn:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}

.sim-container {
    display: flex;
    align-items: stretch;
    gap: 24px;
    margin-bottom: 24px;
}

.sim-panel {
    flex: 1;
    padding: 24px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.panel-header {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 16px;
}

.balance-display {
    margin-bottom: 20px;
}

.balance-item {
    display: flex;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid var(--border-color);
}

.balance-label {
    color: var(--text-secondary);
}

.balance-value {
    font-weight: 700;
    font-size: 1.1rem;
}

.sim-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sim-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    border-radius: 10px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    border: none;
}

.sim-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.deposit-btn {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color: white;
}

.deposit-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(99, 102, 241, 0.4);
}

.withdraw-btn {
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.withdraw-btn:hover:not(:disabled) {
    border-color: var(--accent-primary);
}

.sim-flow {
    width: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.flow-indicator {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    opacity: 0;
    transition: all 0.3s;
}

.flow-indicator.active {
    opacity: 1;
    animation: flowPulse 0.5s ease;
}

.flow-indicator.deposit {
    background: var(--success);
    box-shadow: 0 0 20px rgba(34, 197, 94, 0.5);
}

.flow-indicator.withdraw {
    background: var(--accent-primary);
    box-shadow: 0 0 20px rgba(99, 102, 241, 0.5);
}

@keyframes flowPulse {
    0% {
        transform: scale(0.5);
        opacity: 0;
    }

    50% {
        transform: scale(1.2);
        opacity: 1;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

.treasury-panel {
    text-align: center;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border-color: var(--accent-primary);
}

.treasury-value {
    font-size: 2rem;
    font-weight: 800;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 8px;
}

.treasury-apy {
    color: var(--success);
    font-weight: 600;
    margin-bottom: 12px;
}

.backing-rate {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.backing-rate span:last-child {
    color: var(--accent-primary);
    font-weight: 600;
}

.sim-apps {
    margin-bottom: 24px;
}

.apps-header {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}

.app-buttons {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.app-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px 24px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.2s;
    min-width: 140px;
}

.app-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.app-btn:hover:not(:disabled) {
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.app-name {
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--text-primary);
}

.app-cost {
    font-size: 0.85rem;
    color: var(--accent-primary);
}

.sim-log {
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 12px;
    max-height: 120px;
    overflow-y: auto;
}

.log-entry {
    padding: 6px 0;
    font-size: 0.85rem;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}

.log-entry:last-child {
    border-bottom: none;
}

.log-entry.success {
    color: var(--success);
}

.log-entry.burn {
    color: #ef4444;
}

@media (max-width: 768px) {
    .sim-container {
        flex-direction: column;
    }

    .sim-flow {
        width: 100%;
        height: 40px;
    }

    .app-buttons {
        flex-direction: column;
    }

    .app-btn {
        width: 100%;
    }
}

/* Interactive Flow Diagram Additions */
.sim-status-bar {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 24px;
    padding: 16px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

.balance-pills {
    display: flex !important;
    flex-direction: row !important;
    gap: 16px;
}

.balance-pill {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 100px;
    font-size: 0.9rem;
}

.balance-pill.suite {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.15) 0%, rgba(168, 85, 247, 0.15) 100%);
    border-color: rgba(99, 102, 241, 0.3);
}

.pill-value {
    font-weight: 700;
    color: var(--accent-primary);
    font-size: 1rem;
}

.reset-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    transition: all 0.2s;
}

.reset-btn:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
    background: rgba(99, 102, 241, 0.1);
}

/* Time simulation controls */
.time-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
}

.time-display {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
}

.time-display svg {
    color: var(--accent-primary);
}

#simDay {
    color: var(--accent-primary);
    min-width: 30px;
    text-align: left;
}

.time-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
}

.time-btn:hover {
    border-color: var(--success);
    color: var(--success);
    background: rgba(34, 197, 94, 0.1);
}

.time-btn.playing {
    border-color: var(--success);
    color: var(--success);
    background: rgba(34, 197, 94, 0.15);
}

.time-btn.month {
    width: auto;
    padding: 0 10px;
    font-size: 0.7rem;
    font-weight: 700;
}

/* Treasury pulse animation for yield generation */
.flow-node.primary.yielding .node-circle {
    animation: yieldPulse 0.5s ease;
}

@keyframes yieldPulse {

    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.4);
        transform: scale(1);
    }

    50% {
        box-shadow: 0 0 20px 8px rgba(34, 197, 94, 0.2);
        transform: scale(1.05);
    }
}

/* Yield indicator */
.yield-indicator {
    position: absolute;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--success);
    opacity: 0;
    pointer-events: none;
}

.yield-indicator.active {
    animation: yieldFloat 1s ease-out forwards;
}

@keyframes yieldFloat {
    0% {
        opacity: 0;
        transform: translateY(0);
    }

    20% {
        opacity: 1;
    }

    100% {
        opacity: 0;
        transform: translateY(-30px);
    }
}

/* Interactive node styling */
.flow-node.interactive-node {
    min-width: 160px;
    padding: 20px;
}

.flow-node.you-node {
    min-width: 180px;
}

/* Deposit input styling */
.deposit-input-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    margin: 8px 0;
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: 10px;
    padding: 4px 8px;
    transition: all 0.2s;
}

.deposit-input-group:focus-within {
    border-color: var(--accent-primary);
    background: var(--bg-secondary);
}

.input-prefix {
    font-size: 1rem;
    font-weight: 700;
    color: var(--success);
}

.deposit-input {
    width: 80px;
    background: transparent;
    border: none;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
    text-align: left;
    outline: none;
}

.deposit-input::-webkit-outer-spin-button,
.deposit-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.deposit-input[type=number] {
    -moz-appearance: textfield;
}

/* Redemption Power Display */
.redemption-power {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    margin-top: 10px;
    padding: 8px 12px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1), rgba(99, 102, 241, 0.1));
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 10px;
}

.power-label {
    font-size: 0.65rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.power-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--success);
}

.node-buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px;
    margin-top: 12px;
    width: 100%;
}

.node-buttons.horizontal {
    flex-direction: row !important;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
}

.node-action-btn {
    padding: 10px 16px;
    border-radius: 8px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: all 0.2s;
    white-space: nowrap;
}

.node-action-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.node-action-btn.deposit {
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
    color: white;
    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.3);
}

.node-action-btn.deposit:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(34, 197, 94, 0.4);
}

.node-action-btn.withdraw {
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.node-action-btn.withdraw:hover:not(:disabled) {
    border-color: var(--accent-primary);
    background: rgba(99, 102, 241, 0.1);
}

.app-action-btn {
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 0.75rem;
    font-weight: 600;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.app-action-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.app-action-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(168, 85, 247, 0.2));
    border-color: var(--accent-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.2);
}

.node-value.small {
    font-size: 0.9rem;
    font-weight: 600;
}

/* Particle animation */
.flow-connector.animated {
    position: relative;
    overflow: visible;
}

.flow-particle {
    position: absolute;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 10px rgba(34, 197, 94, 0.6);
    opacity: 0;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
}

.flow-particle.active {
    animation: particleFlow 0.5s ease-out forwards;
}

.flow-particle.burn {
    background: #ef4444;
    box-shadow: 0 0 10px rgba(239, 68, 68, 0.6);
}

@keyframes particleFlow {
    0% {
        opacity: 1;
        left: 0;
        transform: translateY(-50%) scale(1);
    }

    50% {
        opacity: 1;
        transform: translateY(-50%) scale(1.3);
    }

    100% {
        opacity: 0;
        left: 100%;
        transform: translateY(-50%) scale(0.5);
    }
}

/* Value flow interactive mode */
.value-flow.interactive {
    position: relative;
}

@media (max-width: 768px) {
    .sim-status-bar {
        flex-direction: column;
        gap: 12px;
    }

    .balance-pills {
        flex-wrap: wrap;
        justify-content: center;
    }

    .node-buttons {
        flex-direction: column !important;
    }

    .node-buttons.horizontal {
        flex-direction: column !important;
    }
}

/* Two-column flow layout */
.flow-container {
    display: flex;
    gap: 32px;
    max-width: 1200px;
    margin: 0 auto;
}

.flow-container .value-flow {
    flex: 1;
    min-width: 0;
}

/* Node hint text */
.node-hint {
    font-size: 0.7rem;
    color: var(--text-tertiary);
    margin-top: 8px;
    text-align: center;
    max-width: 120px;
}

/* Success styling for DeFi node */
.node-circle.success {
    background: rgba(34, 197, 94, 0.15);
    border-color: rgba(34, 197, 94, 0.4);
    color: var(--success);
}

.success-text {
    color: var(--success) !important;
    font-weight: 700;
}

/* Yield Allocation Panel */
.yield-allocation-panel {
    width: 320px;
    flex-shrink: 0;
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
}

.panel-header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}

.panel-header-row h4 {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0;
}

.info-tooltip {
    position: relative;
    cursor: help;
    color: var(--text-tertiary);
}

.info-tooltip:hover .tooltip-content {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.tooltip-content {
    position: absolute;
    right: 0;
    top: 100%;
    margin-top: 8px;
    width: 220px;
    padding: 12px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-size: 0.8rem;
    color: var(--text-secondary);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-5px);
    transition: all 0.2s;
    z-index: 10;
    line-height: 1.5;
}

/* Allocation bars */
.allocation-bars {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 20px;
}

.allocation-item {
    padding: 12px;
    background: var(--bg-secondary);
    border-radius: 12px;
}

.alloc-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    font-size: 0.85rem;
}

.alloc-header svg {
    flex-shrink: 0;
}

.allocation-item.reinvest .alloc-header svg {
    color: var(--accent-primary);
}

.allocation-item.charity .alloc-header svg {
    color: #f472b6;
}

.alloc-percent {
    margin-left: auto;
    font-weight: 700;
    color: var(--accent-primary);
}

.allocation-item.charity .alloc-percent {
    color: #f472b6;
}

.alloc-bar {
    height: 8px;
    background: var(--bg-tertiary);
    border-radius: 100px;
    overflow: hidden;
}

.alloc-fill {
    height: 100%;
    border-radius: 100px;
    transition: width 0.5s ease;
}

.alloc-fill.reinvest {
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));
}

.alloc-fill.charity {
    background: linear-gradient(90deg, #ec4899, #f472b6);
}

.alloc-desc {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    margin-top: 6px;
    display: block;
}

/* Charity destinations */
.charity-destinations {
    padding: 12px;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 20px;
}

.dest-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    display: block;
    margin-bottom: 8px;
}

.charity-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.charity-tag {
    padding: 4px 10px;
    background: rgba(236, 72, 153, 0.1);
    border: 1px solid rgba(236, 72, 153, 0.2);
    border-radius: 100px;
    font-size: 0.75rem;
    color: #f472b6;
}

/* Governance section */
.governance-section {
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.governance-section h4 {
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 12px;
}

.gov-benefits {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 16px;
}

.gov-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.gov-item svg {
    color: var(--success);
    flex-shrink: 0;
}

/* Stake Button */
.stake-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    padding: 10px 16px;
    margin-top: 10px;
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.2), rgba(99, 102, 241, 0.2));
    border: 2px solid var(--accent-secondary);
    border-radius: 10px;
    color: var(--accent-secondary);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.3s;
}

.stake-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.35), rgba(99, 102, 241, 0.35));
    transform: scale(1.02);
}

.stake-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.stake-btn.staked {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2), rgba(99, 102, 241, 0.2));
    border-color: var(--success);
    color: var(--success);
}

.staked-display {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 8px;
    padding: 6px 12px;
    background: rgba(34, 197, 94, 0.1);
    border-radius: 8px;
    font-size: 0.75rem;
}

.staked-label {
    color: var(--text-tertiary);
}

.staked-value {
    font-weight: 700;
    color: var(--success);
}

/* Governance Header */
.gov-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.gov-header h4 {
    margin: 0;
    font-size: 1rem;
}

.lock-badge {
    font-size: 0.7rem;
    padding: 4px 8px;
    background: var(--bg-tertiary);
    border-radius: 6px;
    color: var(--text-tertiary);
}

.lock-badge.unlocked {
    background: rgba(34, 197, 94, 0.15);
    color: var(--success);
}

/* Governance Locked State */
.gov-locked {
    padding: 24px;
    text-align: center;
}

.locked-overlay {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    color: var(--text-tertiary);
}

.locked-overlay svg {
    opacity: 0.5;
}

.locked-overlay p {
    margin: 0;
    font-size: 0.85rem;
    max-width: 180px;
    line-height: 1.4;
}

/* Governance Unlocked State */
.gov-unlocked {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 16px;
}

.gov-benefit {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    background: var(--bg-secondary);
    border: 1px solid transparent;
    border-radius: 12px;
    animation: benefitSlideIn 0.4s ease forwards;
    opacity: 0;
    transform: translateX(-10px);
}

.gov-benefit:nth-child(1) {
    animation-delay: 0.1s;
}

.gov-benefit:nth-child(2) {
    animation-delay: 0.2s;
}

.gov-benefit:nth-child(3) {
    animation-delay: 0.3s;
}

.gov-benefit:nth-child(4) {
    animation-delay: 0.4s;
}

@keyframes benefitSlideIn {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.gov-benefit.active {
    border-color: rgba(34, 197, 94, 0.3);
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.05), rgba(99, 102, 241, 0.05));
}

.benefit-icon {
    font-size: 1.2rem;
    flex-shrink: 0;
}

.benefit-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.benefit-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
}

.benefit-desc {
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.discussion-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.15), rgba(168, 85, 247, 0.15));
    border: 1px solid var(--accent-primary);
    border-radius: 10px;
    color: var(--accent-primary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    transition: all 0.2s;
}

.discussion-link:hover {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.25), rgba(168, 85, 247, 0.25));
    transform: translateY(-2px);
}

@media (max-width: 1024px) {
    .flow-container {
        flex-direction: column;
    }

    .yield-allocation-panel {
        width: 100%;
    }
}

/* Micro-transaction button styling */
.app-action-btn.micro {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 8px 12px;
    min-width: 90px;
}

.app-action-btn .app-name {
    font-size: 0.7rem;
    font-weight: 600;
}

.app-action-btn .app-cost {
    font-size: 0.65rem;
    color: var(--success);
    font-weight: 700;
}

.micro-explainer {
    font-size: 0.65rem;
    color: var(--success);
    margin-top: 8px;
    text-align: center;
    font-weight: 500;
}

/* Charity Flow Section */
.charity-flow-section {
    padding: 16px;
    background: linear-gradient(135deg, rgba(236, 72, 153, 0.08), rgba(168, 85, 247, 0.08));
    border: 1px solid rgba(236, 72, 153, 0.2);
    border-radius: 14px;
    margin-bottom: 16px;
}

.flow-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    font-size: 0.85rem;
    font-weight: 600;
    color: #f472b6;
}

.flow-header svg {
    flex-shrink: 0;
}

.info-tooltip.small {
    margin-left: auto;
}

/* Liquidity Drip Animation */
.liquidity-flow {
    text-align: center;
    margin-bottom: 16px;
}

.flow-source {
    padding: 6px 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    display: inline-block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.drip-container {
    position: relative;
    height: 40px;
    width: 4px;
    background: linear-gradient(180deg, rgba(236, 72, 153, 0.4), transparent);
    margin: 0 auto;
    border-radius: 4px;
}

.drip-line {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    height: 100%;
    background: linear-gradient(180deg, #ec4899, transparent);
}

.drip {
    position: absolute;
    width: 8px;
    height: 8px;
    background: #ec4899;
    border-radius: 50% 50% 50% 50% / 40% 40% 60% 60%;
    left: 50%;
    transform: translateX(-50%);
    animation: dripFall 2s ease-in infinite;
    box-shadow: 0 0 8px rgba(236, 72, 153, 0.5);
}

.drip.drop1 {
    animation-delay: 0s;
}

.drip.drop2 {
    animation-delay: 0.7s;
}

.drip.drop3 {
    animation-delay: 1.4s;
}

@keyframes dripFall {
    0% {
        top: 0;
        opacity: 0;
        transform: translateX(-50%) scale(0.5);
    }

    10% {
        opacity: 1;
        transform: translateX(-50%) scale(1);
    }

    90% {
        opacity: 1;
        transform: translateX(-50%) scale(1);
    }

    100% {
        top: 100%;
        opacity: 0;
        transform: translateX(-50%) scale(0.3);
    }
}

/* Charity Cards */
.charity-cards {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.charity-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--bg-tertiary);
    border-radius: 10px;
    transition: all 0.2s;
}

.charity-card:hover {
    background: var(--bg-secondary);
    transform: translateX(4px);
}

.charity-icon {
    font-size: 1.2rem;
}

.charity-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.charity-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
}

.charity-location {
    font-size: 0.7rem;
    color: var(--text-tertiary);
}

.charity-pct {
    font-size: 0.85rem;
    font-weight: 700;
    color: #f472b6;
    background: rgba(236, 72, 153, 0.1);
    padding: 4px 10px;
    border-radius: 100px;
}

/* ============================================
   FEE CARDS
   ============================================ */
.fee-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 32px;
}

.fee-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 24px;
}

.fee-card h3 {
    font-size: 1.1rem;
    margin-bottom: 8px;
}

.fee-rate {
    display: inline-block;
    padding: 6px 12px;
    background: rgba(99, 102, 241, 0.15);
    color: var(--accent-primary);
    border-radius: 100px;
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 20px;
}

.fee-example {
    background: var(--bg-secondary);
    border-radius: 12px;
    padding: 16px;
}

.example-title {
    font-size: 0.8rem;
    color: var(--text-tertiary);
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.calc-line {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.9rem;
}

.calc-line:last-of-type {
    border-bottom: none;
}

.calc-line .value {
    font-weight: 600;
}

.calc-line.fee .value {
    color: #ef4444;
}

.calc-line.total {
    border-top: 2px solid var(--accent-primary);
    margin-top: 8px;
    padding-top: 12px;
}

.calc-line.total .value {
    color: var(--success);
    font-size: 1rem;
}

.calc-note {
    margin-top: 12px;
    padding: 8px 12px;
    background: rgba(99, 102, 241, 0.1);
    border-radius: 8px;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.why-fees-box {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 16px;
    padding: 24px 32px;
    text-align: center;
}

.why-fees-box h3 {
    font-size: 1.2rem;
    margin-bottom: 12px;
}

.why-fees-box p {
    color: var(--text-secondary);
    line-height: 1.7;
    max-width: 700px;
    margin: 0 auto;
}

.allocation-note {
    margin-top: 24px;
    padding: 16px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    text-align: center;
}

.allocation-note p {
    color: var(--text-secondary);
    margin: 0;
}

@media (max-width: 900px) {
    .fee-grid {
        grid-template-columns: 1fr;
    }

    .flow-diagram {
        height: auto;
        min-height: 600px;
        padding: 20px;
    }

    .flow-node {
        position: relative;
        margin: 10px auto;
    }

    .flow-arrows {
        display: none;
    }
}

/* =============================================== */
/* COMPACT MODE - Fit entire flow in one screen   */
/* =============================================== */

/* Status bar compact */
.sim-status-bar {
    margin-bottom: 12px;
    padding: 8px 16px;
}

.balance-pills {
    gap: 10px;
}

.balance-pill {
    padding: 6px 10px;
    font-size: 0.75rem;
}

.pill-value {
    font-size: 0.85rem;
}

.time-controls {
    padding: 4px 10px;
}

.time-display {
    font-size: 0.75rem;
}

.time-btn {
    width: 26px;
    height: 26px;
}

.reset-btn {
    padding: 6px 10px;
    font-size: 0.75rem;
}

/* Flow container compact */
.flow-container {
    gap: 16px;
}

.value-flow.interactive {
    gap: 12px;
    padding: 16px;
}

/* Flow main row compact */
.flow-main {
    gap: 8px;
}

/* Node circles compact */
.node-circle {
    width: 40px;
    height: 40px;
}

.node-circle svg {
    width: 18px;
    height: 18px;
}

.node-circle.large {
    width: 55px;
    height: 55px;
}

.node-circle.large svg {
    width: 22px;
    height: 22px;
}

/* Flow nodes compact */
.flow-node {
    padding: 12px;
    min-width: 90px;
    gap: 4px;
}

.flow-node.interactive-node {
    min-width: 130px;
    padding: 12px;
}

.flow-node.you-node {
    min-width: 140px;
}

.flow-node.primary {
    min-width: 130px;
    padding: 14px;
}

.node-label {
    font-size: 0.7rem;
    margin-top: 4px;
}

.node-value {
    font-size: 0.85rem;
}

.node-sub {
    font-size: 0.65rem;
}

.node-hint {
    font-size: 0.6rem;
    margin-top: 4px;
}

/* Deposit input compact */
.deposit-input-group {
    padding: 3px 6px;
    margin: 4px 0;
}

.input-prefix {
    font-size: 0.85rem;
}

.deposit-input {
    width: 60px;
    font-size: 0.85rem;
}

/* Buttons compact */
.node-buttons {
    gap: 4px;
    margin-top: 6px;
}

.node-action-btn {
    padding: 6px 10px;
    font-size: 0.7rem;
}

.node-action-btn.deposit,
.node-action-btn.withdraw {
    padding: 6px 10px;
}

/* Redemption power compact */
.redemption-power {
    margin-top: 6px;
    padding: 4px 8px;
}

.power-label {
    font-size: 0.55rem;
}

.power-value {
    font-size: 0.8rem;
}

/* Stake button compact */
.stake-btn {
    padding: 6px 10px;
    margin-top: 6px;
    font-size: 0.7rem;
}

.staked-display {
    margin-top: 4px;
    padding: 4px 8px;
    font-size: 0.65rem;
}

/* Connectors compact */
.flow-connector {
    padding: 0 8px;
    min-width: 50px;
}

.connector-line {
    width: 30px;
}

.connector-label {
    font-size: 0.6rem;
}

/* Flow returns compact */
.flow-returns {
    padding: 8px 0;
    gap: 20px;
}

.return-path span {
    font-size: 0.65rem;
}

/* Bottom row compact */
.flow-bottom {
    gap: 8px;
    padding-top: 12px;
}

.flow-bottom .flow-node {
    min-width: 80px;
    padding: 10px;
}

/* App buttons compact */
.app-action-btn {
    padding: 4px 8px;
    font-size: 0.6rem;
}

.app-action-btn.micro {
    padding: 4px 6px;
    min-width: 60px;
    gap: 1px;
}

.app-action-btn .app-name {
    font-size: 0.6rem;
}

.app-action-btn .app-cost {
    font-size: 0.55rem;
}

.micro-explainer {
    font-size: 0.55rem;
    margin-top: 4px;
}

/* Right panel compact */
.yield-allocation-panel {
    width: 240px;
    padding: 12px;
    gap: 10px;
}

/* Allocation cards compact */
.alloc-card {
    padding: 5px 6px;
    overflow: hidden;
    display: flex;
    flex-wrap: wrap;
}

.alloc-left {
    gap: 4px;
    flex: 1;
    min-width: 0;
}

.alloc-icon svg {
    width: 12px;
    height: 12px;
}

.alloc-label {
    font-size: 0.6rem;
    white-space: nowrap;
}

.alloc-pct {
    font-size: 0.85rem;
    flex-shrink: 0;
}

.alloc-bar {
    height: 3px;
    margin-top: 3px;
}

.alloc-desc {
    font-size: 0.5rem;
    margin-top: 2px;
}

/* Charity flow compact */
.charity-flow-section {
    padding: 8px;
    margin-bottom: 6px;
}

.flow-header {
    font-size: 0.65rem;
    margin-bottom: 6px;
}

.liquidity-flow {
    margin-bottom: 6px;
}

.flow-source {
    padding: 3px 6px;
    font-size: 0.55rem;
    margin-bottom: 4px;
}

.drip-container {
    height: 25px;
}

/* Charity cards compact */
.charity-cards {
    gap: 4px;
    display: flex;
    flex-direction: column;
}

.charity-card {
    padding: 5px 6px;
    gap: 4px;
    display: flex;
    align-items: center;
    min-width: 0;
    overflow: hidden;
}

.charity-icon {
    font-size: 0.8rem;
    flex-shrink: 0;
}

.charity-info {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.charity-name {
    font-size: 0.65rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.charity-location {
    font-size: 0.5rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.charity-pct {
    font-size: 0.65rem;
    flex-shrink: 0;
    margin-left: auto;
}

/* Governance compact */
.governance-section {
    padding: 10px;
}

.gov-header {
    margin-bottom: 8px;
}

.gov-header h4 {
    font-size: 0.8rem;
}

.lock-badge {
    font-size: 0.6rem;
    padding: 2px 6px;
}

.gov-locked {
    padding: 12px;
}

.locked-overlay svg {
    width: 24px;
    height: 24px;
}

.locked-overlay p {
    font-size: 0.7rem;
    max-width: 150px;
}

.gov-unlocked {
    gap: 6px;
    margin-bottom: 10px;
}

.gov-benefit {
    padding: 8px;
    gap: 8px;
}

.benefit-icon {
    font-size: 0.9rem;
}

.benefit-title {
    font-size: 0.7rem;
}

.benefit-desc {
    font-size: 0.6rem;
}

/* Discussion link compact */
.discussion-link {
    padding: 8px 12px;
    font-size: 0.75rem;
    gap: 6px;
}

.discussion-link svg {
    width: 12px;
    height: 12px;
}

/* Section header compact */
.section-header {
    margin-bottom: 20px;
}

.section-header h2 {
    font-size: 1.5rem;
}

.section-header p {
    font-size: 0.9rem;
}

/* =============================================== */
/* THREE COLUMN LAYOUT                            */
/* =============================================== */

.flow-container.three-col {
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
    gap: 8px !important;
    max-width: 900px !important;
    margin: 0 auto !important;
    padding: 0 !important;
}

/* Left Governance Panel */
.governance-panel-left {
    width: 120px;
    min-width: 120px;
    padding: 8px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    transition: all 0.3s ease;
}

.governance-panel-left.unlocked {
    border-color: var(--success);
    box-shadow: 0 0 20px rgba(34, 197, 94, 0.2);
}

.governance-panel-left .gov-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-bottom: 4px;
}

.governance-panel-left .gov-header h4 {
    font-size: 0.75rem;
    margin: 0;
    color: var(--text-primary);
}

.governance-panel-left .lock-badge {
    font-size: 0.55rem;
    padding: 2px 6px;
}

.governance-panel-left .gov-locked {
    padding: 6px 4px;
    text-align: center;
}

.governance-panel-left .locked-overlay {
    gap: 4px;
}

.governance-panel-left .locked-overlay svg {
    width: 20px;
    height: 20px;
}

.governance-panel-left .locked-overlay p {
    font-size: 0.6rem;
    margin: 0;
    max-width: 100%;
}

.governance-panel-left .gov-unlocked {
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-bottom: 4px;
}

.governance-panel-left .gov-benefit {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 6px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(99, 102, 241, 0.08));
    border-radius: 6px;
    border: 1px solid rgba(34, 197, 94, 0.2);
}

.governance-panel-left .benefit-icon {
    font-size: 0.85rem;
}

.governance-panel-left .benefit-title {
    font-size: 0.6rem;
    color: var(--text-primary);
    font-weight: 500;
}

.discussion-link-mini {
    display: block;
    text-align: center;
    padding: 6px;
    background: var(--bg-tertiary);
    border-radius: 6px;
    color: var(--accent-primary);
    text-decoration: none;
    font-size: 0.6rem;
    font-weight: 600;
    transition: all 0.2s;
}

.discussion-link-mini:hover {
    background: rgba(99, 102, 241, 0.1);
}

/* Center flow - constrained width */
.flow-container.three-col .value-flow.interactive {
    flex: 0 1 auto;
    max-width: 480px;
    padding: 6px;
}

/* Right panel - wider for content */
.flow-container.three-col .yield-allocation-panel {
    width: 210px;
    min-width: 210px;
    padding: 10px;
    overflow: visible;
}

/* Fix bottom row to be tighter */
.flow-bottom {
    justify-content: center !important;
    gap: 10px !important;
    padding-top: 8px !important;
}

/* Make flow-main row horizontal and tight */
.flow-main {
    justify-content: center !important;
    gap: 6px !important;
    align-items: center !important;
}

/* Reduce flow returns padding */
.flow-returns {
    padding: 6px 0 !important;
    gap: 30px !important;
}

/* Usage Potential Blurb */
.usage-potential {
    margin-top: 6px;
    padding: 6px 8px;
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.1), rgba(245, 158, 11, 0.1));
    border: 1px solid rgba(251, 191, 36, 0.3);
    border-radius: 8px;
    text-align: center;
}

.usage-header {
    display: block;
    font-size: 0.55rem;
    color: #fbbf24;
    font-weight: 600;
    margin-bottom: 2px;
}

.usage-example {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    color: #f59e0b;
}

/* =============================================== */
/* SIMPLIFIED ALLOCATION CARDS                    */
/* =============================================== */

.alloc-cards-simple {
    display: flex;
    gap: 6px;
    margin-bottom: 8px;
}

.alloc-card-simple {
    flex: 1;
    padding: 10px 8px;
    border-radius: 10px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.alloc-card-simple.reinvest {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15), rgba(34, 197, 94, 0.05));
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.alloc-card-simple.charity {
    background: linear-gradient(135deg, rgba(236, 72, 153, 0.15), rgba(236, 72, 153, 0.05));
    border: 1px solid rgba(236, 72, 153, 0.3);
}

.alloc-big-pct {
    font-size: 1.4rem;
    font-weight: 800;
    line-height: 1;
}

.alloc-card-simple.reinvest .alloc-big-pct {
    color: #22c55e;
}

.alloc-card-simple.charity .alloc-big-pct {
    color: #ec4899;
}

.alloc-title {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--text-primary);
}

.alloc-subtitle {
    font-size: 0.55rem;
    color: var(--text-tertiary);
}

/* =============================================== */
/* YIELD MESSAGING                                 */
/* =============================================== */

.yield-badge {
    display: inline-block;
    background: linear-gradient(135deg, #22c55e, #10b981);
    color: white;
    font-size: 0.7rem;
    padding: 4px 10px;
    border-radius: 12px;
    margin-left: 8px;
    font-weight: 600;
    animation: pulse-glow 2s ease-in-out infinite;
}

@keyframes pulse-glow {

    0%,
    100% {
        box-shadow: 0 0 5px rgba(34, 197, 94, 0.3);
    }

    50% {
        box-shadow: 0 0 15px rgba(34, 197, 94, 0.6);
    }
}

.yield-explainer {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1), rgba(16, 185, 129, 0.05));
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 12px;
    padding: 16px;
    margin-top: 16px;
}

.yield-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.yield-text {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.yield-text strong {
    color: #22c55e;
}

.payment-methods {
    text-align: center;
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin: 8px 0 16px;
}

/* =============================================== */
/* VALUE FLOW VISUAL                               */
/* =============================================== */

.value-flow-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 24px;
    background: var(--bg-tertiary);
    border-radius: 16px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.flow-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 16px 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    min-width: 100px;
}

.flow-step.deposit-step {
    border-color: rgba(59, 130, 246, 0.4);
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), transparent);
}

.flow-step.suite-step {
    border-color: rgba(168, 85, 247, 0.4);
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.15), transparent);
}

.flow-icon {
    font-size: 1.8rem;
}

.flow-label {
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--text-primary);
}

.flow-sub {
    font-size: 0.7rem;
    color: var(--text-tertiary);
}

.flow-arrow {
    font-size: 1.5rem;
    color: var(--text-tertiary);
    font-weight: 300;
}

.flow-branches {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}

.flow-branch {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-size: 0.85rem;
    transition: all 0.2s ease;
}

.flow-branch:hover {
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.branch-icon {
    font-size: 1.1rem;
}

.branch-text {
    color: var(--text-secondary);
    font-weight: 500;
}

/* New flow row layout */
.flow-row.main-flow {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
}

.flow-step.action-step {
    border-color: rgba(251, 191, 36, 0.4);
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.1), transparent);
}

.flow-step.withdraw-step {
    border-color: rgba(34, 197, 94, 0.4);
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15), transparent);
}

.flow-sub.growing {
    color: #22c55e;
    font-weight: 600;
}

.flow-sub.profit {
    color: #22c55e;
    font-weight: 700;
    font-size: 0.8rem;
}

/* Option pills section */
.flow-options {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
    flex-wrap: wrap;
    justify-content: center;
}

.options-label {
    font-size: 0.85rem;
    color: var(--text-tertiary);
}

.option-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.option-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    .value-flow-visual {
        flex-direction: column;
        gap: 12px;
    }

    .flow-row.main-flow {
        flex-direction: column;
    }

    .flow-arrow {
        transform: rotate(90deg);
    }

    .flow-options {
        flex-direction: column;
        text-align: center;
    }
}

/* ============================================
   YIELD POOL SECTION
   ============================================ */
.yield-section {
    margin-top: 64px;
    padding-top: 64px;
    border-top: 1px solid var(--border-color);
}

.yield-header {
    text-align: center;
    margin-bottom: 40px;
}

.yield-header h2 {
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 12px;
}

.yield-subtitle {
    color: var(--text-secondary);
    font-size: 1rem;
    max-width: 600px;
    margin: 0 auto;
}

.yield-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
    margin-bottom: 40px;
}

.yield-card {
    display: flex;
    gap: 16px;
    padding: 20px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.05), rgba(16, 185, 129, 0.02));
    border: 1px solid rgba(34, 197, 94, 0.2);
    border-radius: 16px;
    transition: all 0.2s ease;
}

.yield-card:hover {
    border-color: rgba(34, 197, 94, 0.4);
    transform: translateY(-2px);
}

.yield-protocol {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.protocol-icon {
    font-size: 1.2rem;
}

.protocol-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.yield-stats {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
}

.yield-apy {
    padding: 4px 10px;
    background: rgba(34, 197, 94, 0.15);
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 700;
    color: #22c55e;
}

.yield-risk {
    font-size: 0.8rem;
    font-weight: 500;
}

.yield-risk.risk-low {
    color: #22c55e;
}

.yield-risk.risk-medium {
    color: #f59e0b;
}

.yield-risk.risk-high {
    color: #ef4444;
}

@media (max-width: 768px) {
    .yield-cards {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   DEFI FEATURE SECTION
   ============================================ */
.defi-feature-section {
    padding: var(--section-padding) 0;
    background: var(--bg-primary);
    position: relative;
    overflow: hidden;
}

.defi-feature-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 100%;
    background: radial-gradient(ellipse at center, rgba(99, 102, 241, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.defi-feature-content {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.defi-feature-text {
    max-width: 550px;
}

.defi-features-list {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin: 40px 0;
}

.defi-feature-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.feature-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 1.5rem;
    flex-shrink: 0;
}

.feature-content h4 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--text-primary);
}

.feature-content p {
    font-size: 0.95rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

.defi-protocols {
    margin: 32px 0;
    padding: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.protocols-label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 12px;
}

.protocol-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.protocol-badge {
    padding: 8px 16px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 100px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
    transition: all var(--transition-fast);
}

.protocol-badge:hover {
    background: var(--bg-tertiary);
    border-color: var(--border-hover);
}

/* Phone Mockup */
.defi-feature-visual {
    display: flex;
    justify-content: center;
    align-items: center;
}

.defi-phone-mockup {
    perspective: 1000px;
}

.phone-frame {
    width: 320px;
    height: 650px;
    background: linear-gradient(145deg, #1a1a25 0%, #12121a 100%);
    border-radius: 40px;
    padding: 12px;
    box-shadow:
        0 20px 60px rgba(0, 0, 0, 0.4),
        0 0 0 10px rgba(255, 255, 255, 0.02),
        0 0 0 12px rgba(255, 255, 255, 0.01);
    transform: rotateY(-5deg) rotateX(3deg);
    transition: transform 0.3s ease;
}

.phone-frame:hover {
    transform: rotateY(0deg) rotateX(0deg);
}

.phone-screen {
    width: 100%;
    height: 100%;
    background: var(--bg-primary);
    border-radius: 30px;
    overflow: hidden;
}

.defi-app-preview {
    height: 100%;
    display: flex;
    flex-direction: column;
    padding: 20px;
}

.preview-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
}

.app-name {
    font-size: 1rem;
    font-weight: 600;
}

.network-badge {
    padding: 4px 10px;
    background: rgba(0, 82, 255, 0.15);
    border: 1px solid rgba(0, 82, 255, 0.3);
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #3b82f6;
}

.preview-balance {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    margin-bottom: 20px;
}

.balance-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 8px;
}

.balance-amount {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.balance-change {
    font-size: 0.85rem;
    color: var(--success);
    font-weight: 600;
}

.preview-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 20px;
}

.action-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    cursor: pointer;
    transition: all var(--transition-fast);
    gap: 8px;
}

.action-btn:hover {
    background: var(--bg-card-hover);
    border-color: var(--border-hover);
}

.action-btn span:first-child {
    font-size: 1.8rem;
}

.action-btn span:last-child {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
}

.swap-btn:hover {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(168, 85, 247, 0.1) 100%);
    border-color: rgba(99, 102, 241, 0.3);
}

.lend-btn:hover {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(16, 185, 129, 0.1) 100%);
    border-color: rgba(34, 197, 94, 0.3);
}

.preview-positions {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.position-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
}

.position-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border-radius: 10px;
    font-size: 1.3rem;
    flex-shrink: 0;
}

.position-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.position-name {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-primary);
}

.position-apy {
    font-size: 0.75rem;
    color: var(--success);
    font-weight: 600;
}

.position-value {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-primary);
}

/* Responsive */
@media (max-width: 968px) {
    .defi-feature-content {
        grid-template-columns: 1fr;
        gap: 60px;
    }

    .defi-feature-text {
        max-width: 100%;
    }

    .phone-frame {
        transform: none;
    }
}