/* ========================================= */
/* 1. ГЛОБАЛЬНІ НАЛАШТУВАННЯ ТА ЗМІННІ */
/* ========================================= */
:root {
    --primary: #ff4500; /* Неоновий оранжевий */
    --primary-glow: rgba(255, 69, 0, 0.6);
    --secondary: #00d4ff; /* Неоновий блакитний */
    --bg-dark: #050505;
    --bg-panel: rgba(20, 20, 20, 0.8);
    --text-main: #ffffff;
    --text-muted: #aaaaaa;
    --border: 1px solid rgba(255, 69, 0, 0.3);
    --glass: blur(12px);
    --font-head: 'Orbitron', sans-serif;
    --font-body: 'Rajdhani', sans-serif;
    --discord-color: #5865F2;
    --google-color: #4285F4;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: var(--font-body);
    background-color: var(--bg-dark);
    color: var(--text-main);
    line-height: 1.6;
    overflow-x: hidden; /* Забороняє горизонтальний скрол сторінки */

    /* === КІБЕРПАНК ФОН === */
    background-image: 
        linear-gradient(rgba(255, 69, 0, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 69, 0, 0.05) 1px, transparent 1px),
        radial-gradient(circle at 90% 90%, rgba(255, 69, 0, 0.15) 0%, transparent 60%),
        radial-gradient(circle at center, transparent 20%, #000000 100%);
    background-size: 40px 40px, 40px 40px, 100% 100%, 100% 100%;
    background-position: center;
    background-attachment: fixed; 
}

/* ========================================= */
/* 2. ТИПОГРАФІКА */
/* ========================================= */
h1, h2, h3, h4 { font-family: var(--font-head); text-transform: uppercase; letter-spacing: 2px; }
a { text-decoration: none; color: inherit; transition: 0.3s; }

/* ========================================= */
/* 3. НАВІГАЦІЯ (ВИПРАВЛЕНО) */
/* ========================================= */
nav {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: var(--glass);
    border-bottom: 1px solid var(--primary);
    padding: 15px 0;
    width: 100%;
}

.nav-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    width: 100%;
    padding: 0 20px;
}

nav ul {
    display: flex;
    list-style: none;
    gap: 20px; /* Зменшили відступ, щоб влізло більше */
    align-items: center;
    flex-wrap: wrap; /* ВАЖЛИВО: Дозволяє перенос кнопок на новий рядок на ПК */
    justify-content: center;
}

nav a {
    font-size: 1rem; /* Трохи компактніший шрифт */
    font-weight: 700;
    color: var(--text-main);
    white-space: nowrap; /* Текст не розривається */
}

nav a:hover, nav a.active {
    color: var(--primary);
    text-shadow: 0 0 10px var(--primary-glow);
}

.btn-register {
    border: 1px solid var(--primary);
    padding: 8px 20px;
    color: var(--primary) !important; /* Примусовий колір тексту */
    background: rgba(0,0,0,0.5); /* Темний фон для контрасту */
    border-radius: 4px;
    transition: 0.3s;
}

.btn-register:hover {
    background: var(--primary);
    color: #fff !important;
    box-shadow: 0 0 15px var(--primary-glow);
}

/* ========================================= */
/* 4. HERO SECTION (ШАПКА) */
/* ========================================= */
.hero {
    text-align: center;
    padding: 80px 20px;
    background: radial-gradient(circle, rgba(0,0,0,0) 0%, rgba(0,0,0,0.8) 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.uni-support {
    font-family: var(--font-head);
    color: var(--primary);
    font-size: 1.2em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 3px;
    margin-bottom: 20px;
    display: block;
    text-shadow: 0 0 10px var(--primary-glow), 0 0 20px var(--primary-glow);
}

.hero h1 {
    font-size: 4rem;
    margin-bottom: 10px;
    text-shadow: 0 0 20px var(--primary-glow);
    animation: glitch 2s infinite;
}

.hero p {
    font-size: 1.5rem;
    color: var(--text-muted);
}

/* ========================================= */
/* 5. ЗАГАЛЬНІ КОНТЕЙНЕРИ */
/* ========================================= */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px;
}

.section {
    background: var(--bg-panel);
    backdrop-filter: var(--glass);
    border: var(--border);
    padding: 40px;
    border-radius: 10px;
    margin-bottom: 40px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.section h2 {
    color: var(--primary);
    border-bottom: 2px solid var(--primary);
    padding-bottom: 15px;
    margin-bottom: 30px;
    display: inline-block;
}

.league-title { font-size: 1.6em; color: #fff; margin-bottom: 5px; border: none; padding: 0; }
.subsection-title { color: var(--primary); margin-top: 30px; font-size: 1.2em; }

hr { border: 0; height: 1px; background: #444; margin: 40px 0; }
.short-hr { width: 50%; margin: 30px auto; background: #3a3a3a; }

/* ========================================= */
/* 6. КОМАНДИ (МАГІЧНІ КАРТКИ) */
/* ========================================= */
.teams-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 25px;
    padding: 20px 0;
}

.magic-card {
    position: relative;
    background: rgba(20, 20, 20, 0.9);
    border-radius: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    overflow: hidden;
    transition: 0.3s;
    z-index: 1;
    backdrop-filter: blur(10px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.5);
}

.magic-card::before {
    content: '';
    position: absolute;
    top: -50%; left: -50%; width: 200%; height: 200%;
    background: conic-gradient(from 0deg, transparent 0deg, var(--primary) 60deg, transparent 120deg, var(--secondary) 180deg, transparent 240deg, #ff0055 300deg, transparent 360deg);
    animation: rotate-border 4s linear infinite;
    z-index: -2;
}

.magic-card::after {
    content: ''; position: absolute; inset: 2px; background: #151515; border-radius: 8px; z-index: -1;
}

.magic-card.empty::before {
    background: conic-gradient(from 0deg, transparent 0deg, #444 60deg, transparent 120deg);
    animation: rotate-border 10s linear infinite;
}

.magic-card:hover { transform: translateY(-5px) scale(1.02); box-shadow: 0 0 20px rgba(255, 69, 0, 0.4); }

.team-info { display: flex; flex-direction: column; }
.team-tag { color: var(--primary); font-weight: 900; font-size: 0.9em; letter-spacing: 1px; }
.team-name { color: #fff; font-size: 1.1em; font-weight: 700; }
.slot-number { font-family: var(--font-head); font-size: 2em; color: rgba(255, 255, 255, 0.05); position: absolute; right: 15px; top: 5px; pointer-events: none; }

.status-badge { font-size: 0.8em; padding: 3px 8px; border-radius: 4px; font-weight: bold; z-index: 2; }
.status-free { background: rgba(0, 255, 136, 0.1); color: #00ff88; border: 1px solid #00ff88; }
.status-busy { background: rgba(255, 69, 0, 0.1); color: var(--primary); border: 1px solid var(--primary); }

@keyframes rotate-border { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

/* ========================================= */
/* 7. ТУРНІРНА СІТКА (ЧИСТИЙ СТИЛЬ / БЕЗ ЛІНІЙ) */
/* ========================================= */
.bracket-scroll {
    overflow-x: auto;
    padding: 40px 0;
    scrollbar-width: thin;
    scrollbar-color: var(--primary) #111;
}

.bracket-container {
    display: flex;
    justify-content: center; /* Центруємо сітку, якщо вона мала */
    padding: 0 20px;
    min-width: max-content; /* Розтягується під контент */
    gap: 30px; /* Акуратний відступ між раундами замість ліній */
}

/* Колонки раундів */
.round {
    display: flex;
    flex-direction: column;
    justify-content: space-around; /* Рівномірний розподіл по висоті */
    width: 260px;
    position: relative;
}

.round-header {
    text-align: center;
    color: var(--primary);
    position: absolute;
    top: -50px;
    width: 100%;
    font-size: 1.2rem;
    font-weight: 700;
    text-shadow: 0 0 10px rgba(255, 69, 0, 0.3);
}

/* Обгортка пари */
.match-pair {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%; 
    margin-bottom: 20px;
}

/* Сама картка матчу */
.match-card {
    background: rgba(20, 20, 20, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-left: 3px solid var(--primary);
    border-radius: 6px;
    padding: 12px;
    position: relative;
    box-shadow: 0 5px 15px rgba(0,0,0,0.5);
    transition: 0.3s;
    margin-bottom: 15px; /* Відступ між матчами */
}

/* Прибираємо margin у останньої картки в групі */
.match-card:last-child {
    margin-bottom: 0;
}

.match-card:hover {
    transform: scale(1.03);
    border-color: var(--primary);
    box-shadow: 0 0 20px rgba(255, 69, 0, 0.2);
    z-index: 2;
}

/* Команди */
.match-card .team {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 0.95rem;
    font-weight: 600;
}
.match-card .team:first-child {
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

.winner span { color: #00ff88; text-shadow: 0 0 5px rgba(0, 255, 136, 0.5); }
.loser span { color: #666; text-decoration: line-through; }
.score { font-family: monospace; color: #fff; }

/* Фінальний матч */
.final-match {
    border-color: gold;
    box-shadow: 0 0 30px rgba(255, 215, 0, 0.1);
}

/* Чемпіон */
.champion-box {
    width: 140px;
    height: 140px;
    margin: 0 auto;
    background: radial-gradient(circle, rgba(255, 215, 0, 0.2) 0%, rgba(0,0,0,0) 70%);
    border: 2px solid gold;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: gold;
    animation: pulse-gold 3s infinite;
}
.champion-box i { font-size: 3em; margin-bottom: 10px; }
.champion-box span { font-size: 1.2em; font-weight: bold; }

@keyframes pulse-gold {
    0% { box-shadow: 0 0 20px rgba(255, 215, 0, 0.2); }
    50% { box-shadow: 0 0 50px rgba(255, 215, 0, 0.5); }
    100% { box-shadow: 0 0 20px rgba(255, 215, 0, 0.2); }
}
/* ========================================= */
/* 8. РЕЄСТРАЦІЯ ТА ІНШІ ЕЛЕМЕНТИ */
/* ========================================= */
.reg-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: start; }
.reg-subtitle { color: var(--primary); margin-bottom: 25px; font-size: 1.4em; border-bottom: 1px solid rgba(255, 69, 0, 0.3); padding-bottom: 10px; }

.step-card {
    display: flex; align-items: center; background: rgba(30, 30, 30, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.05); border-radius: 8px;
    padding: 15px; margin-bottom: 15px; transition: 0.3s;
}
.step-card:hover { background: rgba(40, 40, 40, 0.9); border-color: var(--primary); transform: translateX(10px); }
.step-icon { font-size: 1.8em; color: var(--primary); margin-right: 20px; width: 50px; text-align: center; }
.step-info h4 { margin-bottom: 5px; color: #fff; font-size: 1.1em; }
.step-info p { font-size: 0.9em; color: var(--text-muted); margin: 0; }

.action-box { background: rgba(0, 0, 0, 0.4); border: 1px solid var(--primary); padding: 30px; border-radius: 10px; text-align: center; position: relative; overflow: hidden; }
.action-box::before { content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%; background: radial-gradient(circle, rgba(255, 69, 0, 0.1) 0%, transparent 70%); z-index: -1; }

.btn-google-pulse {
    display: block; width: 100%; padding: 18px; background: linear-gradient(45deg, #FF4500, #FF8C00);
    color: white; font-weight: 900; font-size: 1.2em; text-transform: uppercase; text-decoration: none;
    border-radius: 6px; margin: 20px 0; position: relative; transition: 0.3s;
    box-shadow: 0 0 20px rgba(255, 69, 0, 0.4); animation: pulse-orange 2s infinite;
}
.btn-google-pulse:hover { transform: scale(1.02); box-shadow: 0 0 30px rgba(255, 69, 0, 0.8); }

@keyframes pulse-orange { 0% { box-shadow: 0 0 0 0 rgba(255, 69, 0, 0.7); } 70% { box-shadow: 0 0 0 15px rgba(255, 69, 0, 0); } 100% { box-shadow: 0 0 0 0 rgba(255, 69, 0, 0); } }

.divider { display: flex; align-items: center; text-align: center; color: #666; margin: 20px 0; }
.divider::before, .divider::after { content: ''; flex: 1; border-bottom: 1px solid #444; }
.divider span { padding: 0 10px; font-size: 0.9em; font-weight: bold; }

.btn-discord-block { display: block; width: 100%; padding: 15px; background: #5865F2; color: white; font-weight: 700; text-decoration: none; border-radius: 6px; transition: 0.3s; border: 1px solid rgba(255,255,255,0.1); }
.btn-discord-block:hover { background: #4752c4; box-shadow: 0 0 15px rgba(88, 101, 242, 0.5); }

.btn-discord { display: block; width: 100%; padding: 15px; background: var(--discord-color); color: white; border: none; font-weight: bold; text-align: center; margin-top: 20px; text-decoration: none; border-radius: 4px;}
.btn-discord:hover { background: #7289DA; }

.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; }
.stats-grid div { background: #333; padding: 20px; border-radius: 5px; border-left: 3px solid var(--primary); }
.stats-grid span { font-weight: bold; color: #fff; display: block; margin-bottom: 5px; }

.why-join-list li { background: #333; margin-bottom: 10px; padding: 10px; border-left: 3px solid #009688; }
.stream-link { color: #4CAF50; }
.stream-placeholder { color: #ccc; font-style: italic; }
.cta-action { font-size: 1.4em; text-align: center; color: var(--primary); font-weight: bold; margin-top: 15px; }

.leaderboard-table { width: 100%; border-collapse: collapse; margin-top: 20px; }
.leaderboard-table th, .leaderboard-table td { padding: 15px; border-bottom: 1px solid rgba(255,255,255,0.1); text-align: left;}
.leaderboard-table th { color: var(--primary); }
.rank-1 { border-left: 4px solid gold; background: rgba(255, 215, 0, 0.1); }
.table-note { margin-top: 20px; font-size: 0.95em; color: #aaa; text-align: center; }

.warning-note { text-align: center; color: #ffaa00; margin-top: 10px; font-size: 0.9em; }

.btn-submit { display: block; width: 100%; padding: 15px; background: #0088cc; color: white; border: none; font-weight: bold; text-align: center; margin-top: 10px; cursor: pointer; border-radius: 4px; text-decoration: none;}
.btn-submit:hover { background: #00afff; }

/* ========================================= */
/* 9. ФУТЕР І АНІМАЦІЇ */
/* ========================================= */
footer { text-align: center; padding: 20px 0; color: #888; font-size: 0.9em; border-top: 1px solid #333; margin-top: 50px;}

@keyframes glitch { 0% { transform: skew(0deg); } 20% { transform: skew(-2deg); } 40% { transform: skew(2deg); } 60% { transform: skew(-1deg); } 80% { transform: skew(3deg); } 100% { transform: skew(0deg); } }

/* ========================================= */
/* 10. МОБІЛЬНА АДАПТАЦІЯ (ТЕЛЕФОНИ + ПЛАНШЕТИ < 900px) */
/* ========================================= */
@media (max-width: 900px) {
    
    /* 1. Фіксуємо сторінку від "хитання" */
    html, body {
        overflow-x: hidden;
        width: 100%;
        position: relative;
    }

    /* 2. Зменшуємо шапку, щоб не займала багато місця */
    .hero { padding: 30px 15px; }
    .hero h1 { font-size: 1.8em; line-height: 1.2; margin-bottom: 5px; }
    .uni-support { font-size: 0.7em; letter-spacing: 1px; margin-bottom: 10px; }
    .hero p { font-size: 0.9em; }

    /* 3. КОМПАКТНЕ МЕНЮ (ВСЕ ВИДНО ВІДРАЗУ) */
    nav {
        padding: 10px 0;
        width: 100%;
        height: auto;
    }

    .nav-container {
        width: 100%;
        padding: 0 10px;
    }

    nav ul {
        display: flex;
        flex-wrap: wrap; /* Дозволяємо перенос на новий рядок */
        justify-content: center; /* Центруємо кнопки */
        gap: 8px; /* Маленькі відступи між кнопками */
        padding: 0;
    }

    nav li {
        flex: 0 1 auto; /* Кнопки займають стільки місця, скільки треба */
    }

    /* Стиль кнопок меню на телефоні */
    nav a {
        font-size: 0.75rem; /* Компактний шрифт */
        padding: 6px 12px;
        display: block;
        background: rgba(255, 255, 255, 0.05); /* Легкий фон */
        border-radius: 4px;
        border: 1px solid rgba(255, 255, 255, 0.1);
        text-transform: uppercase;
    }

    /* Активна кнопка або ховер */
    nav a:hover, nav a.active {
        background: var(--primary);
        color: white;
        border-color: var(--primary);
    }

    .btn-register { 
        margin: 0; 
        font-size: 0.75rem; 
        padding: 6px 12px;
        background: rgba(255, 69, 0, 0.2); /* Виділяємо реєстрацію */
        border-color: var(--primary);
    }

    /* 4. Адаптація контенту */
    .container { padding: 20px 10px; }
    .section { padding: 20px 15px; }
    
    .reg-box, .stats-grid, .teams-grid { grid-template-columns: 1fr; }
    .reg-layout { grid-template-columns: 1fr; gap: 30px; }

    /* Таблиця з прокруткою (щоб не ламала верстку) */
    .leaderboard-table { display: block; overflow-x: auto; white-space: nowrap; }
    
    /* Сітка турніру з прокруткою */
    .bracket-container { min-width: 200vw; }
}


/* ========================================= */
/* СТИЛІ ДЛЯ DOUBLE ELIMINATION */
/* ========================================= */

.bracket-title {
    text-align: center;
    border-bottom: 2px solid var(--primary);
    display: inline-block;
    padding-bottom: 10px;
    margin-bottom: 20px;
    font-size: 1.8rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    /* Центрування блоку заголовка */
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
}

/* Відступи між сітками */
#lowerBracketRoot {
    margin-bottom: 50px;
}

/* Корекція для великої кількості раундів */
.bracket-container {
    gap: 40px; /* Більший відступ між колонками для читабельності */
}

.match-pair {
    margin-bottom: 15px; /* Компактніші матчі */
}

/* Різні кольори для Upper/Lower */
#lowerBracketRoot .match-card {
    border-left-color: #00d4ff; /* Блакитний для нижньої сітки */
}

#lowerBracketRoot .round-header {
    color: #00d4ff;
}

#finalRoot .match-card {
    border-left-color: gold;
    border-right: 3px solid gold; /* Золота рамка для фіналу */
    width: 300px;
}

/* Адаптація для Гранд Фіналу */
#finalRoot {
    align-items: center;
    min-width: auto; /* Не розтягувати */
}

/* ========================================= */
/* 15. БОКС С ДАТОЙ (НОВОЕ) */
/* ========================================= */
.date-box {
    margin-top: 30px;
    background: rgba(0, 0, 0, 0.6); /* Полупрозрачный фон */
    border: 2px solid var(--primary);
    padding: 15px 40px;
    display: inline-block;
    border-radius: 8px;
    position: relative;
    box-shadow: 0 0 20px rgba(255, 69, 0, 0.3); /* Свечение */
    animation: pulse-date 2s infinite; /* Анимация пульсации */
}

.date-label {
    font-size: 0.9em;
    color: #ccc;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 5px;
    font-family: var(--font-body);
}

.date-value {
    font-family: var(--font-head);
    font-size: 2.2em;
    color: #fff;
    font-weight: 700;
    text-shadow: 0 0 10px var(--primary);
}

.date-icon {
    margin-right: 10px;
    color: var(--primary);
}

/* Анимация пульсации рамки */
@keyframes pulse-date {
    0% { box-shadow: 0 0 10px rgba(255, 69, 0, 0.2); border-color: rgba(255, 69, 0, 0.7); }
    50% { box-shadow: 0 0 30px rgba(255, 69, 0, 0.6); border-color: var(--primary); }
    100% { box-shadow: 0 0 10px rgba(255, 69, 0, 0.2); border-color: rgba(255, 69, 0, 0.7); }
}

/* Адаптация для мобильных */
@media (max-width: 600px) {
    .date-value { font-size: 1.8em; }
    .date-box { padding: 10px 20px; width: 90%; }
}
