:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;--color-bg: #f5f5f5;--color-text: #1a1a2e;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-link: #2563eb;--color-header-bg: #1e3a5f;--color-card-bg: #ffffff;--color-card-shadow: rgba(0,0,0,.1);--color-input-bg: #ffffff;--color-input-border: #d1d5db;--color-border: #e5e7eb;--color-surface: #f9fafb;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-btn-secondary-bg: #e5e7eb;--color-btn-secondary-text: #374151;--color-btn-secondary-hover: #d1d5db;--color-conditions-bg: #ffffff;--color-conditions-value: #1e3a5f;--color-forecast-bg: #f9fafb;--color-forecast-border: #e5e7eb;--color-map-btn-bg: #ffffff;--color-map-btn-hover: #f3f4f6;--color-disclaimer-bg: #fef3c7;--color-disclaimer-border: #f59e0b;--color-disclaimer-text: #92400e;--color-loading-spinner: #d1d5db;--color-loading-spinner-active: #2563eb;--color-page-title: #1e3a5f;--color-label: #374151;color:var(--color-text);background-color:var(--color-bg)}[data-theme=dark]{--color-bg: #0f172a;--color-text: #e2e8f0;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-link: #60a5fa;--color-header-bg: #0c1524;--color-card-bg: #1e293b;--color-card-shadow: rgba(0,0,0,.3);--color-input-bg: #1e293b;--color-input-border: #334155;--color-border: #334155;--color-surface: #1e293b;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-btn-secondary-bg: #334155;--color-btn-secondary-text: #e2e8f0;--color-btn-secondary-hover: #475569;--color-conditions-bg: #1e293b;--color-conditions-value: #93c5fd;--color-forecast-bg: #1e293b;--color-forecast-border: #334155;--color-map-btn-bg: #1e293b;--color-map-btn-hover: #334155;--color-disclaimer-bg: #422006;--color-disclaimer-border: #92400e;--color-disclaimer-text: #fbbf24;--color-loading-spinner: #334155;--color-loading-spinner-active: #60a5fa;--color-page-title: #93c5fd;--color-label: #cbd5e1}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;height:100vh}a{color:var(--color-link);text-decoration:none}a:hover{text-decoration:underline}.risk-low{color:#16a34a}.risk-moderate{color:#d97706}.risk-high{color:#dc2626}.risk-extreme{color:#7f1d1d}.risk-bg-low{background-color:#16a34a}.risk-bg-moderate{background-color:#d97706}.risk-bg-high{background-color:#dc2626}.risk-bg-extreme{background-color:#7f1d1d}.leaflet-container{height:100%;width:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--color-header-bg);color:#fff;box-shadow:0 2px 4px #0000001a}.app-header h1{font-size:1.25rem;font-weight:700}.app-header nav{display:flex;gap:1rem;align-items:center}.app-header nav a{color:#ffffffd9;font-size:.875rem;text-decoration:none}.app-header nav a:hover{color:#fff;text-decoration:none}.theme-toggle{background:none;border:none;color:#ffffffd9;cursor:pointer;font-size:1rem;padding:.15rem .3rem;border-radius:4px;line-height:1}.theme-toggle:hover{color:#fff;background:#ffffff1a}.app-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;background:var(--color-bg)}.page-container{max-width:800px;margin:0 auto;padding:2rem 1rem;width:100%;box-sizing:border-box}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--color-page-title)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.25rem;color:var(--color-label)}.form-group input,.form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--color-input-border);border-radius:6px;font-size:.875rem;background:var(--color-input-bg);color:var(--color-text);box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb33}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-btn-secondary-bg);color:var(--color-btn-secondary-text)}.btn-secondary:hover{background:var(--color-btn-secondary-hover)}.btn-lg{padding:.75rem 2rem;font-size:1rem}.card{background:var(--color-card-bg);border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px var(--color-card-shadow);margin-bottom:1rem}.safety-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:700;color:#fff;text-transform:uppercase}.spot-card{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.spot-card:hover{box-shadow:0 2px 8px #00000026}.spot-card-info h3{font-size:1rem;margin-bottom:.25rem}.spot-card-info p{font-size:.8rem;color:var(--color-text-secondary)}.map-page{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.map-container{flex:1;min-height:0}.map-controls{position:absolute;top:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem}.map-btn{width:40px;height:40px;border-radius:8px;background:var(--color-map-btn-bg);color:var(--color-text);border:none;box-shadow:0 2px 6px #0003;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center}.map-btn:hover{background:var(--color-map-btn-hover)}.conditions-bar{background:var(--color-conditions-bg);padding:.75rem 1rem;box-shadow:0 -2px 4px #0000001a;display:flex;gap:1.5rem;font-size:.8rem;overflow-x:auto}.conditions-bar .condition-item{display:flex;flex-direction:column;align-items:center;white-space:nowrap}.conditions-bar .condition-label{color:var(--color-text-secondary);font-size:.7rem}.conditions-bar .condition-value{font-weight:700;color:var(--color-conditions-value)}.forecast-strip{display:flex;gap:0;background:var(--color-forecast-bg);border-top:1px solid var(--color-forecast-border);overflow-x:auto;scrollbar-width:none}.forecast-strip::-webkit-scrollbar{display:none}.forecast-hour{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;padding:.35rem .25rem;gap:.1rem;border-right:1px solid var(--color-border)}.forecast-hour:last-child{border-right:none}.forecast-time{font-size:.6rem;color:var(--color-text-muted);font-weight:500}.forecast-icon{font-size:.85rem;line-height:1}.forecast-temp{font-size:.7rem;font-weight:700;color:var(--color-conditions-value)}.forecast-wind{font-size:.55rem;color:var(--color-text-secondary)}.forecast-wind:after{content:" km/h"}.condition-alerts{display:flex;flex-direction:column;gap:0}.condition-alert{padding:.5rem 1rem;font-size:.8rem;font-weight:500}.condition-alert-warning{background:#fef3c7;color:#92400e;border-bottom:1px solid #f59e0b}.condition-alert-severe{background:#fef2f2;color:#991b1b;border-bottom:1px solid #dc2626}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.score-breakdown{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin:1rem 0}.score-item{text-align:center;padding:.75rem;background:var(--color-surface);border-radius:8px}.score-item .score-value{font-size:1.5rem;font-weight:700}.score-item .score-label{font-size:.75rem;color:var(--color-text-secondary)}.landing{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2d5f8a);color:#fff;text-align:center;padding:2rem}.landing h1{font-size:3rem;margin-bottom:.5rem}.landing .tagline{font-size:1.25rem;opacity:.85;margin-bottom:2rem;max-width:500px}.landing .actions{display:flex;gap:1rem}.landing .btn-primary{background:#f59e0b;color:#1e3a5f}.landing .btn-primary:hover{background:#d97706}.landing .btn-secondary{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3)}.landing .btn-secondary:hover{background:#ffffff40}.wizard-step{text-align:center;max-width:500px;margin:0 auto}.wizard-step h2{margin-bottom:.5rem;color:var(--color-page-title)}.wizard-step p{color:var(--color-text-secondary);margin-bottom:1.5rem}.option-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:2rem}.option-card{padding:1rem;border:2px solid var(--color-border);border-radius:8px;cursor:pointer;text-align:center;transition:all .15s;background:var(--color-card-bg)}.option-card:hover{border-color:#93c5fd}.option-card.selected{border-color:var(--color-primary);background:#eff6ff}[data-theme=dark] .option-card.selected{background:#1e3a5f}.option-card .option-icon{font-size:2rem;margin-bottom:.5rem}.option-card .option-label{font-size:.8rem;font-weight:600}.wizard-nav{display:flex;justify-content:space-between;margin-top:1rem}.disclaimer{background:var(--color-disclaimer-bg);border:1px solid var(--color-disclaimer-border);border-radius:8px;padding:.35rem .6rem;font-size:.7rem;color:var(--color-disclaimer-text);margin:.75rem 0}.disclaimer a{color:var(--color-disclaimer-text);font-weight:600}.error-msg{color:#dc2626;font-size:.85rem;margin-top:.5rem}.loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-secondary)}.loading:before{content:"";width:1.25rem;height:1.25rem;border:2px solid var(--color-loading-spinner);border-top-color:var(--color-loading-spinner-active);border-radius:50%;animation:spin .6s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-secondary)}.empty-state h3{font-size:1.1rem;color:var(--color-label);margin-bottom:.5rem}.empty-state p{font-size:.9rem}[data-theme=dark] .leaflet-popup-content-wrapper{background:var(--color-card-bg);color:var(--color-text)}[data-theme=dark] .leaflet-popup-tip{background:var(--color-card-bg)}@media(max-width:768px){.app-header{padding:.5rem 1rem}.app-header h1{font-size:1rem}.app-header nav{gap:.5rem}.app-header nav a{font-size:.75rem}.page-container{padding:1rem .75rem}.page-title{font-size:1.25rem;margin-bottom:1rem}.detail-header{flex-direction:column;gap:.5rem}.score-breakdown{grid-template-columns:repeat(2,1fr);gap:.5rem}.score-item .score-value{font-size:1.25rem}.landing h1{font-size:2rem}.landing .tagline{font-size:1rem}.landing .actions{flex-direction:column;width:100%;max-width:280px}.option-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.conditions-bar{gap:1rem;padding:.5rem .75rem}.card{padding:1rem}.btn-lg{padding:.625rem 1.5rem;font-size:.9rem}.spot-card{flex-direction:column;align-items:flex-start;gap:.5rem}.page-container>div[style*="display: flex"][style*=gap]{flex-wrap:wrap}}@media(max-width:480px){.score-breakdown{grid-template-columns:repeat(2,1fr)}.map-controls{top:.5rem;right:.5rem}.map-btn{width:36px;height:36px;font-size:1rem}}
