/*
* SACRED FOUNDATION - 2026-02-23
* This file is now the single source of truth for all visual styles.
* No inline <style> blocks allowed in templates.
* No duplicate selectors permitted.
* Do not add new global rules without high-specificity scoping (e.g. .terminal-card > ...)
* Overlay logic must remain in .restricted-section-wrapper only.
* Carousel & snap-back mechanics are sacred — do not touch.
* Last major cleanup: removed 25+ duplicates, consolidated inline styles.
*/

/* 
  GLITCH WORLD CSS ARCHITECTURE
  New components use gw-[component]__[element] naming
  Never use generic selectors like h1, h2 without a parent class prefix
  Never override glitch-70 globally — it's a shared animation class
*/

/* ============================================
   GLITCH WORLD - INSTITUTIONAL DESIGN SYSTEM
   Professionalization Update: Feb 24, 2026
   ============================================ */

/* 1. GLOBAL & RESET */
::-webkit-scrollbar { display: none; }

html, body {
    -ms-overflow-style: none;
    scrollbar-width: none;
    background-color: #0E1116 !important;
    background: #0E1116 !important;
    color: var(--gw-text-main);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    margin: 0;
    padding: 0;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    background-image: 
        linear-gradient(rgba(18, 22, 28, 0.1) 1px, transparent 1px),
        radial-gradient(circle at top center, rgba(255, 255, 255, 0.02) 0%, rgba(255, 255, 255, 0) 60%);
    background-size: 100% 3px, 100% 100%;
    background-attachment: fixed;
}

:root {
    --gw-bg: #0E1116;
    --gw-surface: #12161C;
    --gw-surface-mid: #1C2128;
    --gw-text-main: #F9FAFB;
    --gw-text-muted: #9CA3AF;
    --gw-accent: #14F195;
    --gw-accent-yellow: #F4B400;
    --gw-solana: #A855F7;
    --gw-bnb: #F3BA2F;
    --gw-base: #0052FF;
    --gw-arbitrum: #96BEDC;
    --gw-card-bg: rgba(13, 17, 23, 0.8);
    --gw-border-subtle: rgba(255, 255, 255, 0.05);
    --gw-font-mono: 'JetBrains Mono', 'IBM Plex Mono', monospace;
}

/* 2. ANIMATIONS (Unified) */
.g-word, .g-icon {
    display: inline-block !important;
    position: relative !important;
    will-change: opacity, transform, filter; 
    margin: 0;
    padding: 0;
}

.g-word { animation: glitch-natural-shimmer 14.5s infinite !important; opacity: 1 !important; }
.g-icon { animation: glitch-icon-shimmer 18.2s infinite !important; opacity: 1 !important; }

/* 
   GLITCH PIANO RHYTHM ENGINE
   Mathematical prime-number distribution for "trance" effect.
   No two words in the same proximity should hit the spike simultaneously.
*/
.gw-1 { animation-delay: 0.13s !important; animation-duration: 13.1s !important; }
.gw-2 { animation-delay: 1.87s !important; animation-duration: 15.7s !important; }
.gw-3 { animation-delay: 3.41s !important; animation-duration: 12.3s !important; }
.gw-4 { animation-delay: 5.12s !important; animation-duration: 17.9s !important; }
.gw-5 { animation-delay: 0.76s !important; animation-duration: 14.2s !important; }
.gw-6 { animation-delay: 4.29s !important; animation-duration: 16.3s !important; }
.gw-7 { animation-delay: 2.15s !important; animation-duration: 13.7s !important; }
.gw-8 { animation-delay: 6.44s !important; animation-duration: 19.1s !important; }

@keyframes glitch-natural-shimmer {
    0%, 0.8%, 1.8%, 100% { transform: none; filter: none; text-shadow: none; opacity: 1; }
    0.3% { transform: skewX(1.2deg) translateX(-0.8px); filter: brightness(1.3) contrast(1.2); text-shadow: 1px 0 rgba(20, 241, 149, 0.5), -1px 0 rgba(255, 0, 193, 0.4); opacity: 0.98; }
    1.1% { transform: skewX(-1.2deg) translateX(0.8px); filter: brightness(0.85) contrast(1.2); text-shadow: -1px 0 rgba(20, 241, 149, 0.4), 1px 0 rgba(255, 0, 193, 0.5); opacity: 1; }
}

@keyframes glitch-icon-shimmer {
    0%, 1.2%, 100% { filter: none; transform: none; opacity: 1; }
    0.2% { filter: drop-shadow(-1.5px 0 rgba(20, 241, 149, 0.4)) drop-shadow(1.5px 0 rgba(255, 0, 193, 0.3)); transform: translateX(-1px) scale(1.03); opacity: 0.96; }
    0.5% { filter: drop-shadow(1.5px 0 rgba(20, 241, 149, 0.4)) drop-shadow(-1.5px 0 rgba(255, 0, 193, 0.3)); transform: translateX(1px) rotate(1.2deg); opacity: 1; }
}

@keyframes scanline {
    0% { transform: translateY(0); }
    100% { transform: translateY(200vh); }
}

@keyframes skeleton-pulse {
    0%, 100% { opacity: 0.6; }
    50% { opacity: 1; }
}

.scanline {
    width: 100%; height: 100px; z-index: 9999;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(255, 255, 255, 0.02) 50%, rgba(0, 0, 0, 0) 100%);
    opacity: 0.1; position: fixed; bottom: 100%; left: 0; pointer-events: none; animation: scanline 10s linear infinite;
}

/* 3. LAYOUT COMPONENTS */
.hero-title-desktop { font-weight: 800 !important; }

@media (min-width: 769px) {
    .navbar-brand .glitch-logo-text {
        font-weight: 800 !important;
        letter-spacing: -0.04em !important;
    }
}

.hero-subtitle-desktop {
    color: var(--gw-text-main) !important;
    opacity: 0.9;
    font-weight: 500 !important;
    letter-spacing: 0.02em;
}

.no-scrollbar { -ms-overflow-style: none !important; scrollbar-width: none !important; }
.no-scrollbar::-webkit-scrollbar { display: none !important; }

.glass-card {
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    background: rgba(18, 22, 28, 0.4) !important;
    border-radius: 16px !important;
    padding: 24px !important;
    box-shadow: inset 0 0 40px rgba(0,0,0,0.2) !important;
    transition: border-color 0.2s ease;
}

.glass-card:hover { border-color: var(--gw-text-muted) !important; }

/* 4. TERMINAL CARD (Source of Truth) */
.terminal-card {
    min-width: 310px !important;
    max-width: 310px !important;
    width: 310px !important;
    height: 420px !important;
    min-height: 420px !important;
    background: rgba(18, 22, 28, 0.98) !important;
    border: 1.5px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 12px !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    position: relative !important;
    transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
    box-sizing: border-box !important;
    backdrop-filter: blur(25px);
    box-shadow: 0 15px 35px -12px rgba(0,0,0,0.6) !important;
    flex-shrink: 0 !important;
    scroll-snap-align: center !important;
}

.carousel-container {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    scroll-behavior: smooth !important;
    gap: 20px !important;
    padding: 20px 0 !important;
    -webkit-overflow-scrolling: touch !important;
    pointer-events: auto !important;
}

.carousel-container::-webkit-scrollbar { display: none !important; }

@media (min-width: 769px) {
    .card-header-bar, .metrics-strip, .card-footer-bar {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    .card-chart-container {
        padding: 0 20px !important;
    }
    .terminal-card {
        padding: 0 20px !important;
    }
}

.terminal-card:hover {
    border-color: rgba(20, 241, 149, 0.5) !important;
    transform: translateY(-6px) scale(1.01) !important;
    box-shadow: 0 25px 50px -15px rgba(0,0,0,0.7) !important;
}

.terminal-card.status-positive:hover { border-color: #10B981 !important; }
.terminal-card.status-negative:hover { border-color: #EF4444 !important; }

/* CHART-FIRST CARD INTERNALS */

.card-header-bar {
    padding: 16px 0 8px 0 !important;
    flex-shrink: 0;
}
.card-header-left {
    padding-left: 0 !important;
    gap: 4px !important;
    max-width: 65%;
    align-items: flex-start !important;
}
.card-symbol {
    font-family: var(--gw-font-mono);
    font-size: 1rem;
    font-weight: 800;
    color: var(--gw-text-main) !important;
    letter-spacing: -0.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    display: block;
    line-height: 1.2;
}
.chain-tag {
    background: transparent !important;
    border: 1.5px solid var(--gw-text-muted) !important;
    color: var(--gw-text-muted) !important;
    padding: 1px 8px !important;
    font-size: 0.6rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    border-radius: 4px !important;
    display: inline-block;
    line-height: 1.4;
    width: fit-content !important;
}
.chain-tag[data-chain="solana"] { border-color: var(--gw-solana) !important; color: var(--gw-solana) !important; }
.chain-tag[data-chain="bnb"], .chain-tag[data-chain="bsc"] { border-color: var(--gw-bnb) !important; color: var(--gw-bnb) !important; }
.chain-tag[data-chain="base"] { border-color: var(--gw-base) !important; color: var(--gw-base) !important; }
.chain-tag[data-chain="arbitrum"] { border-color: var(--gw-arbitrum) !important; color: var(--gw-arbitrum) !important; }

.current-gain-text {
    font-family: var(--gw-font-mono);
    font-size: 1.3rem !important;
    font-weight: 800 !important;
    line-height: 1;
}
.peak-gain-text {
    line-height: 1;
    margin-top: 2px;
}

/* Chart Hero — dominant central element */
.card-chart-container {
    width: 100% !important;
    height: 190px !important;
    min-height: 190px !important;
    flex-shrink: 0;
    padding: 0 !important;
    position: relative;
}
.card-chart-container canvas {
    width: 100% !important;
    height: 100% !important;
    display: block;
}

/* Metrics Strip — compressed horizontal row */
.metrics-strip {
    display: flex;
    justify-content: space-between;
    padding: 8px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    flex-shrink: 0;
}
.metrics-strip__cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
}
.metrics-strip__cell--peak .metrics-strip__value { color: #10B981 !important; }
.metrics-strip__label {
    font-family: var(--gw-font-mono);
    font-size: 0.55rem !important;
    color: var(--gw-text-muted) !important;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 2px;
}
.metrics-strip__value {
    font-family: var(--gw-font-mono);
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    color: var(--gw-text-main) !important;
}

/* Card Footer — DexScreener link + tracking badge */
.card-footer-bar {
    padding: 6px 0 14px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    flex-shrink: 0;
}
.card-dex-link {
    display: inline-block;
    color: var(--gw-text-main) !important;
    font-size: 0.7rem !important;
    font-weight: 700;
    letter-spacing: 1px;
    text-decoration: none;
    text-transform: uppercase;
    transition: color 0.2s;
}
.card-dex-link:hover { color: #10B981 !important; }
.card-tracking-badge {
    color: #10B981 !important;
    font-size: 0.55rem;
    font-weight: 700;
    letter-spacing: 2px;
    margin-top: 4px;
}

/* Legacy stat-row (used in operator templates) */
.stat-row { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 0.5rem 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.stat-row:last-child { border-bottom: none; }
.stat-label { font-family: var(--gw-font-mono); font-size: 0.65rem; color: var(--gw-text-muted); letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600; }
.stat-value { font-family: var(--gw-font-mono); font-size: 0.85rem; font-weight: 600; color: var(--gw-text-main); }

/* 5. OVERLAYS & STATUS */
.restricted-section-wrapper { position: relative !important; height: 100% !important; }
.tier-ghost-overlay {
    position: absolute !important; top: 0; left: 0; right: 0; bottom: 0;
    background: #0E1116 !important; backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important; z-index: 900 !important;
    display: flex !important; flex-direction: column !important;
    align-items: center !important; justify-content: center !important;
    text-align: center !important; border-radius: 0 !important; pointer-events: all !important;
}
.tier-ghost-content { max-width: 280px !important; animation: fadeIn 0.5s ease-out !important; }
.tier-lock-icon { font-size: 2.5rem !important; margin-bottom: 1rem !important; color: var(--gw-accent-yellow) !important; text-shadow: 0 0 20px rgba(244, 180, 0, 0.4) !important; }
.tier-ghost-title { font-size: 1.25rem !important; font-weight: 800 !important; letter-spacing: 2px !important; color: var(--gw-text-main) !important; margin-bottom: 0.75rem !important; text-transform: uppercase !important; }
.tier-ghost-text { font-size: 0.85rem !important; color: var(--gw-text-muted) !important; margin-bottom: 1.5rem !important; line-height: 1.5 !important; }

@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* 6. NAVBAR & NAVIGATION */
.navbar {
    position: relative !important; overflow: hidden !important; background: var(--gw-bg) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
    min-height: 80px !important; display: flex !important; align-items: center !important; padding: 0 !important;
}
.navbar .container { display: flex !important; align-items: center !important; max-width: 85% !important; }
.navbar-brand { font-size: 1.25rem !important; margin: 0 !important; z-index: 10; display: flex !important; align-items: center !important; }
.navbar-nav { margin-left: auto !important; gap: 1.5rem !important; }
.nav-link {
    font-size: 0.75rem !important; text-transform: uppercase !important; letter-spacing: 0.1em !important;
    font-weight: 700 !important; color: var(--gw-text-main) !important; opacity: 0.8; transition: all 0.2s ease !important; padding: 0.5rem 0 !important;
}
.nav-link:hover, .nav-link.active { color: var(--gw-text-main) !important; opacity: 1; }
.navbar-toggler { display: none !important; }

/* 7. MOBILE SPECIFIC (Scoped) */
@media (max-width: 768px) {
    .mobile-bottom-tabs {
        display: flex !important; position: fixed; bottom: 0; left: 0; right: 0; z-index: 1050;
        background: var(--gw-surface); border-top: 1px solid rgba(255, 255, 255, 0.08);
        padding: 0.5rem 0; padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0px));
        justify-content: space-around; align-items: center;
    }
    .mobile-tab-item {
        display: flex; flex-direction: column; align-items: center; gap: 0.25rem;
        text-decoration: none; color: var(--gw-text-muted); font-size: 0.6rem;
        font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em;
        padding: 0.25rem 1rem; transition: color 0.2s;
    }
    .mobile-tab-item.active { color: #14F195; }
    .mobile-tab-item svg { opacity: 0.6; }
    .mobile-tab-item.active svg { opacity: 1; stroke: #14F195; }
    
    .terminal-card { width: 310px !important; margin: 0 auto !important; }
    .signals-table-container { min-height: auto !important; padding: 0 !important; }

    /* Strip desktop containers on mobile — only token cards should be visible */
    body.subdomain-feed .glass-card {
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
        backdrop-filter: none !important;
    }

    body.subdomain-feed .row,
    body.subdomain-feed .row.mb-5,
    body.subdomain-feed .row.mb-5.g-4,
    body.subdomain-feed .col-12,
    body.subdomain-feed .col-md-6 {
        margin: 0 !important;
        padding: 0 !important;
    }

    body.subdomain-feed .desktop-section-header { display: none !important; }
    body.subdomain-feed .section-descriptor { display: none !important; }
}

.mobile-bottom-tabs { display: none; }

/* 8. LEGACY / UTILITY CLEANUP */
.glitch-font, .display-4, .h3, h3, h4, h5, h6 { font-weight: 600 !important; letter-spacing: -0.04em !important; color: var(--gw-text-main) !important; }
.text-muted { color: var(--gw-text-muted) !important; }
.skeleton-pulse { animation: skeleton-pulse 1.5s ease-in-out infinite; }
.signals-table-container { height: 420px !important; display: flex !important; align-items: center !important; justify-content: center; width: 100% !important; overflow: hidden !important; }

/* ============================================
   SNAKE-WRAP GLITCH — DESKTOP SOURCE
   Same physics as mobile.css version.
   Required here because base.html does not load mobile.css.
   On mobile: mobile.css loads after and takes cascade precedence.
   ============================================ */
:root {
    --snake-duration: 5.2s;
    --snake-color: #14F195;
    --snake-glow: rgba(20, 241, 149, 0.65);
    --snake-afterglow: rgba(20, 241, 149, 0.18);
}

.gw-mobile__snake-hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    position: relative;
    overflow: visible !important;
}

.gw-mobile__snake-node {
    position: relative;
    display: inline-block;
}

.gw-mobile__snake-node::before {
    content: '';
    position: absolute;
    top: 0;
    left: -5%;
    width: 0%;
    height: 1.5px;
    background: linear-gradient(90deg, transparent 0%, var(--snake-color) 30%, rgba(255,255,255,0.9) 50%, var(--snake-color) 70%, transparent 100%);
    box-shadow: 0 0 4px var(--snake-glow), 0 0 10px var(--snake-glow), 0 0 20px rgba(20, 241, 149, 0.3);
    z-index: 10;
    opacity: 0;
    pointer-events: none;
    animation: gw-snake-current var(--snake-duration) ease-in-out infinite;
}

.gw-mobile__snake-node::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--snake-afterglow), transparent);
    filter: blur(2px);
    z-index: 9;
    opacity: 0;
    pointer-events: none;
    animation: gw-snake-tail var(--snake-duration) ease-in-out infinite;
}

.gw-mobile__snake-node > span {
    display: inline-block;
    animation: gw-snake-spike var(--snake-duration) ease-out infinite !important;
}

@keyframes gw-snake-current {
    0%   { left: -5%; width: 0%;   opacity: 0; }
    3%   { left: -2%; width: 15%;  opacity: 0.8; }
    7%   { left: 20%; width: 80%;  opacity: 1; }
    11%  { left: 95%; width: 10%;  opacity: 0.6; }
    13%  { left: 110%; width: 0%;  opacity: 0; }
    100% { left: -5%; width: 0%;   opacity: 0; }
}

@keyframes gw-snake-tail {
    0%   { opacity: 0; }
    6%   { opacity: 0; }
    9%   { opacity: 0.5; filter: blur(3px); }
    18%  { opacity: 0.15; filter: blur(5px); }
    28%  { opacity: 0; }
    100% { opacity: 0; }
}

@keyframes gw-snake-spike {
    0%   { filter: none; transform: none; }
    4%   { filter: brightness(1.6) drop-shadow(0 0 6px var(--snake-glow)); transform: skewX(2deg) scale(1.02); }
    8%   { filter: brightness(1.25) drop-shadow(0 0 3px var(--snake-afterglow)); transform: skewX(0.5deg); }
    13%  { filter: none; transform: none; }
    100% { filter: none; transform: none; }
}

.gw-mobile__snake-node--w0::before,.gw-mobile__snake-node--w0::after,.gw-mobile__snake-node--w0 > span { animation-delay: 0s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w1::before,.gw-mobile__snake-node--w1::after,.gw-mobile__snake-node--w1 > span { animation-delay: 0.55s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w2::before,.gw-mobile__snake-node--w2::after,.gw-mobile__snake-node--w2 > span { animation-delay: 1.0s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w3::before,.gw-mobile__snake-node--w3::after,.gw-mobile__snake-node--w3 > span { animation-delay: 1.35s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w4::before,.gw-mobile__snake-node--w4::after,.gw-mobile__snake-node--w4 > span { animation-delay: 1.8s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w5::before,.gw-mobile__snake-node--w5::after,.gw-mobile__snake-node--w5 > span { animation-delay: 2.2s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w6::before,.gw-mobile__snake-node--w6::after,.gw-mobile__snake-node--w6 > span { animation-delay: 2.55s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w7::before,.gw-mobile__snake-node--w7::after,.gw-mobile__snake-node--w7 > span { animation-delay: 2.9s !important; animation-duration: var(--snake-duration) !important; }
.gw-mobile__snake-node--w8::before,.gw-mobile__snake-node--w8::after,.gw-mobile__snake-node--w8 > span { animation-delay: 3.2s !important; animation-duration: var(--snake-duration) !important; }

/* Phantom Layer Audit: Ensure Snake Nodes and Overlays don't block interaction */
.gw-mobile__snake-node::before,
.gw-mobile__snake-node::after {
    pointer-events: none !important;
}

/* Ensure Operator Buttons in Hero are clickable */
.mobile-home-logo a, 
.mobile-home-logo .btn {
    position: relative;
    z-index: 10;
    pointer-events: auto !important;
}
