/* GLOBAL RESET & BASICS */
:root {
    --neon: #00FFA3;
    --void: #050505;
}

html.lenis {
    height: auto;
}
.lenis.lenis-smooth {
    scroll-behavior: auto;
}
.lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain;
}
.lenis.lenis-stopped {
    overflow: hidden;
}

/* Pasy animacji (Digital Shutters) */
.transition-bar {
    height: 100%;
    flex: 1;
    background-color: #050505;
    transform: translateY(0%); /* Zawsze startują jako zasłonięte, skrypt to obsłuży */
    border-right: 1px solid rgba(255, 255, 255, 0.05);
    position: relative;
}
.transition-bar::after {
    content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 4px;
    background-color: var(--neon); box-shadow: 0 0 15px var(--neon);
}
.transition-bar::before {
    content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px;
    background-color: var(--neon); box-shadow: 0 0 15px var(--neon); z-index: 10;
}

/* CUSTOM SCROLLBAR */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--void); }
::-webkit-scrollbar-thumb { background: #222; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--neon); }

/* CURSOR STYLES (Podbity Z-Index, zeby byl nawet nad preloaderem) */
.cursor-dot, .cursor-outline {
    position: fixed; top: 0; left: 0; transform: translate(-50%, -50%);
    border-radius: 50%; z-index: 9999999; pointer-events: none;
}
.cursor-dot { width: 8px; height: 8px; background-color: var(--neon); }
.cursor-outline {
    width: 40px; height: 40px; border: 1px solid rgba(255, 255, 255, 0.5);
    transition: width 0.2s, height 0.2s, background-color 0.2s;
}
body.hovering .cursor-outline {
    width: 60px; height: 60px; background-color: rgba(0, 255, 163, 0.1); border-color: var(--neon);
}

/* NOISE FILTER */
.noise-overlay {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='1'/%3E%3C/svg%3E");
}

/* GLITCH EFFECT */
.glitch-wrapper { position: relative; }
.glitch-wrapper::before, .glitch-wrapper::after {
    content: attr(data-text); position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--void);
}
.glitch-wrapper::before {
    left: 2px; text-shadow: -1px 0 #ff00c1; clip: rect(44px, 450px, 56px, 0);
    animation: glitch-anim 5s infinite linear alternate-reverse;
}
.glitch-wrapper::after {
    left: -2px; text-shadow: -1px 0 #00fff9; clip: rect(44px, 450px, 56px, 0);
    animation: glitch-anim2 5s infinite linear alternate-reverse;
}

@keyframes glitch-anim {
    0% { clip: rect(12px, 9999px, 5px, 0); } 5% { clip: rect(65px, 9999px, 80px, 0); }
    10% { clip: rect(10px, 9999px, 90px, 0); } 100% { clip: rect(20px, 9999px, 10px, 0); }
}
@keyframes glitch-anim2 {
    0% { clip: rect(80px, 9999px, 10px, 0); } 5% { clip: rect(20px, 9999px, 60px, 0); }
    10% { clip: rect(10px, 9999px, 20px, 0); } 100% { clip: rect(50px, 9999px, 90px, 0); }
}

.stroke-text { -webkit-text-stroke: 1px rgba(255, 255, 255, 0.2); }
.reveal-text { opacity: 0; transform: translateY(20px); }

/* --- NOWE STYLE (TOASTY PHP, BRUTALIZM, GLASS) --- */

.toast-msg {
    padding: 16px 24px; border-radius: 4px; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: bold;
    color: #fff; box-shadow: 0 10px 30px rgba(0,0,0,0.5); display: flex; align-items: center; gap: 12px;
    animation: slideInUp 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.toast-msg.success { background-color: var(--neon); color: #000; border: 1px solid #00ffaa; }
.toast-msg.error { background-color: #ff3366; border: 1px solid #ff0044; }
.toast-msg.fade-out { animation: fadeOutDown 0.4s ease forwards; }

@keyframes slideInUp { from { opacity: 0; transform: translateY(50px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeOutDown { from { opacity: 1; transform: translateY(0); } to { opacity: 0; transform: translateY(20px); } }

.brutal-shadow { box-shadow: 6px 6px 0px rgba(0,0,0,1); }