
:root {
    --neon-color: #bc13fe; 
    --neon-glow: rgba(188, 19, 254, 0.4);
    /* Zmeníme bg-dark na veľmi tmavú fialovo-sivú, aby nebola "mŕtva" čierna */
    --bg-dark: #0a0a0c; 
    --bg-light: #1a1a1f; /* Trochu svetlejší stred pre hĺbku */
}

body {
    background-color: var(--bg-dark);
    color: #ffffff;
    font-family: 'Times New Roman', serif;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 100vh;
    padding: 40px 20px;
    box-sizing: border-box;
    /* Gradient, ktorý pôsobí prirodzenejšie a menej kontrastne */
    background-image: radial-gradient(circle at center, var(--bg-light) 0%, var(--bg-dark) 100%);
}

body::before {
    content: '⚜';
    position: fixed;
    top: 50%; 
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 50vw;
    /* Zvýšená viditeľnosť na 8% (0.08) */
    color: rgba(188, 19, 254, 0.08); 
    z-index: 0;
    pointer-events: none;
}


.neon-style {
    /* Kľúčové pre mobily: vypne natívny vzhľad iOS/Androidu */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    
    /* Farby a pozadie */
    background: rgba(20, 20, 25, 0.9); 
    color: var(--neon-color); 
    box-shadow: 0 0 10px var(--neon-glow);
    border: 1px solid var(--neon-color);
    padding: 8px 15px; 
    font-size: 16px; /* Minimálne 16px, aby iOS automaticky nepribližoval obrazovku */
    outline: none;
    cursor: pointer;
}



  /* Sekcia pre externé odkazy */
        .links-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 15px;
            width: 100%;
            margin-top: 30px;
        }

        .url-tile {
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 15px;
            border: 1px solid var(--neon-color);
            background: rgba(188, 19, 254, 0.05);
            color: #ffffff;
            text-decoration: none;
            font-size: 0.8rem;
            text-transform: uppercase;
            letter-spacing: 2px;
            transition: 0.3s;
            text-align: center;
            font-weight: bold;
        }

        .url-tile:hover {
            background: var(--neon-color);
            color: #000;
            box-shadow: 0 0 20px var(--neon-glow);
            transform: translateY(-3px);
        }

        .motto-container {
            margin-top: 10px;
            display: flex;
            flex-direction: column;
            gap: 5px;
        }

        .motto-secondary {
            font-size: 0.85rem;
            color: var(--neon-color);
            text-transform: uppercase;
            letter-spacing: 5px;
            font-weight: bold;
            text-shadow: 0 0 10px var(--neon-glow);
        }

        .links-header {
            width: 100%;
            margin-top: 50px;
            margin-bottom: 15px;
            font-size: 0.7rem;
            text-transform: uppercase;
            letter-spacing: 4px;
            color: rgba(255, 255, 255, 0.4);
            border-bottom: 1px solid rgba(188, 19, 254, 0.2);
            padding-bottom: 5px;
        }

        /* Navigácia */
        .lang-switcher { position: absolute; top: 30px; right: 40px; display: flex; gap: 20px; z-index: 30;}
        .lang-link { text-decoration: none; color: rgba(255, 255, 255, 0.3); font-size: 0.9rem; font-weight: bold; }
        .lang-link:hover, .lang-link.active { color: var(--neon-color); text-shadow: 0 0 10px var(--neon-color); }
        .back-nav { position: absolute; top: 30px; left: 40px; z-index: 30; }

        .back-link { text-decoration: none; color: var(--neon-color); font-size: 0.8rem; border: 1px solid var(--neon-color); padding: 8px 15px; box-shadow: 0 0 10px var(--neon-glow); }

        .header-section { text-align: center; z-index: 10; margin-bottom: 40px; }
        .logo-erb { max-width: 100px; filter: drop-shadow(0 0 15px var(--neon-glow)); margin-bottom: 15px; }
        h1 { font-size: clamp(1.6rem, 5vw, 2.5rem); text-transform: uppercase; letter-spacing: 6px; text-shadow: 0 0 20px var(--neon-color); margin: 0; }
        .section-title { color: var(--neon-color); text-transform: uppercase; letter-spacing: 4px; font-size: 1.2rem; margin-top: 10px; display: block; font-weight: bold; }

/* Mriežka s info dlaždicami */
.info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 15px;
    width: 100%;
    max-width: 1100px;
    margin-bottom: 40px;
    z-index: 10;
}

.info-tile {
    /* Mierne tmavšie a menej priehľadné pozadie pre lepšiu stabilitu textu */
    background: rgba(20, 20, 25, 0.9); 
    /* Zjemnený okraj, ktorý nepúta príliš pozornosti */
    border: 1px solid rgba(188, 19, 254, 0.2);
    padding: 20px 15px;
    text-align: center;
    border-radius: 4px; /* Zjednotené so zvyškom dizajnu */
    backdrop-filter: blur(8px); /* Silnejší blur lepšie "odfiltruje" rušivé pozadie */
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.info-label { 
    display: block; 
    font-size: 0.75rem; /* Mierne zväčšené pre lepšiu čitateľnosť */
    text-transform: uppercase; 
    /* Svetlejšia fialová namiesto čistej neónovej pre ostrosť */
    color: #d170ff; 
    letter-spacing: 1.5px; 
    margin-bottom: 8px; 
    font-weight: 600; 
}

.info-value { 
    display: block; 
    font-size: 1rem; /* Mierne zväčšené pre pohodlie očí */
    color: #ffffff; 
    font-weight: 500; /* Medium váha pôsobí v Times New Roman čistejšie ako čistý Bold */
    text-shadow: 0 0 5px rgba(255, 255, 255, 0.1); /* Veľmi jemná žiara pre prémiový vzhľad */
}

/* Jemný efekt pri prejdení myšou, ktorý vráti trochu "života" */
.info-tile:hover {
    border-color: rgba(188, 19, 254, 0.5);
    transform: translateY(-2px);
}

        .audio-tile { cursor: pointer !important; border-color: var(--neon-color); transition: 0.3s; position: relative; }
        .audio-tile:hover { box-shadow: 0 0 20px var(--neon-glow); transform: scale(1.02); }

/* TEXTOVÝ KONTAJNER */
.content-container {
    max-width: 850px;
    /* Mierne svetlejšie pozadie ako čistá čierna pre lepší kontrast s bielym písmom */
    background: rgba(15, 15, 18, 0.95); 
    /* Veľmi decentný okraj, ktorý nepôsobí ako ostrá čiara */
    border: 1px solid rgba(188, 19, 254, 0.15); 
    padding: 60px 50px;
    position: relative;
    z-index: 10;
    /* Vonkajší tieň je teraz hlbší a menej rozptýlený, aby kontajner nepôsobil rozmazane */
    box-shadow: 0 10px 50px rgba(0, 0, 0, 0.9);
    border-radius: 4px; /* Jemné zaoblenie (4px namiesto 2px) pôsobí prirodzenejšie */
    margin-bottom: 20px;
    
    /* Bonus: Jemná žiara na okraji, ktorá neunavuje oči */
    outline: 1px solid rgba(188, 19, 254, 0.05);
    outline-offset: -4px;
}

        .content-container::before { content: '⚜'; position: absolute; top: 20px; left: 20px; font-size: 2.5rem; color: var(--neon-color); }
        .content-container::after { content: '⚜'; position: absolute; bottom: 20px; right: 20px; font-size: 2.5rem; color: var(--neon-color); }

        /* História Dlaždice */
/* História Dlaždice */
.history-tile { 
    width: 100%; 
    margin-bottom: 15px; 
    /* Zjemnený okraj - menej neónu, viac elegancie */
    border: 1px solid rgba(188, 19, 254, 0.2); 
    background: rgba(30, 30, 35, 0.6); 
    overflow: hidden; 
}

.tile-header { 
    padding: 20px; 
    cursor: pointer; 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    background: rgba(188, 19, 254, 0.08); 
    font-weight: 600; 
    letter-spacing: 1.5px; 
    text-transform: uppercase; 
    /* Písmo v hlavičke je svetlejšie pre lepšiu čitateľnosť */
    color: #e0b0ff; 
    text-shadow: 0 0 8px rgba(188, 19, 254, 0.3);
}

.tile-content { 
    max-height: 0; 
    padding: 0 20px; 
    transition: max-height 0.5s ease-in-out, padding 0.5s ease-in-out; 
    background: rgba(10, 10, 12, 0.4); 
    font-size: 1rem; 
    line-height: 1.7; 
    /* Čisto biela/svetlosivá pre maximálnu ostrosť bez tieňov */
    color: #efefef; 
    text-align: justify;
    overflow: hidden; 
}

/* Keď je dlaždica otvorená (predpokladám triedu .active alebo otvorený stav cez JS) */
.history-tile.open .tile-content {
    padding: 20px; /* Vráti padding pri otvorení */
}

.history-tile.active .tile-content { 
    max-height: 3300px; /* Dostatočná rezerva pre dlhý text a obrázok */
    padding: 20px; /* Vertikálny padding sa vráti až pri otvorení */
    border-top: 1px solid rgba(188, 19, 254, 0.2); 
}
        .tile-icon { transition: transform 0.3s; }
        .history-tile.active .tile-icon { transform: rotate(180deg); }

.highlight {
    color: #b8860b; /* Elegantná tmavozlatá farba ladiaca s heraldikou */
    font-weight: 700;
    text-shadow: 1px 1px 0px rgba(0,0,0,0.05); /* Jemný tieň pre hĺbku */
    border-bottom: 1px solid rgba(184, 134, 11, 0.3); /* Decentné podčiarknutie */
    padding: 0 2px;
}


        /*.highlight { color: var(--neon-color); font-weight: bold; text-shadow: 0 0 8px var(--neon-glow); }*/

        /* Externé Odkazy */
        .links-header { width: 100%; margin-top: 40px; margin-bottom: 15px; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 3px; color: var(--neon-color); text-align: center; }
        .links-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 15px; width: 100%; }
        .url-tile { padding: 15px; border: 1px solid var(--neon-color); background: rgba(188, 19, 254, 0.05); color: #fff; text-decoration: none; text-align: center; font-size: 0.8rem; text-transform: uppercase; font-weight: bold; transition: 0.3s; }
        .url-tile:hover { background: var(--neon-color); color: #000; box-shadow: 0 0 15px var(--neon-glow); }

/* KONTAKTNÁ KARTA */
.modern-contact-card { 
    margin-top: 50px; 
    padding: 40px; /* Viac priestoru pre "dýchanie" textu */
    /* Zjemnený okraj namiesto plnej neónovej */
    border: 1px solid rgba(188, 19, 254, 0.2); 
    background: rgba(15, 15, 18, 0.95); 
    text-align: center; 
    border-radius: 4px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
}

.modern-contact-card h3 { 
    /* Svetlejšia fialová pre lepšiu ostrosť */
    color: #d170ff; 
    letter-spacing: 3px; 
    text-transform: uppercase; 
    margin-bottom: 25px; 
    font-weight: 600;
    text-shadow: 0 0 10px rgba(188, 19, 254, 0.3);
}

.input-group { 
    margin-bottom: 20px; 
    text-align: left; 
}

.input-group label { 
    display: block; 
    /* Jemnejšia fialová, aby "nekričala" pri každom políčku */
    color: #c4a1ff; 
    margin-bottom: 8px; 
    font-weight: 500; 
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.input-field { 
    width: 100%; 
    padding: 12px 15px; 
    /* Mierne svetlejšie pozadie inputu pre lepší kontrast s textom */
    background: #1a1a1f; 
    border: 1px solid rgba(188, 19, 254, 0.25); 
    color: #ffffff; 
    font-family: 'Times New Roman', serif; 
    font-size: 1rem;
    box-sizing: border-box; 
    border-radius: 2px;
    transition: all 0.3s ease;
}

/* Efekt pri kliknutí do políčka - pre lepšiu orientáciu oka */
.input-field:focus {
    outline: none;
    border-color: rgba(188, 19, 254, 0.8);
    background: #202025;
    box-shadow: 0 0 8px rgba(188, 19, 254, 0.2);
}

        .btn-submit { width: 100%; padding: 15px; background: transparent; border: 1px solid var(--neon-color); color: var(--neon-color); text-transform: uppercase; letter-spacing: 2px; font-weight: bold; cursor: pointer; transition: 0.3s; }
        .btn-submit:hover { background: var(--neon-color); color: #000; box-shadow: 0 0 15px var(--neon-glow); }

        /* MODÁLY */
        .modal { display: none; position: fixed; z-index: 100; left: 0; top: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.9); }
        .modal-content { background: #000; margin: 15% auto; padding: 20px; border: 1px solid var(--neon-color); width: 80%; max-width: 450px; text-align: center; box-shadow: 0 0 30px var(--neon-glow); }
        .close { float: right; color: var(--neon-color); font-size: 24px; font-weight: bold; cursor: pointer; }
        #some_text1 { font-size: 3rem; color: var(--neon-color); margin: 20px 0; }
        #btn_random { background: #000; border: 1px solid var(--neon-color); color: #fff; padding: 10px; font-size: 1.5rem; width: 100px; text-align: center; }
        #btn_odoslat1 { margin-top: 15px; padding: 10px 20px; background: var(--neon-color); color: #000; border: none; font-weight: bold; cursor: pointer; }

        footer { margin-top: auto; padding: 40px 0; font-size: 0.75rem; letter-spacing: 2px; color: rgba(255, 255, 255, 0.3); text-align: center; }

        @media (max-width: 768px) { .info-grid { grid-template-columns: 1fr 1fr; } .content-container { padding: 30px; } }

        .historic-image { margin-top: 35px; max-width: 200px; border: 1px solid var(--neon-color); box-shadow: 0 0 15px var(--neon-glow); border-radius: 2px; }
        .image-caption { margin-top: 10px; font-size: 0.8rem; font-style: italic; color: rgba(255, 255, 255, 0.4); }


  .tree-container {
        position: relative;
        width: 100%;
        max-width: 900px;
        margin: 0 auto;
        display: flex;
        flex-direction: column;
        gap: 60px; /* Priestor pre šípky na desktope */
    }

    .row {
        display: flex;
        justify-content: center;
        gap: 40px;
        z-index: 2;
    }

    /* MOBILNÁ ÚPRAVA - Dlaždice pod seba */
    @media (max-width: 600px) {
        .row {
            flex-direction: column;
            align-items: center;
            gap: 50px; /* Väčšia medzera pre zvislé šípky */
        }
        .tree-container { gap: 50px; }
        .tile { width: 85% !important; min-width: unset !important; }
    }

    .tile {
            width: 300px;
            height: 150px;
            border: 2px solid var(--neon-color);
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            text-decoration: none;
            color: white;
            transition: 0.4s ease;
            background: #000;
            border-radius: 2px;
            box-shadow: 0 0 15px var(--neon-glow), inset 0 0 10px var(--neon-glow);
            position: relative;
            text-align: center;
            padding: 10px;
        }

        .tile::after {
            content: '⚜';
            position: absolute;
            bottom: 8px;
            right: 12px;
            font-size: 1.2rem;
            color: var(--neon-color);
        }

        .tile:hover {
            transform: scale(1.03);
            box-shadow: 0 0 35px var(--neon-color), inset 0 0 15px var(--neon-color);
        }

        .tile .title {
            font-size: 1.4rem;
            font-weight: bold;
            letter-spacing: 2px;
            z-index: 2;
        }

        .tile .subtitle {
            font-size: 0.75rem;
            text-transform: uppercase;
            color: var(--neon-color);
            margin-top: 8px;
            letter-spacing: 2px;
            z-index: 2;
        }

        #svg-canvas {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            pointer-events: none;
            z-index: 5;
        }

        .arrow-line {
            stroke: var(--neon-color);
            stroke-width: 2.5;
            fill: none;
            filter: drop-shadow(0 0 8px var(--neon-color));
            opacity: 0.8;
        }

        .arrow-head {
            fill: var(--neon-color);
        }


.tile-active {
            transform: scale(1.03);
            box-shadow: 0 0 35px var(--neon-color), inset 0 0 15px var(--neon-color);
}

