:root{--orange: #FC4C02;--orange-light: #ff7043;--orange-pale: #fff3ee;--navy: #1a1a2e;--navy-light: #222244;--navy-mid: #2a2a4a;--text-primary: #1a1a2e;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e5e7eb;--bg-page: #f4f6f8;--bg-card: #ffffff;--card: #ffffff;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--radius: 12px;--radius-sm: 8px;--sidebar-width: 220px;--color-run: #22c55e;--color-run-bg: #f0fdf4;--color-longrun: #16a34a;--color-longrun-bg: #dcfce7;--color-strength: #8b5cf6;--color-strength-bg: #f5f3ff;--color-bike: #3b82f6;--color-bike-bg: #eff6ff;--color-rest: #94a3b8;--color-rest-bg: #f8fafc;--color-race: #FC4C02;--color-race-bg: #fff3ee;--color-optional: #f59e0b;--color-optional-bg: #fffbeb;font-family:Inter,system-ui,-apple-system,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg-page);color:var(--text-primary)}#root{height:100%}h1,h2,h3,h4{margin:0;font-weight:600;color:var(--text-primary);line-height:1.3}p{margin:0}button{font-family:inherit;cursor:pointer;border:none;background:none;padding:0}input{font-family:inherit}ul{list-style:none;padding:0;margin:0}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--navy);display:flex;flex-direction:column;height:100vh;position:relative;z-index:100;overflow-y:auto;overflow-x:hidden}.sidebar-top{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar-brand{display:flex;align-items:center;gap:10px;margin-bottom:6px}.brand-name{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px}.sidebar-subtitle{font-size:11px;color:#fff6;margin-left:2px}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#fff9;font-size:13.5px;font-weight:500;transition:all .15s ease;width:100%;text-align:left}.nav-item:hover{background:#ffffff12;color:#ffffffe6}.nav-item.active{background:var(--orange);color:#fff}.nav-item.active .nav-icon svg{stroke:#fff}.nav-icon{display:flex;align-items:center;flex-shrink:0}.nav-label{white-space:nowrap}.sidebar-bottom{padding:16px 12px 20px;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:10px}.sidebar-stats{font-size:11px;color:#ffffff59;text-align:center}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh}.main-content{flex:1;overflow-y:auto;padding:24px 28px}.mobile-header,.mobile-bottom-nav,.sidebar-overlay{display:none}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;border:1px solid var(--border)}.card-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px}.dashboard{display:flex;flex-direction:column;gap:20px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:20px;transition:transform .15s ease,box-shadow .15s ease}.stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.stat-card.accent{border-color:var(--orange);background:linear-gradient(135deg,#fff3ee,#fff)}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.1;letter-spacing:-.5px}.stat-card.accent .stat-value{color:var(--orange)}.stat-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.stat-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.dashboard-mid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.today-week-label{font-size:11px;font-weight:600;color:var(--orange);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.today-activity{display:flex;align-items:flex-start;gap:10px;padding:12px;border-radius:var(--radius-sm);background:var(--bg-page);margin-bottom:12px}.today-day{font-weight:700;font-size:13px;min-width:28px}.today-text{font-size:14px;line-height:1.4}.today-tip{font-size:12px;color:var(--text-muted);line-height:1.5;font-style:italic;border-left:3px solid var(--border);padding-left:10px}.next-entries{margin-top:12px;border-top:1px solid var(--border);padding-top:10px;display:flex;flex-direction:column;gap:6px}.next-entries-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:2px}.next-entry{display:flex;align-items:baseline;gap:8px;font-size:13px;padding:5px 8px;border-radius:6px;border-left:3px solid var(--border);background:#fafafa;opacity:.85}.next-entry.type-run{border-left-color:#4caf50}.next-entry.type-longrun{border-left-color:#2196f3}.next-entry.type-strength{border-left-color:#9c27b0}.next-entry.type-bike{border-left-color:#ff9800}.next-entry.type-race{border-left-color:#fc4c02}.next-entry.type-rest{border-left-color:#9e9e9e}.next-entry-day{font-weight:600;min-width:28px;color:var(--text-secondary);white-space:nowrap}.next-entry-kw{font-size:10px;font-weight:400;color:var(--text-muted)}.next-entry-text{color:var(--text-primary);line-height:1.3}.last-runs-list{display:flex;flex-direction:column;gap:2px}.last-run-item{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:var(--radius-sm);transition:background .1s;cursor:default}.last-run-item:hover{background:var(--bg-page)}.last-run-date{font-size:11px;color:var(--text-muted);min-width:50px;font-weight:500}.last-run-info{flex:1;min-width:0}.last-run-name{display:block;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.last-run-stats{display:flex;gap:8px;font-size:12px;color:var(--text-secondary)}.pace-badge{color:var(--orange);font-weight:600}.race-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.race-card{padding:16px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-page);transition:all .15s ease}.race-card:hover{border-color:var(--orange);box-shadow:var(--shadow-sm)}.race-card.main-race{border-color:var(--orange);background:var(--orange-pale)}.race-card.past{opacity:.5}.race-name{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.race-card.main-race .race-name{color:var(--orange)}.race-date{font-size:11px;color:var(--text-secondary);margin-bottom:4px;font-weight:500}.race-goal{font-size:11px;color:var(--text-muted);line-height:1.4;margin-bottom:8px}.race-countdown{font-size:13px;font-weight:700;color:var(--orange)}.race-card.past .race-countdown{color:var(--text-muted);font-weight:500}.empty-text{font-size:13px;color:var(--text-muted);font-style:italic}.training-plan{display:flex;flex-direction:column;gap:20px}.plan-header h2{font-size:22px;font-weight:700}.plan-subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px}.plan-legend{display:flex;flex-wrap:wrap;gap:12px;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.weeks-list{display:flex;flex-direction:column;gap:16px}.week-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1.5px solid var(--border);overflow:hidden;transition:box-shadow .15s ease}.week-card:hover{box-shadow:var(--shadow-md)}.week-card.current-week{border-color:var(--orange);box-shadow:0 0 0 3px #fc4c021a,var(--shadow-md)}.week-card.recovery-week{border-color:#a7f3d0}.week-card.key-week{border-color:#fbbf24;box-shadow:0 0 0 2px #fbbf2426,var(--shadow-md)}.week-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px 12px;background:var(--bg-page);border-bottom:1px solid var(--border);gap:12px}.week-header-left{display:flex;align-items:flex-start;gap:12px}.week-number{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;min-width:56px}.week-card.current-week .week-number{color:var(--orange)}.week-meta{display:flex;flex-direction:column;gap:2px;padding-top:3px}.week-date-range{font-size:12px;color:var(--text-muted);font-weight:500}.week-title{font-size:14px;font-weight:600;color:var(--text-primary)}.week-header-right{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;align-items:center}.badge{padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-current{background:var(--orange);color:#fff}.badge-key{background:#fef3c7;color:#d97706;border:1px solid #fbbf24}.badge-recovery{background:#d1fae5;color:#059669;border:1px solid #6ee7b7}.badge-race{background:var(--orange-pale);color:var(--orange);border:1px solid rgba(252,76,2,.3)}.completion-bar-container{display:flex;align-items:center;gap:8px;padding:8px 20px;background:var(--bg-page);border-bottom:1px solid var(--border)}.completion-bar-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.completion-bar-fill{height:100%;background:var(--orange);border-radius:2px;transition:width .3s ease}.completion-label{font-size:11px;font-weight:600;color:var(--text-muted);min-width:32px;text-align:right}.week-days{padding:8px 0}.day-row{display:flex;align-items:center;gap:10px;padding:9px 20px;cursor:pointer;transition:background .1s ease;border-left:3px solid transparent}.day-row:hover{background:var(--bg-page)}.day-row.done{opacity:.55}.day-row.done .day-activity{text-decoration:line-through;color:var(--text-muted)}.day-row.type-run{border-left-color:var(--color-run)}.day-row.type-longrun{border-left-color:var(--color-longrun)}.day-row.type-strength{border-left-color:var(--color-strength)}.day-row.type-bike{border-left-color:var(--color-bike)}.day-row.type-rest{border-left-color:var(--color-rest)}.day-row.type-race{border-left-color:var(--color-race)}.day-row.type-optional{border-left-color:var(--color-optional)}.type-run .legend-dot{background:var(--color-run)}.type-longrun .legend-dot{background:var(--color-longrun)}.type-strength .legend-dot{background:var(--color-strength)}.type-bike .legend-dot{background:var(--color-bike)}.type-rest .legend-dot{background:var(--color-rest)}.type-race .legend-dot{background:var(--color-race)}.type-optional .legend-dot{background:var(--color-optional)}.day-row.type-run .day-type-icon{color:var(--color-run)}.day-row.type-longrun .day-type-icon{color:var(--color-longrun)}.day-row.type-strength .day-type-icon{color:var(--color-strength)}.day-row.type-bike .day-type-icon{color:var(--color-bike)}.day-row.type-rest .day-type-icon{color:var(--color-rest)}.day-row.type-race .day-type-icon{color:var(--color-race)}.day-row.type-optional .day-type-icon{color:var(--color-optional)}.day-checkbox{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff;transition:all .15s;color:var(--orange)}.day-row:hover .day-checkbox{border-color:var(--orange)}.day-row.done .day-checkbox{background:var(--orange);border-color:var(--orange);color:#fff}.checkbox-empty{width:6px;height:6px}.day-name{font-size:12px;font-weight:700;color:var(--text-secondary);min-width:24px;text-transform:uppercase}.day-type-icon{display:flex;align-items:center;flex-shrink:0}.day-activity{font-size:13px;color:var(--text-primary);line-height:1.4;flex:1}.week-tip{padding:10px 20px 12px;border-top:1px solid var(--border)}.week-tip summary{font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;text-transform:uppercase;letter-spacing:.04em;list-style:none}.week-tip summary:before{content:"+ "}.week-tip[open] summary:before{content:"- "}.week-tip p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-top:8px;border-left:3px solid var(--border);padding-left:10px}.activities{display:flex;flex-direction:column;gap:16px}.activities-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.activities-header h2{font-size:22px;font-weight:700}.activities-count{font-size:13px;color:var(--text-muted)}.filter-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.filter-type-group{display:flex;gap:4px;background:var(--bg-page);padding:3px;border-radius:var(--radius-sm)}.filter-btn{padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .15s}.filter-btn:hover{background:#0000000d}.filter-btn.active{background:var(--orange);color:#fff;box-shadow:0 1px 3px #fc4c024d}.filter-search{display:flex;align-items:center;gap:8px;background:var(--bg-page);border-radius:var(--radius-sm);padding:6px 12px;border:1.5px solid var(--border);flex:1;min-width:160px;max-width:260px;color:var(--text-muted)}.filter-search:focus-within{border-color:var(--orange);color:var(--text-primary)}.search-input{border:none;background:none;outline:none;font-size:13px;color:var(--text-primary);width:100%}.search-input::placeholder{color:var(--text-muted)}.filter-range-group{display:flex;gap:4px}.filter-dates{display:flex;align-items:center;gap:6px;margin-left:auto}.activities-sentinel{text-align:center;padding:16px;color:var(--text-muted);font-size:13px}.date-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:5px 8px;font-size:12px;color:var(--text-secondary);background:var(--bg-page);outline:none;transition:border-color .15s}.date-input:focus{border-color:var(--orange)}.date-sep{font-size:13px;color:var(--text-muted)}.activity-list{display:flex;flex-direction:column;gap:6px}.activity-row{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden;transition:box-shadow .15s ease}.activity-row:hover{box-shadow:var(--shadow-md)}.activity-main{display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer}.activity-type-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-type-icon.activity-run{background:var(--color-run-bg);color:var(--color-run)}.activity-type-icon.activity-bike{background:var(--color-bike-bg);color:var(--color-bike)}.activity-type-icon.activity-walk{background:#f8fafc;color:#64748b}.activity-type-icon.activity-other{background:#f8fafc;color:#94a3b8}.activity-info{flex:1;min-width:0}.activity-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.activity-date{font-size:12px;color:var(--text-muted);font-weight:500}.activity-name{font-size:13px;font-weight:600;color:var(--text-primary)}.activity-type-label{font-size:11px;color:var(--text-muted);background:var(--bg-page);padding:2px 6px;border-radius:4px;border:1px solid var(--border)}.activity-metrics{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.metric{font-size:13px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.metric.pace{color:var(--orange);font-weight:600}.activity-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.trimp-badge{font-size:11px;font-weight:600;background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe;padding:3px 8px;border-radius:20px;white-space:nowrap}.expand-btn{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s}.expand-btn:hover{background:var(--bg-page);color:var(--text-primary)}.activity-detail{padding:16px 20px;background:var(--bg-page);border-top:1px solid var(--border)}.detail-grid{display:flex;flex-wrap:wrap;gap:20px}.detail-section{flex:1;min-width:200px}.detail-section h4{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.metric-pills{display:flex;flex-wrap:wrap;gap:6px}.metric-pill{display:flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px}.metric-pill-label{color:var(--text-muted)}.metric-pill-value{color:var(--text-primary);font-weight:600}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 20px;color:var(--text-muted)}.empty-state p{font-size:14px;text-align:center;max-width:320px}.analysis{display:flex;flex-direction:column;gap:20px}.analysis-header h2{font-size:22px;font-weight:700}.tab-bar{display:flex;gap:4px;background:var(--bg-card);padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-wrap:wrap}.tab-btn{padding:8px 18px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .15s}.tab-btn:hover{background:var(--bg-page);color:var(--text-primary)}.tab-btn.active{background:var(--orange);color:#fff;box-shadow:0 1px 4px #fc4c024d}.tab-panel{display:flex;flex-direction:column;gap:16px}.chart-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:20px}.chart-card h3{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px}.chart-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.empty-chart{height:120px;display:flex;align-items:center;justify-content:center}.empty-chart p{font-size:13px;color:var(--text-muted);font-style:italic}.hr-chart-layout{display:flex;align-items:center;gap:20px}.hr-zone-legend{flex:1;display:flex;flex-direction:column;gap:8px}.zone-legend-item{display:flex;align-items:center;gap:10px;font-size:12px}.zone-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.zone-details{flex:1;display:flex;flex-direction:column}.zone-name{font-weight:600;color:var(--text-primary)}.zone-range{color:var(--text-muted);font-size:11px}.zone-count{font-size:12px;color:var(--text-secondary);white-space:nowrap}.hr-zones-info{margin-bottom:8px}.zones-subtitle{font-size:12px;color:var(--text-muted)}.custom-tooltip{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;box-shadow:var(--shadow-md)}.tooltip-label{font-size:12px;color:var(--text-muted);margin-bottom:2px}.tooltip-value{font-size:14px;font-weight:600;color:var(--orange)}.upload-container{display:flex;flex-direction:column;gap:14px}.upload-dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--bg-page);display:flex;flex-direction:column;align-items:center;gap:10px}.upload-dropzone:hover,.upload-dropzone.dragging{border-color:var(--orange);background:var(--orange-pale)}.upload-dropzone.processing{opacity:.6;cursor:not-allowed;pointer-events:none}.upload-icon{color:var(--orange)}.upload-text{font-size:14px;font-weight:500;color:var(--text-primary)}.upload-subtext{font-size:12px;color:var(--text-muted)}.upload-status{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;line-height:1.4}.upload-status.success{background:#f0fdf4;color:#16a34a;border:1px solid #86efac}.upload-status.error{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5}.upload-compact{display:flex;flex-direction:column;gap:6px}.btn-upload-compact{display:flex;align-items:center;justify-content:center;gap:8px;padding:9px 12px;background:#fc4c0226;color:var(--orange-light);border-radius:var(--radius-sm);font-size:12.5px;font-weight:600;transition:all .15s;width:100%;border:1.5px solid rgba(252,76,2,.25)}.btn-upload-compact:hover{background:#fc4c0240;color:#ff8a65}.btn-upload-compact:disabled{opacity:.5;cursor:not-allowed}.upload-status-compact{font-size:11px;line-height:1.4;padding:6px 8px;border-radius:6px}.upload-status-compact.success{background:#22c55e1a;color:#22c55e}.upload-status-compact.error{background:#ef44441a;color:#ef4444}@media (max-width: 900px){.stat-grid,.race-grid{grid-template-columns:repeat(2,1fr)}.dashboard-mid{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100%;transform:translate(-100%);transition:transform .25s ease;z-index:200;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:150}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50}.mobile-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--text-primary)}.hamburger{padding:4px;color:var(--text-primary);display:flex;align-items:center;border-radius:6px}.hamburger:hover{background:var(--bg-page)}.mobile-bottom-nav{display:flex;align-items:center;justify-content:space-around;background:#fff;border-top:1px solid var(--border);padding:8px 0 env(safe-area-inset-bottom,8px);position:sticky;bottom:0;z-index:50;box-shadow:0 -2px 8px #0000000f}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;border-radius:var(--radius-sm);color:var(--text-muted);flex:1;transition:color .15s}.mobile-nav-item.active{color:var(--orange)}.mobile-nav-icon{display:flex;align-items:center}.mobile-nav-label{font-size:10px;font-weight:500}.main-content{padding:16px}.chart-row-2{grid-template-columns:1fr}.hr-chart-layout{flex-direction:column}.filter-bar{gap:8px}.filter-search{min-width:120px}.filter-dates{display:none}.race-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-value{font-size:22px}.race-grid{grid-template-columns:1fr}.main-content,.activity-main{padding:12px}.week-header{flex-direction:column}.week-header-right{justify-content:flex-start}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f1e99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:20px;width:100%;max-width:500px;max-height:92vh;overflow-y:auto;box-shadow:0 24px 80px #0000004d;animation:modalIn .2s cubic-bezier(.34,1.3,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:22px 20px 18px;background:linear-gradient(135deg,#fc4c02,#ff7043);border-radius:20px 20px 0 0}.modal-header-text{flex:1}.modal-title{font-size:1.2rem;font-weight:700;color:#fff;line-height:1.3}.modal-subtitle{font-size:.82rem;color:#fffc;margin-top:4px;display:flex;align-items:center;gap:8px}.modal-type-badge{background:#fff3;border-radius:20px;padding:1px 8px;font-size:.74rem;font-weight:500;color:#fff}.modal-close{background:#fff3;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s;margin-left:10px}.modal-close svg{width:16px;height:16px;stroke:#fff}.modal-close:hover{background:#ffffff59}.modal-hero{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#f0f0f0;border-bottom:1px solid #f0f0f0}.modal-hero-stat{background:#fff;padding:18px 12px 14px;display:flex;flex-direction:column;align-items:center;gap:6px}.modal-hero-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-hero-icon svg{width:18px;height:18px}.modal-hero-value{font-size:1.15rem;font-weight:800;color:#1a1a2e;line-height:1;text-align:center}.modal-hero-label{font-size:.68rem;color:#999;text-transform:uppercase;letter-spacing:.05em;text-align:center}.modal-body{padding:16px 18px 20px}.modal-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#bbb;margin-bottom:12px}.modal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.modal-grid-item{display:flex;align-items:center;gap:10px;background:#f8f8f8;border-radius:12px;padding:11px 12px}.modal-grid-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-grid-icon svg{width:15px;height:15px}.modal-grid-text{display:flex;flex-direction:column;gap:1px;min-width:0}.modal-grid-value{font-size:.92rem;font-weight:700;color:#1a1a2e;white-space:nowrap}.modal-grid-label{font-size:.68rem;color:#999;text-transform:uppercase;letter-spacing:.04em}.chart-hint{font-size:.72rem;font-weight:400;color:#aaa;margin-left:8px}.chart-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px;flex-wrap:wrap}.chart-year-btns{display:flex;gap:6px;flex-wrap:wrap}.chart-year-btn{padding:4px 12px;border-radius:20px;border:1px solid #e0e0e0;background:#f5f5f5;color:#666;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s}.chart-year-btn:hover{border-color:#fc4c02;color:#fc4c02}.chart-year-btn.active{background:#fc4c02;border-color:#fc4c02;color:#fff}.chart-nav-controls{display:flex;align-items:center;gap:6px}.chart-range-label{font-size:.82rem;color:#888;min-width:80px;text-align:center}.chart-nav-btn{width:30px;height:30px;border-radius:50%;border:1px solid #e0e0e0;background:#fff;color:#444;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0}.chart-nav-btn:hover:not(:disabled){border-color:#fc4c02;color:#fc4c02}.chart-nav-btn:disabled{opacity:.35;cursor:default}.chart-range-btns{display:flex;gap:2px;background:#f0f0f0;border-radius:8px;padding:2px}.chart-range-btn{padding:3px 10px;border-radius:6px;border:none;background:transparent;color:#666;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.chart-range-btn:hover{color:#333}.chart-range-btn.active{background:#fff;color:#fc4c02;box-shadow:0 1px 3px #0000001f}.chart-view-toggle{display:flex;gap:2px;background:#f0f0f0;border-radius:8px;padding:2px;margin-left:4px}.chart-view-btn{width:28px;height:26px;border-radius:6px;border:none;background:transparent;color:#888;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.chart-view-btn:hover{color:#333}.chart-view-btn.active{background:#fff;color:#22c55e;box-shadow:0 1px 3px #0000001f}.chart-dense-hint{font-size:11px;color:#bbb;text-align:center;margin:4px 0 0}.activity-type-filters{display:flex;flex-wrap:wrap;gap:8px}.activity-type-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;border:1.5px solid var(--type-color, #ccc);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.activity-type-btn .activity-type-dot{width:8px;height:8px;border-radius:50%;background:var(--type-color, #ccc);opacity:.4;transition:opacity .15s}.activity-type-btn.active{background:color-mix(in srgb,var(--type-color) 12%,transparent);color:var(--text-primary)}.activity-type-btn.active .activity-type-dot{opacity:1}.chart-subtitle{font-size:12px;color:var(--text-muted);margin-bottom:12px}.pmc-legend{display:flex;flex-wrap:wrap;gap:12px 20px;margin-top:12px;font-size:12px;color:var(--text-secondary)}.pmc-legend-item{display:flex;align-items:center;gap:6px}.pmc-legend-item i{display:inline-block;width:14px;height:3px;border-radius:2px;font-style:normal}.pmc-zones-grid{display:flex;flex-direction:column;gap:6px}.pmc-zone-row{display:flex;align-items:center;gap:10px;font-size:13px}.pmc-zone-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pmc-zone-range{min-width:100px;font-weight:600;color:var(--text-primary);font-size:12px;font-variant-numeric:tabular-nums}.pmc-zone-label{min-width:140px;font-weight:500}.pmc-zone-desc{color:var(--text-muted);font-size:12px}.import-page{max-width:600px}.import-page-header{margin-bottom:24px}.import-page-header h2{margin:0 0 4px}.import-page-sub{font-size:.88rem;color:#888;margin:0}.km-splits{margin:12px 0}.km-splits-title{font-size:.75rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.km-splits-rows{display:flex;flex-wrap:wrap;gap:4px}.km-split-row{display:flex;align-items:center;gap:6px;background:#f5f5f5;border-radius:6px;padding:4px 10px;font-size:.82rem;color:#444}.km-split-num{font-weight:700;color:#fc4c02;min-width:20px}.km-split-pace{font-weight:500}.km-split-hr{color:#e11d48}.km-split-elev{color:#6b7280;font-size:.78rem}.bestzeiten{display:flex;flex-direction:column;gap:24px}.bz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.predictor{display:flex;flex-direction:column;gap:20px}.predictor-header h2{margin:0 0 4px;font-size:22px;font-weight:700;color:var(--text-primary)}.predictor-sub{font-size:12px;color:var(--text-muted);margin:0}.predictor-empty{text-align:center;padding:48px 24px;color:var(--text-muted);background:#fff;border-radius:var(--radius);border:1px solid var(--border);line-height:1.6}.predictor-form-bar{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:13px;color:var(--text-secondary);flex-wrap:wrap}.form-badge{font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}.form-up{background:#dcfce7;color:#16a34a}.form-down{background:#fee2e2;color:#dc2626}.form-stable{background:#f1f5f9;color:#475569}.pred-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media (max-width: 480px){.pred-grid{grid-template-columns:1fr 1fr}}.pred-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px 18px 16px;display:flex;flex-direction:column;gap:4px}.pred-card-empty{opacity:.5}.pred-dist-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.pred-time{font-size:32px;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-.5px}.pred-pace{font-size:15px;font-weight:600;color:var(--orange);margin-top:2px}.pred-basis{font-size:11px;color:var(--text-muted);margin-top:8px;padding-top:8px;border-top:1px solid #f0f0f0}.pred-direct{color:#16a34a;font-weight:600}.pred-nodata{font-size:13px;color:var(--text-muted);margin-top:8px}.pred-source-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px}.pred-source-card h3{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 14px}.pred-source-table{width:100%;border-collapse:collapse;font-size:13px}.pred-source-table th{text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:0 8px 8px 0;border-bottom:1px solid #f0f0f0}.pred-source-table td{padding:8px 8px 8px 0;border-bottom:1px solid #f8f8f8;color:var(--text-secondary)}.pred-source-row{cursor:pointer;transition:background .1s}.pred-source-row:hover td{background:#fafafa}.pred-src-dist{font-weight:600;color:var(--text-primary)!important}.pred-src-pace{color:var(--orange)!important;font-weight:600}.pred-days-ago{color:var(--text-muted);font-size:11px}.pred-source-note{font-size:11px;color:var(--text-muted);margin:10px 0 0;text-align:right}.bz-card{background:#fff;border:1px solid #e8e8e8;border-radius:16px;padding:20px 16px;display:flex;flex-direction:column;gap:4px;box-shadow:0 1px 4px #0000000a}.bz-card-empty{opacity:.5}.bz-card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.bz-card-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.bz-row-clickable{cursor:pointer}.bz-row-clickable:hover td{background:#fff8f5}.bz-distance{font-size:.78rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.05em}.bz-pace{font-size:1.7rem;font-weight:700;color:#fc4c02;line-height:1.1}.bz-pace-unit{font-size:.9rem;font-weight:400;color:#aaa}.bz-time{font-size:1rem;font-weight:600;color:#222}.bz-meta{font-size:.78rem;color:#aaa;margin-top:4px}.bz-approx{color:#fc4c02}.bz-no-data{font-size:.85rem;color:#bbb;margin-top:8px}.bz-tables{display:flex;flex-direction:column;gap:16px}.bz-table-card{overflow-x:auto}.bz-table{width:100%;border-collapse:collapse;font-size:.88rem}.bz-table th{text-align:left;font-size:.75rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.04em;padding:0 12px 8px 0;border-bottom:1px solid #f0f0f0}.bz-table td{padding:8px 12px 8px 0;border-bottom:1px solid #f8f8f8;color:#444}.bz-row-gold td{background:#fffbeb}.bz-rank{font-size:1rem;width:32px}.bz-cell-pace{font-weight:600;color:#fc4c02}.bz-footnote{font-size:.78rem;color:#bbb;margin:0}.gpx-import{display:flex;flex-direction:column;gap:16px}.gpx-import-header h3{font-size:1rem;font-weight:600;margin:0 0 2px}.import-tabs{display:flex;gap:6px}.import-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid #e0e0e0;background:#f5f5f5;color:#666;transition:all .15s}.import-tab.active{background:#fc4c02;border-color:#fc4c02;color:#fff}.import-tab:not(.active):hover{border-color:#fc4c02;color:#fc4c02}.import-info{font-size:.84rem;color:#666;background:#f8f8f8;border:1px solid #e8e8e8;border-radius:8px;padding:12px 14px;line-height:1.6}.import-code{margin:8px 0 0;padding:8px 12px;background:#1e1e1e;color:#d4d4d4;border-radius:6px;font-size:.82rem;overflow-x:auto;white-space:pre}.gpx-dropzone{border:2px dashed #ddd;border-radius:12px;padding:32px 20px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s;background:#fafafa}.gpx-dropzone:hover,.gpx-dropzone.dragging{border-color:#fc4c02;background:#fff8f5}.gpx-dropzone-text{font-size:.95rem;font-weight:500;color:#444;margin:0}.gpx-dropzone-sub{font-size:.82rem;color:#aaa;margin:0}.gpx-progress{display:flex;flex-direction:column;gap:8px}.gpx-progress-label{font-size:.88rem;color:#555}.gpx-progress-bar-track{height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.gpx-progress-bar-fill{height:100%;background:#fc4c02;border-radius:4px;transition:width .2s ease}.gpx-progress-pct{font-size:.85rem;color:#888;text-align:right}.gpx-result{display:flex;flex-direction:column;gap:8px}.gpx-result-row{display:flex;align-items:center;gap:8px;font-size:.88rem;padding:8px 12px;border-radius:8px}.gpx-result-added{background:#f0fdf4;color:#166534}.gpx-result-skipped{background:#f5f5f5;color:#666}.gpx-result-error{background:#fef2f2;color:#991b1b}.gpx-result-total{font-size:.82rem;color:#888;padding-left:4px}.route-map-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#f8f8f8;border-radius:12px;color:#bbb;font-size:.85rem}.plan-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.plan-header-actions{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}.plan-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s}.plan-btn-edit{background:#f5f5f5;border-color:#e0e0e0;color:#444}.plan-btn-edit:hover{background:#ebebeb;border-color:#ccc}.plan-btn-reset{background:#fff;border-color:#e0e0e0;color:#888}.plan-btn-reset:hover{border-color:#fc4c02;color:#fc4c02}.plan-btn-save{background:#fc4c02;color:#fff}.plan-btn-save:hover{background:#e04400}.plan-btn-cancel{background:#fff;border-color:#e0e0e0;color:#666}.plan-btn-cancel:hover{border-color:#999;color:#333}.plan-edit-banner{background:#fff8f5;border:1px solid #FC4C02;border-radius:8px;padding:10px 14px;font-size:.85rem;color:#fc4c02;margin-bottom:16px}.week-card.edit-mode{border-color:#ffd5c2;background:#fffaf8}.plan-edit-input,.plan-edit-select,.plan-edit-textarea{background:#fff;border:1px solid #d0d0d0;border-radius:6px;font-size:.85rem;color:#333;padding:4px 8px;transition:border-color .15s;font-family:inherit}.plan-edit-input:focus,.plan-edit-select:focus,.plan-edit-textarea:focus{outline:none;border-color:#fc4c02;box-shadow:0 0 0 2px #fc4c021f}.week-title-input{width:100%;max-width:340px}.day-type-select{min-width:90px;flex-shrink:0}.day-activity-input{flex:1;min-width:0}.week-tip-edit{margin-top:12px;display:flex;flex-direction:column;gap:4px}.plan-edit-label{font-size:.78rem;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.plan-edit-textarea{width:100%;resize:vertical;line-height:1.5;padding:8px 10px}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-page)}.app-loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-page);padding:24px}.login-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:40px 36px;width:100%;max-width:380px}.login-header{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:32px}.login-header h1{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin:0}.login-form{display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.login-field input{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;color:var(--text-primary);background:var(--bg-page);transition:border-color .15s;outline:none}.login-field input:focus{border-color:var(--orange);background:#fff}.login-error{font-size:.875rem;color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:9px 12px}.login-btn{width:100%;padding:12px;background:var(--orange);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.login-btn:hover:not(:disabled){background:var(--orange-light)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.logout-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;margin-top:8px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:#ffffff8c;font-size:.8rem;cursor:pointer;transition:background .15s,color .15s;text-align:left}.logout-btn:hover{background:#ffffff14;color:#ffffffd9}.ai-chat-fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--orange);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #fc4c0266;transition:transform .2s,box-shadow .2s;z-index:1000}.ai-chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #fc4c0280}.ai-chat-fab.open{background:#555;box-shadow:0 4px 16px #0000004d}@media (max-width: 768px){.ai-chat-fab{bottom:72px;right:16px;width:46px;height:46px}}.ai-chat-panel{position:fixed;bottom:90px;right:24px;width:340px;max-height:520px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 12px 40px #00000038,0 2px 8px #0000001f;display:flex;flex-direction:column;z-index:999;overflow:hidden}@media (max-width: 768px){.ai-chat-panel{bottom:120px;right:8px;left:8px;width:auto;max-height:60vh}}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:#fff}.ai-chat-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.9rem}.ai-chat-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px;display:flex;align-items:center}.ai-chat-clear:hover{color:var(--text);background:#f4f6f8}.ai-chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.ai-chat-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 0;color:var(--text-muted);text-align:center}.ai-chat-empty-icon{opacity:.3}.ai-chat-empty p{font-size:.85rem;margin:0}.ai-suggestions{display:flex;flex-direction:column;gap:6px;width:100%}.ai-suggestion{background:#f4f6f8;border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:.8rem;color:var(--text);cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.ai-suggestion:hover{background:var(--orange-pale);border-color:var(--orange);color:var(--orange)}.ai-message-user{display:flex;justify-content:flex-end}.ai-message-assistant{display:flex;justify-content:flex-start}.ai-message-bubble{max-width:85%;padding:8px 12px;border-radius:12px;font-size:.85rem;line-height:1.5;white-space:pre-wrap}.ai-message-user .ai-message-bubble{background:var(--orange);color:#fff;border-bottom-right-radius:4px}.ai-message-assistant .ai-message-bubble{background:#f4f6f8;color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.ai-typing{display:inline-flex;gap:4px;align-items:center;height:16px}.ai-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:ai-bounce 1.2s infinite}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes ai-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.ai-chat-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:#fff}.ai-chat-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:.85rem;color:var(--text);outline:none}.ai-chat-input:focus{border-color:var(--orange)}.ai-chat-send{background:var(--orange);color:#fff;border:none;border-radius:8px;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.ai-chat-send:hover:not(:disabled){background:var(--orange-light)}.ai-chat-send:disabled{background:var(--border);cursor:not-allowed}.ai-analyze-section{border-top:1px solid var(--border)}.ai-analyze-btn{display:inline-flex;align-items:center;gap:7px;background:var(--orange-pale);color:var(--orange);border:1px solid var(--orange);border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.ai-analyze-btn:hover{background:var(--orange);color:#fff}.ai-analyze-loading{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:.85rem;padding:4px 0}.ai-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.ai-analyze-text{font-size:.85rem;line-height:1.6;color:var(--text);white-space:pre-wrap;background:var(--bg);border-radius:8px;padding:12px;border:1px solid var(--border)}.ai-analyze-error{font-size:.82rem;color:#ef4444}.plan-btn-ai{background:linear-gradient(135deg,#fc4c02,#ff7043);color:#fff;border:none}.plan-btn-ai:hover{opacity:.9}.ai-plan-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;padding:16px}.ai-plan-modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;border:1px solid var(--border);box-shadow:0 16px 48px #0003}.ai-plan-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:.95rem}.ai-plan-form{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.ai-plan-field{display:flex;flex-direction:column;gap:4px}.ai-plan-field label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.ai-plan-field input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:.88rem;color:var(--text);outline:none}.ai-plan-field input:focus{border-color:var(--orange)}.ai-plan-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--orange);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:600;cursor:pointer;width:100%;transition:opacity .15s}.ai-plan-generate-btn:hover:not(:disabled){opacity:.9}.ai-plan-generate-btn:disabled{opacity:.6;cursor:not-allowed}.ai-plan-error{font-size:.82rem;color:#ef4444;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;padding:8px 12px}.ai-plan-preview{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.ai-plan-preview-info{font-size:.85rem;color:var(--text-muted);margin:0}.ai-plan-preview-list{display:flex;flex-direction:column;gap:6px;background:var(--bg);border-radius:8px;padding:12px;border:1px solid var(--border)}.ai-plan-preview-week{font-size:.85rem;display:flex;flex-direction:column;gap:2px}.ai-plan-preview-days{font-size:.75rem;color:var(--text-muted)}.ai-plan-preview-more{font-size:.8rem;color:var(--text-muted);text-align:center;padding-top:4px}.ai-plan-preview-actions{display:flex;gap:8px;flex-direction:column}
