:root{--color-primary: #ff6b35;--color-primary-dark: #e55a2b;--color-primary-light: #ff8c5a;--color-wind-none: #9E9E9E;--color-wind-light: #81D4FA;--color-wind-light-medium: #4FC3F7;--color-wind-medium: #29B6F6;--color-wind-medium-strong: #03A9F4;--color-wind-strong: #0288D1;--color-wind-very-strong: #0277BD;--color-wind-extreme: #01579B;--color-thermveryweak: #FFECB3;--color-thermweak: #FFD54F;--color-thermmoderate: #FFA726;--color-thermstrong: #FF7043;--color-thermverystrong: #FF5722;--color-success: #4caf50;--color-success-light: #81c784;--color-warning: #ff9800;--color-danger: #f44336;--color-info: #2196f3;--color-bg: #f5f5f5;--color-bg-dark: #eeeeee;--color-card: #ffffff;--color-surface: #fafafa;--color-border: #e0e0e0;--color-border-light: #f0f0f0;--color-text: #212121;--color-text-secondary: #757575;--color-text-muted: #9e9e9e;--color-text-light: #ffffff;--color-muted: #9e9e9e;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;color-scheme:light}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.5;min-height:100vh}.app{min-height:100vh;background:var(--color-bg)}.app-header{background:var(--color-card);padding:var(--space-md);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.logo-btn{display:flex;align-items:center;gap:var(--space-sm);background:none;border:none;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.logo-btn:hover{background:var(--color-bg)}.logo-icon{font-size:var(--font-size-2xl)}.logo-text{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);letter-spacing:-.5px}.date-picker{display:flex;align-items:center;gap:var(--space-sm)}.nav-btn{min-width:44px;min-height:44px;padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);background:var(--color-card);border-radius:var(--radius-sm);font-size:var(--font-size-lg);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.nav-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.current-date{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);min-width:80px;text-align:center}.header-buttons{display:flex;gap:var(--space-xs)}.spot-nav{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-xs);scrollbar-width:none}.spot-nav::-webkit-scrollbar{display:none}.nav-item{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.nav-item:hover{background:var(--color-bg);color:var(--color-text)}.nav-item.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 2px 8px #ff6b354d}.nav-item:active{transform:scale(.95)}.nav-icon{font-size:var(--font-size-base)}.dashboard{padding:var(--space-md)}.bise-card{background:var(--color-card);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.bise-info{display:flex;align-items:center;gap:var(--space-sm)}.bise-icon{font-size:var(--font-size-xl)}.bise-label{font-weight:600;font-size:var(--font-size-base)}.bise-status{margin-left:auto;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.bise-status.active{color:var(--color-info);font-weight:600;background:#2196f31a;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full)}.bise-timeline{display:flex;gap:var(--space-sm);margin-top:var(--space-sm);overflow-x:auto;padding-top:var(--space-xs)}.bise-hour{display:flex;flex-direction:column;align-items:center;min-width:40px}.bise-hour .hour{font-size:var(--font-size-xs);color:var(--color-text-muted)}.bise-hour .diff{font-size:var(--font-size-sm);font-weight:600;color:var(--color-info)}.bora-card{background:var(--color-card);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.bora-info{display:flex;align-items:center;gap:var(--space-sm)}.bora-icon{font-size:var(--font-size-xl)}.bora-label{font-weight:600;font-size:var(--font-size-base)}.bora-status{margin-left:auto;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.bora-status.light{color:var(--color-warning);font-weight:600;background:#ff98001a;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full)}.bora-status.strong{color:var(--color-danger);font-weight:700;background:#f443361a;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full)}.bora-timeline{display:flex;gap:var(--space-sm);margin-top:var(--space-sm);overflow-x:auto;padding-top:var(--space-xs)}.bora-hour{display:flex;flex-direction:column;align-items:center;min-width:40px}.bora-hour .hour{font-size:var(--font-size-xs);color:var(--color-text-muted)}.bora-hour .diff{font-size:var(--font-size-sm);font-weight:600;color:var(--color-warning)}.bora-boost{margin-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-warning);font-weight:500;padding:var(--space-xs) var(--space-sm);background:#ff98001a;border-radius:var(--radius-sm)}.bora-warning{width:100%;margin-top:var(--space-sm);padding:var(--space-sm);background:#f4433626;border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-danger);font-weight:500;border:1px solid rgba(244,67,54,.3)}.spots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-md)}.spot-card{background:var(--color-card);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);cursor:pointer;border:2px solid transparent;transition:all var(--transition-normal);text-align:left;display:flex;flex-direction:column;gap:var(--space-sm);min-height:120px;-webkit-tap-highlight-color:transparent}.spot-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.spot-card:active{transform:scale(.98)}.spot-card.error{opacity:.6;border-color:var(--color-danger)}.spot-card .spot-header{display:flex;justify-content:space-between;align-items:center}.spot-card .spot-name{font-weight:600;font-size:var(--font-size-base);color:var(--color-text)}.spot-card .spot-temp{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.spot-card .spot-loading{color:var(--color-text-muted);animation:pulse 1.5s infinite}.spot-card .spot-wind{font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--space-xs)}.spot-card .wind-icon{font-size:var(--font-size-base)}.spot-card .wind-text{font-size:var(--font-size-xs)}.spot-card .spot-thermik{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);margin-top:auto;border:1px solid rgba(0,0,0,.1)}.spot-card .thermik-label{font-size:var(--font-size-xs);font-weight:500}.spot-card .thermik-value{font-size:var(--font-size-xs);font-weight:600}.spot-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.spot-card:active{transform:scale(.98);box-shadow:var(--shadow-sm)}.spot-card-wrapper{display:flex;flex-direction:column}.spot-card-wrapper .spot-card{width:100%}.weekly-forecast{margin-top:var(--space-xs)}.weekly-forecast-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);width:100%;padding:var(--space-xs) var(--space-sm);background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);color:var(--color-text-secondary);transition:background var(--transition-normal)}.weekly-forecast-toggle:hover{background:var(--color-bg-hover)}.weekly-forecast-label{font-weight:500}.weekly-forecast-icon{font-size:10px}.weekly-forecast-content{padding:var(--space-xs) 0}.weekly-forecast-loading{display:flex;align-items:center;gap:var(--space-sm);justify-content:center;padding:var(--space-sm);color:var(--color-text-muted);font-size:var(--font-size-xs)}.weekly-forecast-loading .spinner{width:16px;height:16px;border-width:2px}.weekly-forecast-error{padding:var(--space-sm);color:var(--color-danger);font-size:var(--font-size-xs);text-align:center}.weekly-forecast-retry{margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs)}.weekly-forecast-retry:hover{opacity:.9}.weekly-forecast-grid{display:flex;flex-direction:column;gap:var(--space-xs);overflow:visible}.weekly-row{display:flex;gap:2px}.weekly-row-label{font-size:10px;color:var(--color-text-muted);padding:0 4px;min-width:28px;text-align:right}.weekly-days{display:flex;gap:2px}.day-forecast-box{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:36px;position:relative;cursor:default;overflow:visible}.day-label{font-size:10px;color:var(--color-text-muted);font-weight:500;margin-bottom:1px}.day-wind-box,.day-thermik-box{width:32px;min-height:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:3px;overflow:visible;border:1px solid rgba(0,0,0,.15);box-sizing:border-box}.day-thermik-box{box-shadow:inset 0 0 0 1px #0000000d}.day-wind-value,.day-thermik-value{font-size:9px;font-weight:600;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.3);overflow:visible;text-overflow:ellipsis;white-space:nowrap;max-width:30px}.day-direction-box{width:32px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:3px;margin:1px 0}.day-direction-value{font-size:8px;font-weight:600;color:#fff}.day-forecast-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--color-text);color:#fff;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:11px;white-space:nowrap;z-index:100;pointer-events:none;box-shadow:var(--shadow-md);min-width:80px}.day-forecast-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--color-text)}.tooltip-wind{font-weight:600}.tooltip-category{color:var(--color-text-secondary);font-size:10px}.tooltip-thermik{font-size:10px}.spot-header{display:flex;justify-content:space-between;align-items:center}.spot-name{font-weight:700;font-size:var(--font-size-base);color:var(--color-text)}.spot-temp{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.spot-wind{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm)}.wind-icon{font-size:var(--font-size-xs)}.spot-thermik{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1)}.thermik-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:inherit}.thermik-value{font-size:var(--font-size-sm);font-weight:700;color:inherit}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-md);color:var(--color-text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-muted);font-size:var(--font-size-lg)}.content{padding:var(--space-md);max-width:800px;margin:0 auto}.card{background:var(--color-card);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.wind-summary{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:linear-gradient(135deg,var(--color-success-light) 0%,var(--color-success) 100%);border-radius:var(--radius-md);color:#fff}.wind-summary .icon{font-size:var(--font-size-2xl)}.wind-summary .direction{font-weight:700;font-size:var(--font-size-lg)}.wind-summary .speed{font-size:var(--font-size-base);opacity:.95}.wind-summary .gusts{font-size:var(--font-size-sm);opacity:.85;margin-left:auto}.wind-summary.loading,.wind-summary.no-wind{background:var(--color-card);color:var(--color-text-secondary);border:1px solid var(--color-border)}.wind-summary.thermik-wind{background:linear-gradient(135deg,var(--color-thermmoderate) 0%,var(--color-thermstrong) 100%);color:#fff}.wind-summary.weak-wind{background:linear-gradient(135deg,var(--color-thermveryweak) 0%,var(--color-thermweak) 100%);color:var(--color-text);border:1px solid rgba(0,0,0,.1)}.thermik-box{border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.thermik-header{background:linear-gradient(135deg,var(--color-thermstrong) 0%,var(--color-thermverystrong) 100%);color:#fff;padding:var(--space-md);font-weight:600;font-size:var(--font-size-base);display:flex;align-items:center;justify-content:space-between}.thermik-title{display:flex;align-items:center;gap:var(--space-xs)}.thermik-header .prob{font-weight:700;font-size:var(--font-size-lg);display:flex;align-items:center;gap:var(--space-sm)}.thermik-content{padding:var(--space-md);background:var(--color-card);display:flex;flex-direction:column}.thermik-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-sm)}.thermik-content p:last-child{margin-bottom:0}.thermik-content p.neutral{color:#9e9e9e}.thermik-content p.good{color:var(--color-success)}.thermik-content .time-window{display:inline-block;background:var(--color-bg);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-sm)}.thermik-content .temp-diff{display:inline-block;background:var(--color-bg);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm);border-left:3px solid var(--color-success)}.factor-group{display:flex;flex-direction:column}.factor-group+.factor-group{margin-top:var(--space-sm)}.factor{display:block;margin:var(--space-xs) 0;font-size:var(--font-size-sm);color:var(--color-text);padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-light)}.factor-group .factor:last-child{border-bottom:none}.factor.positive{color:var(--color-success)}.factor.neutral{color:#9e9e9e}.factor.positive.good{color:var(--color-success)}.factor.negative{color:var(--color-danger)}.factor.bora-warning{background:#f443361a;color:var(--color-danger);padding:var(--space-sm);border-radius:var(--radius-sm);border:1px solid rgba(244,67,54,.3);font-weight:500;margin:var(--space-xs) 0}.warning-box{background:#fff3e0;border-left:4px solid var(--color-warning);padding:var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.warning-box.danger{background:#ffebee;border-left-color:var(--color-danger)}.warning-box ul{margin-left:var(--space-lg);margin-top:var(--space-sm)}.warning-box li{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.table-container{overflow-x:auto;margin-bottom:var(--space-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:var(--color-card)}table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}th{background:var(--color-bg);font-weight:600;color:var(--color-text);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:2px solid var(--color-border)}td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light);color:var(--color-text)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--color-surface)}td.model-wind{font-weight:600;color:var(--color-primary)}td.wind-good{color:var(--color-success);font-weight:500}.weather-info{display:flex;flex-wrap:wrap;gap:var(--space-md);padding:var(--space-md);background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:var(--space-md)}.weather-info span{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.error-message,.login-error{color:var(--color-danger);padding:var(--space-md);background:#ffebee;border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:var(--font-size-sm)}.loading-state{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:200px;color:var(--color-text-secondary)}.card .loading-state{min-height:100px;padding:var(--space-lg)}.skeleton-bise,.skeleton-bora{height:60px;background:linear-gradient(90deg,var(--color-bg) 25%,var(--color-bg-dark) 50%,var(--color-bg) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.skeleton-card{height:120px;background:linear-gradient(90deg,var(--color-bg) 25%,var(--color-bg-dark) 50%,var(--color-bg) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 380px){.spots-grid{grid-template-columns:1fr}.nav-item span:not(.nav-icon){display:none}.nav-item{padding:var(--space-xs) var(--space-sm);min-width:44px;justify-content:center}.header-top{gap:var(--space-xs)}}@media (max-width: 639px){.app-header{padding:var(--space-sm)}.header-top{margin-bottom:var(--space-sm)}.logo-text{font-size:var(--font-size-lg)}.logo-icon{font-size:var(--font-size-xl)}.current-date{font-size:var(--font-size-sm);min-width:70px}.nav-btn{width:32px;height:32px;font-size:var(--font-size-base)}.spot-nav{gap:var(--space-xs);padding:var(--space-xs) 0}.nav-item{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);border-radius:var(--radius-full)}.nav-icon{font-size:var(--font-size-sm)}.dashboard,.bise-card{padding:var(--space-sm)}.bise-timeline{gap:var(--space-xs)}.bise-hour{min-width:32px}.bise-hour .hour{font-size:.65rem}.bise-hour .diff{font-size:var(--font-size-xs)}.spots-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.spot-card{padding:var(--space-sm);border-radius:var(--radius-md)}.spot-name{font-size:var(--font-size-sm)}.spot-temp,.spot-wind{font-size:var(--font-size-xs)}.spot-thermik{padding:var(--space-xs) var(--space-sm)}.thermik-label{font-size:.65rem}.thermik-value{font-size:var(--font-size-xs)}.content{padding:var(--space-sm)}.wind-summary{padding:var(--space-sm);flex-wrap:wrap;gap:var(--space-xs)}.wind-summary .direction{font-size:var(--font-size-base)}.wind-summary .speed{font-size:var(--font-size-sm)}.wind-summary .gusts{width:100%;margin-left:0;margin-top:var(--space-xs)}.thermik-box{margin-bottom:var(--space-sm)}.thermik-header{padding:var(--space-sm);flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.thermik-content{padding:var(--space-sm);gap:0}table{font-size:.7rem}th,td{padding:var(--space-xs) var(--space-sm)}}@media (min-width: 640px) and (max-width: 1023px){.spots-grid{grid-template-columns:repeat(2,1fr)}.content{padding:var(--space-md)}.nav-item{padding:var(--space-sm) var(--space-md)}}@media (min-width: 1024px){.spots-grid{grid-template-columns:repeat(3,1fr)}.header-top{margin-bottom:var(--space-lg)}.spot-nav{flex-wrap:wrap;justify-content:center}.nav-item{padding:var(--space-sm) var(--space-lg)}}.icon-strong{color:var(--color-thermstrong)}.icon-moderate{color:var(--color-thermmoderate)}.icon-weak{color:var(--color-thermweak)}.icon-yes{color:var(--color-success)}.icon-no{color:var(--color-danger)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.spinner{animation:none;border-color:var(--color-border);border-top-color:transparent}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus-visible,.nav-item:focus-visible,.spot-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media print{.app-header,.nav-btn,.spot-nav{display:none}.content{max-width:100%}.card,.thermik-box,.wind-summary{break-inside:avoid;box-shadow:none;border:1px solid var(--color-border)}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-dark) 100%);padding:var(--space-md)}.login-card,.login-form{background:var(--color-card);padding:var(--space-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;text-align:center}.login-card h1,.login-form h2{margin:0 0 var(--space-xs);font-size:var(--font-size-2xl);color:var(--color-text)}.login-subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.form-group{margin-bottom:var(--space-md);text-align:left}.form-group label{display:block;margin-bottom:var(--space-xs);font-weight:500;color:var(--color-text)}.form-group input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ff6b351a}.login-button,.login-btn{width:100%;padding:var(--space-sm) var(--space-lg);background:var(--color-primary);color:var(--color-text-light);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:600;cursor:pointer;margin-top:var(--space-md);transition:background var(--transition-fast)}.login-button:hover:not(:disabled),.login-btn:hover:not(:disabled){background:var(--color-primary-dark)}.login-button:disabled,.login-btn:disabled{opacity:.6;cursor:not-allowed}.logout-btn{padding:var(--space-xs) var(--space-sm);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background:var(--color-danger);color:var(--color-text-light);border-color:var(--color-danger)}.info-btn{padding:var(--space-xs) var(--space-sm);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.info-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.info-page{padding:var(--space-md);max-width:900px;margin:0 auto}.info-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.info-header h1{font-size:var(--font-size-xl);color:var(--color-text)}.back-btn{padding:var(--space-xs) var(--space-sm);background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm)}.back-btn:hover{background:var(--color-surface)}.info-content{display:flex;flex-direction:column;gap:var(--space-lg)}.info-section{background:var(--color-card);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-sm)}.info-section h2{font-size:var(--font-size-lg);color:var(--color-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:2px solid var(--color-border-light)}.wind-card{background:var(--color-bg);border-radius:var(--radius-sm);padding:var(--space-md);margin-bottom:var(--space-sm);border-left:4px solid var(--color-primary)}.wind-card.negative{border-left-color:var(--color-danger);background:#fff5f5}.wind-card.warning{border-left-color:var(--color-warning);background:#fff8e1}.wind-card h3{font-size:var(--font-size-base);color:var(--color-text);margin-bottom:var(--space-xs)}.wind-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;margin-bottom:var(--space-sm)}.conditions{font-size:var(--font-size-sm)}.conditions h4{color:var(--color-text);margin-bottom:var(--space-xs)}.conditions ul{list-style:none;padding-left:0}.conditions li{padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-light)}.conditions li:last-child{border-bottom:none}.strength-levels{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.level{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600}.level.strong{background:#ff6b35;color:#fff}.level.moderate{background:#ffa726;color:#fff}.level.weak{background:#bdbdbd;color:#fff}.note{margin-top:var(--space-sm);padding:var(--space-sm);background:#e3f2fd;border-radius:var(--radius-sm);font-size:var(--font-size-sm);border-left:3px solid #2196f3}.note.warning{background:#fff3e0;border-left-color:#ff9800}.note.warning p{margin-top:var(--space-xs);margin-bottom:0}.negative-factors{margin-top:var(--space-sm);padding:var(--space-sm);background:#ffebee;border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.negative-factors ul{margin-top:var(--space-xs)}.toast-container{position:fixed;bottom:var(--space-md);right:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);z-index:1000;max-width:400px}.toast{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);background:var(--color-card);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;border-left:4px solid var(--color-warning);transform:translate(120%);opacity:0;transition:transform .3s ease,opacity .3s ease}.toast.visible{transform:translate(0);opacity:1}.toast.exiting{transform:translate(120%);opacity:0}.toast-icon{font-size:var(--font-size-lg);flex-shrink:0}.toast-content{flex:1}.toast-source{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-xs)}.toast-message{font-size:var(--font-size-sm);color:var(--color-text)}.toast-close{background:none;border:none;font-size:var(--font-size-lg);color:var(--color-text-muted);cursor:pointer;padding:0;line-height:1}.toast-close:hover{color:var(--color-text)}@media (max-width: 640px){.toast-container{left:var(--space-sm);right:var(--space-sm);bottom:var(--space-sm);max-width:none}}.weather-stations{max-width:1200px;margin:0 auto;padding:1rem}.stations-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;position:relative;flex-wrap:wrap}.stations-header h1{font-size:1.5rem;margin:0}.stations-subtitle{color:#555;font-size:.95rem;margin:0;align-self:center}.refresh-btn{position:absolute;right:0;background:#f0f0f0;border:none;border-radius:12px;width:44px;height:44px;min-width:44px;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .1s}.refresh-btn:hover{background:#e0e0e0}.refresh-btn:active{transform:scale(.95)}.info-box{background:#f8f9fa;border:1px solid #dee2e6;border-radius:12px;margin-top:1.5rem;overflow:hidden}.info-header{background:#e9ecef;padding:.875rem 1rem;display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;cursor:pointer;border:none;width:100%;text-align:left;min-height:44px;transition:background .2s}.info-header:hover{background:#dee2e6}.info-header:active{background:#d0d7de}.info-icon{font-size:1.1rem}.info-title{flex:1}.info-arrow{transition:transform .2s;font-size:.75rem;color:#555}.info-arrow.open{transform:rotate(180deg)}.info-content{padding:1rem;border-top:1px solid #dee2e6}.info-item{margin-bottom:1rem;font-size:.875rem}.info-item:last-child{margin-bottom:0}.info-item strong{display:block;color:#333;margin-bottom:.25rem;font-size:.95rem}.info-item p{margin:0;color:#555;line-height:1.5;font-size:.875rem}.stations-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 640px){.stations-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.stations-grid{grid-template-columns:repeat(3,1fr)}}.station-card{background:#fff;border:1px solid #dee2e6;border-radius:12px;overflow:hidden;transition:box-shadow .2s,border-color .2s}.station-card:focus-within{outline:2px solid #4a90d9;outline-offset:2px}.station-card.live-station{border-color:#4caf50;border-width:2px}.station-card .station-header{background:#f8f9fa;padding:1rem;border:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%;cursor:pointer;text-align:left;font-family:inherit;min-height:56px;transition:background .2s}@media (min-width: 640px){.station-card .station-header{cursor:default}}.station-card .station-header:hover{background:#e9ecef}.station-card .station-header:active{background:#dee2e6}.station-card:not(.expanded) .station-header{border-bottom:1px solid #dee2e6}.station-title{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex:1;min-width:0}.station-title h2{margin:0;font-size:.9rem;font-weight:600;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}@media (min-width: 480px){.station-title h2{max-width:180px;font-size:.95rem}}.station-icao{background:#dee2e6;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#555}.station-distance{color:#555;font-size:.875rem}.station-summary{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.station-wind{font-weight:700;font-size:1rem;color:#222}@media (max-width: 639px){.expand-icon{font-size:.875rem;color:#666;transition:transform .2s}.expand-icon.open{transform:rotate(180deg)}}@media (min-width: 640px){.expand-icon{display:none}}.status-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.status-badge.live{background:#e8f5e9;color:#2e7d32}.status-badge.not-configured{background:#fff3e0;color:#ef6c00}.status-badge.error{background:#ffebee;color:#c62828}.station-content{padding:1rem}@media (max-width: 639px){.station-content{animation:slideDown .2s ease-out}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.history-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;margin-top:.75rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;font-size:.9rem;font-weight:500;color:#444;cursor:pointer;min-height:44px;transition:background .2s,border-color .2s}.history-toggle:hover{background:#e9ecef;border-color:#adb5bd}.history-toggle:active{background:#dee2e6}.history-toggle span:first-child{flex:1;text-align:left}.current-weather{padding:.5rem 0}.weather-row{display:flex;justify-content:space-between;margin-bottom:.875rem;gap:.5rem}.weather-row:last-of-type{margin-bottom:.5rem}.weather-item{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.item-icon{font-size:1.1rem;flex-shrink:0}.item-label{font-size:.875rem;color:#555;min-width:45px;flex-shrink:0}.item-value{font-weight:600;font-size:.95rem;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.update-time{margin-top:.875rem;padding-top:.75rem;border-top:1px solid #e9ecef;font-size:.8rem;color:#666;text-align:center}.no-data{padding:1.5rem;text-align:center;color:#666;font-size:.9rem}.station-stats{display:flex;background:#f8f9fa;border-top:1px solid #dee2e6;border-bottom:1px solid #dee2e6;margin:0 -1rem;padding:0 1rem}.stat-item{flex:1;padding:.75rem .5rem;text-align:center;border-right:1px solid #dee2e6}.stat-item:last-child{border-right:none}.stat-label{display:block;font-size:.75rem;color:#555;text-transform:uppercase;margin-bottom:.25rem;font-weight:500}.stat-value{display:block;font-size:1.1rem;font-weight:700;color:#222}.history-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-top:.75rem}.history-table th,.history-table td{padding:.5rem .375rem;text-align:left;border-bottom:1px solid #e9ecef}.history-table th{font-weight:600;color:#444;background:#f8f9fa;font-size:.75rem;text-transform:uppercase}.history-table td{color:#333;font-size:.8rem}.history-table td:first-child{color:#555;font-size:.75rem}.history-table td:nth-child(2){font-family:SF Mono,Monaco,Courier New,monospace;font-size:.8rem}.history-table tr.wind-medium{background-color:#fff8e1}.history-table tr.wind-medium td:first-child{border-left:3px solid #ffc107}.history-table tr.wind-strong{background-color:#ffe0b2}.history-table tr.wind-strong td:first-child{border-left:3px solid #ff9800}.history-table tr.wind-extreme{background-color:#ffcdd2}.history-table tr.wind-extreme td:first-child{border-left:3px solid #f44336}.direction-arrow{display:inline-block;width:1.2em;text-align:center}.history-section{margin-top:.5rem}.loading-history{padding:1rem;text-align:center;color:#666;font-size:.875rem}.no-history{padding:1rem;text-align:center;color:#777;font-size:.875rem;font-style:italic}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#666}.spinner{width:36px;height:36px;border:3px solid #e9ecef;border-top-color:#4a90d9;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.error-container{text-align:center;padding:2rem;color:#c62828}.retry-btn{background:#4a90d9;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;margin-top:1rem;font-weight:600;font-size:.95rem;min-height:44px;transition:background .2s}.retry-btn:hover{background:#3a7bc8}@media (max-width: 639px){.weather-stations{padding:.75rem}.stations-header{padding-right:3rem}.stations-header h1{font-size:1.35rem;flex:1}.stations-subtitle{width:100%;margin-top:.25rem;font-size:.9rem}.stations-grid{gap:.75rem}.station-card{border-radius:10px}.station-card .station-header{min-height:52px;padding:.875rem}.station-title h2{font-size:.875rem}}.station-wind{font-size:.95rem}.station-content{padding:.875rem}.current-weather{padding:.25rem 0}.weather-row{margin-bottom:.625rem}.item-label{font-size:.8rem;min-width:40px}.item-value{font-size:.875rem}.stat-label{font-size:.7rem}.stat-value{font-size:1rem}.history-table{font-size:.75rem}.history-table th,.history-table td{padding:.375rem .25rem;font-size:.75rem}.station-stats{margin:0 -.875rem;padding:0 .875rem}} @media (max-width: 374px){.weather-stations{padding:.5rem}.stations-header h1{font-size:1.2rem}.station-card .station-header{flex-wrap:wrap}.station-title{width:100%;margin-bottom:.375rem}.station-summary{width:100%;justify-content:flex-start}.weather-row{flex-direction:column;gap:.25rem}.weather-item{flex:none}.item-label{min-width:50px}}button:focus-visible,.station-card .station-header:focus-visible{outline:2px solid #4a90d9;outline-offset:2px}@media (prefers-reduced-motion: reduce){.station-content,.expand-icon,.info-arrow,.spinner{animation:none;transition:none}}
