/* --- 1. UNIVERZÁLNÍ RESET (Důležité!) --- */
/* Toto vymaže všechny skryté okraje, které dělají neplechu */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* --- 2. TĚLO STRÁNKY (GRID CENTROVÁNÍ) --- */
body {
    /* Magické centrování pomocí Gridu */
    display: grid;
    place-items: center;
    
    min-height: 100vh; /* Výška přes celou obrazovku */
    width: 100%;
    overflow: hidden; /* Žádné posuvníky */
    position: relative; /* Nutné pro tlačítko zpět */

    /* Pozadí - puntíky */
    background-color: #ffe6e6;
    background-image: radial-gradient(#ffb3b3 15%, transparent 16%), radial-gradient(#ffb3b3 15%, transparent 16%);
    background-size: 30px 30px;
    background-position: 0 0, 15px 15px;
    
    font-family: 'Comic Sans MS', 'Arial', sans-serif;
}


/* --- 4. HERNÍ OBAL (RÁMEC) --- */
.game-wrapper {
    /* Protože používáme Grid na body, tady už NEMUSÍ být margin: auto */
    text-align: center;
    width: 95%; /* Na mobilu zabere skoro vše */
    max-width: 900px; /* Na PC se zastaví na této šířce */
    
    padding: 10px;
    background: rgba(255, 255, 255, 0.8); 
    border-radius: 30px;
    box-shadow: 0 0 50px rgba(0,0,0,0.1);
    
    /* Posun nahoru (tvých 1.5 cm) */
    transform: translateY(0px); 
}

h1 {
    color: #d63384;
    margin-bottom: 10px;
    font-size: 2.5rem;
    text-shadow: 2px 2px 0px #fff;
}

/* --- 5. HERNÍ PLOCHA (NEBE) --- */
#game-area {
    position: relative;
    width: 100%;
    height: 600px; 
    background: linear-gradient(to bottom, #87CEEB, #c9ebf7);
    border: 6px solid #fff;
    border-radius: 25px;
    box-shadow: inset 0 0 20px rgba(0,0,0,0.1);
    overflow: hidden; 
    cursor: none; /* Skryje myš při hře */
    touch-action: none; 
}

/* SKÓRE */
#score-board {
    position: absolute;
    top: 20px;
    left: 20px;
    font-size: 1.5rem;
    font-weight: bold;
    color: #fff;
    background: rgba(214, 51, 132, 0.7);
    padding: 10px 20px;
    border-radius: 30px;
    z-index: 5;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

/* --- POSTAVY --- */
#player-container {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 200px; 
    height: auto;
    pointer-events: none;
    transition: transform 0.1s ease-out;
    z-index: 2;
}

#player-img {
    width: 100%;
    display: block;
    filter: drop-shadow(0px 5px 10px rgba(0,0,0,0.4));
}

.heart {
    position: absolute;
    top: -40px;
    font-size: 45px;
    user-select: none;
    z-index: 1; 
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}

/* --- VÝHRA --- */
#win-screen {
    display: none; 
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.95);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 10;
    animation: fadeIn 0.5s ease;
    cursor: default; /* Zobrazí myš po výhře */
}

#win-screen h2 {
    color: #ff0000;
    font-size: 3.5rem; 
    margin: 0;
}

#win-screen p {
    font-size: 1.5rem;
    color: #555;
    margin-bottom: 30px;
}

.buttons-row {
    display: flex;
    gap: 20px;
}

#win-screen button, .menu-btn {
    padding: 15px 30px;
    background: #ff0000;
    color: white;
    border: none;
    border-radius: 50px;
    font-size: 1.2rem;
    font-weight: bold;
    cursor: pointer;
    text-decoration: none;
    box-shadow: 0 10px 20px rgba(255, 0, 0, 0.3);
    transition: transform 0.2s;
}

.menu-btn {
    background: #ff66b2; 
    box-shadow: 0 10px 20px rgba(214, 51, 132, 0.3);
}

#win-screen button:hover, .menu-btn:hover {
    transform: scale(1.1);
}

.controls-hint {
    margin-top: 15px;
    font-size: 1rem;
    color: #555;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* --- MOBILNÍ VERZE: FULL SCREEN --- */
@media (max-width: 768px) {
    /* 1. Resetujeme nastavení stránky, aby hra mohla být přes všechno */
    body {
        place-items: start; /* Zarovnání odshora, ne na střed */
        background: #87CEEB; /* Aby při načítání neproblikla růžová */
    }

    /* 2. Obal hry se roztáhne na celý displej */
    .game-wrapper {
        position: fixed; /* Přilepíme to k oknu */
        top: 0;
        left: 0;
        width: 100vw;  /* 100% šířky okna */
        height: 100vh; /* 100% výšky okna */
        
        /* Odstraníme všechny mezery a rámečky */
        margin: 0;
        padding: 0;
        border-radius: 0;
        background: none;
        box-shadow: none;
        transform: none;
        z-index: 50; /* Musí to být nad vším ostatním */
    }

    /* 3. Samotná herní plocha */
    #game-area {
        width: 100%;
        height: 100%; /* Vyplní celý obal */
        border: none; /* Zrušíme bílý rámeček */
        border-radius: 0;
        background: linear-gradient(to bottom, #87CEEB, #c9ebf7); /* Nebe */
    }

    /* 4. Úpravy prvků, aby nezavazely ve hře */
    h1 {
        position: absolute;
        top: 50px; /* Pod skóre */
        width: 100%;
        font-size: 1.5rem; /* Menší nadpis */
        opacity: 0.5;      /* Průhledný, aby bylo vidět padající srdce */
        pointer-events: none; /* Aby šlo klikat "skrz" nadpis */
        z-index: 1;
    }

    .controls-hint {
        display: none; /* Nápovědu skryjeme, zabírá místo */
    }

    /* 5. Úprava medvěda pro mobil */
    #player-container {
        width: 130px; /* Ideální velikost pro palec */
        bottom: 10px; /* Těsně u spodního okraje */
    }

    /* 6. Skóre tabulka */
    #score-board {
        top: 15px;
        left: 15px;
        font-size: 1.1rem;
        padding: 5px 15px;
        z-index: 20;
    }

    /* 7. Tlačítko zpět - musí být vidět */
    .menu-btn {
        position: fixed; /* Aby zůstalo na místě */
        top: 15px;
        right: 15px; /* Dáme ho doprava, aby nezavazelo skóre */
        left: auto;  /* Zrušíme levé zarovnání */
        padding: 8px 15px;
        font-size: 0.9rem;
        z-index: 100; /* Úplně nahoře */
    }
}