/* --- START OF FILE styles.css --- */

/* =========================================
   1. TEEMA JA VÄRIMUUTTUJAT
   ========================================= */
:root {
    /* --- SIIRRETTY ALKUUN VARMISTUKSEN VUOKSI --- */
    --radius-sm: 6px;
    --radius-md: 12px;
    --radius-lg: 18px;

    /* --- LIGHT MODE (Solid / Clean) --- */
    
    /* Taustaväri */
    --bg-color: #eff5f6;
    
    /* Paneelit ja modaalit: Täysin peittävä valkoinen */
    --panel-bg: #eff5f6;
    --panel-backdrop: none; /* Ei sumennusta tarvita, koska tausta on peittävä */
    
    /* Teksti */
    --text-color: #1a1a1a;
    --text-muted: #5f6368;
    
    /* Reunat */
    --border-color: #dadce0;
    
    /* Input-kentät */
    --input-bg: #ffffff;
    
    /* Hover-tilat */
    --hover-bg: #f1f3f4;
    --active-bg: #e8eaed;
    
    /* Brändivärit */
    --accent-color: #007bff;
    --accent-hover: #0062cc;
    --accent-text: #ffffff;
    
    /* Statusvärit */
    --success-color: #1e8e3e;
    --success-bg: #e6f4ea;
    --success-text: #137333;
    
    --danger-color: #d93025;
    --danger-bg: #fce8e6;
    --danger-text: #c5221f;

    /* Varjot */
    --shadow-sm: 0 1px 2px 0 rgba(60,64,67,0.3), 0 1px 3px 1px rgba(60,64,67,0.15);
    --shadow-md: 0 4px 8px 3px rgba(60,64,67,0.15);
    --shadow-lg: 0 8px 24px rgba(60,64,67,0.2);

    /* Kartta */
    --map-filter: none;
    --map-bg-color: #e5e3df;
    
    /* Scrollbar */
    --scrollbar-track: #f1f1f1;
    --scrollbar-thumb: #c1c1c1;
}

body.dark-mode {
    /* --- DARK MODE OVERRIDES (Solid Dark Blue) --- */
    
    /* Tumma tausta */
    --bg-color: #151d28;
    
    /* Paneelit ja modaalit: Täysin peittävä tummasininen */
    --panel-bg: #151d28; 
    --panel-backdrop: none;
    
    --text-color: #e0e0e0;
    --text-muted: #94a3b8;
    
    /* Reunat */
    --border-color: #2a3b55;
    
    /* Input-kentät ja painikkeet */
    --input-bg: #222e3f;
    
    /* Hover-tilat */
    --hover-bg: #2d3d52;
    --active-bg: #384c66;
    
    /* Brändi */
    --accent-color: #4dabf7; 
    --accent-hover: #74c0fc;
    --accent-text: #000000;

    /* Status */
    --success-color: #28a745;
    --success-bg: rgba(40, 167, 69, 0.2);
    --success-text: #b2f2bb;
    --danger-color: #dc3545;
    --danger-bg: rgba(220, 53, 69, 0.2);
    --danger-text: #ffc9c9;

    --shadow-sm: 0 2px 4px rgba(0,0,0,0.3);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.6);
    
    /* Kartan himmennys */
    --map-filter: brightness(0.9) contrast(1.1) saturate(1);
    --map-bg-color: #151d28;
    
    --scrollbar-track: #151d28;
    --scrollbar-thumb: #2f3e52;
}

/* =========================================
   2. PERUSASETUKSET (RESET & LAYOUT)
   ========================================= */
html, body {
    height: 100%; margin: 0; padding: 0; overflow: hidden;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    -webkit-tap-highlight-color: transparent;
    background-color: var(--bg-color); color: var(--text-color);
    transition: background-color 0.3s ease, color 0.3s ease;
}

*, *::before, *::after { box-sizing: border-box; }

/* Custom Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent-color); }

/* Kartan tausta */
#map-container { 
    width: 100%; 
    height: 100%; 
    position: relative; 
    background-color: var(--map-bg-color) !important; 
    transition: background-color 0.3s ease;
}

/* MUUTOS: Lisätty touch-action ja user-select estot, jotta tuplaklikkaus-raahaus ei katkea */
#map { 
    width: 100%; 
    height: 100%; 
    cursor: default; 
    position: relative;
    /* MUUTOS: none -> manipulation. Tämä sallii raahauksen, mutta estää selaimen 
       oman tuplaklikkaus-zoomin, jolloin sovelluksen oma zoom toimii. */
    touch-action: manipulation;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
    
}
#map.drawing { cursor: crosshair; }
#map canvas { filter: var(--map-filter); transition: filter 0.5s ease; }

/* =========================================
   3. YLEISET KOMPONENTIT
   ========================================= */

/* --- Piirto-ohje --- */
#draw-instruction-overlay {
    display: none; position: absolute; top: 15px; left: 50%; transform: translateX(-50%);
    z-index: 1011;
    background-color: rgba(0, 0, 0, 0.85) !important; color: white !important;
    padding: 8px 16px; border-radius: 20px; font-size: 0.9em; text-align: center; pointer-events: none;
    box-shadow: var(--shadow-md); transition: opacity 0.3s ease-out, top 0.3s ease-out;
}
#draw-instruction-overlay.visible { display: block; }
#draw-instruction-overlay.pushed-down { top: 75px; }

/* --- GPS Status Overlay (Aika/Nopeus) --- */
#gps-status-overlay {
    position: absolute;
    /* Työpöytä: Nappi on 10px reunasta + 44px korkea. 60px jättää pienen välin. */
    top: 60px; 
    left: 10px;
    background-color: rgba(0, 0, 0, 0.75);
    color: #fff;
    padding: 6px 10px;
    border-radius: 8px;
    font-size: 0.9em;
    font-weight: 500;
    z-index: 1010;
    pointer-events: none; /* Ei estä kartan käyttöä */
    box-shadow: var(--shadow-sm);
    backdrop-filter: blur(4px);
    display: none;
    line-height: 1.3;
    min-width: 100px;
}

#gps-status-overlay strong {
    font-weight: 700;
    color: var(--accent-color);
}

/* Mobiili-override status overlaylle: Nostetaan ylös */
body.mobile-view #gps-status-overlay {
    top: max(10px, env(safe-area-inset-top)); 
    left: 10px;
    font-size: 0.85em;
    padding: 6px 10px;
}

/* --- Icon Toolbars --- */
.icon-toolbar {
    position: absolute; z-index: 1010; display: flex; flex-direction: column; gap: 10px;
    background-color: transparent; padding: 0;
    transition: right 0.3s ease-out, left 0.3s ease-out, opacity 0.3s ease-out, visibility 0.3s ease-out;
}

/* 
   VASEN TYÖKALUPALKKI (Työpöytä)
*/
#left-icon-toolbar { 
    display: none; /* Piilotetaan oletuksena mobiilissa */
    top: 10px; 
    left: 10px; 
}

#right-icon-toolbar { top: 10px; right: 10px; }
.icon-toolbar hr { width: 70%; margin: 8px auto; border: 0; border-top: 1px solid var(--border-color); }

.toolbar-separator {
    width: 60%;
    height: 1px;
    background-color: var(--border-color);
    margin: 8px auto;
    opacity: 0.6;
}

#collapsible-tools-content {
    display: none; 
    flex-direction: column;
    gap: 10px;
    margin-top: 10px;
}

/* --- Painikkeet (Karttatyökalut) - PÄIVITETTY "Button 13" -tyyliseksi --- */
.map-tool-button, .ol-control button {
    /* Perusmuotoilu (Button 13 inspiroima) */
    background-color: #ffffff !important; 
    
    /* Selkeämpi reunaviiva erottumaan kartasta */
    border: 1px solid #d5d9d9 !important; 
    
    /* Pehmeämpi pyöristys */
    border-radius: 8px !important; 
    
    color: var(--text-color) !important; 
    opacity: 1 !important; 
    padding: 0 !important; 
    margin: 0 !important;
    cursor: pointer !important;
    font-size: 1.3em !important; 
    line-height: 1 !important; 
    text-align: center !important;
    
    /* Koko pidetään samana */
    width: 44px !important; 
    height: 44px !important; 
    min-width: 44px !important; 
    min-height: 44px !important;
    
    display: inline-flex !important; 
    align-items: center !important; 
    justify-content: center !important;
    
    /* 3D-efekti varjolla: Hieman tummempi kuin esimerkissä, jotta erottuu karttapohjasta */
    box-shadow: 0 2px 5px 0 rgba(0,0,0,0.2), 0 1px 2px 0 rgba(0,0,0,0.1) !important;
    
    transition: all 0.15s ease-out !important;
    flex-shrink: 0 !important;
    
    /* Estetään tekstin valinta */
    user-select: none;
    -webkit-user-select: none;
    touch-action: manipulation;
}

/* Hover-tila: Vaalea tausta ja hieman tummempi reuna */
.map-tool-button:hover:not(:disabled):not(.disabled), 
.ol-control button:hover:not(:disabled):not(.disabled) {
    background-color: #f7fafa !important; 
    border-color: #b0b3b3 !important; 
    box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2) !important; /* Nappi "nousee" */
    transform: translateY(-1px) !important;
}

/* Disabled-tila */
.map-tool-button:disabled, 
.map-tool-button.disabled, 
.ol-control button:disabled {
    background-color: #f0f2f5 !important; 
    color: #a0a0a0 !important;
    cursor: not-allowed !important; 
    border-color: #e1e4e8 !important;
    opacity: 0.8 !important; 
    box-shadow: none !important; 
    transform: none !important;
}

/* Aktiivinen tila (Painettu) */
.map-tool-button.active, 
.ol-control button:active {
    background-color: var(--accent-color) !important; 
    border-color: var(--accent-color) !important;
    color: var(--accent-text) !important; 
    
    /* Varjo sisäänpäin, luo "painetun" efektin */
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.2) !important;
    transform: translateY(1px) !important;
}

.map-tool-button.active:hover:not(:disabled):not(.disabled), 
.ol-control button:active:hover:not(:disabled):not(.disabled) {
    background-color: var(--accent-hover) !important; 
    border-color: var(--accent-hover) !important;
}

/* GPS Seuranta aktiivinen */
.map-tool-button.active.gps-following {
    background-color: var(--success-color) !important; 
    border-color: var(--success-color) !important; 
    color: #fff !important;
}
.map-tool-button.active.gps-following:hover:not(:disabled) { filter: brightness(1.1); }

.map-tool-button .button-icon {
    width: 20px; height: auto; vertical-align: middle; fill: currentColor !important; transition: fill 0.2s ease;
}
.map-tool-button.active .button-icon { fill: var(--accent-text) !important; }
.map-tool-button:disabled .button-icon, .map-tool-button.disabled .button-icon { fill: var(--text-muted) !important; }



/* Mittaa ala -kuvakkeen suurennus */
#measure-area-button .button-icon,
#mobile-measure-area .button-icon {
    transform: scale(1.15);
}

.button-hidden { display: none !important; }

#zoom-to-selected-button:not(.button-hidden), #clear-selection-button:not(.button-hidden) { display: inline-flex !important; }

#clear-selection-button:not(:disabled):not(.disabled) {
    background-color: var(--danger-bg) !important; border-color: var(--danger-color) !important; color: var(--danger-text) !important;
}
#clear-selection-button:not(:disabled):not(.disabled):hover { background-color: var(--danger-color) !important; color: #fff !important; }
#clear-selection-button:not(:disabled):not(.disabled) .button-icon { fill: currentColor !important; }
#clear-selection-button:not(:disabled):not(.disabled):hover .button-icon { fill: #fff !important; }

/* --- Floating Controls & Action Buttons (PÄIVITETTY FAB-TYYLI) --- */
.floating-controls-container {
    position: absolute;
    top: 80px; /* Siirretty alemmas, jotta ei peitä ohjelaatikkoa */
    left: 50%;
    transform: translateX(-50%);
    z-index: 1012;
    display: none; /* Näytetään JS:llä flexinä */
    gap: 20px; /* Väljempi väli */
    align-items: center;
    justify-content: center;
    
    background-color: transparent !important;
    backdrop-filter: none !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    
    pointer-events: none; /* Klikkaukset läpi nappien välistä */
}

.floating-controls-container[style*="display: flex"] {
    display: flex !important;
}

/* Nappien muotoilu pyöreiksi (FAB) */
.floating-controls-container .map-tool-button {
    pointer-events: auto;
    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important;
    min-height: 50px !important;
    border-radius: 50% !important; /* Pyöreä */
    
    padding: 0 !important;
    margin: 0 !important;
    
    font-size: 0 !important; /* Piilotetaan teksti */
    
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    
    box-shadow: 0 4px 10px rgba(0,0,0,0.3) !important;
    border: none !important;
    transition: transform 0.2s ease, filter 0.2s ease, opacity 0.2s ease !important; /* Lisätty opacity transition */
}

/* Ikonit */
.floating-controls-container .map-tool-button .button-icon {
    width: 24px !important;
    height: 24px !important;
    margin: 0 !important;
    display: block !important;
    fill: currentColor !important;
}

/* --- Clear Measurements (Desktop) - Pidetään tekstimuotoisena "roskiksena" --- */
#clear-measurements-button {
    position: absolute; 
    top: 15px; 
    left: 50%; 
    transform: translateX(-50%); 
    z-index: 1012; 
    box-shadow: var(--shadow-md);
    display: none; 
    
    /* Palautetaan vanhat tyylit tälle napille */
    width: auto !important;
    min-width: 80px !important;
    height: 40px !important;
    padding: 0 16px !important;
    font-size: 0.9em !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background-color: var(--danger-color) !important;
    color: #fff !important;
    border: none !important;
}

#clear-measurements-button .button-icon {
    width: 16px;
    height: 16px;
    margin: 0 !important;
}

#clear-measurements-button:hover:not(:disabled) {
    transform: translateX(-50%) translateY(-1px) !important; 
    filter: brightness(1.1);
}

#clear-measurements-button:not(.button-hidden) {
    display: inline-flex !important;
}

#clear-measurements-button.button-hidden {
    display: none !important;
}

/* --- Action Button Värit (FAB) --- */

/* Peruuta (Punainen) */
#cancel-geometry-modify-button,
#cancel-offline-area-button,
#stop-gps-recording-button {
    background-color: var(--danger-color) !important;
    color: white !important;
}

/* Kumoa (Keltainen/Oranssi) */
#undo-geometry-modify-button {
    background-color: #f0ad4e !important;
    color: white !important;
}

/* Tallenna / Valmis (Vihreä) */
#accept-geometry-modify-button,
#accept-offline-area-button {
    background-color: var(--success-color) !important;
    color: white !important;
}

/* Hover efektit FABeille */
.floating-controls-container .map-tool-button:hover:not(:disabled) {
    transform: scale(1.1) !important;
    filter: brightness(1.1);
    box-shadow: 0 6px 12px rgba(0,0,0,0.4) !important;
    z-index: 10;
}

.floating-controls-container .map-tool-button:active:not(:disabled) {
    transform: scale(0.95) !important;
}

/* --- Modal Footer Buttons --- */
#infoPanelNavigation button.map-tool-button, .modal-footer button.map-tool-button {
    font-family: inherit; 
    font-size: 0.9em !important; 
    padding: 6px 12px !important; 
    min-width: auto !important;
    width: auto !important; 
    height: auto !important; 
    box-shadow: var(--shadow-sm) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

.modal-footer button.map-tool-button .button-icon {
    width: 1em !important;
    height: 1em !important;
    margin: 0 !important;
}
.modal-footer button#settingsModalSaveButton, .modal-footer button#offlineSettingsModalStartButton, .modal-footer button#styleModalSaveButton { 
    background-color: var(--success-bg) !important; color: var(--success-text) !important; border-color: var(--success-color) !important;
}
.modal-footer button#settingsModalSaveButton:hover:not(:disabled), .modal-footer button#offlineSettingsModalStartButton:hover:not(:disabled), .modal-footer button#styleModalSaveButton:hover:not(:disabled) { 
    background-color: var(--success-color) !important; color: #fff !important;
}
.modal-footer button#settingsModalCancelButton, .modal-footer button#offlineSettingsModalCancelButton, .modal-footer button#multipleFeaturesModalCancelButton, .modal-footer button#styleModalCancelButton, .modal-footer button#offlineModalFooterCloseButton, .modal-footer button#printModalCancelButton { 
    background-color: var(--hover-bg) !important; color: var(--text-color) !important; border-color: var(--border-color) !important;
}
.modal-footer button#settingsModalCancelButton:hover:not(:disabled) { background-color: var(--active-bg) !important; }

/* --- OFFLINE MODAALIN UUSI TYYLI --- */

/* Poistetaan modaalin oletuspaddingit ja säädetään tilankäyttöä */
#offlineModalBody {
    padding: 0 5px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.modal-description {
    font-size: 0.95em;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.5;
}

/* Tilastokortti (Dashboard) */
.offline-stats-container {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    background-color: rgba(0, 0, 0, 0.2); /* Hienovarainen tausta */
    padding: 15px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
}

.stat-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.stat-box.highlight .stat-value {
    color: var(--accent-color); /* Korostusvärillä (esim. sininen/vihreä) */
}

.stat-value {
    font-size: 1.4em;
    font-weight: 700;
    color: var(--text-color);
    margin-bottom: 4px;
    font-variant-numeric: tabular-nums;
}

.stat-label {
    font-size: 0.75em;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
}

/* Painikkeet */
.offline-actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Ylikirjoitetaan map-tool-button perusmuotoiluja tässä kontekstissa */
#offlineModalBody button {
    width: 100% !important;
    justify-content: center !important;
    height: 48px !important;
    border-radius: 10px !important;
    font-weight: 600;
    font-size: 1em !important;
    margin: 0 !important;
    transition: all 0.2s ease;
}

/* Ensisijainen nappi (Vihreä/Sininen) */
#offlineModalBody .primary-btn {
    background-color: var(--success-color) !important;
    color: white !important;
    border: 1px solid transparent !important;
    box-shadow: 0 4px 12px rgba(40, 167, 69, 0.3) !important;
}

#offlineModalBody .primary-btn:hover:not(:disabled) {
    /* Hoverissa pidetään vihreänä, mutta hieman kirkkaampana (brightness) */
    background-color: var(--success-color) !important;
    color: white !important;
    border-color: transparent !important;
    
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(40, 167, 69, 0.4) !important;
    filter: brightness(1.1);
}

.primary-btn .button-icon {
    fill: white !important;
    margin-right: 10px;
}

/* Toissijainen nappi (Punainen reunus) */
/* KORJATTU: Sama korjaus tähän varmuuden vuoksi */
#offlineModalBody .danger-outline-btn {
    background-color: transparent !important;
    border: 2px solid var(--danger-color) !important;
    color: var(--danger-color) !important;
    box-shadow: none !important;
}

#offlineModalBody .danger-outline-btn:hover:not(:disabled) {
    background-color: var(--danger-bg) !important;
    color: var(--danger-color) !important;
}

.danger-outline-btn .button-icon {
    fill: var(--danger-color) !important;
    margin-right: 10px;
}

.modal-footnote {
    font-size: 0.8em;
    color: var(--text-muted);
    text-align: center;
    margin: 0;
    opacity: 0.7;
}

/* --- OFFLINE PROGRESS BAR --- */

#offlineProgressInfo {
    margin-top: 15px;
    display: none; /* Piilossa oletuksena! */
    flex-direction: column;
    gap: 5px;
}

.progress-labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.9em;
    color: var(--text-color);
    font-weight: 500;
}

.progress-track {
    width: 100%;
    height: 10px;
    background-color: rgba(128, 128, 128, 0.2); /* Haalea tausta */
    border-radius: 5px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background-color: var(--success-color); /* Vihreä täyttö */
    width: 0%;
    transition: width 0.3s ease-out; /* Pehmeä animaatio */
}

/* UUSI: Latausosoitteen tyyli */
#offlineCurrentUrl {
    font-size: 0.75em;
    color: var(--text-muted);
    text-align: center;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    min-height: 1.2em; /* Varaa tilaa jotta ei hypi */
}

/* --- OFFLINE ASETUKSET MODAALIN FOOTER-KORJAUS --- */

/* Pakotetaan footer käyttämään space-between, jotta arvio menee vasemmalle ja napit oikealle */
#offlineSettingsModal .modal-footer {
    justify-content: space-between !important;
    align-items: center;
    gap: 10px;
}

/* Arviolaskurin tyylit */
.tile-estimate {
    font-size: 0.9em;
    font-weight: 600;
    margin-right: auto; /* Varmistus */
}

/* Väriluokat varoituksille */
.est-normal {
    color: var(--text-muted);
}

.est-warning {
    color: #e6a23c; /* Oranssi */
}

.est-danger {
    color: var(--danger-color); /* Punainen */
}

/* Tumma tila */
body.dark-mode .est-warning {
    color: #f0ad4e; /* Vaaleampi oranssi tummalla taustalla */
}


/* --- Selection Mode Container --- */
.map-tool-select {
    font-family: inherit; font-size: 0.9em; background-color: var(--input-bg); color: var(--text-color);
    border: 1px solid var(--border-color); border-radius: 3px; padding: 0 25px 0 8px;
    appearance: none; -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236c757d' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 0.7rem center;
}
#selection-mode-container {
    display: none !important; position: absolute; top: 10px; left: calc(10px + 44px + 10px);
    z-index: 1011; background-color: var(--panel-bg); backdrop-filter: var(--panel-backdrop);
    padding: 5px 8px; 
    border-radius: 6px !important; 
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-md); flex-direction: column; align-items: flex-start; gap: 8px;
    transition: opacity 0.3s ease-out, visibility 0.3s ease-out;
}
#selectionMode { width: 140px; height: 36px; }
#selection-mode-container .map-tool-button {
    width: 36px !important; height: 36px !important; min-width: 36px !important; min-height: 36px !important; font-size: 1.1em !important;
}
#selection-mode-container .map-tool-button .button-icon { width: 16px; }
#selection-tools-row, #annotation-tools-row { display: flex; align-items: center; gap: 8px; }
#annotation-tools-row:not(.button-hidden) { display: flex !important; }

/* --- Layer Switcher Panel --- */
#layer-switcher-panel {
    display: none; position: absolute; width: calc(100vw - 40px); max-width: 380px; overflow-y: auto;
    z-index: 1020; background-color: var(--panel-bg); backdrop-filter: var(--panel-backdrop);
    padding: 15px; border: 1px solid var(--border-color); 
    border-radius: 10px !important;
    box-shadow: var(--shadow-lg); color: var(--text-color);
    transition: opacity 0.3s ease-out, visibility 0.3s ease-out, right 0.3s ease-out;
    right: 60px; 
}
#layer-switcher-panel.active { display: block; }
#layer-switcher-panel .panel-header { 
    display: flex; justify-content: space-between; align-items: center; 
    margin-bottom: 10px; border-bottom: 1px solid var(--border-color); padding-bottom: 5px;
}
#layer-switcher-panel .panel-header h4 { margin: 0; flex-grow: 1; }
#pin-layer-switcher-button.map-tool-button { margin-left: auto; margin-right: 5px; }
#close-layer-switcher-button { display: none !important; }
.layer-switcher h5 { margin: 5px 0; font-size: 0.95em; color: var(--text-color); }
.layer-switcher .layer-item { margin-bottom: 5px; display: flex; align-items: center; min-height: 34px; }
.layer-switcher label { cursor: pointer; transition: color 0.3s ease; display: flex; align-items: center; flex-grow: 1; margin-right: 8px; color: var(--text-color); }
.layer-switcher label.disabled { color: var(--text-muted) !important; cursor: default !important; }
.layer-switcher label input[type="checkbox"] { margin-right: 5px; accent-color: var(--accent-color); }
.layer-switcher .style-config-button.map-tool-button, #pin-layer-switcher-button.map-tool-button {
    padding: 0 !important; font-size: 1em !important; 
    width: 20px !important; height: 30px !important; min-width: 30px !important; min-height: 20px !important;
    margin-left: 5px !important; margin-right: 5px;
    border-radius: 3px !important; flex-shrink: 0; display: inline-flex !important; align-items: center !important; justify-content: center !important;
    background-color: transparent !important; border: none !important; box-shadow: none !important;
}
.layer-switcher .style-config-button.map-tool-button .button-icon, #pin-layer-switcher-button.map-tool-button .button-icon {
    width: 18px; height: auto; transition: transform 0.1s ease-in-out, fill 0.15s ease-out; fill: var(--text-muted);
}
#pin-layer-switcher-button.map-tool-button:hover:not(:disabled):not(.disabled) {
    background-color: var(--hover-bg) !important; transform: none !important; box-shadow: none !important;
}
#pin-layer-switcher-button.map-tool-button.active .button-icon { fill: var(--accent-color) !important; }
#pin-layer-switcher-button.map-tool-button:not(.active) .button-icon { transform: scale(0.8); }
.layer-switcher input[type="range"] { width: 80px; flex-shrink: 0; margin-left: auto; }
.layer-switcher hr { margin: 8px 0; border: 0; border-top: 1px solid var(--border-color); }

/* --- Side Panels (Info & Summary) --- */
#infoSidePanel, #summarySidePanel {
    width: 600px; min-width: 350px; max-width: 60%; height: 100vh;
    background-color: var(--panel-bg); backdrop-filter: var(--panel-backdrop);
    border-left: 1px solid var(--border-color); box-shadow: -2px 0 5px rgba(0,0,0,0.1);
    display: flex; flex-direction: column; position: absolute; top: 0; right: 0;
    transform: translateX(100%);
    transition: transform 0.3s ease-out, width 0.2s ease-out;
    color: var(--text-color);
}

/* LISÄTTY: Määritellään z-indeksit erikseen kerrostamista varten */
#summarySidePanel {
    z-index: 1015;
}

#infoSidePanel {
    z-index: 1016; /* Infopaneeli listan päällä */
}
#infoSidePanel.visible, #summarySidePanel.visible { transform: translateX(0); }
#infoSidePanel.truly-hidden, #summarySidePanel.truly-hidden { display: none; }
#infoPanelResizer { 
    width: 8px; background-color: var(--border-color); cursor: ew-resize; 
    position: absolute; top: 0; left: -4px; height: 100%; z-index: 1016; 
}
#infoPanelContentWrapper, #summaryPanelContentWrapper { display: flex; flex-direction: column; height: 100%; overflow-y: hidden; }
#infoPanelHeader, #summaryPanelHeader { 
    display: flex; justify-content: space-between; align-items: center; 
    padding: 10px 15px; border-bottom: 1px solid var(--border-color); gap: 10px; flex-shrink: 0; 
}
#infoPanelHeader #infoPanelTitle, #summaryPanelHeader #summaryPanelTitle { margin-right: auto; font-size: 1.1em; }
#infoPanelHeader label[for="autoZoomToInfoFeature"] { font-size: 0.9em; display: flex; align-items: center; cursor: pointer; white-space: nowrap; }
.info-tabs { 
    list-style-type: none; padding: 0 10px; margin: 0 0 10px 0; 
    display: flex; border-bottom: 1px solid var(--border-color); flex-shrink: 0;
}
#infoPanelTabs {
    display: none !important;
}
.info-tabs li { 
    padding: 8px 8px; cursor: pointer; border: 1px solid transparent; border-bottom: none; margin-right: 3px; 
    background-color: var(--hover-bg); border-radius: 4px 4px 0 0; 
    font-size: 0.9em; color: var(--text-muted);
}
.info-tabs li.active { 
    background-color: var(--panel-bg); border-color: var(--border-color); 
    border-bottom-color: var(--panel-bg); position: relative; top: 1px; 
    font-weight: bold; color: var(--accent-color);
}

/* --- MUUTETTU: Poistetaan overflow-y täältä --- */
#infoPanelBody, #summaryPanelBody { 
    flex-grow: 1; 
    overflow-y: hidden; 
    padding: 0; 
    display: flex; 
    flex-direction: column; 
    position: relative;
}
#summaryPanelBody { padding: 5px 15px 15px; overflow-y: auto; } /* Summary panel saa pitää scrollin vielä tässä */

/* --- MUUTETTU: Lisätään overflow-y lapsille --- */
.info-tab-content { 
    display: none; 
    flex-grow: 1; 
    overflow-y: auto; 
    padding: 10px 15px; 
}
.info-tab-content.active { display: flex; flex-direction: column; }

/* ... */

.info-tab-content table { width: 100%; border-collapse: collapse; font-size: 0.9em; }
.info-tab-content th, .info-tab-content td { 
    border: 1px solid var(--border-color); padding: 6px; text-align: left; color: var(--text-color);
}
.info-tab-content th { background-color: var(--hover-bg); font-weight: 600; }
#infoPanelNavigation { display: none !important; }
#infoPanelAutoZoomButton.map-tool-button { width: 34px !important; height: 34px !important; min-width: 34px !important; min-height: 34px !important; }
#infoPanelAutoZoomButton.map-tool-button .button-icon { width: 16px; }

/* --- Modals --- */
.modal {
    display: none; position: fixed; z-index: 21000;
    left: 0; top: 0; right: 0; bottom: 0;
    background-color: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
    padding: 10px; align-items: center; justify-content: center;
}
.modal-content {
    background-color: var(--panel-bg); color: var(--text-color); margin: 0; padding: 20px;
    border: 1px solid var(--border-color); 
    border-radius: 10px !important;
    width: 95%; max-width: 500px; box-shadow: var(--shadow-md);
    display: flex; flex-direction: column; max-height: calc(100vh - 40px); position: relative; font-family: inherit;
}

.modal-header-with-menu {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    margin-bottom: 20px;
    padding-right: 40px;
    position: relative;
}

.modal-header-logo {
    height: 40px; width: auto; margin-right: 15px; object-fit: contain; flex-shrink: 0;
}

.modal-header-with-menu h3 {
    margin: 0; 
    font-size: 1.3em; 
    line-height: 1.2;
    /* MUUTOS TÄSSÄ: Vaihdettu flex-grow 1 -> 0 */
    flex-grow: 0; 
    white-space: nowrap; 
    overflow: hidden; 
    text-overflow: ellipsis;
}

.settings-menu-container {
    position: relative; display: inline-flex; align-items: center; margin-left: 10px;
}

#settingsMenuButton { 
    width: 36px !important; height: 36px !important; min-width: 36px !important; min-height: 36px !important;
    padding: 0 !important; display: flex !important; align-items: center; justify-content: center;
}

#styleModalTitle, #settingsModalTitle, #offlineSettingsModalTitle, #multipleFeaturesModalTitle, #helpModalTitle, #offlineModalTitle, #printModalTitle,
#copyFormatModalTitle, #gpxExportOptionsModalTitle, #geoJsonExportOptionsModalTitle {
    margin-top: 0; font-size: 1.2em; flex-shrink: 0;
}
/* KORJAUS: Keskitetään otsikot pystysuunnassa sulkemisrastin (X) kanssa.
   Koskee yksinkertaisia modaaleja, joissa ei ole erikoista yläpalkkia (kuten Asetukset). */
#drawTypeModalTitle,
#gpsChoiceModalTitle,
#offlineModalTitle,
#helpModalTitle,
#styleModalTitle,
#offlineSettingsModalTitle,
#multipleFeaturesModalTitle,
#exportFormatModalTitle,
#gpxExportOptionsModalTitle,
#geoJsonExportOptionsModalTitle,
#copyFormatModalTitle,
#addLayerModalTitle {
    /* Kompensoidaan modal-contentin 20px paddingia vs rastin 10px top-positio */
    margin-top: -10px !important; 
    
    /* Varmistetaan tila rastille oikealla */
    margin-right: 40px;
    
    /* Varmistetaan väli sisältöön alhaalla */
    margin-bottom: 15px !important;
    
    /* Asetetaan korkeus samaksi kuin rastilla (36px) ja keskitetään teksti */
    min-height: 36px;
    display: flex;
    align-items: center;
}
.modal-body, #settingsModalBody, #styleModalBody, #offlineSettingsModalBody, #multipleFeaturesModalBody, #helpModalBody, #offlineModalBody, #printModalBody {
    margin-bottom: 10px; overflow-y: auto; overflow-x: hidden; flex-grow: 1;
}
#styleModalBody label, #settingsModalBody label, #offlineSettingsModalBody label, #multipleFeaturesModalBody p, #helpModalBody p, #helpModalBody li, #offlineModalBody p, #printModalBody label {
    display: block; margin-top: 6px; margin-bottom: 2px; font-weight: normal; font-size: 0.9em;
}
#styleModalBody .style-group, #settingsModalBody .setting-item, #offlineSettingsModalBody .setting-item, #offlineModalBody .setting-item, #printModalBody .setting-item { 
    margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--border-color);
}
#settingsModalBody .setting-item:last-of-type { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }

#styleModalBody input[type="color"], #styleModalBody input[type="number"], #styleModalBody input[type="range"], #styleModalBody select,
/* 1. Yleinen asettelu asetusriveille */
#settingsModalBody .setting-item label {
    display: flex !important;
    align-items: center !important; /* Kohdistaa tekstin ja laatikon pystysuunnassa keskelle */
    justify-content: flex-start;
    gap: 12px; /* Väli laatikon ja tekstin välillä */
    margin-bottom: 12px !important; /* Väli rivien välillä */
    margin-top: 0 !important;
    font-weight: normal !important;
    font-size: 1rem !important;
    cursor: pointer;
    line-height: 1.2;
    padding: 5px 0; /* Hieman kosketuspintaa */
}
/* 2. Valintaruudun tyyli */
#settingsModalBody .setting-item input[type="checkbox"] {
    margin: 0 !important; /* Nollataan marginaalit, gap hoitaa välin */
    width: 20px !important; /* Isompi laatikko */
    height: 20px !important;
    flex-shrink: 0; /* Estää laatikkoa kutistumasta */
    cursor: pointer;
    accent-color: var(--accent-color);
}
#offlineSettingsModalBody input[type="checkbox"] {
    width: auto; padding: 6px; margin-bottom: 8px; 
    border: 1px solid var(--border-color); border-radius: 3px;
    margin-right: 5px; vertical-align: middle;
    background-color: var(--input-bg); color: var(--text-color);
}
#settingsModalBody .color-picker-item { flex: 1; }
#styleModalBody input[type="color"], #settingsModalBody input[type="color"] { height: 35px; width: 100%; padding: 2px; }
#styleModalBody input[type="number"], #styleModalBody input[type="range"], #styleModalBody select { width: 100%; }
#featureSelectListModal li {
    padding: 8px 10px; cursor: pointer; border-bottom: 1px solid var(--border-color); font-size: 0.9em; color: var(--text-color);
}
#featureSelectListModal li:hover { background-color: var(--hover-bg); }
.modal-footer {
    margin-top: auto; padding-top: 15px; text-align: right;
    display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 10px; flex-shrink: 0;
    border-top: 1px solid var(--border-color);
}
.modal-footer .reset-button-container { margin-right: auto; }

/* Panel Close Button (Korjattu keskitys) */
.panel-close-button {
    font-size: 1rem !important;
    line-height: 1 !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    color: var(--text-muted) !important;
    box-shadow: none !important;
    transform: none !important;
    border-radius: 6px !important;
    transition: background-color 0.2s;
}

.panel-close-button:hover {
    background: var(--hover-bg) !important;
    color: var(--text-color) !important;
}

/* Säädetään SVG-ikonin kokoa sulkupainikkeen sisällä */
.panel-close-button svg,
.panel-close-button .button-icon {
    width: 26px !important;
    height: 26px !important;
    display: block;
    fill: currentColor;
}

/* Modal Close Button (oikea yläkulma) sijainnin hienosäätö */
.modal-close-button.map-tool-button {
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    z-index: 10;
}
.modal-close-button.map-tool-button:hover { background: var(--hover-bg) !important; color: var(--text-color) !important; }

/* --- Toggle Switch --- */
#dataSourceToggleContainer { display: flex; align-items: center; gap: 8px; }
.data-source-toggle { position: relative; display: inline-block; width: 44px; height: 22px; cursor: pointer; }
.data-source-toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
    position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0;
    background-color: var(--border-color); transition: .4s; border-radius: 22px;
}
.toggle-slider:before {
    position: absolute; content: ""; height: 18px; width: 18px;
    left: 2px; bottom: 2px; background-color: white; transition: .4s; border-radius: 50%;
}
.data-source-toggle input:checked + .toggle-slider { background-color: var(--accent-color); }
.data-source-toggle input:checked + .toggle-slider:before { transform: translateX(22px); }
.toggle-label { font-size: 0.9em; font-weight: 500; vertical-align: middle; color: var(--text-color); }

/* --- Splash Screen --- */
#splash-screen {
    position: fixed; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 100%;
    background-color: var(--bg-color); 
    z-index: 99999;
    display: flex; 
    justify-content: center; 
    align-items: center; 
    flex-direction: column;
    
    /* Lähtötilanne */
    opacity: 1;
    /* Animoidaan vain opacity (läpinäkyvyys) */
    transition: opacity 0.5s ease-out;
}

#splash-screen img { 
    max-width: 250px; 
    width: 60%; 
    animation: pulse-fade-in 1.2s both; 
    display: block; 
}
#splash-screen .update-container { display: none; flex-direction: column; align-items: center; gap: 20px; color: var(--text-color); }
#splash-screen .update-container h4 { margin: 0; font-size: 1.2em; font-weight: 500; }
#splash-screen .spinner {
    width: 35px; height: 35px; border: 4px solid var(--hover-bg); border-top-color: var(--accent-color);
    border-radius: 50%; animation: spin 1.2s ease-in-out infinite;
}
html.app-is-updating #splash-screen img { display: none; }
html.app-is-updating #splash-screen .update-container { display: flex; animation: fadeInUp 0.6s 0.2s both; }
#splash-screen.fade-out { 
    opacity: 0;           /* Täysin läpinäkyvä */
    pointer-events: none; /* Päästää klikkaukset läpi karttaan heti */
    /* EI display: none; tähän! */
}


@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
@keyframes pulse-fade-in { 0% { transform: scale(0.95); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* --- Dropdown Menu --- */
.dropdown-menu {
    display: none; 
    position: absolute; 
    top: calc(100% + 8px);
    
    /* KORJAUS: Palautetaan kohdistus oikeaan reunaan, jotta se mahtuu ruudulle */
    left: -100px;     /* Aiemmin: left: 0; */
    right: 0;       /* Aiemmin: right: auto; */
    
    background-color: var(--panel-bg); 
    backdrop-filter: var(--panel-backdrop);
    -webkit-backdrop-filter: var(--panel-backdrop);
    min-width: 240px; 
    box-shadow: var(--shadow-lg); 
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md); 
    z-index: 21001; 
    padding: 5px 0;
    overflow: hidden;
}

.dropdown-menu.active { 
    display: block; 
    animation: fadeInMenu 0.2s ease-out;
}

@keyframes fadeInMenu {
    from { opacity: 0; transform: translateY(-5px); }
    to { opacity: 1; transform: translateY(0); }
}

.dropdown-menu a { 
    color: var(--text-color); 
    padding: 10px 15px; 
    text-decoration: none; 
    display: flex; 
    flex-direction: column;
    font-size: 0.95em; 
    transition: background-color 0.15s;
}

.dropdown-menu a:hover { 
    background-color: var(--hover-bg); 
}

.dropdown-menu hr { 
    margin: 5px 0; 
    border: 0;
    border-top: 1px solid var(--border-color); 
}

.dropdown-menu a.danger-action { 
    color: var(--danger-color); 
}
.dropdown-menu a.danger-action:hover {
    background-color: var(--danger-bg);
}

.dropdown-menu a small {
    display: block;
    font-size: 0.8em;
    color: var(--text-muted);
    margin-top: 2px;
    font-weight: normal;
}

/* --- OpenLayers Overrides --- */
/* PIILOTETAAN OLETUSATTRIBUUTIO */
.ol-attribution {
    display: none !important;
}

.ol-control { background-color: transparent !important; padding: 0 !important; border-radius: 5px !important; z-index: 1005 !important; position: absolute; }
.ol-zoom { right: 10px; left: auto !important; display: flex !important; flex-direction: column !important; gap: 0 !important; }
.ol-zoom .ol-zoom-in { border-radius: 5px 5px 0 0 !important; }
.ol-zoom .ol-zoom-out { border-radius: 0 0 5px 5px !important; margin-top: -1px !important; }
.ol-rotate { right: 10px; left: auto !important; }
.ol-rotate button { border-radius: 5px !important; }
.ol-full-screen { display: none !important; }
.ol-control button:focus { outline: none; }

.ol-scale-line,
.ol-scale-line-inner,
#zoom-level-indicator,
.custom-mouse-position {
    background: transparent !important;
    background-color: rgba(0,0,0,0) !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.ol-scale-line-inner,
#zoom-level-indicator,
.custom-mouse-position {
    color: #ffffff !important;
    font-family: system-ui, -apple-system, sans-serif !important;
    font-weight: 700 !important;
    text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000, 0 0 4px rgba(0,0,0,0.8) !important;
    text-decoration: none !important;
}

.ol-scale-line-inner {
    border: 2px solid #ffffff !important;
    border-top: none !important;
    filter: drop-shadow(0px 0px 1px #000) drop-shadow(0px 0px 1px #000);
}

.ol-scale-line {
    padding: 0 !important;
    bottom: calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    left: 10px; right: auto !important;
    z-index: 1000 !important;
}

#zoom-level-indicator {
    position: absolute; 
    /* Varmuuden vuoksi CSS-fallback, JS ylikirjoittaa tämän */
    bottom: calc(75px + env(safe-area-inset-bottom, 0px)); /* Changed from 90px */
    right: 10px; 
    padding: 2px 8px;
    font-size: 12px; 
    z-index: 1000; /* Changed from 1010 to be behind Legend (1005) */
    display: none;
}
.custom-mouse-position {
    position: absolute; bottom: 10px; right: 10px;
    padding: 5px; font-size: 12px; z-index: 1000; display: none !important;
}
#selected-count-indicator { display: none; }

#measure-output {
    display: none; position: absolute; top: 10px; left: 10px;
    background: var(--panel-bg); padding: 8px 12px; border-radius: 5px;
    font-size: 0.9em; z-index: 1010; min-height: 1.5em;
    box-shadow: var(--shadow-md); max-width: 250px; word-wrap: break-word; color: var(--text-color);
}

.ol-tooltip {
    position: relative;
    background: rgba(255, 255, 255, 0.9) !important;
    border: 2px solid var(--accent-color) !important;
    border-radius: 4px !important;
    color: #000 !important;
    padding: 4px 8px !important;
    font-size: 13px !important;
    font-weight: bold !important;
    opacity: 1 !important;
    white-space: nowrap;
    box-shadow: 0 2px 6px rgba(0,0,0,0.3) !important;
    pointer-events: none;
    z-index: 1020; 
}
.ol-tooltip-measure {
    opacity: 1;
    font-weight: bold;
}
.ol-tooltip-static {
    background-color: rgba(255, 255, 255, 0.95) !important;
    color: black !important;
    border: 1px solid #999 !important;
}
.ol-tooltip:before { display: none !important; }


/* --- Summary Panel & Annotations --- */
#summaryPanelBody .info-tabs {
    list-style-type: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap;
    border-bottom: 1px solid var(--border-color); flex-shrink: 0;
}
#summaryPanelBody .info-tabs li {
    padding: 8px 6px; cursor: pointer; border: 1px solid transparent; border-bottom: none;
    margin-right: 3px; background-color: var(--hover-bg); border-radius: 4px 4px 0 0;
    font-size: 0.9em; white-space: nowrap; color: var(--text-color);
}
#summaryPanelBody .info-tabs li.active {
    background-color: var(--panel-bg); border-color: var(--border-color);
    border-bottom-color: var(--panel-bg); position: relative; top: 1px; font-weight: bold;
}
#summaryPanelBody .summary-tab-content { display: none; }
#summaryPanelBody .summary-tab-content.active { display: block; overflow-x: hidden; }
#summaryPanelBody .info-table {
    width: 100%; max-width: 500px; border-collapse: collapse; font-size: 0.9em; margin: 0 0 15px 0; table-layout: fixed;
}
#summaryPanelBody .info-table th, #summaryPanelBody .info-table td {
    border: 1px solid var(--border-color); padding: 6px; overflow-wrap: break-word; color: var(--text-color);
}
#summaryPanelBody .info-table th { background-color: var(--hover-bg); text-align: left; }
#summaryPanelBody .info-table.summary-key-value th { width: auto; }
#summaryPanelBody .info-table.summary-key-value td { width: 35%; text-align: right; }
#summaryPanelBody .info-table tbody tr.row-hover th, #summaryPanelBody .info-table tbody tr.row-hover td { background-color: var(--active-bg); cursor: pointer; }

.summary-barchart-container {
    position: relative; margin: 25px 0; padding: 15px;
    border: 1px solid var(--border-color); border-radius: 4px; background-color: var(--hover-bg);
}
.summary-barchart-container h4 { margin-top: 0; margin-bottom: 15px; text-align: center; font-weight: normal; color: var(--text-color); }
.summary-barchart-container canvas { max-height: 250px; }

#summaryPanelTitle { flex-shrink: 0; white-space: nowrap; }
#headerKpiContainer { display: flex; flex-grow: 1; justify-content: center; gap: 20px; align-items: center; overflow: hidden; }
.kpi-item { text-align: center; line-height: 1.1; }
.kpi-item strong { font-size: 1.1em; color: var(--text-color); display: block; }
.kpi-item .kpi-label { font-size: 0.7em; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; }

#summaryPanelBody .annotation-list { list-style: none; padding: 0; margin: 10px 0; }
#summaryPanelBody .annotation-list li {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 10px; border-bottom: 1px solid var(--border-color); font-size: 0.9em; color: var(--text-color);
}
#summaryPanelBody .annotation-list li:last-child { border-bottom: none; }
#summaryPanelBody .annotation-list .annotation-info { display: flex; flex-direction: column; }
#summaryPanelBody .annotation-list .annotation-name { font-weight: 500; }
#summaryPanelBody .annotation-list .annotation-timestamp { font-size: 0.8em; color: var(--text-muted); margin-top: 2px; }
#summaryPanelBody .annotation-list .zoom-to-annotation-btn {
    width: 34px !important; height: 34px !important; min-width: 34px !important; min-height: 34px !important;
    flex-shrink: 0; margin-left: 15px;
}
#summaryPanelBody .annotation-list .zoom-to-annotation-btn .button-icon { width: 16px; }
body:not(.mobile-view) #summaryPanelBody .annotation-list li:hover { 
    background-color: var(--hover-bg); 
    cursor: pointer; 
}
#summaryPanelBody .annotation-list .annotation-type-icon { flex-shrink: 0; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; }
#summaryPanelBody .annotation-list .annotation-type-icon .button-icon { width: 18px; height: 18px; }
#summaryPanelBody .annotation-list .annotation-info { flex-grow: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#summaryPanelBody .annotation-list .annotation-actions { display: flex; gap: 5px; flex-shrink: 0; }
#summaryPanelBody .annotation-list .annotation-actions .map-tool-button {
    width: 32px !important; height: 32px !important; min-width: 32px !important; min-height: 32px !important; font-size: 1em !important;
}
#summaryPanelBody .annotation-list .annotation-actions .map-tool-button .button-icon { width: 15px; height: 15px; }

/* --- KORJATTU: Listan roskakorit punaisiksi (Desktop) --- */
#summaryPanelBody .annotation-list .annotation-actions .delete-btn { 
    background-color: var(--danger-color) !important; 
    border-color: var(--danger-color) !important; 
    color: #ffffff !important;
}
#summaryPanelBody .annotation-list .annotation-actions .delete-btn .button-icon { 
    fill: #ffffff !important; 
}
#summaryPanelBody .annotation-list .annotation-actions .delete-btn:hover:not(:disabled) { 
    background-color: #bb2d3b !important; /* Hieman tummempi punainen hoverissa */
    filter: brightness(1.1);
}

#annotation-editor-container.view-mode .annotation-view-item { margin-bottom: 12px; }
#annotation-editor-container.view-mode label { font-weight: bold; font-size: 0.9em; color: var(--text-muted); margin-bottom: 2px; display: block; }
#annotation-editor-container.view-mode p {
    font-size: 1em; margin: 0; padding: 8px; background-color: var(--active-bg); border-radius: 4px; border: 1px solid var(--border-color);
    word-wrap: break-word; white-space: pre-wrap; color: var(--text-color);
}
#annotation-editor-container.view-mode .annotation-color-view { display: flex; align-items: center; gap: 10px; padding: 8px; background-color: var(--active-bg); border-radius: 4px; border: 1px solid var(--border-color); }
#annotation-editor-container.view-mode .color-swatch { width: 24px; height: 24px; border-radius: 4px; border: 1px solid var(--border-color); flex-shrink: 0; }
.annotation-edit-item { display: flex; align-items: center; gap: 8px; }
#summaryPanelFooter { gap: 15px; background-color: var(--hover-bg); border-top: 1px solid var(--border-color); padding: 10px 15px; margin-top: auto; }
#summaryPanelFooter #deleteAllAnnotationsButton { background-color: var(--danger-bg) !important; border-color: var(--danger-color) !important; color: var(--danger-text) !important; font-size: 0.85em !important; }
#summaryPanelFooter #deleteAllAnnotationsButton:hover:not(:disabled) { background-color: var(--danger-color) !important; border-color: var(--danger-color) !important; color: #fff !important; }
#summaryPanelFooter #deleteAllAnnotationsButton .button-icon { fill: currentColor !important; margin-right: 5px; }

.annotation-view-item-row { display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; }
.annotation-view-item.compact { margin-bottom: 5px; flex: 1; }
.annotation-view-item.compact label { margin-bottom: 4px; }
.annotation-view-item.compact p, .annotation-view-item.compact span, .annotation-view-item.compact .annotation-color-view {
    padding: 8px; background-color: var(--active-bg); border-radius: 4px; border: 1px solid var(--border-color); margin: 0; min-height: 38px; display: flex; align-items: center;
}
.annotation-view-item.compact .annotation-color-view { padding: 6px 8px; }
#annotation-editor-container.edit-mode input[type="text"], #annotation-editor-container.edit-mode textarea {
    width: 100%; padding: 8px; border-radius: 4px; border: 1px solid var(--border-color); font-size: 1em; font-family: inherit; margin-bottom: 10px; background-color: var(--input-bg); color: var(--text-color);
}
#annotation-editor-container.edit-mode textarea#anno-desc { min-height: 80px; resize: vertical; }
#annotation-editor-container.edit-mode label { font-size: 0.9em; font-weight: bold; color: var(--text-muted); margin-bottom: 4px; display: block; }
.annotation-edit-row { display: flex; gap: 20px; align-items: flex-end; margin-bottom: 10px; }
.annotation-edit-item-group { display: flex; flex-direction: column; }
.annotation-edit-item-group.flex-grow { flex-grow: 1; }
.annotation-edit-item-group input[type="color"] { width: 60px; height: 38px; padding: 2px; }
.slider-container { display: flex; align-items: center; gap: 10px; }
.slider-container input[type="range"] { flex-grow: 1; margin: 0; }
.annotation-edit-item label { font-weight: normal; margin-bottom: 0; }

/* --- KORJATTU: Muokkausikkunan Tallenna (Vihreä) ja Poista (Punainen) --- */
#annotation-editor-container #save-anno-btn { 
    background-color: var(--success-color) !important; 
    color: #ffffff !important; 
    border-color: var(--success-color) !important; 
}
#annotation-editor-container #save-anno-btn:hover:not(:disabled) { 
    filter: brightness(1.1);
}

#annotation-editor-container #delete-anno-btn { 
    background-color: var(--danger-color) !important; 
    color: #ffffff !important; 
    border-color: var(--danger-color) !important; 
}
#annotation-editor-container #delete-anno-btn:hover:not(:disabled) { 
    filter: brightness(1.1);
}

/* --- KORJATTU: Lukutilan "Poista" -painike punaiseksi --- */
#annotation-editor-container #delete-anno-view-btn { 
    background-color: var(--danger-color) !important; 
    color: #ffffff !important; 
    border-color: var(--danger-color) !important; 
}
#annotation-editor-container #delete-anno-view-btn:hover:not(:disabled) { 
    filter: brightness(1.1);
}

/* --- UUSI: Merkinnän muokkausnäkymän kiinteä footer (Edit Mode Sticky Footer) --- */

/* Kun ollaan edit-tilassa, otetaan koko korkeus käyttöön ja poistetaan paddingit containerilta */
#annotation-editor-container.edit-mode {
    padding: 0 !important;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Sisältöalue, joka rullaa (scrollaa) */
.editor-scroll-view {
    flex: 1;
    overflow-y: auto;
    padding: 10px 15px; /* Sisältöpadding */
}

/* Kiinteä alatunniste (Footer) muokkaustilassa */
#annotation-editor-container.edit-mode .modal-footer {
    flex-shrink: 0; /* Ei kutistu */
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px)) 10px !important; /* Kompakti padding */
    background-color: var(--panel-bg);
    border-top: 1px solid var(--border-color);
    margin-top: 0;
    box-shadow: 0 -2px 8px rgba(0,0,0,0.05); /* Pieni varjo ylöspäin erottamaan sisällöstä */
    z-index: 10;
    display: flex;
    justify-content: space-between;
    gap: 8px;
}

/* Mobiililaitteiden säätö (vielä tiiviimpi footer) */
@media (max-height: 600px) {
    #annotation-editor-container.edit-mode .modal-footer {
        padding-top: 6px !important;
        padding-bottom: calc(6px + env(safe-area-inset-bottom, 0px)) !important;
    }
    #annotation-editor-container.edit-mode .map-tool-button {
        height: 36px !important;
        font-size: 0.9em !important;
    }
}

/* ... (footer & mobile) ... */

.footer-group-left, .footer-group-right { display: flex; gap: 10px; align-items: center; }
.map-tool-button.text-button { width: auto !important; padding: 6px 12px !important; font-size: 0.9em !important; }
.map-tool-button.text-button.danger-action { background-color: var(--danger-bg) !important; border-color: var(--danger-color) !important; color: var(--danger-text) !important; }
.map-tool-button.text-button.danger-action:hover:not(:disabled) { background-color: var(--danger-color) !important; color: #fff !important; }

.dropdown-menu-container { position: relative; display: inline-block; }
.action-dropdown-menu {
    display: none; position: absolute; bottom: calc(100% + 5px); right: 0;
    background-color: var(--panel-bg); box-shadow: var(--shadow-md); border: 1px solid var(--border-color);
    border-radius: 4px; z-index: 21001; padding: 5px 0; list-style: none; margin: 0;
}
.action-dropdown-menu.active { display: block; }
.action-dropdown-menu a { color: var(--text-color); padding: 8px 12px; text-decoration: none; display: block; font-size: 0.9em; white-space: nowrap; }
.action-dropdown-menu a:hover { background-color: var(--hover-bg); }
.action-dropdown-menu a.danger-action { color: var(--danger-color); }
.action-dropdown-menu a.danger-action:hover { background-color: var(--danger-bg); }
.action-dropdown-menu a.disabled { color: var(--text-muted); pointer-events: none; cursor: default; }
.action-dropdown-menu a.disabled:hover { background-color: transparent !important; }

#annotation-footer-container { display: none; width: 100%; justify-content: flex-end; align-items: center; flex-wrap: wrap; gap: 10px; }

body.immersive-mode #right-icon-toolbar, body.immersive-mode .ol-control:not(.ol-attribution):not(.ol-scale-line),
body.immersive-mode #measure-output, body.immersive-mode #zoom-level-indicator, body.immersive-mode #mobile-tools-handle {
    opacity: 0; visibility: hidden; pointer-events: none;
}

#mobile-tools-button-container { display: none !important; }
#mobile-tools-handle {
    display: flex; position: fixed; bottom: 0; left: 50%; transform: translateX(-50%);
    width: 110px; height: calc(35px + env(safe-area-inset-bottom, 0px));
    padding-top: 10px; padding-bottom: env(safe-area-inset-bottom, 0px);
    z-index: 20000; cursor: pointer; justify-content: center; align-items: flex-start;
    -webkit-tap-highlight-color: transparent;
    
    /* MUUTOS: Päivitetty tyyli vastaamaan "Button 13" -nappeja */
    background-color: #ffffff !important; 
    border: 1px solid #d5d9d9 !important; 
    border-bottom: none !important; /* Ei reunaa alhaalla */
    
    /* Varjo ylöspäin, jotta erottuu kartasta */
    box-shadow: 0 -3px 10px rgba(0,0,0,0.15) !important;
    
    border-top-left-radius: 12px; border-top-right-radius: 12px;
    
    touch-action: none;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
/* LISÄÄ TÄMÄ UUSI LUOKKA: */
#mobile-tools-handle.hidden-handle {
    opacity: 0;
    visibility: hidden;
    pointer-events: none; /* Estää virheklikkaukset kun piilossa */
}
.grabber-dots { 
    /* Kahvan "kosketusalueen" koko */
    width: 60px; 
    height: 20px; 
    
    /* Asetetaan väri neutraaliksi harmaaksi, jotta se näyttää kahvalta */
    color: #e0e0e0; 
    
    display: flex;
    justify-content: center;
    align-items: center;
    
    /* Poistetaan opacity, säädetään väriä suoraan yllä */
    opacity: 1; 
}

/* Tumma teema: kahva hieman tummemmaksi */
body.dark-mode .grabber-dots {
    color: #4a4a4a;
}

.grabber-dots .button-icon { 
    /* Pakotetaan SVG täyttämään leveys, korkeus automaattinen */
    width: 40px !important; 
    height: auto !important; 
    display: block;
}

#map-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(0,0,0,0.4); z-index: 20000;
    opacity: 0; transition: opacity 0.3s ease-out;
}
#map-overlay:not(.hidden) { opacity: 1; }
.hidden { display: none !important; }

/* --- Mobiilin työkalupalkki (Bottom Sheet) --- */
.bottom-sheet {
    position: fixed; bottom: 0; left: 0; width: 100%;
    background-color: var(--panel-bg); z-index: 20001;
    border-top-left-radius: 12px; border-top-right-radius: 12px;
    box-shadow: 0 -4px 15px rgba(0,0,0,0.2);
    transform: translateY(100%); 
    
    /* Lisätty transition, joka animoi transformin */
     transition: transform 0.3s ease-out, visibility 0s linear 0.3s;
    
    padding-bottom: env(safe-area-inset-bottom, 0px);
    max-height: 50vh; display: flex; flex-direction: column; visibility: hidden;
}

/* Kun paneelia raahataan sormella, poistetaan transition, jotta se seuraa sormea viiveettä. 
   TÄRKEÄÄ: Pakotetaan näkyviin (visibility: visible), koska ilman .active-luokkaa se olisi hidden. */
.bottom-sheet.dragging {
    transition: none !important;
    visibility: visible !important;
}

.bottom-sheet.active { 
    transform: translateY(0); 
    visibility: visible; 
    transition: transform 0.3s ease-out, visibility 0s linear 0s;
}

.bottom-sheet-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 15px; border-bottom: 1px solid var(--border-color); flex-shrink: 0;
    
    /* Lisätty: kosketustoimintojen esto headerista (vetämistä varten) */
    touch-action: none;
}
.bottom-sheet-header h4 { margin: 0; flex-grow: 1; color: var(--text-color); }
.bottom-sheet-header-actions { display: flex; align-items: center; gap: 5px; }
.bottom-sheet-header .map-tool-button {
    background: none !important; border: none !important; box-shadow: none !important;
    color: var(--text-muted) !important; width: 36px !important; height: 36px !important;
    min-width: 36px !important; min-height: 36px !important;
}
.bottom-sheet-header .map-tool-button:hover { background: var(--hover-bg) !important; color: var(--text-color) !important; transform: none !important; }
.bottom-sheet-header #help-button, .bottom-sheet-header #close-mobile-tools-button { font-size: 1.6em !important; }
.bottom-sheet-header #settings-button .button-icon { width: 18px; height: 18px; fill: var(--text-muted); }
.bottom-sheet-header #settings-button:hover .button-icon { fill: var(--text-color); }
.bottom-sheet-content { padding: 15px; overflow-y: auto; }
.tools-section { margin-bottom: 20px; }
.tools-section:last-child { margin-bottom: 0; }
.tools-section h5 { margin: 0 0 10px 0; font-size: 0.9em; color: var(--text-muted); text-transform: uppercase; }
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 10px; }
.tool-grid-button {
    background-color: var(--input-bg); border: 1px solid var(--border-color); border-radius: 8px;
    padding: 12px 8px; font-size: 0.85em; text-align: center; cursor: pointer;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 8px; color: var(--text-color); transition: background-color 0.2s, box-shadow 0.2s; min-height: 80px;
}
.tool-grid-button:hover { background-color: var(--hover-bg); }
.tool-grid-button.active {
    background-color: rgba(0, 123, 255, 0.15); border-color: var(--accent-color);
    color: var(--accent-color); font-weight: bold;
}
.tool-grid-button:disabled { opacity: 0.5; cursor: not-allowed; background-color: var(--bg-color); }
.tool-grid-button .tool-icon { width: 24px; height: 24px; }
.tool-grid-button .tool-icon svg {
    width: 24px;
    height: 24px;
    display: block;
}
.tool-grid-button .tool-icon .button-icon { width: 100%; height: 100%; fill: currentColor !important; }

/* --- Mobiilivalikon logo --- */
#mobile-menu-logo {
    height: 28px; /* Sopiva koko otsikon viereen */
    width: auto;
    margin-right: 12px;
    cursor: pointer;
    transition: transform 0.2s ease, opacity 0.2s;
    /* Estetään kuvan litistyminen */
    flex-shrink: 0;
}

#mobile-menu-logo:active {
    transform: scale(0.9);
    opacity: 0.8;
}

/* Varmistetaan että otsikko ei veny liikaa vasemmalle, vaan logo vie tilansa */
body.mobile-view #mobile-tools-panel .bottom-sheet-header h4 {
    flex-grow: 1; /* Teksti täyttää yhä tilan, mutta logon jälkeen */
    text-align: left;
}

/* --- Mobiilin yhtenäiset toimintopainikkeet --- */
/* KORJATTU MEDIA QUERY: Sisältää nyt myös matalat näytöt (vaakamobiili) */
@media (max-width: 768px), (max-height: 500px) {
    
    /* 1. LAYER SWITCHER PANEL (Mobiili) - KORJATTU */
    #layer-switcher-panel {
        display: none; 
        position: fixed !important;
        top: 0 !important;
        bottom: auto !important; /* IRROTETAAN ALAREUNASTA */
        right: 0 !important;
        left: auto !important;
        transform: none !important;
        
        width: calc(100vw - 60px) !important; /* Levitetään vasemmalle, 60px tilaa napille */
        max-width: 400px !important;
        
        height: auto !important;
        max-height: 80vh !important; /* 80% korkeudesta */
        
        background-color: var(--panel-bg); 
        backdrop-filter: var(--panel-backdrop);
        
        border-radius: 0 0 0 10px !important; /* Pyöristys vain vasemmalle alas */
        border-left: 1px solid var(--border-color);
        border-bottom: 1px solid var(--border-color);
        
        box-shadow: -2px 5px 15px rgba(0,0,0,0.15) !important;
        
        padding: 15px !important;
        /* Yläreunan pehmuste, jotta sisältö ei mene napin alle piiloon */
        padding-top: 70px !important; 
        
        overflow-y: auto !important;
        z-index: 20010 !important;
    }
    
    /* 2. PIILOTA MUUT NAPIT KUN KARTTATASOT ON AUKI - KORJATTU: Vain mobiilissa (.mobile-view) */
    body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) #right-icon-toolbar button:not(#toggle-layers-panel-button),
    body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) .toolbar-separator,
    body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) #custom-zoom-in-button,
    body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) #custom-zoom-out-button {
        display: none !important;
    }
    
    /* Varmistetaan että työpöydän sulkunappi ei näy */
    #close-layer-switcher-button { display: none !important; }

    /* Varmistetaan että oikean yläkulman napit näkyvät paneelin päällä */
    #right-icon-toolbar {
        z-index: 20020 !important; 
    }
    
    /* ... (muut mobiilityylit pysyvät samana) ... */

    .floating-controls-container,
    #clear-measurements-button {
        top: auto !important;
        bottom: 100px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        background-color: transparent !important;
        border: none !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        padding: 0 !important;
        width: auto !important;
        min-width: 300px;
        justify-content: center !important;
        gap: 12px !important;
        z-index: 20000 !important;
        pointer-events: none;
    }

    .floating-controls-container .map-tool-button,
    #clear-measurements-button {
        pointer-events: auto;
        height: 44px !important;
        min-height: 44px !important;
        width: auto !important;
        min-width: 60px !important;
        border-radius: 10px !important;
        box-shadow: 0 4px 10px rgba(0,0,0,0.3) !important;
        font-weight: 700 !important;
        font-size: 0.9em !important;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        display: inline-flex !important; 
        align-items: center !important;
        justify-content: center !important;
        padding: 0 16px !important;
        opacity: 1 !important;
    }
    
    #clear-measurements-button.button-hidden {
        display: none !important;
    }

    .floating-controls-container .map-tool-button .button-icon,
    #clear-measurements-button .button-icon {
        display: none !important;
    }

    .success-action,
    #accept-geometry-modify-button,
    #accept-offline-area-button {
        background-color: var(--success-color) !important;
        border: 1px solid rgba(255,255,255,0.2) !important;
        color: #ffffff !important;
    }
    
    .danger-action,
    #cancel-geometry-modify-button,
    #cancel-offline-area-button,
    #stop-gps-recording-button,
    #clear-measurements-button {
        background-color: var(--danger-color) !important;
        border: 1px solid rgba(255,255,255,0.2) !important;
        color: #ffffff !important;
    }

    #undo-geometry-modify-button {
        background-color: var(--panel-bg) !important;
        border: 1px solid var(--border-color) !important;
        color: var(--text-color) !important;
        min-width: 44px !important;
        padding: 0 !important;
        width: 44px !important;
    }
    #undo-geometry-modify-button .button-icon {
        display: block !important;
        fill: currentColor !important;
    }

    #accept-geometry-modify-button::after { content: "Tallenna"; display: block; }
    #accept-geometry-modify-button { font-size: 0 !important; }
    #accept-geometry-modify-button::after { font-size: 14px !important; }

    #cancel-geometry-modify-button::after { content: "Peruuta"; display: block; }
    #cancel-geometry-modify-button { font-size: 0 !important; }
    #cancel-geometry-modify-button::after { font-size: 14px !important; }

    body.mobile-view #measure-output {
        top: 15px !important; 
        bottom: auto;
        left: 50%;
        transform: translateX(-50%);
        max-width: 90%;
        z-index: 1010;
    }

    /* 1. Estetään selaimen omat eleet otsikoissa, jotta JS-raahaus toimii */
    #infoPanelHeader,
    #summaryPanelHeader {
        touch-action: none !important; 
        cursor: grab;
        padding: 10px 15px !important;
        gap: 10px !important;
    }

    /* --- UUSI MOBIILIPANEELIN MUOTOILU (BOTTOM SHEET) --- */
    body.mobile-view #infoSidePanel, 
    body.mobile-view #summarySidePanel {
        top: auto !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        height: 50vh !important; 
        position: fixed !important;
        
        /* MUUTETTU: Poistetaan padding-bottom, jotta footer menee alas */
        padding-bottom: 0 !important; 
        
        border-left: none !important;
        border-top: 1px solid var(--border-color) !important;
        border-radius: 16px 16px 0 0 !important;
        box-shadow: 0 -4px 20px rgba(0,0,0,0.2) !important;
        transition: transform 0.3s ease-out;
        transform: translateY(100%);
    }
    /* Määritellään mobiilinäkymän tasojärjestys erikseen */
    body.mobile-view #summarySidePanel {
        z-index: 20002 !important; /* Lista on alempana */
    }

    body.mobile-view #infoSidePanel {
        z-index: 20003 !important; /* Infopaneeli/Lomake on listan päällä */
    }

    #infoSidePanel.visible, 
    #summarySidePanel.visible { 
        transform: translateY(0); 
    }
    
    #infoSidePanel.truly-hidden, 
    #summarySidePanel.truly-hidden { 
        display: none !important; 
    }

    #infoPanelResizer { display: none !important; }
    
    #right-icon-toolbar { right: 10px !important; top: 10px !important; }
    
    #infoPanelBody {
        /* MUUTETTU: Poistetaan padding-bottom */
        padding-bottom: 0 !important;
    }

    #featureSelectListModal {
        max-height: 40vh;
    }

    /* Piilotetaan "Desktop" napit mobiilissa */
    #desktop-offline-maps,
    #desktop-settings-button,
    #desktop-print-button,
    #desktop-help-button,
    #right-icon-toolbar .toolbar-separator {
        display: none !important;
    }

    /* --- ZOOM-PAINIKKEIDEN KIINTEÄ SIJOITTELU MOBIILISSA --- */
    
    #custom-zoom-in-button,
    #custom-zoom-out-button {
        position: fixed !important;
        right: 10px !important;
        left: auto !important;
        top: auto !important; 
        z-index: 20005 !important;
        transition: none !important; /* Ei animaatiota */
    }

    /* Alempi nappi (-) - Sijoitetaan 50vh:n yläpuolelle + pieni marginaali */
    #custom-zoom-out-button {
        bottom: calc(50vh + 20px) !important; 
        margin: 0 !important;
    }

    /* Ylempi nappi (+) - Alemman napin yläpuolelle */
    #custom-zoom-in-button {
        bottom: calc(50vh + 20px + 44px + 10px) !important; /* 50vh + väli + napin korkeus + väli nappejen välissä */
        margin: 0 !important;
    }

    /* --- LISÄTTY: Offline-asetusikkunan mobiilikoko --- */
    #offlineSettingsModal .modal-content {
        width: 95%;
        max-height: 80vh; /* Sama maksimikorkeus kuin usein isoissa modaaleissa */
        height: auto;
        display: flex;
        flex-direction: column;
    }
    #offlineSettingsModalBody {
        max-height: 60vh; /* Vastaava scrollattava alue kuin help-ikkunassa */
        overflow-y: auto;
    }
}

/* --- VAAKAMOBIILIN ERITYISKORJAUKSET (Landscape Mobile Fixes) --- */
@media (max-height: 500px) and (orientation: landscape) {
    
    /* 1. Palautetaan paneelit oikeaan laitaan (kuten työpöydällä) */
    #infoSidePanel, #summarySidePanel {
        top: 0 !important;
        bottom: 0 !important;
        left: auto !important;
        right: 0 !important;
        width: 350px !important;
        max-width: 45vw !important; /* Jätetään tilaa kartalle */
        height: 100% !important;
        max-height: 100% !important;
        
        /* Tyylin palautus sivupaneeliksi */
        border-top: none !important;
        border-left: 1px solid var(--border-color) !important;
        border-radius: 0 !important;
        
        /* Animaatio sivusuunnassa */
        transform: translateX(100%) !important;
    }

    #infoSidePanel.visible, 
    #summarySidePanel.visible { 
        transform: translateX(0) !important; 
    }

    /* 2. Siirretään zoom-painikkeet alas oikealle, etteivät ne törmää yläpalkkiin */
    #custom-zoom-in-button,
    #custom-zoom-out-button {
        right: 10px !important;
        left: auto !important;
        position: fixed !important;
        margin: 0 !important;
    }

    /* NOSTETTU REILUSTI YLÖSPÄIN, JOTTA EIVÄT PEITÄ ZOOM-TEKSTIÄ */
    #custom-zoom-out-button {
        top: auto !important;
        bottom: 80px !important; 
    }

    #custom-zoom-in-button {
        top: auto !important;
        bottom: 135px !important; 
    }

    /* UUSI SÄÄNTÖ: Piilota Mapis-logo vaakamobiilissa */
    #app-branding {
        display: none !important;
    }
}

/* --- Uudet tyylit Lopeta-painikkeen kuvakkeelle ja reunukselle --- */
#gps-recording-controls .map-tool-button .button-icon {
    margin-right: 8px;
}

#gps-recording-controls .map-tool-button {
    border-color: transparent !important;
}
#gps-recording-controls .map-tool-button:hover:not(:disabled) {
    border-color: transparent !important;
}

/* KORJATTU MEDIA QUERY: Työpöytä vaatii nyt sekä leveyttä että korkeutta */
/* KORJATTU MEDIA QUERY: Työpöytä vaatii nyt sekä leveyttä että korkeutta */
@media (min-width: 769px) and (min-height: 501px) {
    .bottom-sheet {
        left: 50%; transform: translate(-50%, 100%);
        max-width: 500px; border-radius: 12px;
    }
    .bottom-sheet.active { transform: translate(-50%, 0); }
    
    /* --- DESKTOP TOOLBARS (Yhtenäiset paneelit) --- */
    
    /* Piilotetaan mobiilin kahva ja paneeli */
    #mobile-tools-handle,
    #mobile-tools-panel {
        display: none !important;
    }

    /* Piilotetaan mobiilin "Toggle" -nappi vasemmasta yläkulmasta */
    #toggle-tools-menu-button {
        display: none !important;
    }

    /* YHTEISET TYYLIT VASEMMALLE JA OIKEALLE PALKILLE */
    /* MUUTOS: Poistettu taustaväri ja reunat, jotta napit kelluvat vapaasti kuten mobiilissa */
    #left-icon-toolbar,
    #right-icon-toolbar {
        display: flex !important;
        position: absolute;
        top: 10px;
        flex-direction: column;
        gap: 10px; /* Palautetaan rako nappien väliin */
        
        /* Poistetaan paneelimainen ulkoasu */
        background-color: transparent;
        backdrop-filter: none;
        border: none;
        box-shadow: none;
        padding: 0;
        
        z-index: 1010;
        pointer-events: auto; /* Varmistetaan klikattavuus */
    }

    #left-icon-toolbar { left: 10px; }
    #right-icon-toolbar { right: 10px; }

    /* --- KORJAUS: Siirretään mittaustuloksia oikealle työpöydällä, jotta ne eivät jää palkin alle --- */
    #measure-output {
        left: 70px !important; /* 10px (reuna) + 44px (palkki) + 16px (väli) */
        top: 65px !important;
    }

    /* Työkalujen kääre vasemmalla (varmistetaan näkyvyys) */
    #collapsible-tools-content {
        display: flex !important;
        flex-direction: column;
        gap: 10px; /* Palautetaan rako */
        margin: 0;
        padding: 0;
    }

    /* --- Nappien tyylitys paneelin sisällä --- */
    /* MUUTOS: Poistettu pakotukset, jotka poistivat reunat ja taustat. 
       Nyt napit käyttävät globaalia .map-tool-button tyyliä (Button 13). */
    
    #left-icon-toolbar .map-tool-button,
    #right-icon-toolbar .map-tool-button {
        /* Varmistetaan vain koko, muu tyyli tulee globaalista luokasta */
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        min-height: 44px !important;
        margin-bottom: 0; 
    }

    /* Aktiivinen tila (säilytetään korostus) */
    #left-icon-toolbar .map-tool-button.active,
    #right-icon-toolbar .map-tool-button.active {
        background-color: var(--accent-color) !important;
        color: #fff !important;
        border-color: var(--accent-color) !important;
    }
    
    #left-icon-toolbar .map-tool-button.active .button-icon,
    #right-icon-toolbar .map-tool-button.active .button-icon {
        fill: #fff !important;
    }

    /* --- ZOOM-PAINIKKEIDEN SIJOITTELU --- */
    /* Lisätään tilaa ylä- ja alapuolelle, jotta ne erottuvat muista */
    #custom-zoom-in-button {
        margin-top: 10px !important; /* Pieni väli */
        position: relative; 
    }
    
    /* Poistetaan viiva zoom-nappien yläpuolelta, koska nyt on raot */
    #custom-zoom-in-button::before {
        content: none;
    }
    
    #custom-zoom-out-button {
        margin-bottom: 0 !important;
    }

    /* Piilotetaan erotinviiva, koska napit kelluvat erillään */
    .toolbar-separator {
        display: none;
    }
}

/* --- TULOSTUKSEN HALLINTAPANEELI (Kelluva) --- */
.floating-controls-panel {
    position: absolute;
    top: 65px;
    /* MUUTETTU: SIIRRETTY VASEMPAAN LAITAAN */
    left: 70px; /* KORJATTU: Hieman enemmän tilaa vasempaan reunaan */
    right: auto;
    width: 300px;
    background-color: var(--panel-bg);
    backdrop-filter: var(--panel-backdrop);
    border: 1px solid var(--border-color);
    border-radius: 10px !important;
    box-shadow: var(--shadow-lg);
    z-index: 11000;
    display: flex;
    flex-direction: column;
    padding: 15px;
}

.panel-header-compact { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.panel-header-compact h4 { margin: 0; font-size: 1em; }
.print-input { width: 100%; padding: 6px; margin-bottom: 10px; border: 1px solid var(--border-color); border-radius: 4px; font-family: inherit; font-size: 0.9em; background-color: var(--input-bg); color: var(--text-color); }
.print-options-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; font-size: 0.9em; }
.orientation-selector { display: flex; gap: 10px; }
.full-width { width: 100% !important; justify-content: center; }

/* --- TULOSTUKSEN RAJAUSALUE (Paper Guide) --- */
/* Tämä elementti näyttää ruudulla A4-alueen */
#print-guide {
    display: none;
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1000;
    border: 2px dashed #333;
    background: transparent;
    /* Himmennys ulkopuolelle */
    box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.5); 
    pointer-events: none; 
    box-sizing: border-box;
}

/* TARKAT A4 KUVASUHTEET (Suhdeluku 1.4142) */

/* Pysty (Portrait): Leveys on korkeus / 1.4142 */
#print-guide.portrait {
    height: 60vh;
    width: calc(60vh / 1.4142); 
}

/* Vaaka (Landscape): Leveys on korkeus * 1.4142 */
#print-guide.landscape {
    height: 50vh; /* Pienempi korkeus jotta leveys mahtuu ruudulle */
    width: calc(50vh * 1.4142);
}

/* Esikatselutekstit rajausalueen sisällä */
.print-preview-header {
    position: absolute;
    top: 0; left: 0; width: 100%;
    padding: 10px;
    background: rgba(255, 255, 255, 0.9);
    border-bottom: 1px solid #ccc;
    box-sizing: border-box;
    pointer-events: none;
}
.print-preview-header h1 { margin: 0 0 5px 0; font-size: 16px; color: black; }
.print-preview-header p { margin: 0; font-size: 12px; color: black; white-space: pre-wrap; }
.print-preview-header .meta { font-size: 10px; color: #555; margin-top: 5px; }

/* --- VARSINAINEN TULOSTUS (@media print) --- */
@media print {
    /* 1. SIVUN ASETUKSET */
    @page {
        margin: 10mm; 
        size: auto; 
    }

    html, body {
        margin: 0 !important;
        padding: 0 !important;
        background: white !important;
        width: 100%;
        height: 100%;
        overflow: hidden !important;
        display: block !important;
    }

    /* 2. PIILOTETAAN KAIKKI KÄYTTÖLIITTYMÄELEMENTIT */
    /* TÄRKEÄÄ: Lisätty ID:t (#left-icon-toolbar, #right-icon-toolbar) listaan,
       jotta ne ylikirjoittavat työpöytänäkymän pakotetun näkyvyyden. */
    .floating-controls-panel, 
    .icon-toolbar, 
    #left-icon-toolbar, 
    #right-icon-toolbar,
    .ol-control, 
    #measure-output, 
    #zoom-level-indicator, 
    #mobile-tools-handle, 
    #selection-mode-container, 
    .modal, 
    .overlay-panel, 
    #print-guide, 
    #draw-instruction-overlay, 
    #gps-recording-controls, 
    #offline-area-controls,
    #geometry-modify-controls, 
    #splash-screen, 
    #clear-measurements-button,
    #gps-status-overlay, /* Piilotetaan GPS status tulosteessa */
    
    /* KORJAUS: Lisätty sivupaneelit ja mobiilipaneelit piilotuslistaan */
    #infoSidePanel,
    #summarySidePanel,
    #mobile-tools-panel,
    .bottom-sheet,

    #map {
        display: none !important;
        opacity: 0 !important;
        visibility: hidden !important;
    }

    /* 3. PÄÄCONTAINER (Kehys) */
    #map-container {
        position: relative !important;
        width: 100% !important;
        height: 100% !important;
        background: white !important;
        border: 2px solid #000 !important;
        box-sizing: border-box !important;
        overflow: hidden !important;
        margin: 0 !important;
        z-index: 1;
    }

    /* 4. KARTTAKUVA (Taustalle) */
    #print-snapshot {
        display: block !important;
        visibility: visible !important;
        position: absolute !important;
        top: 0; left: 0;
        width: 100% !important;
        height: 100% !important;
        
        /* Täyttää koko alueen ilman valkoisia rakoja */
        object-fit: cover !important; 
        object-position: center !important;
        
        z-index: 0; /* Alimpana */
        border: none !important;
    }

    /* 5. OTSIKKO (Kelluva laatikko vasemmassa yläkulmassa) */
    #print-header-overlay {
        display: block !important;
        visibility: visible !important;
        position: absolute !important;
        
        /* Asemoidaan mustan reunaviivan päälle */
        top: -2px !important;
        left: -2px !important;
        
        width: auto !important;
        max-width: 60%; 
        
        /* Täysin valkoinen tausta */
        background-color: #ffffff !important;
        
        /* Mustat reunat vain oikealle ja alas */
        border-right: 2px solid #000 !important;
        border-bottom: 2px solid #000 !important;
        
        padding: 12px 18px;
        
        z-index: 100; /* Kartan päällä */
        box-sizing: border-box;
    }
    
    #print-header-title { 
        font-family: Arial, sans-serif !important;
        font-size: 22px !important; 
        margin: 0 0 5px 0 !important; 
        color: #000 !important; 
        font-weight: bold !important;
    }
    #print-header-notes { 
        font-family: Arial, sans-serif !important;
        font-size: 12px !important; 
        margin: 0 0 5px 0 !important; 
        color: #000 !important; 
        white-space: pre-wrap !important; 
    }
    #print-header-meta { 
        font-family: Arial, sans-serif !important;
        font-size: 10px !important; 
        color: #444 !important; 
        margin: 0 !important;
    }

    /* 6. ALATUNNISTEET - Piilotetaan nämä, koska ne on nyt poltettu kuvaan (print-snapshot) */
    #print-footer-overlay {
        display: none !important;
    }
    
    /* Varmuuden vuoksi piilotetaan myös yksittäiset elementit */
    #print-scale-box,
    #print-attribution-box {
        display: none !important;
    }
}

/* Pieni huomioteksti karttatasolistaan */
.layer-note {
    font-size: 0.75em;
    color: var(--text-muted); /* Tai esim. #e6a23c (oranssi) jos haluat enemmän huomiota */
    font-weight: normal;
    margin-left: 6px;
    white-space: nowrap;
    opacity: 0.8;
}

/* Layer Switcherin otsikkorivi */
.layer-group-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    margin-bottom: 5px;
}

/* Pieni + lisäyspainike */
.add-layer-mini-btn {
    background: none;
    border: none;
    color: var(--accent-color);
    font-size: 1.5em;
    line-height: 1;
    padding: 0 5px;
    cursor: pointer;
    font-weight: bold;
    transition: transform 0.2s, color 0.2s;
}

.add-layer-mini-btn:hover {
    color: var(--accent-hover);
    transform: scale(1.2);
    background-color: rgba(0,0,0,0.05);
    border-radius: 4px;
}

/* --- Layer Switcher Drag & Drop Styles (UUSI) --- */

/* Tason rivi */
.layer-switcher .layer-item {
    display: flex;
    align-items: center;
    padding: 8px 5px;
    background-color: var(--panel-bg);
    border: 1px solid transparent;
    transition: background-color 0.2s, border-color 0.2s, transform 0.2s;
}

/* Raahauskahva (Drag Handle) */
.layer-drag-handle {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: grab; /* Hiiren kursori */
    color: var(--text-muted);
    margin-right: 8px;
    flex-shrink: 0;
    touch-action: none;
}

.layer-drag-handle:active {
    cursor: grabbing;
    color: var(--accent-color);
}

.layer-drag-handle svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    pointer-events: none; /* Estää SVG:tä kaappaamasta hiiritapahtumaa */
}

/* Visuaalinen tila raahauksen aikana */
.layer-item.dragging {
    opacity: 0.9;
    background-color: var(--hover-bg);
    border: 1px dashed var(--accent-color);
    box-shadow: var(--shadow-md);
    z-index: 1000;
}

/* Placeholder, joka näyttää mihin elementti putoaa */
.layer-item.drag-placeholder {
    background-color: rgba(0, 123, 255, 0.1);
    border: 1px dashed var(--accent-color);
    height: 40px;
    margin-bottom: 5px;
}

/* Label vie kaiken liikenevän tilan */
.layer-switcher label {
    flex-grow: 1;
    margin-right: 5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    user-select: none; /* Estää tekstin valinnan raahatessa */
}

/* Opacity slider ja napit */
.layer-switcher input[type="range"] {
    width: 60px; 
}

/* Poistetaan oletus margin-bottom layer-itemiltä, koska padding hoitaa välin */
.layer-switcher .layer-item {
    margin-bottom: 2px;
    border-radius: 4px;
}

/* --- Feature Selection List Styles (UUSI: Usean kohteen valinta) --- */

/* Poistetaan vanha lista-tyyli */
#featureSelectListModal {
    list-style: none; 
    padding: 0; 
    margin: 0; 
    max-height: 300px; 
    overflow-y: auto;
}

/* Uusi tyyli listan elementeille */
.feature-select-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 10px;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    transition: background-color 0.2s;
}

.feature-select-item:last-child {
    border-bottom: none;
}

.feature-select-item:hover {
    background-color: var(--hover-bg);
}

/* Tekstiosa */
.feature-name-span {
    flex-grow: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-right: 10px;
    padding: 4px 0;
}

/* Esikatselupainike (Silmä) */
.preview-feature-btn {
    background: none !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-muted) !important;
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 4px !important;
    transition: all 0.2s;
    box-shadow: none !important;
}

.preview-feature-btn:hover {
    background-color: var(--accent-color) !important;
    color: #fff !important;
    border-color: var(--accent-color) !important;
    transform: scale(1.05) !important;
}

.preview-feature-btn .button-icon {
    width: 18px;
    height: 18px;
}

/* Poistetaan taustan sumennus ja tummennus "Valitse kohde" -ikkunalta,
   jotta kartan korostukset näkyvät selkeästi läpi. */
#multipleFeaturesModal {
    backdrop-filter: none !important;
    background-color: rgba(0, 0, 0, 0.01) !important; /* Käytännössä läpinäkyvä */
}

/* Layer Switcher - Desktop oletus */
#layer-switcher-panel {
    display: none; 
    position: absolute; 
    width: 400px; /* Kiinteämpi leveys desktopille */
    max-width: 90vw;
    z-index: 1020; /* Kartan kontrollien päällä */
    background-color: var(--panel-bg); 
    backdrop-filter: var(--panel-backdrop);
    padding: 15px; 
    border: 1px solid var(--border-color); 
    border-radius: 10px !important;
    box-shadow: var(--shadow-lg); 
    color: var(--text-color);
    overflow-y: auto;
    /* Desktop sijainti lasketaan JS:llä (ui-layout.js handleLayoutChange) */
}

/* Layer Switcher - Mobiili Override */
body.mobile-view #layer-switcher-panel {
    /* MUUTOS: Irrotetaan ylä- ja oikeasta reunasta */
    top: 5px !important;
    right: 5px !important;
    
    left: auto !important;
    bottom: auto !important; 
    transform: none !important;
    
    /* MUUTOS: Leveys lasketaan siten, että molemmille puolille jää 10px (yht. 20px) */
    width: calc(100vw - 20px) !important; 
    max-width: 400px !important;
    
    height: auto !important;
    
    /* --- MUUTOS TÄSSÄ --- */
    /* Aiemmin: max-height: 80vh !important; */
    /* Nyt: Käytetään koko korkeutta miinus alareunan tila (90px kahvalle/tyhjää) */
    max-height: calc(100dvh - 90px) !important; 
    /* Fallback selaimille jotka eivät tue dvh:ta */
    max-height: calc(100vh - 90px) !important;
    /* -------------------- */
    
    background-color: var(--panel-bg); 
    backdrop-filter: var(--panel-backdrop);
    
    /* MUUTOS: Kaikki kulmat pyöristetyksi */
    border-radius: 10px !important; 
    
    /* MUUTOS: Reunus joka sivulle */
    border: 1px solid var(--border-color) !important;
    
    box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
    
    padding: 15px !important;
    
    overflow-y: auto !important;
    z-index: 20010 !important;
}

/* 2. PIILOTA MUUT NAPIT KUN KARTTATASOT ON AUKI */
body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) #right-icon-toolbar button:not(#toggle-layers-panel-button),
body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) .toolbar-separator,
body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) #custom-zoom-in-button,
body.mobile-view:has(#layer-switcher-panel[style*="display: block"]) #custom-zoom-out-button {
    display: none !important;
}

/* Close button Layer Switcherissä (näkyy vain mobiilissa oletuksena) */
#close-layer-switcher-button {
    display: none !important;
}
/* Piilotetaan oma sulkunappi mobiilissa, koska pääpainike hoitaa sen */
body.mobile-view #close-layer-switcher-button {
    display: none !important;
}

/* Varmista että Pin-nappi piilotetaan mobiilissa */
body.mobile-view #pin-layer-switcher-button {
    display: none !important;
}

/* Varmistetaan että oikean yläkulman työkalupalkki on paneelin päällä */
#right-icon-toolbar {
    position: fixed !important; /* Pakotetaan fixed mobiilissa */
    z-index: 20020 !important; /* Korkeampi kuin paneeli (20010) */
}

/* Korjaus settings menun z-indexiin jotta se näkyy modaalien päällä tarvittaessa */
.dropdown-menu {
    z-index: 22000 !important;
}

/* Korjaus: Varmista että floating controls (esim. lopeta piirto) näkyy */
.floating-controls-container {
    z-index: 1030 !important;
}

/* Mobiilin työkalupalkki (Bottom Sheet) */
#mobile-tools-panel {
    z-index: 20005 !important; /* Infopaneelin alla mutta kartan päällä */
}

/* Infopaneeli ja Summarypaneeli mobiilissa */
body.mobile-view #infoSidePanel, 
body.mobile-view #summarySidePanel {
    width: 100% !important;
    max-width: 100% !important;
    height: 50vh !important; /* Puoli ruutua */
    top: auto !important;
    bottom: 0 !important;
    border-radius: 15px 15px 0 0;
    transform: translateY(110%); /* Piilossa alhaalla */
    transition: transform 0.3s ease-out;
}
body.mobile-view #infoSidePanel.visible, 
body.mobile-view #summarySidePanel.visible {
    transform: translateY(0);
}

/* Mobiilipaneelien raahaus-tila */
body.mobile-view #infoSidePanel.dragging, 
body.mobile-view #summarySidePanel.dragging {
    transition: none !important;
    /* Varmistetaan että transform pysyy synkassa sormen kanssa ilman viivettä */
}

/* Varmistetaan että otsikot "kutsuvat" tarttumaan */
body.mobile-view #infoPanelHeader,
body.mobile-view #summaryPanelHeader {
    /* Tämä oli jo aiemmin, mutta varmistetaan */
    cursor: grab;
    touch-action: none; /* Tärkeä: estää selaimen scrollauksen vedettäessä */
}

@media (max-width: 768px) {
    /* Tiivistetään kuvauskenttää mobiilissa */
    #annotation-editor-container.edit-mode textarea#anno-desc {
        min-height: 45px !important; /* Noin 2 riviä */
        height: 45px !important;
        margin-bottom: 5px !important;
    }
    
    /* Varmistetaan että otsikot vievät vähemmän tilaa */
    #annotation-editor-container.edit-mode label {
        margin-bottom: 2px !important;
        font-size: 0.85em !important;
    }
    
    /* Tiivistetään input-kenttää hieman */
    #annotation-editor-container.edit-mode input[type="text"] {
        padding: 6px !important;
        margin-bottom: 5px !important;
    }
}

/* --- VAAKAMOBIILIN ERITYISKORJAUKSET (Landscape Mobile Fixes) --- */
@media (max-height: 500px) and (orientation: landscape) {
    
    /* 1. KAHVA (HANDLE) VASEMPAAN LAITAAN (Aiemmin tehty) */
    #mobile-tools-handle {
        left: 0 !important;
        top: 50% !important;
        bottom: auto !important;
        right: auto !important;
        transform: translateY(-50%) !important;
        width: 36px !important;
        height: 100px !important;
        border-radius: 0 12px 12px 0 !important;
        border: 1px solid var(--border-color) !important;
        border-left: none !important;
        flex-direction: column;
        justify-content: center;
        padding: 0 !important;
    }
    
    #mobile-tools-handle .grabber-dots {
        transform: rotate(90deg);
        width: 100%;
    }

    /* 2. TYÖKALUPANEELI VASEMMALLE (Aiemmin tehty) */
    #mobile-tools-panel {
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        right: auto !important;
        width: 300px !important;
        max-width: 80vw !important;
        height: 100% !important;
        max-height: 100% !important;
        transform: translateX(-100%);
        border-radius: 0 16px 16px 0 !important;
        border-top: none !important;
        border-right: 1px solid var(--border-color) !important;
    }

    #mobile-tools-panel.active {
        transform: translateX(0);
    }
    
    .bottom-sheet-content {
        height: calc(100% - 60px);
        overflow-y: auto;
    }

    /* 3. INFO- JA SUMMARY-PANEELIT OIKEAAN LAITAAN (UUSI MUUTOS) */
    body.mobile-view #infoSidePanel, 
    body.mobile-view #summarySidePanel {
        top: 0 !important;
        bottom: 0 !important;
        left: auto !important;
        right: 0 !important;
        
        /* Leveys: maksimissaan puolet ruudusta tai 400px */
        width: 400px !important;
        max-width: 50vw !important; 
        
        height: 100% !important;
        max-height: 100% !important;
        
        /* Palautetaan tyyli sivupaneeliksi */
        border-top: none !important;
        border-left: 1px solid var(--border-color) !important;
        border-radius: 0 !important; /* Ei pyöristyksiä */
        
        /* Animaatio sivusuunnassa (oikealta sisään) */
        transform: translateX(100%) !important;
        transition: transform 0.3s ease-out;
        z-index: 20030 !important; /* Työkalujen päälle */
    }

    body.mobile-view #infoSidePanel.visible, 
    body.mobile-view #summarySidePanel.visible { 
        transform: translateX(0) !important; 
    }
    
    /* Paneelin sisältö scrollattavaksi */
    body.mobile-view #infoPanelContentWrapper,
    body.mobile-view #summaryPanelContentWrapper {
        height: 100%;
        overflow-y: auto;
    }
}

/* --- KORJATTU MOBIILIASETTELU JA TOIMINNALLISUUS (Versio 3) --- */

/* 1. Piilota muokkausnappi työpöydällä (Desktop) */
#toggle-layer-edit-mode-button {
    display: none !important;
}

/* 2. Headerin asettelu mobiilissa: Otsikko vasemmalle, nappi heti perään */
body.mobile-view #layer-switcher-panel .panel-header {
    justify-content: flex-start !important;
    gap: 0 !important;
}

body.mobile-view #layer-switcher-panel .panel-header h4 {
    flex-grow: 0 !important;
    margin-right: 0 !important;
    white-space: nowrap;
}

/* 3. Muokkausnapin (yläpalkki) tyyli mobiilissa */
body.mobile-view #toggle-layer-edit-mode-button {
    display: inline-flex !important;
    margin-left: 10px !important;
    margin-right: auto !important; /* Työntää muut header-napit oikeaan reunaan */
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    padding: 0 !important;
    background-color: transparent !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 6px !important;
    color: var(--text-color) !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease;
}

/* Napin ikoni */
body.mobile-view #toggle-layer-edit-mode-button .button-icon {
    width: 18px !important;
    height: 18px !important;
    fill: currentColor !important;
}

/* Aktiivinen tila: Sininen tausta ja valkoinen ikoni */
body.mobile-view #toggle-layer-edit-mode-button.active {
    background-color: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    color: #ffffff !important;
}

body.mobile-view #toggle-layer-edit-mode-button.active .button-icon {
    fill: #ffffff !important;
}

/* 4. LOGIIKKA: Piilota elementit OLETUKSENA mobiilissa (kun EI ole editing-layers -luokkaa) */
/* Piilotetaan: Raahauskahvat, Opacity-sliderit JA Asetusnapit (rattaat) */
body.mobile-view #layer-switcher-panel:not(.editing-layers) .layer-drag-handle,
body.mobile-view #layer-switcher-panel:not(.editing-layers) input[type="range"],
body.mobile-view #layer-switcher-panel:not(.editing-layers) .style-config-button {
    display: none !important;
}

/* 5. LOGIIKKA: Näytä elementit VAIN kun editing-layers -luokka on aktiivinen */
body.mobile-view #layer-switcher-panel.editing-layers .layer-drag-handle {
    display: flex !important;
}
body.mobile-view #layer-switcher-panel.editing-layers input[type="range"] {
    display: block !important;
}
body.mobile-view #layer-switcher-panel.editing-layers .style-config-button {
    display: inline-flex !important;
}

/* Jos laite on mobiili (leveys alle 768px) JA korkeus on alle 600px, 
   piilotetaan zoom-painikkeet tilan säästämiseksi ja päällekkäisyyden estämiseksi. */
@media (max-width: 768px) and (max-height: 600px) {
    #custom-zoom-in-button,
    #custom-zoom-out-button {
        display: none !important;
    }
}

/* --- UUSI: Tietolähteet (Data Sources) UI --- */
#attribution-container {
    position: absolute;
    bottom: calc(8px + env(safe-area-inset-bottom, 0px));
    right: 10px;
    z-index: 1005;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

#attribution-button {
    background-color: rgba(255, 255, 255, 0.8);
    border: none;
    border-radius: 4px;
    padding: 2px 6px;
    font-size: 11px;
    color: #333;
    cursor: pointer;
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
    font-family: system-ui, -apple-system, sans-serif;
    transition: background-color 0.2s, color 0.2s;
    backdrop-filter: blur(2px);
}

#attribution-button:hover {
    background-color: rgba(255, 255, 255, 1);
    color: var(--accent-color);
}

#attribution-list {
    background-color: var(--panel-bg);
    backdrop-filter: var(--panel-backdrop);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 10px;
    margin-bottom: 5px;
    max-width: 250px;
    max-height: 200px;
    overflow-y: auto;
    box-shadow: var(--shadow-md);
    font-size: 0.85em;
    color: var(--text-color);
    text-align: left;
    display: block; /* Näytetään oletuksena (JS hoitaa togglauksen) */
}

#attribution-list.hidden {
    display: none;
}

#attribution-list h5 {
    margin: 0 0 8px 0;
    font-size: 1em;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 4px;
}

.attribution-item {
    margin-bottom: 6px;
    line-height: 1.3;
}

.attribution-item:last-child {
    margin-bottom: 0;
}

.attribution-layer-name {
    font-weight: bold;
    display: block;
    color: var(--accent-color);
    font-size: 0.9em;
}

.attribution-text {
    font-size: 0.9em;
    color: var(--text-muted);
}

/* Tulostuksessa piilotetaan painike, mutta lista saatetaan haluta näyttää (tai piilottaa) */
@media print {
    #attribution-container { display: none !important; }
}

/* --- TÄMÄ LISÄTÄÄN LOPPUUN: Mobiili Theme Toggle --- */

.theme-toggle-wrapper {
    display: flex;
    align-items: center;
    margin-left: 15px; /* Väli otsikon ja kytkimen välillä */
    margin-right: auto; /* Työntää sulkemisnapin oikeaan laitaan */
}

.theme-switch {
    position: relative;
    display: inline-block;
    width: 52px;
    height: 28px;
    margin-right: 10px;
}

.theme-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.theme-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #e4e4e4; /* Light mode tausta */
    transition: .4s;
    border-radius: 34px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 5px;
    border: 1px solid var(--border-color);
}

body.dark-mode .theme-slider {
    background-color: #2b2b2b; /* Dark mode tausta */
    border-color: #444;
}

/* Liukuva pallo */
.theme-slider:before {
    position: absolute;
    content: "";
    height: 22px;
    width: 22px;
    left: 3px;
    bottom: 2px; /* Keskitys pystysuunnassa (28px - 22px - 2xborder) / 2 */
    background-color: white;
    transition: .4s;
    border-radius: 50%;
    z-index: 2;
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

input:checked + .theme-slider:before {
    transform: translateX(22px);
}

/* Ikonit */
.theme-icon {
    width: 14px;
    height: 14px;
    z-index: 1;
    transition: opacity 0.3s;
}

.icon-sun {
    fill: #f39c12; /* Aurinko keltainen */
    margin-left: 2px;
}

.icon-moon {
    fill: #f1c40f; /* Kuu vaalea keltainen */
    margin-right: 2px;
}

/* Piilotetaan työpöydällä, näytetään vain mobiilissa */
@media (min-width: 769px) and (min-height: 501px) {
    .theme-toggle-wrapper {
        display: none !important;
    }
}

/* Mobiilin toimintopainikkeet (FAB) */
.mobile-fab-container {
    position: absolute;
    
    /* MUUTOS TÄSSÄ: 40px -> 120px */
    /* Nostetaan ylemmäs, jotta ei mene Zoom-tekstin tai Selite-napin päälle */
    bottom: calc(120px + env(safe-area-inset-bottom, 0px)); 
    
    right: 15px;
    display: none; /* Piilossa oletuksena */
    flex-direction: column;
    gap: 15px;
    z-index: 20060; /* Kaiken muun päällä */
    pointer-events: none; /* Container ei estä klikkauksia */
}

/* Näytetään vain mobiilissa kun aktiivinen */
body.mobile-view .mobile-fab-container.active {
    display: flex;
}

.fab-btn {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0,0,0,0.3);
    cursor: pointer;
    pointer-events: auto; /* Itse napit toimivat */
    transition: transform 0.2s, filter 0.2s;
    color: white;
}

.fab-btn:active {
    transform: scale(0.95);
}

.fab-btn .button-icon {
    width: 24px;
    height: 24px;
    fill: currentColor;
}

/* Värit */
.fab-danger {
    background-color: var(--danger-color);
}
.fab-warning {
    background-color: #f0ad4e; /* Oranssi/Keltainen */
    color: white;
}
.fab-success {
    background-color: var(--success-color);
}

/* Piilotetaan vanhat tekstipainikkeet mobiilissa, jos FAB on näkyvissä */
body.mobile-view:has(.mobile-fab-container.active) .floating-controls-container,
body.mobile-view:has(.mobile-fab-container.active) #geometry-modify-controls,
body.mobile-view:has(.mobile-fab-container.active) #offline-area-controls {
    display: none !important;
}

/* Säädetään sijaintia vaakatilassa */
@media (max-height: 500px) and (orientation: landscape) {
    .mobile-fab-container {
        bottom: 20px;
        right: 80px; /* Zoom nappien vasemmalle puolelle */
    }
}

/* =========================================
   PÄIVITETYT TYÖPÖYDÄN MUOKKAUSPAINIKKEET (FAB-TYYLI - KORJAUS)
   ========================================= */

/* 1. Kontainerin siirto ja tyylin poisto */
.floating-controls-container,
#geometry-modify-controls, 
#offline-area-controls,
#gps-recording-controls {
    /* Siirretään alemmas */
    top: 80px !important; 
    
    /* Poistetaan "palkkimainen" tausta ja reunat */
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    
    /* Asettelu */
    display: none; /* JS vaihtaa flexiksi */
    flex-direction: row !important; /* Pakotetaan vaaka */
    gap: 15px !important; 
    padding: 0 !important;
    pointer-events: none; /* Sallii klikkaukset nappien välistä */
    
    /* Nollataan mitat */
    width: auto !important;
    min-width: auto !important;
    height: auto !important;
}

/* Näytetään flexinä kun aktiivinen */
.floating-controls-container[style*="display: flex"],
#geometry-modify-controls[style*="display: flex"],
#offline-area-controls[style*="display: flex"],
#gps-recording-controls[style*="display: flex"] {
    display: flex !important;
}

/* 2. Nappien muotoilu pyöreiksi (FAB) */
.floating-controls-container .map-tool-button,
#geometry-modify-controls .map-tool-button,
#offline-area-controls .map-tool-button,
#gps-recording-controls .map-tool-button {
    pointer-events: auto;
    
    /* Pakotetaan pyöreä muoto */
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    border-radius: 50% !important;
    
    padding: 0 !important;
    margin: 0 !important;
    
    /* PIILOTETAAN TEKSTIT */
    font-size: 0 !important;
    line-height: 0 !important;
    
    display: flex !important;
    align-items: center;
    justify-content: center;
    
    box-shadow: 0 4px 8px rgba(0,0,0,0.3) !important;
    border: 2px solid rgba(255,255,255,0.2) !important;
    transition: transform 0.2s ease, filter 0.2s ease, opacity 0.2s ease !important; /* Lisätty opacity transition */
}

/* --- TÄRKEÄ KORJAUS: Piilotetaan mobiilitekstit (::after) --- */
.floating-controls-container .map-tool-button::after,
#geometry-modify-controls .map-tool-button::after,
#offline-area-controls .map-tool-button::after,
#gps-recording-controls .map-tool-button::after {
    content: none !important;
    display: none !important;
}

/* 3. Ikonien varmistus */
.floating-controls-container .map-tool-button .button-icon,
#geometry-modify-controls .map-tool-button .button-icon,
#offline-area-controls .map-tool-button .button-icon,
#gps-recording-controls .map-tool-button .button-icon {
    width: 22px !important;
    height: 22px !important;
    min-width: 22px !important;
    min-height: 22px !important;
    margin: 0 !important;
    display: block !important;
    fill: currentColor !important;
    /* Varmistetaan että ikoni on keskellä eikä siirry tekstin takia */
    position: static !important; 
    transform: none !important;
}

/* 4. Värit */

/* Peruuta / Lopeta (Punainen) */
#cancel-geometry-modify-button,
#cancel-offline-area-button,
#stop-gps-recording-button {
    background-color: var(--danger-color) !important;
    color: white !important;
}

/* Kumoa (Keltainen/Oranssi) */
#undo-geometry-modify-button {
    background-color: #f0ad4e !important;
    color: white !important;
}

/* Tallenna / Valmis (Vihreä) */
#accept-geometry-modify-button,
#accept-offline-area-button {
    background-color: var(--success-color) !important;
    color: white !important;
}

/* 5. Hover-efektit */
.floating-controls-container .map-tool-button:hover:not(:disabled) {
    transform: scale(1.1) !important;
    filter: brightness(1.1);
    box-shadow: 0 6px 12px rgba(0,0,0,0.4) !important;
    z-index: 10;
}

.floating-controls-container .map-tool-button:active:not(:disabled) {
    transform: scale(0.95) !important;
}

/* 6. Inaktiivinen tila (Himmennys) */
.floating-controls-container .map-tool-button[style*="opacity: 0.5"],
.floating-controls-container .map-tool-button:disabled {
    box-shadow: none !important;
    filter: grayscale(0.5);
}

/* Piilota tumman tilan asetusvalinta mobiilin asetusikkunasta, 
   koska se löytyy jo alatyökalupalkista */
body.mobile-view #desktopDarkModeLabel {
    display: none !important;
}
/* Työpöytäpiilotus Immersive Modelle (Piilota painikkeet...) */
@media (min-width: 769px) {
    #immersiveModeLabelRow {
        display: none !important;
    }
}
/* Salli teemakytkin työpöydällä, jos se on asetukset-ikkunan sisällä */
@media (min-width: 769px) {
    .theme-toggle-wrapper.in-modal {
        display: flex !important;
    }
}

/* --- KORJAUS: Mobiilipaneelien otsikoiden tiivistäminen --- */

@media (max-width: 768px) {
    
    /* 1. Pakotetaan otsikkoalueen mitat ja välit samoiksi kuin työkalupalkissa */
    body.mobile-view #infoPanelHeader,
    body.mobile-view #summaryPanelHeader {
        padding: 10px 15px !important;
        min-height: 57px;
        max-height: 57px;
        gap: 0 !important;
    }

    /* 2. Pienennetään otsikkotekstin kokoa ja nollataan marginaalit */
    body.mobile-view #infoPanelTitle,
    body.mobile-view #summaryPanelTitle {
        font-size: 1rem !important;
        font-weight: bold;
        margin: 0 !important;
        line-height: 1.2;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        flex-grow: 1; /* Varmistetaan että otsikko täyttää tilan vasemmalla */
    }

    /* 3. Piilotetaan otsikosta tilastot (KPI) mobiilissa */
    body.mobile-view #headerKpiContainer {
        display: none !important;
    }

    /* 4. PERUSTYYLI OTSAKKEEN PAINIKKEILLE (esim. Auto-zoom) */
    body.mobile-view #infoPanelHeader .map-tool-button,
    body.mobile-view #summaryPanelHeader .map-tool-button {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
        padding: 0 !important;
        margin-left: 8px !important;
        
        /* Box-tyyli oletuksena (kuten kohdistusnapilla) */
        background-color: var(--panel-bg) !important; 
        border: 1px solid var(--border-color) !important;
        box-shadow: var(--shadow-sm) !important;
        color: var(--text-color) !important;
        border-radius: 6px !important;
        
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* 4b. AKTIIVINEN TILA (Kun kohdistus on päällä -> Sininen tausta) */
    body.mobile-view #infoPanelHeader .map-tool-button.active,
    body.mobile-view #summaryPanelHeader .map-tool-button.active {
        background-color: var(--accent-color) !important;
        border-color: var(--accent-color) !important;
        color: #fff !important; /* Valkoinen ikoni */
        box-shadow: inset 0 2px 4px rgba(0,0,0,0.2) !important;
    }

    /* 4c. SULKEMISPAINIKE (Poistetaan laatikko -> Läpinäkyvä X) */
    body.mobile-view #infoPanelHeader .panel-close-button,
    body.mobile-view #summaryPanelHeader .panel-close-button {
        background-color: transparent !important;
        border: none !important;
        box-shadow: none !important;
        color: var(--text-muted) !important;
    }
    
    /* 5. Varmistetaan ikonien koko - KORJATTU */
    
    /* Oletuskoko otsakkeen toimintopainikkeille (kuten Kohdistus) - Pieni ja siisti */
    body.mobile-view #infoPanelHeader .map-tool-button .button-icon,
    body.mobile-view #summaryPanelHeader .map-tool-button .button-icon {
        width: 18px !important;
        height: 18px !important;
        fill: currentColor !important;
    }

    /* Poikkeus: Sulkemis-rasti (X) pidetään isompana jotta siihen on helppo osua */
    body.mobile-view #infoPanelHeader .panel-close-button .button-icon,
    body.mobile-view #summaryPanelHeader .panel-close-button .button-icon {
        width: 26px !important;
        height: 26px !important;
    }
}

/* Fix: Piilotetaan GPS-kontrollit mobiilissa kun FAB on aktiivinen, ylikirjoittaen aiemmat säännöt */
body.mobile-view:has(.mobile-fab-container.active) #gps-recording-controls {
    display: none !important;
}

/* --- OFFLINE-ASETUSTEN ASETTELUN PARANNUS --- */

/* Muutetaan zoom-valinta kaksisarakkeiseksi gridiksi */
#offlineZoomLevelSelection {
    display: grid;
    grid-template-columns: 1fr 1fr; /* Kaksi yhtä leveää saraketta */
    grid-template-rows: repeat(3, auto); /* Pakotetaan 3 riviä */
    grid-auto-flow: column; /* Täytetään ensin sarake alas, sitten seuraava (10,11,12 vasemmalle) */
    gap: 5px 15px; /* Pystyväli 5px, vaakaväli 15px */
    margin-bottom: 15px;
}

/* Nollataan oletusmarginaalit gridin sisällä tilan säästämiseksi */
#offlineZoomLevelSelection label {
    margin: 0 !important;
    padding: 4px 0;
    white-space: nowrap;
}

/* Varmistetaan, että checkbox ja teksti ovat nätisti linjassa */
#offlineZoomLevelSelection input[type="checkbox"] {
    margin-right: 8px;
}

/* Karttatasot pidetään edelleen yhtenä sarakkeena, mutta tiivistetään hieman */
#offlineLayerSelection label {
    margin-top: 4px !important;
    margin-bottom: 4px !important;
}

/* --- MODAALIEN INPUT-KENTTIEN TUMMAN TEEMAN KORJAUS --- */

/* Määritellään input-kentät käyttämään globaaleja teemamuuttujia */
#styleModalBody input[type="text"],
#styleModalBody input[type="number"],
#styleModalBody input[type="color"],
#styleModalBody select {
    background-color: var(--input-bg) !important;
    color: var(--text-color) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 4px; /* Pieni pyöristys näyttää paremmalta */
}

/* Korjataan valintalistojen nuolen väri tummassa tilassa (SVG-data URL) */
body.dark-mode #styleModalBody select {
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23e0e0e0%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 0.7rem top 50%;
    background-size: 0.65rem auto;
    appearance: none; /* Poistaa selaimen vakio-tyylin jotta nuoli näkyy oikein */
    padding-right: 25px !important; /* Tilaa nuolelle */
}

/* --- SELITE (LEGEND) UI --- */
#legend-container {
    position: absolute;
    /* Sijoitetaan oletuksena hieman tietolähteiden yläpuolelle */
    bottom: calc(40px + env(safe-area-inset-bottom, 0px));
    right: 10px;
    z-index: 1005;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

#legend-button {
    background-color: rgba(255, 255, 255, 0.8);
    border: none;
    border-radius: 4px;
    padding: 2px 6px;
    font-size: 11px;
    color: #333;
    cursor: pointer;
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
    font-family: system-ui, -apple-system, sans-serif;
    transition: background-color 0.2s, color 0.2s;
    backdrop-filter: blur(2px);
    
    /* Lisätään pieni ikoni tekstin eteen CSS:llä (valinnainen) */
    display: flex;
    align-items: center;
    gap: 4px;
}

#legend-button::before {
    content: "ⓘ"; /* Yksinkertainen info-ikoni merkkinä */
    font-weight: bold;
    font-family: monospace;
}

#legend-button:hover {
    background-color: rgba(255, 255, 255, 1);
    color: var(--accent-color);
}

#legend-list {
    background-color: var(--panel-bg);
    backdrop-filter: var(--panel-backdrop);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 10px;
    margin-bottom: 5px;
    max-width: 300px; /* Hieman leveämpi kuville */
    max-height: 300px;
    overflow-y: auto;
    box-shadow: var(--shadow-md);
    font-size: 0.85em;
    color: var(--text-color);
    text-align: left;
    display: block;
}

#legend-list.hidden {
    display: none;
}

.legend-item {
    margin-bottom: 15px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 10px;
}

.legend-item:last-child {
    margin-bottom: 0;
    border-bottom: none;
    padding-bottom: 0;
}

.legend-layer-title {
    font-weight: bold;
    font-size: 0.95em;
    margin-bottom: 5px;
    display: block;
    color: var(--accent-color);
}

.legend-image {
    display: block;
    max-width: 100%;
    height: auto;
    border: 1px solid #eee;
    background: white; /* Varmistetaan valkoinen tausta läpinäkyville PNG:ille */
    padding: 2px;
    border-radius: 2px;
}

/* Tulostuksessa piilotetaan */
@media print {
    #legend-container { display: none !important; }
}

/* --- MODAALIEN INPUT-KENTTIEN TUMMAN TEEMAN KORJAUS --- */

/* Määritellään input-kentät käyttämään globaaleja teemamuuttujia */
/* LISÄTTY: #addLayerModal ja .modal-body selektorit */
#styleModalBody input[type="text"],
#styleModalBody input[type="number"],
#styleModalBody input[type="color"],
#styleModalBody select,
#addLayerModal .modal-body input[type="text"],
#addLayerModal .modal-body select {
    background-color: var(--input-bg) !important;
    color: var(--text-color) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 4px; /* Pieni pyöristys näyttää paremmalta */
}

/* LISÄTTY: Lihavoidaan otsikot lisäysikkunassa kuten muokkausikkunassa */
#addLayerModal .setting-item label {
    font-weight: bold;
    margin-bottom: 5px;
    display: block;
}

/* Korjataan valintalistojen nuolen väri tummassa tilassa (SVG-data URL) */
/* LISÄTTY: #addLayerModal selektori */
body.dark-mode #styleModalBody select,
body.dark-mode #addLayerModal .modal-body select {
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23e0e0e0%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 0.7rem top 50%;
    background-size: 0.65rem auto;
    appearance: none; /* Poistaa selaimen vakio-tyylin jotta nuoli näkyy oikein */
    padding-right: 25px !important; /* Tilaa nuolelle */
}



/* --- PÄIVITETTY: Vektorityylin esikatselu (Muotoilu kuvioksi) --- */
.vector-preview-container {
    margin-bottom: 15px;
    padding: 15px 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: var(--input-bg) !important;
    
    /* Keskitetään sisältö (otsikko ja pallo) */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
}

/* Otsikon väri */
.vector-preview-container label {
    color: var(--text-color) !important;
    margin-bottom: 10px !important;
    font-size: 0.85em;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    opacity: 0.8;
}

.transparency-checkered {
    /* Hienovarainen shakkiruutu */
    background-image: 
        linear-gradient(45deg, rgba(128, 128, 128, 0.08) 25%, transparent 25%), 
        linear-gradient(-45deg, rgba(128, 128, 128, 0.08) 25%, transparent 25%), 
        linear-gradient(45deg, transparent 75%, rgba(128, 128, 128, 0.08) 75%), 
        linear-gradient(-45deg, transparent 75%, rgba(128, 128, 128, 0.08) 75%);
    background-size: 20px 20px;
    background-position: 0 0, 0 10px, 10px -10px, -10px 0px;
}

.vector-style-preview-box {
    /* MUUTOS: Suorakulmion mitat */
    width: 120px !important; 
    height: 60px !important;
    
    /* MUUTOS: Pieni pyöristys kulmissa, ei 50% (ympyrä) */
    border-radius: 6px !important; 
    
    box-sizing: border-box;
    transition: all 0.15s ease-out;
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

/* --- Pakotetaan "Poista taso" -nappi punaiseksi --- */
#deleteCustomLayerBtn {
    background-color: var(--danger-color) !important;
    border-color: var(--danger-color) !important;
    color: #ffffff !important;
}

#deleteCustomLayerBtn:hover {
    background-color: var(--danger-color) !important; /* Pidetään punaisena myös hoverissa */
    filter: brightness(1.1); /* Hieman vaaleampi hover-efekti */
    box-shadow: 0 2px 8px rgba(220, 53, 69, 0.4) !important;
}

/* Varmistetaan että ikoni (roskakori) on valkoinen */
#deleteCustomLayerBtn .button-icon {
    fill: #ffffff !important;
}

/* --- KORJAUS: Lisäysikkunan kentät tummaan teemaan --- */
#addLayerModal input[type="text"],
#addLayerModal input[type="number"],
#addLayerModal select,
#addLayerModal input[type="color"] {  /* <--- TÄMÄ LISÄTTY */
    background-color: var(--input-bg) !important;
    color: var(--text-color) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 4px;
    padding: 6px !important; /* <--- LISÄTTY: Yhtenäinen padding (6px) kaikkiin kenttiin */
}

/* LISÄYS: Pienennetään värivalitsimen paddingia, jotta väri näkyy isompana */
#addLayerModal input[type="color"] {
    padding: 2px !important;
}

/* Korjataan myös select-nuoli tummassa tilassa lisäysikkunalle */
body.dark-mode #addLayerModal select {
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23e0e0e0%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 0.7rem top 50%;
    background-size: 0.65rem auto;
    appearance: none;
    padding-right: 25px !important;
}

/* --- KORJAUS: Lisäysikkunan (Add Layer) asettelu ja marginaalit --- */

/* 1. Lisätään väliä jokaisen asetusrivin (otsikko + kenttä) väliin */
#addLayerModal .setting-item {
    margin-bottom: 20px !important; /* Reilumpi väli alaspäin */
}

/* 2. Poistetaan marginaali viimeisestä elementistä, jotta se ei työnnä nappia liikaa */
#addLayerModal .setting-item:last-child {
    margin-bottom: 0 !important;
}

/* 3. Lisätään ilmaa otsikon (Label) ja itse syötekentän (Input/Select) väliin */
#addLayerModal label {
    margin-bottom: 8px !important;
    display: block;
    line-height: 1.2;
}

/* 4. Korjataan tyyliasetukset-osion ylämarginaali (erottaa sen ylemmistä kentistä) */
#addLayerStyleSettings {
    margin-top: 20px !important;
    padding-top: 15px !important;
    border-top: 1px solid var(--border-color);
}

/* 5. Varmistetaan, että esikatselulaatikko ei ole kiinni reunoissa flex-näkymässä */
#addLayerModal .vector-preview-container {
    margin: 0 !important; /* Nollataan containerin omat marginaalit */
    margin-right: 15px !important; /* Väli oikealla oleviin säätimiin */
}

/* Lukitun PRO-ominaisuuden nappi */
.locked-pro-btn {
    background-color: #333 !important; /* Tummanharmaa */
    border: 1px solid #ffd700 !important; /* Kultainen reunus */
    color: #ffd700 !important; /* Kultainen teksti */
}

.locked-pro-btn:hover:not(:disabled) {
    background-color: #444 !important;
    filter: brightness(1.2);
    box-shadow: 0 0 8px rgba(255, 215, 0, 0.4) !important; /* Kultainen hehku */
}

.locked-pro-btn .button-icon {
    fill: #ffd700 !important; /* Kultainen ikoni */
    margin-right: 8px;
}

.modal-close-button {
    /* Pakotetaan samat mitat */
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    
    /* Flex-keskitys */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    
    /* Sijainti modaalin kulmassa */
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    z-index: 10;
    
    /* Ulkoasu */
    padding: 0 !important;
    background: none !important;
    border: none !important;
    color: var(--text-muted) !important;
    border-radius: 6px !important;
    cursor: pointer;
}

.modal-close-button:hover {
    background-color: var(--hover-bg) !important;
    color: var(--text-color) !important;
}

/* Varmistetaan että sisällä oleva SVG on oikean kokoinen (sama kuin asetuksissa) */
.modal-close-button svg,
.modal-close-button .button-icon {
    width: 26px !important;
    height: 26px !important;
    display: block;
    fill: currentColor;
}

/* --- APP BRANDING (Logo & Nimi) --- */
#app-branding {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 1010;
    
    /* Sama tyyli kuin työkalupalkeissa */
    background-color: var(--panel-bg);
    backdrop-filter: var(--panel-backdrop);
    -webkit-backdrop-filter: var(--panel-backdrop);
    border: 1px solid var(--border-color);
    border-top: 1px solid rgba(255, 255, 255, 0.5); /* Valoheijastus ylhäällä */
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);   /* Varjo alhaalla */
    box-shadow: var(--shadow-md);
    border-radius: 10px; /* Tai 50px jos haluat pillerin muotoisen */
    
    padding: 5px 12px 5px 8px; /* Hieman tilaa ympärille */
    display: flex;
    align-items: center;
    gap: 10px;
    
    /* Estä tekstin valinta ja hiiritapahtumat tarvittaessa */
    user-select: none;
    pointer-events: none; /* Klikkaukset menevät läpi karttaan */

    /* MUUTOS: Salli klikkaus ja vaihda kursori */
    pointer-events: auto; 
    cursor: pointer;
    
    /* Lisää pehmeä animaatio painallukselle */
    transition: transform 0.1s ease, background-color 0.2s;
}

/* Hover-efekti */
#app-branding:hover {
    background-color: var(--hover-bg);
}

/* Painallusefekti (pieni kutistus) */
#app-branding:active {
    transform: scale(0.97);
}

#app-branding img {
    width: 36px; /* Sopiva ikonikoko */
    height: 36px;
    object-fit: contain;
    /* Pieni varjo ikonille */
    filter: drop-shadow(0 2px 2px rgba(0,0,0,0.2));
}

#app-branding span {
    font-family: system-ui, -apple-system, sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--text-color);
    letter-spacing: 0.5px;
}
/* Tumma tila vaatii oman säädön */
body.dark-mode #app-branding {
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    border-bottom: 1px solid rgba(0, 0, 0, 0.3);
}

/* --- KORJAUS TYÖKALUPALKIN SIJAINTIIN --- */
/* Koska logo on nyt vasemmassa yläkulmassa, siirretään vasenta palkkia alemmas */
@media (min-width: 769px) {
    #left-icon-toolbar {
        top: 65px !important; /* 10px (logo top) + ~40px (logo height) + 15px (väli) */
    }
}

/* Piilotetaan mobiilissa, jotta säästetään tilaa */
@media (max-width: 768px) {
    #app-branding {
        display: none;
    }
}

/* --- PRO-MERKINTÄ (BADGE) PAINIKKEISIIN --- */

/* 1. Määritellään painikkeet, joissa merkintä näkyy */
#desktop-offline-maps,
#mobile-offline-maps {
    position: relative !important; /* Varmistaa että ::after asemoituu tähän */
    overflow: visible !important;  /* Sallii merkin mennä hieman reunan yli */
}

/* 2. Yhteiset tyylit merkkijonolle */
#desktop-offline-maps::after,
#mobile-offline-maps::after {
    content: "PRO";
    position: absolute;
    background-color: #ffd700; /* Kultainen väri */
    color: #000;               /* Musta teksti */
    font-family: system-ui, -apple-system, sans-serif;
    font-weight: 900;          /* Erittäin lihava */
    border-radius: 4px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
    z-index: 10;
    pointer-events: none;      /* Klikkaukset menevät läpi */
    line-height: 1;
}

/* 3. Työpöytä-näkymän hienosäätö (Pieni nappi) */
#desktop-offline-maps::after {
    top: -5px;
    right: -5px;
    font-size: 8px;
    padding: 2px 3px;
    border: 1px solid var(--panel-bg); /* Pieni reunus erottamaan napista */
}

/* 4. Mobiili-näkymän hienosäätö (Iso ruutu) */
#mobile-offline-maps::after {
    top: 8px;
    right: 8px;
    font-size: 10px;
    padding: 3px 5px;
    transform: rotate(5deg); /* Pieni kallistus tyylittelyksi */
}

/* --- MOBIILIN TARTTUMISKAHVA (Pilleri) --- */
.mobile-pull-handle {
    display: none; /* Piilossa työpöydällä */
}

@media (max-width: 768px), (max-height: 500px) {
    .mobile-pull-handle {
        display: block;
        width: 40px;
        height: 5px;
        background-color: var(--text-muted);
        border-radius: 3px;
        margin: 8px auto 0; /* Keskitetään ja jätetään vähän tilaa ylös */
        opacity: 0.4;
        flex-shrink: 0;
        
        /* KORJAUS: Estää selaimen skrollauksen ja sallii JS-raahauksen */
        touch-action: none !important;
        cursor: grab;
    }
    
    /* Varmistetaan että paneelien headerit eivät peitä kahvaa */
    .bottom-sheet-header, 
    #infoPanelHeader, 
    #summaryPanelHeader {
        padding-top: 5px !important; /* Pienennetään yläpaddingia kahvan alta */
    }
}

/* Vaakamobiilissa (Landscape) kahva voi olla tarpeeton tai siirretty, 
   mutta pidetään se tässäkin selkeyden vuoksi keskellä */
@media (max-height: 500px) and (orientation: landscape) {
    .mobile-pull-handle {
        margin-top: 6px;
    }
}

/* 1. SÄÄNTÖKORTTI */
.rule-editor-card {
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    border-left: 4px solid var(--accent-color); /* Korostus vasemmalla */
    padding: 15px;
    margin-bottom: 15px;
    border-radius: 6px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Rule Header Layout - Päivitetty */
.rule-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 8px;
    margin-bottom: 8px; /* Hieman enemmän tilaa input-kentille */
    gap: 10px;
}

/* UUSI: Kontaineri nuolille ja kahvalle */
.rule-order-controls {
    display: flex;
    align-items: center;
    gap: 2px;
    background-color: var(--bg-color); /* Erotetaan taustasta hieman */
    padding: 2px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
}

/* Nuolinappien tyyli */
.rule-order-controls .btn-icon-only {
    padding: 6px;
    width: 32px;
    height: 32px;
    border-radius: 4px;
    color: var(--text-color);
    transition: background-color 0.2s;
}

.rule-order-controls .btn-icon-only:hover:not(:disabled) {
    background-color: var(--hover-bg);
    color: var(--accent-color);
}

.rule-order-controls .btn-icon-only:disabled {
    opacity: 0.3;
    cursor: default;
}

/* Pienennetään SVG-ikoneita hieman, jotta mahtuvat */
.rule-order-controls .btn-icon-only svg {
    width: 16px;
    height: 16px;
}

/* Mobiilioptimointi: Jos tila loppuu, piilota raahauskahva (koska nuolet ovat nyt paremmat) */
@media (max-width: 450px) {
    .rule-drag-handle {
        display: none; /* Säästää tilaa mobiilissa, nuolet riittävät */
    }
    .rule-order-controls {
        border: none;
        background: transparent;
        padding: 0;
    }
}

.rule-number-badge {
    background: var(--accent-color);
    color: #fff;
    font-size: 0.8em;
    font-weight: bold;
    padding: 2px 8px;
    border-radius: 12px;
    margin-right: 10px;
}

.rule-name-input {
    border: none;
    background: transparent;
    font-weight: 600;
    color: var(--text-color);
    font-size: 1em;
    width: 100%;
    min-width: 0; /* Estää flex-laatikon leviämisen */
}

.rule-name-input:focus {
    outline: none;
    border-bottom: 1px dashed var(--accent-color);
}

/* 3. GRID-ASETTELU LOMAKKEILLE */
.rule-grid-row {
    display: grid;
    grid-template-columns: 80px 1fr; /* Etiketti (80px) | Sisältö (loput) */
    align-items: center;
    gap: 10px;
}

/* Ehdon sisäinen grid (Operaattori | Kenttä | Arvo) */
.condition-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr 1fr; /* Suhteet */
    gap: 8px;
    width: 100%;
}

/* Jos "AINA" on valittu, piilotetaan muut (JS hoitaa, mutta tässä fallback) */
.condition-grid.single-col {
    grid-template-columns: 1fr;
}

/* Tyyli-osion grid (Reuna ja Täyttö vierekkäin isolla näytöllä) */
.style-cols-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

/* Mobiililaitteessa tyylit allekkain */
@media (max-width: 600px) {
    .style-cols-wrapper {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .condition-grid {
        grid-template-columns: 1fr; /* Mobiilissa ehdot allekkain */
    }
}

/* 4. INPUT-KENTTIEN YHDISTÄMINEN */
.input-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Värivalitsimen ja numerokentän yhdistelmä */
.color-input-wrapper {
    display: flex;
    align-items: center;
    background: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 4px;
    width: 100%;
}

.rule-color-input {
    width: 32px;
    height: 32px;
    border: none;
    padding: 0;
    background: none;
    cursor: pointer;
    flex-shrink: 0;
}

.rule-number-input {
    border: none;
    background: transparent;
    width: 100%;
    padding-left: 8px;
    color: var(--text-color);
    font-size: 0.95em;
}
.rule-number-input:focus { outline: none; }

/* 5. ESIKATSELU */
.rule-preview-bar {
    height: 12px;
    width: 100%;
    border-radius: 6px;
    margin-top: 5px;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.1);
}

/* 6. UUSI PAINIKE-TYYLI (Korjaa tekstin rivityksen) */
.modal-wide-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 20px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: all 0.2s;
    text-decoration: none;
    /* Nollaa map-tool-buttonin asettamat rajoitteet */
    height: auto !important;
    min-height: 44px;
}

.modal-wide-btn.success {
    background-color: var(--success-color);
    color: white;
}
.modal-wide-btn.success:hover {
    background-color: #155724; /* Tummempi vihreä */
}

.modal-wide-btn svg {
    margin-right: 8px;
    width: 18px;
    height: 18px;
    fill: currentColor;
}

/* Pieni poista-nappi (oikea yläkulma) */
.btn-icon-only {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
}
.btn-icon-only:hover {
    background-color: var(--danger-bg);
    color: var(--danger-text);
}
.btn-icon-only svg {
    width: 20px;
    height: 20px;
}

/* --- SÄÄNTÖEDITORIN TEEMAKORJAUKSET JA RAAHAUS --- */

/* 1. Pakotetaan input-kentät noudattamaan teemaa sääntökortin sisällä */
.rule-editor-card input[type="text"],
.rule-editor-card input[type="number"],
.rule-editor-card select {
    background-color: var(--input-bg) !important;
    color: var(--text-color) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 4px;
    padding: 6px !important;
}

/* Korjataan select-nuoli tummassa tilassa */
body.dark-mode .rule-editor-card select {
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23e0e0e0%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 0.7rem top 50%;
    background-size: 0.65rem auto;
    appearance: none;
    padding-right: 25px !important;
}

/* Drag kahva nuolten vieressä */
.rule-drag-handle {
    padding: 0 8px;
    border-left: 1px solid var(--border-color);
    margin-left: 2px;
    cursor: grab;
    color: var(--text-muted);
}

.rule-drag-handle:active {
    cursor: grabbing;
    color: var(--accent-color);
}

.rule-drag-handle svg {
    width: 20px;
    height: 20px;
    pointer-events: none;
}

/* 3. Raahauksen aikainen visuaalinen tila */
.rule-editor-card.dragging {
    opacity: 0.5;
    background-color: var(--hover-bg);
    border: 2px dashed var(--accent-color);
}

.rule-editor-card.drag-over {
    border-top: 3px solid var(--accent-color); /* Indikoi pudotuskohtaa */
}

/* --- SÄÄNTÖEDITORIN ULKOASUPARANNUKSET (VAALEA TEEMA) --- */

/* 1. Kortin yleisilme: Varjostus ja pehmeämpi reuna */
body:not(.dark-mode) .rule-editor-card {
    background-color: #ffffff;
    border: 1px solid #e0e6ed; /* Vaalea siniharmaa reuna */
    border-left: 4px solid var(--accent-color);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03); /* Pehmeä varjo */
    border-radius: 8px;
    margin-bottom: 20px; /* Hieman enemmän väliä korttien väliin */
}

/* 2. Otsikkorivi: Erotetaan taustavärillä */
body:not(.dark-mode) .rule-header-row {
    background-color: #f8f9fa; /* Todella vaalea harmaa */
    border-bottom: 1px solid #e0e6ed;
    
    /* Negatiiviset marginaalit kumoavat kortin paddingin, jotta tausta täyttää yläosan */
    margin: -15px -15px 15px -15px; 
    padding: 10px 15px;
    
    border-top-right-radius: 8px; /* Pyöristys vain oikealle, vasemmalla on accent-viiva */
}

/* 3. Input-kentät: Modernimpi ilme */
body:not(.dark-mode) .rule-editor-card input[type="text"],
body:not(.dark-mode) .rule-editor-card input[type="number"],
body:not(.dark-mode) .rule-editor-card select {
    background-color: #ffffff !important;
    border: 1px solid #cfd5db !important;
    border-radius: 6px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03); /* Hyvin hienovarainen sisävarjo/syvyys */
    transition: border-color 0.2s, box-shadow 0.2s;
}

/* Input-kenttä aktiivisena */
body:not(.dark-mode) .rule-editor-card input:focus,
body:not(.dark-mode) .rule-editor-card select:focus {
    border-color: var(--accent-color) !important;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1); /* Focus-rengas */
    outline: none;
}

/* 4. Numeromerkki (Badge) */
body:not(.dark-mode) .rule-number-badge {
    box-shadow: 0 2px 4px rgba(0,0,0,0.15); /* Pieni varjo pallolle */
    background: linear-gradient(135deg, var(--accent-color), #0056b3); /* Hienovarainen liuku */
}

/* 5. Raahauskahva ja poistonappi */
body:not(.dark-mode) .rule-drag-handle,
body:not(.dark-mode) .btn-delete-rule {
    color: #9ca3af; /* Neutraali harmaa */
    transition: color 0.2s;
}

body:not(.dark-mode) .rule-drag-handle:hover,
body:not(.dark-mode) .btn-delete-rule:hover {
    color: #4b5563; /* Tummempi harmaa hoverissa */
    background-color: rgba(0,0,0,0.05); /* Pyöreä tausta hoverissa */
    border-radius: 4px;
}

/* 6. Säännön nimen input-kenttä otsikossa */
body:not(.dark-mode) .rule-name-input {
    font-weight: 700;
    color: #374151; /* Tummanharmaa teksti mustan sijaan */
}

.ol-viewport {
    touch-action: none !important;
    -webkit-touch-callout: none !important;
    -webkit-user-select: none !important;
    user-select: none !important;
    
    /* UUSI LISÄYS: Estää Androidin/iOS:n "kuminauha"-efektin,
       joka voi katkaista kosketustapahtuman nopeissa liikkeissä. */
    overscroll-behavior: none !important;
}
/* --- DARK MODE KORJAUS ALAKAHVALLE --- */
body.dark-mode #mobile-tools-handle {
    background-color: var(--panel-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-bottom: none !important;
    box-shadow: 0 -2px 10px rgba(0,0,0,0.3) !important;
}
/* KORJAUS: Poistetaan reunat ja taustat otsikkopainikkeilta tummassa tilassa */
body.dark-mode .bottom-sheet-header .map-tool-button,
body.dark-mode .panel-close-button,
body.dark-mode .modal-close-button,
body.dark-mode .modal-header-with-menu .map-tool-button {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Palautetaan hover-efekti kuitenkin kevyenä */
body.dark-mode .bottom-sheet-header .map-tool-button:hover,
body.dark-mode .panel-close-button:hover,
body.dark-mode .modal-close-button:hover,
body.dark-mode .modal-header-with-menu .map-tool-button:hover {
    background-color: var(--hover-bg) !important;
}

/* --- DARK MODE KORJAUS: Selite ja Tietolähteet painikkeet --- */
body.dark-mode #attribution-button,
body.dark-mode #legend-button {
    background-color: rgba(21, 29, 40, 0.85); /* Tumma, hieman läpinäkyvä tausta (var(--panel-bg) sävy) */
    color: var(--text-color);
    border: 1px solid var(--border-color); /* Lisätään reuna erottuvuuden vuoksi */
    box-shadow: 0 2px 6px rgba(0,0,0,0.5);
}

body.dark-mode #attribution-button:hover,
body.dark-mode #legend-button:hover {
    background-color: var(--hover-bg);
    color: var(--accent-color);
}

/* --- FIX: Dark Mode Active Buttons (Mobiili & Desktop) --- */
/* Määritellään säännöt, jotka pakottavat sinisen värin (accent) päälle,
   vaikka elementissä olisi hover-tila päällä (mikä tapahtuu mobiilissa tapauttaessa). */

body.dark-mode .map-tool-button.active,
body.dark-mode .map-tool-button.active:hover,
body.dark-mode .ol-control button.active,
body.dark-mode .ol-control button.active:hover,
/* Erikseen paneelien header-painikkeet (kuten layer switcher toggle) */
body.dark-mode .panel-header .map-tool-button.active,
body.dark-mode .panel-header .map-tool-button.active:hover,
/* Mobiilin bottom sheet header */
body.dark-mode .bottom-sheet-header .map-tool-button.active,
body.dark-mode .bottom-sheet-header .map-tool-button.active:hover,
/* Modaalien headerit */
body.dark-mode .modal-header-with-menu .map-tool-button.active,
body.dark-mode .modal-header-with-menu .map-tool-button.active:hover {
    background-color: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    color: #ffffff !important;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.2) !important;
    opacity: 1 !important;
}

/* Varmistetaan ikonin väri valkoiseksi */
body.dark-mode .map-tool-button.active .button-icon,
body.dark-mode .map-tool-button.active:hover .button-icon,
body.dark-mode .ol-control button.active .button-icon {
    fill: #ffffff !important;
}

/* --- DARK MODE OVERRIDES (Palautetaan tumma teema kun dark mode on päällä) --- */
body.dark-mode .map-tool-button, 
body.dark-mode .ol-control button {
    background-color: var(--panel-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-color) !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.4) !important; /* Hienovaraisempi varjo tummassa */
}

/* KORJAUS: Lisätty :not(.active) jotta harmaa hover ei ylikirjoita sinistä aktiiviväriä */
body.dark-mode .map-tool-button:hover:not(:disabled):not(.disabled):not(.active), 
body.dark-mode .ol-control button:hover:not(:disabled):not(.disabled):not(.active) {
    background-color: var(--hover-bg) !important;
    border-color: var(--text-muted) !important;
}

/* --- LISÄÄ TÄMÄ TIEDOSTON LOPPUUN --- */

/* KORJAUS: Pakotetaan sulkemisrastit (Close Buttons) ilman reunoja ja taustaa tummassa tilassa.
   Tämä on tiedoston lopussa, jotta se ylikirjoittaa yleiset map-tool-button -tyylit. */
body.dark-mode .modal-close-button,
body.dark-mode .panel-close-button,
body.dark-mode .bottom-sheet-header .map-tool-button {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Palautetaan hover-efekti (kevyt tausta) */
body.dark-mode .modal-close-button:hover,
body.dark-mode .panel-close-button:hover,
body.dark-mode .bottom-sheet-header .map-tool-button:hover {
    background-color: var(--hover-bg) !important;
    border: none !important; /* Varmistetaan ettei reuna tule takaisin hoverissa */
}
