.landing-container{background:#f8f9fa;min-height:100vh}.landing-hero{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:center;min-height:70vh;padding:80px 20px;text-align:center}.hero-content{margin:0 auto;max-width:800px}.hero-title{font-size:56px;font-weight:800;margin:0 0 20px;text-shadow:0 2px 10px #0003}.hero-subtitle{font-size:28px;font-weight:600;margin:0 0 15px;opacity:.95}.hero-description{font-size:18px;line-height:1.6;margin:0 0 40px;opacity:.9}.hero-buttons{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.btn{border-radius:10px;display:inline-block;font-size:18px;padding:16px 40px;text-decoration:none;transition:all .3s ease}.btn-primary{background:#fff;box-shadow:0 4px 15px #0003;color:#667eea}.btn-primary:hover{box-shadow:0 6px 25px #0000004d;transform:translateY(-3px)}.btn-secondary{background:#fff3;border:2px solid #fff;color:#fff}.btn-secondary:hover{background:#ffffff4d;transform:translateY(-3px)}.btn-large{font-size:20px;padding:18px 50px}.landing-features{margin:0 auto;max-width:1200px;padding:80px 20px}.landing-features h2{color:#333;font-size:42px;font-weight:700;margin:0 0 60px;text-align:center}.features-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{background:#fff;border-radius:16px;box-shadow:0 4px 15px #00000014;padding:40px;text-align:center;transition:all .3s ease}.feature-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.feature-icon{font-size:64px;margin-bottom:20px}.feature-card h3{color:#333;font-size:22px;font-weight:600;margin:0 0 15px}.feature-card p{color:#666;font-size:16px;line-height:1.6;margin:0}.landing-cta{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:80px 20px;text-align:center}.landing-cta h2{font-size:38px;font-weight:700;margin:0 0 15px}.landing-cta p{font-size:20px;margin:0 0 40px;opacity:.95}.landing-footer{background:#2c3e50;color:#fff;padding:40px 20px;text-align:center}.landing-footer p{font-size:16px;margin:0;opacity:.8}@media (max-width:768px){.hero-title{font-size:40px}.hero-subtitle{font-size:22px}.hero-description{font-size:16px}.landing-features h2{font-size:32px}.features-grid{grid-template-columns:1fr}.landing-cta h2{font-size:28px}.landing-cta p{font-size:18px}.btn{font-size:16px;padding:14px 30px}.btn-large{font-size:18px;padding:16px 40px}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-box{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:40px;width:100%}.auth-header{margin-bottom:30px;text-align:center}.auth-header h1{color:#667eea;font-size:32px;font-weight:700;margin:0 0 10px}.auth-header h2{color:#333;font-size:24px;font-weight:600;margin:0}.error-message{background:#fee;border:1px solid #fcc;color:#c33;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-button,.form-group input{transition:all .3s ease}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px}.auth-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-footer{color:#666;font-size:14px;margin-top:30px;text-align:center}.auth-footer p{margin:10px 0}.auth-footer a{color:#667eea;font-weight:600;text-decoration:none;transition:color .2s}.auth-footer a:hover{color:#764ba2;text-decoration:underline}.loading-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.loading{color:#fff;font-size:24px;font-weight:600}@media (max-width:600px){.auth-box{padding:30px 20px}.form-row{grid-template-columns:1fr}.auth-header h1{font-size:28px}.auth-header h2{font-size:20px}}.app-footer{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-top:auto;padding:25px 0 0}.footer-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0 auto;max-width:1200px;padding:0 30px 20px}.footer-section h3{font-size:18px}.footer-section h3,.footer-section h4{color:#fff;font-weight:700;margin-bottom:10px}.footer-section h4{font-size:14px;letter-spacing:.5px;text-transform:uppercase}.footer-description{color:#ffffffe6;font-size:13px;line-height:1.5;margin:0}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:8px}.footer-links a{color:#ffffffd9;display:inline-block;font-size:13px;text-decoration:none;transition:all .2s}.footer-links a:hover{color:#fff;transform:translateX(5px)}.footer-link-disabled{color:#ffffffd9;display:inline-block;font-size:13px}.social-links{display:flex;gap:12px;margin-top:8px}.social-icon{display:inline-block;font-size:20px;opacity:.85;text-decoration:none;transition:all .2s}.social-icon:hover{opacity:1;transform:scale(1.2)}.footer-bottom{background:#0003;border-top:1px solid #ffffff1a;padding:12px 30px;text-align:center}.footer-bottom p{color:#fffc;font-size:12px;margin:0}@media (max-width:768px){.footer-content{gap:30px;grid-template-columns:1fr}.footer-section{text-align:center}.footer-links a:hover{transform:none}.social-links{justify-content:center}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:rgba(0,0,0,0);background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;touch-action:manipulation}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #00000026;color:#fff;justify-content:space-between;padding:16px 32px;position:relative;z-index:200}.app-header,.app-header-left{align-items:center;display:flex}.app-header-left{gap:20px}.hamburger-btn{background:none;border:none;cursor:pointer;display:none;padding:8px;z-index:201}.hamburger-icon{display:flex;flex-direction:column;height:24px;justify-content:space-around;position:relative;width:28px}.hamburger-icon span{background:#fff;border-radius:3px;display:block;height:3px;transform-origin:center;transition:all .3s ease}.hamburger-icon.open span:first-child{transform:translateY(8px) rotate(45deg)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.app-title{font-size:24px;font-weight:700;margin:0}.app-header-right{align-items:center;display:flex;gap:0}.user-greeting{color:#fff;font-size:14px;opacity:.9}.profile-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin:0 4px;padding:8px 20px;transition:all .2s;white-space:nowrap}.profile-btn:hover{background:#ffffff4d}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-left:20px;padding:8px 20px;transition:all .2s}.logout-btn:hover{background:#ffffff4d}.view-navigation{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a;display:flex;gap:0;padding:0;position:relative;z-index:150}.view-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#ffffffb3;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:18px 30px;transition:all .3s ease;white-space:nowrap}.view-btn:hover{background:#ffffff1a;color:#fff}.view-btn.active{background:#ffffff26;border-bottom-color:#fff;color:#fff}.mobile-menu-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:100}.dashboard{background:#f5f5f5;flex:1 1;overflow-y:auto;padding:30px}.dashboard-page-header{margin-bottom:30px;text-align:center}.dashboard-page-header h1{color:#2d3748;font-size:32px;font-weight:700;margin:0}.dashboard .sport-filters{align-items:center;display:flex;gap:8px}.dashboard .filter-btn{background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.dashboard .filter-btn:hover{background:#f7fafc;border-color:#cbd5e0;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.dashboard .filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 6px #667eea4d;color:#fff;font-weight:600}.dashboard .filter-btn.filter-running.active{background:linear-gradient(135deg,#ed8936,#dd6b20);border-color:#ed8936;box-shadow:0 2px 6px #ed89364d;color:#fff}.dashboard .filter-btn.filter-cycling.active{background:linear-gradient(135deg,#4299e1,#3182ce);border-color:#4299e1;box-shadow:0 2px 6px #4299e14d;color:#fff}.dashboard .filter-btn.filter-swimming.active{background:linear-gradient(135deg,#38b2ac,#319795);border-color:#38b2ac;box-shadow:0 2px 6px #38b2ac4d;color:#fff}.dashboard-grid{margin:0 auto;max-width:1400px}.week-comparison-banner{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin:0 auto 25px;max-width:1400px;padding:16px 24px}.week-comparison-content{display:flex;flex-direction:column;gap:20px}.week-comparison-content .dashboard-grid{margin:0;max-width:100%}.comparison-title{border-bottom:1px solid #e2e8f0;color:#2d3748;display:inline-block;font-size:16px;font-weight:700;padding-bottom:4px}.comparison-title .title-date{margin-left:4px}.comparison-stats{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.comparison-stat{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:8px;padding:8px 12px}.distance-stat-mobile,.time-stat-mobile{display:none}.distance-stat-desktop,.time-stat-desktop{display:flex}.distance-values{align-items:center;display:flex;gap:6px}.comparison-label{color:#718096;font-size:12px;font-weight:600}.comparison-value{color:#2d3748;font-size:13px;font-weight:700}.comparison-note{color:#a0aec0;font-size:10px;font-style:italic;margin-left:4px}.chart-section{margin-top:30px}.recharts-surface:focus,.recharts-surface:focus-visible,.recharts-wrapper:focus,.recharts-wrapper:focus-visible{outline:none!important}.chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.filters-toggle-btn{align-items:center;background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.filters-toggle-btn:hover{background:#667eea;box-shadow:0 4px 6px #667eea33;color:#fff;transform:translateY(-1px)}.filters-toggle-btn:active{transform:translateY(0)}.chart-filters-panel{animation:slideDown .3s ease-out;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;margin-bottom:25px;padding:20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-sections-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.filter-section{margin-bottom:20px}.filter-section:last-child,.filter-sections-row .filter-section{margin-bottom:0}.filter-section-title{color:#2d3748;font-size:14px;font-weight:700;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.chart-range-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:flex-start}.range-control-group{align-items:center;display:flex;gap:10px}.range-control-group label{color:#4a5568;font-size:13px;font-weight:600;white-space:nowrap}.range-select{background:#fff;border:2px solid #cbd5e0;border-radius:6px;color:#2d3748;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s}.range-select:hover{border-color:#a0aec0}.range-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.reset-week-btn{background:#fff;border:2px solid #e53e3e;border-radius:6px;color:#e53e3e;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s}.reset-week-btn:hover{background:#e53e3e;color:#fff;transform:translateY(-1px)}.reset-week-btn:active{transform:translateY(0)}.chart-filter-group{display:flex;flex-wrap:wrap;gap:8px}.chart-filter-btn{background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s}.chart-filter-btn:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px)}.chart-filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 6px #667eea4d;color:#fff}.chart-filter-btn.filter-running.active{background:linear-gradient(135deg,#ed8936,#dd6b20);border-color:#ed8936;box-shadow:0 2px 6px #dd6b204d}.chart-filter-btn.filter-cycling.active{background:linear-gradient(135deg,#4299e1,#3182ce);border-color:#4299e1;box-shadow:0 2px 6px #3182ce4d}.chart-filter-btn.filter-swimming.active{background:linear-gradient(135deg,#38b2ac,#319795);border-color:#38b2ac;box-shadow:0 2px 6px #3197954d}.day-card.read-only{cursor:default}.day-card.read-only .session-card{cursor:pointer}.day-card.read-only .session-card:hover{transform:translateX(0)}.planning-compact{background:#f5f5f5;display:flex;flex:1 1;flex-direction:column;overflow-y:auto}.planning-header{background:#fff;border-bottom:2px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;padding:20px 30px}.planning-header-content{max-width:100%}.planning-header h2{color:#2d3748;font-size:24px;font-weight:600;margin:0 0 20px;text-align:center}.month-navigation{align-items:center;background:#0000;border:none;border-radius:0;display:flex;gap:15px;justify-content:center;padding:0}.navigation-and-filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:20px}.current-month{color:#2d3748;font-size:20px;font-weight:700;margin:0;min-width:200px;text-align:center;text-transform:capitalize}.planning-filters{display:flex;flex-wrap:wrap;gap:10px}.filter-btn-planning{background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.filter-btn-planning:hover{background:#f7fafc;border-color:#cbd5e0;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.filter-btn-planning.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 6px #667eea4d;color:#fff;font-weight:600}.filter-btn-planning.filter-running.active{background:linear-gradient(135deg,#ed8936,#dd6b20);border-color:#ed8936;box-shadow:0 2px 6px #ed89364d;color:#fff}.filter-btn-planning.filter-cycling.active{background:linear-gradient(135deg,#4299e1,#3182ce);border-color:#4299e1;box-shadow:0 2px 6px #4299e14d;color:#fff}.filter-btn-planning.filter-swimming.active{background:linear-gradient(135deg,#38b2ac,#319795);border-color:#38b2ac;box-shadow:0 2px 6px #38b2ac4d;color:#fff}.planning-stats{display:flex;flex-wrap:wrap;gap:15px}.stat-card-planning{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:8px;flex:1 1;min-width:140px;padding:12px 20px}.stat-card-planning .label{color:#718096;font-size:11px;font-weight:500;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.stat-card-planning .value{color:#2d3748;font-size:20px;font-weight:700}.planning-table{padding:15px 30px}.week-stats-banner{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:8px 8px 0 0;box-shadow:0 1px 3px #0000000d;margin-top:15px;padding:12px 20px}.week-stats-content{gap:20px}.week-stats-content,.week-stats-section{align-items:center;display:flex;flex-wrap:wrap}.week-stats-section{gap:12px}.week-stats-section .section-title{color:#4a5568;font-size:12px;font-weight:700;letter-spacing:.5px;margin-right:8px;text-transform:uppercase}.week-stats-section .section-title.actual{color:#4a5568}.week-volume-total{align-items:center;display:flex;gap:10px;padding-right:20px}.week-volume-total .stats-label{color:#718096;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.week-volume-total .stats-value{color:#2d3748;font-size:16px;font-weight:700}.stats-separator{background:#cbd5e0;height:30px;width:1px}.week-sport-stat{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:8px;padding:6px 12px}.week-sport-stat .sport-icon{font-size:18px}.week-sport-stat .sport-volume{color:#2d3748;font-size:14px;font-weight:600}.week-sport-stat.actual .sport-volume{color:#48bb78}.week-sport-stat.total-stat{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #cbd5e0;padding:8px 14px}.week-sport-stat.total-stat.actual{background:linear-gradient(135deg,#f0fff4,#c6f6d5);border:1px solid #9ae6b4}.sport-volume-total-inline{color:#2d3748;font-size:14px;font-weight:700}.week-sport-stat.actual .sport-volume-total-inline{color:#48bb78}.week-sport-stat .actual-distance{color:#48bb78;font-size:13px;font-weight:600;margin-left:2px}.week-volume-total .actual-value{color:#48bb78;font-size:14px;font-weight:600}.change-indicator{border-radius:4px;cursor:help;font-size:13px;font-weight:700;padding:2px 6px}.change-indicator.increase{background:#f0fff4;color:#48bb78}.change-indicator.decrease{background:#fff5f5;color:#f56565}.change-indicator.neutral{background:#f7fafc;color:#a0aec0}.week-volume-change{align-items:center;display:flex;gap:10px}.week-volume-change.neutral .stats-label{color:#a0aec0;font-size:13px;font-style:italic;text-transform:none}.week-stats-banner .stats-detail{color:#a0aec0;font-size:11px;font-style:italic}.planning-table-virtualized{padding:0 30px 15px}.planning-table-virtualized>div{overflow-x:hidden!important}.planning-table-virtualized .week-row,.week-row{margin-bottom:8px}.week-row{align-items:stretch;background:#fff;border-radius:0 0 8px 8px;box-shadow:0 1px 3px #00000014;display:flex;overflow:hidden;transition:all .2s ease}.week-row:hover{box-shadow:0 2px 6px #0000001f}.week-row.current-week-row{border:2px solid #667eea;box-shadow:0 2px 8px #667eea33}.week-label{align-items:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-right:2px solid #e2e8f0;display:flex;flex-direction:column;justify-content:center;min-width:150px;padding:15px;position:relative}.week-row.current-week-row .week-label{background:linear-gradient(135deg,#e6f2ff,#d6e7ff);border-right-color:#667eea}.week-period{color:#4a5568;font-size:13px;font-weight:600;line-height:1.3;text-align:center}.current-indicator{animation:pulse 2s ease-in-out infinite;color:#667eea;font-size:14px;position:absolute;right:8px;top:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.calendar-grid-compact{grid-gap:8px;display:grid;flex:1 1;gap:8px;grid-template-columns:repeat(7,1fr);padding:10px}@media (max-width:1200px){.calendar-grid-compact{grid-template-columns:repeat(4,1fr)}.week-label{min-width:120px}}@media (max-width:768px){.calendar-grid-compact{grid-template-columns:repeat(2,1fr)}.week-row{flex-direction:column}.week-label{border-bottom:2px solid #e2e8f0;border-right:none;min-width:0;min-width:auto}}.session-info-readonly{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;margin-bottom:20px;padding:20px}.session-info-readonly .info-row{color:#2d3748;font-size:15px;margin-bottom:10px}.session-info-readonly .info-row strong{color:#4a5568;margin-right:8px}.header-sticky{background:#f5f5f5;box-shadow:0 2px 8px #0000001a;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:100}.header-sticky.collapsed .header{padding:12px 30px}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px}.header,.header-title{transition:all .3s ease}.header-title{margin-bottom:15px;max-height:60px;overflow:hidden}.header-title.hidden{margin-bottom:0;max-height:0;opacity:0}.header-title h1{font-size:28px;margin:0}.header-main{display:flex;flex-direction:column;gap:15px}.add-session-btn{background:#48bb78;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.add-session-btn:hover{background:#38a169;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.stats-and-actions{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px}.action-buttons{display:flex;flex-direction:column;gap:10px;min-width:200px}.current-week-btn{background:#fff3;border:2px solid #fff6;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.current-week-btn:hover{background:#ffffff4d;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.sport-filters{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start}.filter-btn{background:#ffffff26;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;min-width:100px;padding:10px 20px;transition:all .3s ease}.filter-btn:hover{background:#ffffff40;box-shadow:0 2px 6px #0003;transform:translateY(-2px)}.filter-btn.active{background:#fffffff2;border-color:#fffffff2;box-shadow:0 4px 8px #0003;color:#667eea;font-weight:600}.filter-btn.filter-running.active{color:#ed8936}.filter-btn.filter-cycling.active{color:#4299e1}.filter-btn.filter-swimming.active{color:#38b2ac}.weekly-stats{display:flex;flex-wrap:wrap;gap:20px}.stat-card{background:#fff3;border:1px solid #ffffff4d;border-radius:10px;min-width:150px;padding:15px 25px}.stat-card .label{font-size:12px;margin-bottom:5px;opacity:.9}.stat-card .value{font-size:24px;font-weight:700}.weeks-container{flex:1 1;overflow-y:auto;padding:20px;scroll-behavior:smooth}.week-section{background:#fff;border-radius:15px;box-shadow:0 2px 8px #00000014;margin-bottom:40px;padding:20px;transition:all .3s ease}.week-section:hover{box-shadow:0 4px 12px #0000001f}.week-section.current-week-section{background:linear-gradient(180deg,#f8f9ff 0,#fff);border:3px solid #667eea;box-shadow:0 4px 16px #667eea33}.week-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.week-header h2{color:#2d3748;font-size:20px;font-weight:600;margin:0}.current-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 4px #667eea4d;color:#fff;font-size:13px;font-weight:600;padding:6px 16px}.calendar-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(7,1fr)}@media (max-width:1200px){.calendar-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.calendar-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.calendar-grid{grid-template-columns:1fr}}.day-card{-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#fafbfc;border:1px solid #e2e8f0;border-radius:8px;box-shadow:none;min-height:160px;padding:12px;perspective:1000px;position:relative;transform:translateZ(0);transition:box-shadow .2s ease,border-color .2s ease}.day-card:hover{border-color:#cbd5e0;box-shadow:0 2px 6px #0000001a}.day-card.today{background:#f7fafc;border:2px solid #667eea}.day-card.drag-over{background:#e6f2ff;border:2px dashed #667eea;box-shadow:0 0 0 3px #667eea33;pointer-events:auto;transform:scale3d(1.02,1.02,1) translateZ(0);transition:none;will-change:transform,box-shadow}.day-card.outside-month{background:#f7fafc;opacity:.4}.day-card.outside-month .day-date,.day-card.outside-month .day-name{color:#a0aec0}.day-card.outside-month .add-session-day{display:none}.day-header{border-bottom:1px solid #e2e8f0;margin-bottom:10px;padding-bottom:8px}.day-name{color:#718096;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.day-date{color:#2d3748;font-size:20px;font-weight:700}.sessions-container{display:flex;flex-direction:column;gap:8px}.rest-day-indicator{align-items:center;background:linear-gradient(135deg,#f0fff4,#fff);border:1px dashed #c6f6d5;border-radius:6px;display:flex;flex-direction:column;justify-content:center;margin:5px 0;padding:20px 10px;transition:all .3s ease}.rest-day-indicator:hover{background:linear-gradient(135deg,#f0fff4,#f0fff4);border-color:#9ae6b4}.rest-icon{font-size:24px;margin-bottom:6px}.rest-text{color:#48bb78;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.add-session-day{background:#0000;border:1px dashed #cbd5e0;border-radius:4px;color:#a0aec0;cursor:pointer;font-size:12px;margin-top:8px;padding:8px;transition:all .2s ease;width:100%}.add-session-day:hover{background:#f7fafc;border-color:#667eea;color:#667eea}.session-card{-webkit-backface-visibility:hidden;backface-visibility:hidden;background:linear-gradient(135deg,#f6f8fb,#fff);border:1px solid #0000;border-radius:6px;cursor:grab;opacity:.7;padding:10px;position:relative;transform:translateZ(0);transition:box-shadow .15s ease,transform .15s ease;-webkit-user-select:none;user-select:none;will-change:transform,box-shadow}.session-card:active{cursor:grabbing}.session-card:hover{box-shadow:0 4px 8px #0000001a;transform:translate3d(2px,0,0)}.session-card.dragging{cursor:grabbing;filter:brightness(.8);opacity:.3;pointer-events:none;transform:scale3d(.95,.95,1) translateZ(0);transition:none;will-change:transform,opacity}.session-card.running{background:linear-gradient(135deg,#fff5f0,#fff);border-left-color:#ed8936}.session-card.running.completed{background:linear-gradient(135deg,#fbd38d,#fed7aa);border:1px solid #dd6b20;border-left-width:4px;box-shadow:0 1px 4px #dd6b2033;opacity:1}.session-card.running.completed:hover{box-shadow:0 2px 8px #dd6b204d}.session-card.cycling{background:linear-gradient(135deg,#f0f8ff,#fff);border-left-color:#4299e1}.session-card.cycling.completed{background:linear-gradient(135deg,#90cdf4,#bee3f8);border:1px solid #3182ce;border-left-width:4px;box-shadow:0 1px 4px #3182ce33;opacity:1}.session-card.cycling.completed:hover{box-shadow:0 2px 8px #3182ce4d}.session-card.swimming{background:linear-gradient(135deg,#f0fffe,#fff);border-left-color:#38b2ac}.session-card.swimming.completed{background:linear-gradient(135deg,#81e6d9,#b2f5ea);border:1px solid #319795;border-left-width:4px;box-shadow:0 1px 4px #31979533;opacity:1}.session-card.swimming.completed:hover{box-shadow:0 2px 8px #3197954d}.session-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.session-sport{font-size:12px;font-weight:600;text-transform:capitalize}.session-status{font-size:16px}.session-details{color:#4a5568;font-size:11px;line-height:1.5}.session-detail-row{display:flex;justify-content:space-between;margin-bottom:3px}.session-notes{border-top:1px solid #e2e8f0;color:#718096;font-size:10px;font-style:italic;margin-top:8px;overflow:hidden;padding-top:8px;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal{animation:modalSlideIn .3s ease;background:#fff;border-radius:15px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:30px;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal h2{color:#2d3748;font-size:24px}.form-group,.modal h2{margin-bottom:20px}.form-group label{color:#4a5568;display:block;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.zone-hint{color:#667eea;display:block;font-size:12px;font-style:italic;font-weight:600;margin-top:6px}.time-input-container{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;gap:8px;padding:10px 12px;transition:border-color .2s ease}.time-input-container:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.time-input-field{border:1px solid #cbd5e0;border-radius:6px;color:#2d3748;font-size:16px;font-weight:600;padding:6px 8px;text-align:center;transition:all .2s ease;width:45px}.time-input-field:focus{background:#f7fafc;border-color:#667eea;outline:none}.time-input-field::placeholder{color:#cbd5e0;font-weight:400}.time-separator{color:#4a5568;font-size:20px;font-weight:700}.time-separator,.time-unit{-webkit-user-select:none;user-select:none}.time-unit{color:#718096;font-size:14px;font-weight:600;margin-left:2px}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:15px;gap:15px}.validation-section{border-top:2px solid #e2e8f0;margin-top:30px;padding-top:30px}.validation-section h3{color:#2d3748;font-size:18px;margin-bottom:15px}.form-actions{border-top:1px solid #e2e8f0;justify-content:space-between;margin-top:30px;padding-top:20px}.form-actions,.form-actions-right{align-items:center;display:flex;gap:10px}.btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3;box-shadow:0 4px 8px #667eea4d;transform:translateY(-2px)}.btn-success{background:#48bb78;color:#fff}.btn-success:hover{background:#38a169;box-shadow:0 4px 8px #48bb784d;transform:translateY(-2px)}.btn-warning{background:#ed8936;color:#fff}.btn-warning:hover{background:#dd6b20;box-shadow:0 4px 8px #ed89364d;transform:translateY(-2px)}.btn-danger{background:#f56565;color:#fff}.btn-danger:hover{background:#e53e3e;box-shadow:0 4px 8px #f565654d;transform:translateY(-2px)}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover{background:#cbd5e0}.loading{color:#718096;font-size:18px;padding:40px}.error,.loading{text-align:center}.error{background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;margin:20px;padding:15px}.session-structure{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:20px;margin-top:20px;padding:20px}.structure-header{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.structure-title-row{align-items:center;display:flex;justify-content:space-between}.structure-header h3{color:#2d3748;font-size:20px;margin:0}.btn-toggle-structure{background:#edf2f7;border:none;border-radius:6px;color:#2d3748;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.btn-toggle-structure:hover{background:#e2e8f0}.btn-add-segment{background:#4299e1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s ease}.btn-add-segment:hover{background:#3182ce;transform:translateY(-1px)}.structure-overview{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:15px}.overview-stats{display:flex;gap:30px;margin-bottom:15px}.overview-stat{display:flex;flex-direction:column;gap:5px}.stat-label{color:#718096;font-size:12px;font-weight:500}.stat-value{color:#2d3748;font-size:18px;font-weight:700}.visual-timeline{border-radius:6px;box-shadow:0 2px 4px #0000001a;display:flex;height:40px;overflow:hidden}.timeline-segment{align-items:center;border-right:2px solid #fff;display:flex;justify-content:center;padding:5px;transition:all .2s ease}.timeline-segment:last-child{border-right:none}.timeline-segment:hover{filter:brightness(1.1);transform:scale(1.02);z-index:1}.timeline-label{color:#fff;font-size:11px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.segments-list{display:flex;flex-direction:column;gap:10px}.empty-structure{color:#718096;padding:40px 20px;text-align:center}.empty-structure p{margin:10px 0}.empty-hint{color:#a0aec0;font-size:14px}.segment-card{background:#fff;border-left:5px solid #4299e1;border-radius:10px;box-shadow:0 2px 4px #0000001a;cursor:grab;margin-bottom:10px;overflow:hidden;transition:all .2s ease}.segment-card:active{cursor:grabbing}.segment-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.segment-header{cursor:pointer;padding:15px}.segment-title-row{align-items:center;display:flex;gap:10px;margin-bottom:10px}.segment-number{background:#edf2f7;border-radius:4px;color:#718096;font-size:12px;font-weight:700;padding:4px 8px}.segment-title{color:#2d3748;flex:1 1;font-size:16px;font-weight:700}.segment-type-badge{border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.segment-expand-btn{background:none;border:none;color:#718096;cursor:pointer;font-size:16px;padding:4px 8px;transition:transform .2s ease}.segment-expand-btn:hover{color:#2d3748}.segment-summary{color:#4a5568;display:flex;flex-wrap:wrap;font-size:13px;gap:10px}.summary-item{background:#f7fafc;border-radius:6px;font-weight:500;padding:4px 10px}.segment-details{border-top:1px solid #e2e8f0;margin-top:10px;padding:15px}.detail-row{border-bottom:1px solid #f7fafc;display:flex;justify-content:space-between;padding:8px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#718096;font-size:14px;font-weight:600}.detail-value{color:#2d3748;font-size:14px;font-weight:500}.segment-actions{border-top:2px solid #edf2f7;display:flex;gap:8px;margin-top:15px;padding-top:15px}.btn-segment-action{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:8px 12px;transition:all .2s ease}.btn-edit{background:#4299e1;color:#fff}.btn-edit:hover{background:#3182ce}.btn-duplicate{background:#48bb78;color:#fff}.btn-duplicate:hover{background:#38a169}.btn-delete{background:#f56565;color:#fff}.btn-delete:hover{background:#e53e3e}.segment-form-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.segment-form-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.segment-form-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.segment-form-header h3{color:#2d3748;font-size:22px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#718096;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s ease;width:30px}.close-btn:hover{background:#edf2f7;color:#2d3748}.segment-form{padding:20px}.radio-group{display:flex;gap:20px}.radio-group label{align-items:center;color:#4a5568;cursor:pointer;display:flex;font-weight:500;gap:8px}.radio-group input[type=radio]{cursor:pointer}.btn-cancel{background:#e2e8f0;color:#2d3748}.btn-cancel:hover{background:#cbd5e0}.btn-save{background:#48bb78;color:#fff}.btn-save:hover{background:#38a169}@media (max-width:768px){.app-header{padding:12px 16px}.hamburger-btn{display:block}.app-header-left{gap:12px}.app-title{font-size:18px}.user-greeting{display:none}.profile-btn{font-size:13px;padding:6px 12px}.view-navigation{box-shadow:2px 0 10px #0003;flex-direction:column;height:100vh;left:-100%;padding:80px 0 20px;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:150}.view-navigation.mobile-open{left:0}.mobile-menu-overlay{display:block}.view-btn{border-bottom:none;border-left:4px solid #0000;font-size:18px;padding:20px 24px;text-align:left}.view-btn.active{background:#fff3;border-bottom:none;border-left-color:#fff}.dashboard{padding:16px}.dashboard-page-header{margin-bottom:20px}.dashboard-page-header h1{font-size:24px}.dashboard-grid{gap:10px}.dashboard .sport-filters{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr)}.dashboard .filter-btn{align-items:center;display:flex;flex-direction:column;gap:2px;justify-content:center;min-height:52px;padding:12px 8px}.dashboard .filter-btn .filter-text{display:none}.dashboard .filter-btn .filter-emoji{font-size:20px}.dashboard .filter-btn.filter-all .filter-text-all{font-size:16px;font-weight:600}.comparison-title{display:flex;flex-direction:column;font-size:15px;gap:4px}.comparison-title .title-text{display:block}.comparison-title .title-date{color:#718096;display:block;font-size:13px;font-weight:600}.week-comparison-banner{margin-bottom:20px;padding:12px 16px}.comparison-stats{align-items:stretch;flex-direction:column;gap:10px}.comparison-stat{justify-content:space-between;padding:10px 14px}.distance-stat-desktop,.time-stat-desktop{display:none!important}.distance-stat-mobile,.time-stat-mobile{align-items:stretch;display:flex!important;flex-direction:column;gap:8px}.distance-stat-mobile .comparison-label,.time-stat-mobile .comparison-label{margin-bottom:4px}.distance-values-merged{align-items:center;display:flex;gap:12px;justify-content:space-between}.distance-fraction{align-items:center;display:flex;gap:4px}.distance-numerator{color:#2d3748;font-size:15px;font-weight:700}.distance-separator{color:#a0aec0;font-size:14px;font-weight:600}.distance-denominator{color:#718096;font-size:13px;font-weight:600}.chart-section{margin-top:20px}.chart-header{align-items:stretch;flex-direction:column;gap:12px;margin-bottom:12px}.filters-toggle-btn{font-size:15px;justify-content:center;padding:12px 20px;width:100%}.chart-filters-panel{padding:16px}.filter-sections-row{gap:16px;grid-template-columns:1fr}.filter-section-title{font-size:13px}.chart-range-controls{align-items:stretch;flex-direction:column;gap:12px}.range-control-group{align-items:stretch;flex-direction:column;gap:6px}.range-control-group label{font-size:14px}.range-select{font-size:14px;padding:10px 12px;width:100%}.reset-week-btn{font-size:13px;padding:10px 12px;width:100%}.chart-filter-group{gap:6px}.chart-filter-btn{flex:1 1;font-size:13px;min-width:calc(50% - 3px);padding:10px 12px}.recharts-wrapper{font-size:11px}.recharts-surface:focus,.recharts-wrapper:focus{outline:none}.recharts-cartesian-axis-tick{font-size:10px}.recharts-legend-wrapper,.recharts-tooltip-wrapper{font-size:12px}.planning-header{padding:16px}.planning-header h2{font-size:20px}.navigation-and-filters-row{flex-direction:column;gap:16px}.month-navigation{gap:10px;padding:0;width:100%}.current-month{font-size:18px;min-width:auto}.planning-filters{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr)}.filter-btn-planning{align-items:center;display:flex;flex-direction:column;gap:2px;justify-content:center;min-height:52px;padding:12px 8px}.filter-btn-planning .filter-text{display:none}.filter-btn-planning .filter-emoji{font-size:20px}.filter-btn-planning.filter-all .filter-text-all{font-size:16px;font-weight:600}.planning-stats{gap:10px}.stat-card-planning{min-width:calc(50% - 5px);padding:10px 16px}.planning-table,.week-stats-banner{padding:12px 16px}.week-stats-content{align-items:stretch;flex-direction:column;gap:12px}.week-volume-total{border-bottom:1px solid #cbd5e0;padding-bottom:12px;padding-right:0}.stats-separator{display:none}.week-sport-stat{padding:8px 12px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:15px 15px 0 0;max-height:95vh;max-width:100%;padding:20px}.modal h2{font-size:20px}.form-row{gap:12px;grid-template-columns:1fr}.session-structure{padding:16px}.structure-header h3{font-size:18px}.overview-stats{flex-direction:column;gap:12px}.visual-timeline{height:50px}.segment-form-modal{border-radius:15px 15px 0 0;max-width:100%}.day-card{min-height:140px;padding:10px}.day-name{font-size:10px}.day-date{font-size:18px}.session-card{padding:12px}.session-sport{font-size:13px}.session-details{font-size:12px}.session-notes{font-size:11px}.add-session-day{font-size:13px;margin-top:10px;padding:10px}}@media (max-width:480px){.app-header{padding:10px 12px}.app-title{font-size:16px}.profile-btn{font-size:12px;padding:5px 10px}.view-navigation{width:100%}.view-btn{font-size:16px;padding:18px 20px}.dashboard{padding:12px}.dashboard-page-header h1{font-size:20px}.dashboard .filter-btn{min-width:100%;width:100%}.comparison-stats{gap:8px}.comparison-stat{padding:8px 12px}.chart-filter-btn{min-width:100%;width:100%}.planning-header h2{font-size:18px}.month-navigation{padding:10px}.month-nav-btn{width:100%}.current-month{font-size:16px}.filter-btn-planning,.stat-card-planning{min-width:100%;width:100%}.planning-table{padding:10px 12px}.modal{border-radius:0;max-height:100vh;padding:16px}.modal h2{font-size:18px}.form-group label{font-size:13px}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:12px}.btn{font-size:15px;padding:12px 20px}.session-structure{padding:12px}.structure-header h3{font-size:16px}.btn-add-segment{padding:12px 20px;width:100%}.overview-stats{gap:10px}.stat-value{font-size:16px}.segment-card{margin-bottom:8px}.segment-title{font-size:14px}.segment-actions{flex-direction:column;gap:6px}.btn-segment-action{padding:10px 12px}.day-card{min-height:120px}.session-card{padding:10px}}@media (max-width:768px){.add-session-day,.btn,.filter-btn,.session-card,.view-btn,button{min-height:44px}.hamburger-btn,.profile-btn{min-height:44px;min-width:44px}.btn:hover,.filter-btn:hover,.session-card:hover,button:hover{transform:none}.btn:active,button:active{opacity:.8;transform:scale(.98)}.calendar-grid,.calendar-grid-compact,.dashboard-grid{will-change:auto}.session-card,.session-card:active{cursor:pointer}body{line-height:1.5}body,input,select,textarea{font-size:16px}.dashboard,.planning-compact,.weeks-container{-webkit-overflow-scrolling:touch}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (max-width:896px) and (orientation:landscape){.app-header{padding:8px 16px}.app-title{font-size:16px}.view-navigation{padding:40px 0 10px}.view-btn{padding:12px 20px}.modal{max-height:90vh;overflow-y:auto}.dashboard,.planning-compact{padding:12px}}@media (max-width:768px){button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid #667eea;outline-offset:2px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.day-card.drag-over{box-shadow:0 0 0 3px #667eea66;transform:none}.session-card.dragging{filter:none;transform:none}.session-card:hover{transform:none}}.profile-container{background:#f5f5f5;flex:1 1;margin:0 auto;max-width:900px;overflow-y:auto;padding:30px;width:100%}.profile-page-header{margin-bottom:30px;text-align:center}.profile-page-header h1{color:#2d3748;font-size:32px;font-weight:700;margin:0}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724}.error-message,.success-message{margin-bottom:20px;padding:12px 16px}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24}.profile-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:30px}.profile-section h2{color:#333;font-size:22px;font-weight:600;margin:0 0 20px}.section-description{color:#666;font-size:14px;line-height:1.5;margin-bottom:25px}.profile-form,.zones-form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#555;font-size:14px;font-weight:600}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .2s}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.save-btn{align-self:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .3s ease}.save-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.zone-editor{background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;padding:20px}.zone-label{color:#333;font-size:18px;font-weight:600;margin:0 0 15px}.zone-inputs{align-items:center;display:flex;gap:15px}.zone-inputs .form-group{flex:1 1}.zone-separator{color:#999;font-size:16px;font-weight:600;margin-top:28px}.logout-btn-profile{background:#dc3545;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .3s ease;width:100%}.logout-btn-profile:hover{background:#c82333;box-shadow:0 6px 20px #dc354566;transform:translateY(-2px)}@media (max-width:768px){.profile-container{padding:20px 15px}.profile-container h1{font-size:26px}.profile-section{padding:20px}.form-row{grid-template-columns:1fr}.zone-inputs{align-items:stretch;flex-direction:column}.zone-separator{margin-top:0;text-align:center}}.week-picker-container{display:inline-block;position:relative}.week-picker-input{align-items:center;background:#fff;border:2px solid #667eea;border-radius:6px;color:#2d3748;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;justify-content:space-between;min-width:200px;padding:8px 12px;transition:all .2s}.week-picker-input:hover{background:#f7fafc;border-color:#5568d3}.week-picker-icon{font-size:16px;opacity:.7}.week-picker-dropdown{animation:fadeIn .2s ease-out;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 25px #00000026;left:0;min-width:320px;position:absolute;top:calc(100% + 5px);z-index:1000}.week-picker-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;border-radius:6px 6px 0 0;display:flex;justify-content:space-between;padding:15px}.week-picker-navigation{grid-gap:12px;align-items:center;display:grid;flex:1 1;gap:12px;grid-template-columns:auto 1fr auto}.week-picker-month-year{align-items:center;display:flex;flex-direction:column;gap:2px;justify-content:center}.week-picker-month-year.clickable{border-radius:4px;cursor:pointer;padding:6px 12px;transition:all .2s}.week-picker-month-year.clickable:hover{background:#e2e8f0}.week-picker-month{color:#2d3748;font-size:14px;font-weight:700;line-height:1.2;text-transform:capitalize}.week-picker-year{color:#667eea;font-size:12px;font-weight:600;line-height:1.2}.week-picker-nav-btn{background:#fff;border:1px solid #cbd5e0;border-radius:4px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:600;padding:6px 10px;transition:all .2s}.week-picker-nav-btn:hover{background:#e2e8f0;border-color:#a0aec0}.week-picker-today-btn{background:#fff;border:1px solid #667eea;border-radius:4px;color:#667eea;cursor:pointer;font-size:12px;font-weight:600;margin-left:12px;padding:6px 12px;transition:all .2s}.week-picker-back-btn,.week-picker-today-btn:hover{background:#667eea;color:#fff}.week-picker-back-btn{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s;width:100%}.week-picker-back-btn:hover{background:#5568d3}.month-year-picker{max-height:400px;overflow-y:auto;padding:15px}.month-selector,.year-selector{margin-bottom:20px}.month-selector:last-child,.year-selector:last-child{margin-bottom:0}.month-selector h4,.year-selector h4{color:#4a5568;font-size:13px;font-weight:700;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.year-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.month-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.month-btn,.year-btn{background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:13px;font-weight:600;padding:10px;transition:all .2s}.month-btn:hover,.year-btn:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-2px)}.month-btn.selected,.year-btn.selected{background:#667eea;border-color:#667eea;color:#fff}.month-btn.selected:hover,.year-btn.selected:hover{background:#5568d3;border-color:#5568d3}.week-picker-weeks{max-height:300px;overflow-y:auto;padding:10px}.week-picker-week{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;justify-content:center;margin-bottom:8px;padding:12px 15px;transition:all .2s}.week-picker-week:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateX(3px)}.week-picker-week.selected{background:#fff;border:3px solid #48bb78;box-shadow:0 4px 6px #48bb7833;color:#2d3748;font-weight:600}.week-picker-week.selected:hover{background:#f0fff4;border-color:#38a169;box-shadow:0 4px 8px #48bb784d;transform:translateX(3px)}.week-picker-week.current{background:#f7fafc;border:2px dashed #cbd5e0}.week-label{background:none;border:none;box-shadow:none;font-size:13px;font-weight:500;margin:0;padding:0;text-align:center}.week-picker-weeks::-webkit-scrollbar{width:8px}.week-picker-weeks::-webkit-scrollbar-track{background:#f7fafc;border-radius:4px}.week-picker-weeks::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.week-picker-weeks::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media (max-width:768px){.week-picker-input{font-size:14px;min-width:100%;padding:10px 14px}.week-picker-dropdown{left:50%;max-width:100vw;min-width:100%;transform:translateX(-50%)}.week-picker-header{padding:12px}.week-picker-month{font-size:13px}.week-picker-nav-btn{font-size:13px;padding:8px 12px}.week-picker-today-btn{font-size:11px;padding:8px 12px}.month-year-picker{max-height:350px;padding:12px}.year-grid{gap:6px;grid-template-columns:repeat(3,1fr)}.month-grid{gap:6px;grid-template-columns:repeat(2,1fr)}.month-btn,.year-btn{font-size:12px;padding:12px 8px}.week-picker-weeks{max-height:250px;padding:8px}.week-picker-week{padding:14px 12px}.week-label{font-size:12px}}@media (max-width:480px){.week-picker-input{font-size:15px;padding:12px}.week-picker-dropdown{animation:slideUp .3s ease-out;border-radius:12px 12px 0 0;bottom:0;left:0;max-height:80vh;position:fixed;right:0;top:auto;transform:none}.month-grid,.year-grid{grid-template-columns:repeat(2,1fr)}.week-picker-week{font-size:14px;padding:16px 12px}}.month-picker-container{display:inline-flex;position:relative;width:auto}.month-picker-external-controls{align-items:center;display:flex;gap:8px}.month-picker-input{align-items:center;background:#0000;border:none;color:#2d3748;cursor:pointer;display:flex;font-size:20px;font-weight:700;justify-content:center;min-width:150px;padding:0 8px;text-align:center;transition:all .2s;white-space:nowrap}.month-picker-input:hover{color:#667eea}.month-nav-btn{background:#fff;border:2px solid #cbd5e0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:16px;font-weight:600;padding:8px 14px;transition:all .2s}.month-nav-btn:hover{background:#e2e8f0;border-color:#a0aec0}.today-btn{background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s;white-space:nowrap}.today-btn:hover{background:#667eea;color:#fff}.month-picker-dropdown{animation:fadeIn .2s ease-out;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 25px #00000026;left:0;min-width:320px;position:absolute;top:calc(100% + 5px);z-index:1000}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.month-picker-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;border-radius:6px 6px 0 0;display:flex;justify-content:space-between;padding:15px}.month-picker-navigation{grid-gap:12px;align-items:center;display:grid;flex:1 1;gap:12px;grid-template-columns:auto 1fr auto}.month-picker-year-display{align-items:center;display:flex;flex-direction:column;gap:2px;justify-content:center}.month-picker-year{color:#667eea;font-size:14px;font-weight:700;line-height:1.2}.month-picker-nav-btn{background:#fff;border:1px solid #cbd5e0;border-radius:4px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:600;padding:6px 10px;transition:all .2s}.month-picker-nav-btn:hover{background:#e2e8f0;border-color:#a0aec0}.month-picker-today-btn{background:#fff;border:1px solid #667eea;border-radius:4px;color:#667eea;cursor:pointer;font-size:12px;font-weight:600;margin-left:12px;padding:6px 12px;transition:all .2s}.month-picker-today-btn:hover{background:#667eea;color:#fff}.month-picker-months{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);padding:15px}.month-picker-month{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:12px 8px;text-align:center;transition:all .2s}.month-picker-month:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-2px)}.month-picker-month.selected{background:#fff;border:3px solid #48bb78;box-shadow:0 4px 6px #48bb7833;color:#2d3748;font-weight:600}.month-picker-month.selected:hover{background:#f0fff4;border-color:#38a169;box-shadow:0 4px 8px #48bb784d;transform:translateY(-2px)}.month-picker-month.current{background:#f7fafc;border:2px dashed #cbd5e0}.month-label{background:none;border:none;box-shadow:none;font-size:13px;font-weight:500;margin:0;padding:0;text-align:center}@media (max-width:768px){.month-picker-external-controls{gap:6px}.month-picker-input{font-size:14px;min-width:130px;padding:0 6px}.month-nav-btn{font-size:14px;padding:6px 10px}.today-btn{font-size:12px;padding:6px 12px}.month-picker-dropdown{left:50%;max-width:100vw;min-width:100%;transform:translateX(-50%)}.month-picker-header{padding:12px}.month-picker-year{font-size:13px}.month-picker-nav-btn{font-size:13px;padding:8px 12px}.month-picker-today-btn{font-size:11px;padding:8px 12px}.month-picker-months{gap:8px;grid-template-columns:repeat(2,1fr);padding:12px}.month-picker-month{padding:14px 10px}.month-label{font-size:12px}}@media (max-width:480px){.month-picker-external-controls{gap:4px}.month-picker-input{font-size:13px;min-width:110px;padding:0 4px}.month-nav-btn{font-size:13px;padding:6px 8px}.today-btn{font-size:11px;padding:6px 10px}.month-picker-dropdown{animation:slideUp .3s ease-out;border-radius:12px 12px 0 0;bottom:0;left:0;max-height:80vh;position:fixed;right:0;top:auto;transform:none}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.month-picker-months{grid-template-columns:repeat(2,1fr)}.month-picker-month{font-size:14px;padding:16px 12px}}
/*# sourceMappingURL=main.aeb4d2b8.css.map*/