
/* Base Global Styles */
body {
    background-color: #0a0a0c;
    color: #f3f4f6;
    font-family: 'Inter', sans-serif;
    overflow-x: hidden;
}

.ambient-glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(140px);
    opacity: 0.15;
    z-index: 0;
    pointer-events: none;
    mix-blend-mode: screen;
}

.glass-panel {
    background: rgba(26, 26, 32, 0.4);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(197, 168, 97, 0.1);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.3);
    position: relative;
    z-index: 10;
}

.text-gradient-gold {
    background: linear-gradient(135deg, #FFD700 0%, #C5A861 50%, #B8860B 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.text-gradient-white {
    background: linear-gradient(180deg, #ffffff 0%, rgba(255,255,255,0.7) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(197,168,97,0.2); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: rgba(197,168,97,0.4); }

@keyframes float {
    0% { transform: translateY(0px); }
    50% { transform: translateY(-20px); }
    100% { transform: translateY(0px); }
}
.animate-float { animation: float 6s ease-in-out infinite; }

@keyframes pulse-slow {
    0%, 100% { opacity: 0.1; }
    50% { opacity: 0.2; }
}
.animate-pulse-slow { animation: pulse-slow 8s ease-in-out infinite; }

.prismatic-btn {
    position: relative;
    overflow: hidden;
}
.prismatic-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 50%;
    height: 100%;
    background: linear-gradient(
        120deg,
        transparent,
        rgba(255, 255, 255, 0.2),
        rgba(139, 92, 246, 0.4),
        rgba(20, 184, 166, 0.2),
        transparent
    );
    transform: skewX(-20deg);
    transition: all 0.6s ease-in-out;
    z-index: 1;
}
.prismatic-btn:hover::before {
    left: 200%;
}

.prismatic-text {
    background: linear-gradient(to right, #ffffff, #C5A861, #8B5CF6);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

html:not(.dark) body { background-color: #f8f9fa !important; color: #1a1a1a !important; }
html:not(.dark) .bg-syc-dark\/70 { background-color: rgba(255, 255, 255, 0.8) !important; border-color: rgba(0,0,0,0.05) !important; }
html:not(.dark) .bg-syc-dark\/80 { background-color: rgba(255, 255, 255, 0.85) !important; border-color: rgba(0,0,0,0.05) !important; }
html:not(.dark) .bg-syc-dark\/90 { background-color: rgba(255, 255, 255, 0.9) !important; border-color: rgba(0,0,0,0.05) !important; }
html:not(.dark) .bg-syc-dark\/95 { background-color: rgba(255, 255, 255, 0.95) !important; border-color: rgba(0,0,0,0.05) !important; }
html:not(.dark) .glass-panel { background: rgba(255, 255, 255, 0.7) !important; border: 1px solid rgba(0,0,0,0.05) !important; box-shadow: 0 8px 30px rgba(0,0,0,0.04) !important; }
html:not(.dark) .text-white { color: #000000 !important; }
html:not(.dark) .text-syc-text-dim { color: #4b5563 !important; }
html:not(.dark) .bg-syc-dark { background-color: #ffffff !important; }
html:not(.dark) .bg-syc-surface-highest\/20 { background-color: rgba(0,0,0,0.02) !important; }
html:not(.dark) .border-white\/5 { border-color: rgba(0,0,0,0.05) !important; }
html:not(.dark) .border-white\/10 { border-color: rgba(0,0,0,0.1) !important; }
html:not(.dark) .bg-white\/5 { background-color: rgba(0,0,0,0.03) !important; }
html:not(.dark) .text-gradient-white { background: linear-gradient(180deg, #111111 0%, rgba(17,17,17,0.7) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
html:not(.dark) .prismatic-text {
    background: linear-gradient(to right, #1a1a1a, #C5A861, #8B5CF6) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

/* Data flow lines */
@keyframes data-flow-horizontal {
    0% { transform: translateX(-100%); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateX(300%); opacity: 0; }
}
.animate-data-flow {
    animation: data-flow-horizontal 3s linear infinite;
}

@keyframes data-flow-vertical {
    0% { transform: translateY(-100%); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateY(300%); opacity: 0; }
}
.animate-data-flow-v {
    animation: data-flow-vertical 3s linear infinite;
}

/* Pulsing Lock / Shield */
@keyframes pulse-intense {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.1); opacity: 0.8; box-shadow: 0 0 30px rgba(197, 168, 97, 0.8); }
}
.animate-pulse-intense {
    animation: pulse-intense 2s ease-in-out infinite;
}

/* Data flow lines */
@keyframes data-flow-horizontal {
    0% { transform: translateX(-100%); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateX(300%); opacity: 0; }
}
.animate-data-flow {
    animation: data-flow-horizontal 3s linear infinite;
}

@keyframes data-flow-vertical {
    0% { transform: translateY(-100%); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateY(300%); opacity: 0; }
}
.animate-data-flow-v {
    animation: data-flow-vertical 3s linear infinite;
}

/* Pulsing Lock / Shield */
@keyframes pulse-intense {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.1); opacity: 0.8; box-shadow: 0 0 30px rgba(197, 168, 97, 0.8); }
}
.animate-pulse-intense {
    animation: pulse-intense 2s ease-in-out infinite;
}
\nhtml:not(.dark) .bg-syc-dark\\/40 { background-color: rgba(255, 255, 255, 0.4) !important; border-color: rgba(0,0,0,0.05) !important; }\nhtml:not(.dark) .bg-syc-dark\\/50 { background-color: rgba(255, 255, 255, 0.5) !important; border-color: rgba(0,0,0,0.05) !important; }\nhtml:not(.dark) .bg-syc-dark\\/60 { background-color: rgba(255, 255, 255, 0.6) !important; border-color: rgba(0,0,0,0.05) !important; }