.start-screen{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a1a 0%,#0d0d0d 100%);padding:20px;overflow-y:auto}.start-container{width:100%;max-width:500px;background:var(--card);border-radius:var(--radius);padding:30px 20px;border:1px solid var(--border)}.start-container h1{font-size:48px;text-align:center;margin-bottom:8px}.start-container .subtitle{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:30px}.start-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.form-group input[type=text]{padding:12px;font-size:16px}.strain-list{display:grid;gap:12px;max-height:300px;overflow-y:auto;padding:4px}.strain-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);padding:12px;text-align:left;transition:all .2s}.strain-card:hover{border-color:var(--primary);background:rgba(46,204,113,.05)}.strain-card.active{border-color:var(--primary);background:rgba(46,204,113,.1)}.strain-name{font-weight:600;margin-bottom:6px}.strain-stats{display:flex;gap:12px;font-size:12px;color:var(--text-muted);margin-bottom:8px}.strain-yield{color:var(--primary);font-weight:600;font-size:14px}.strain-detail{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-top:12px}.strain-detail h3{margin-bottom:8px;font-size:16px}.strain-detail .description{font-size:13px;color:var(--text-muted);margin-bottom:12px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;font-size:13px;margin-bottom:8px}.detail-grid div{background:var(--card);padding:8px;border-radius:4px}.detail-grid strong{color:var(--primary)}.strain-detail .dominant{font-size:12px;color:var(--text-muted);margin-bottom:0}.difficulty-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.difficulty-btn{background:var(--bg);border:2px solid var(--border);padding:12px;border-radius:var(--radius);transition:all .2s;font-weight:600}.difficulty-btn:hover{border-color:var(--primary)}.difficulty-btn.active{background:var(--primary);border-color:var(--primary);color:#000}.error-message{background:rgba(231,76,60,.1);border:1px solid var(--danger);color:#ff7675;padding:12px;border-radius:var(--radius);font-size:13px}.start-button{background:var(--primary);color:#000;padding:14px;font-size:16px;font-weight:700;margin-top:8px}.start-button:hover:not(:disabled){background:#27ae60;transform:translateY(-2px);box-shadow:0 4px 12px #2ecc714d}@media (max-width: 480px){.start-container{padding:20px 16px}.start-container h1{font-size:36px}.detail-grid{grid-template-columns:1fr}}.metric-info-modal{max-width:500px;max-height:85vh;overflow-y:auto}.info-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:2px solid var(--border);margin-bottom:16px}.info-header h2{margin:0;font-size:20px}.current-status{padding:16px;border-radius:8px;margin-bottom:16px;border:2px solid var(--border)}.current-status.status-low{background:rgba(231,76,60,.1);border-color:#e74c3c}.current-status.status-high{background:rgba(243,156,18,.1);border-color:#f39c12}.current-status.status-optimal{background:rgba(39,174,96,.1);border-color:#27ae60}.status-display{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.status-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.current-value{font-size:24px;font-weight:700;color:var(--primary)}.current-status.status-low .current-value{color:#e74c3c}.current-status.status-high .current-value{color:#f39c12}.range-info{display:flex;flex-direction:column;gap:6px;font-size:12px}.range-label,.optimal-label{color:var(--text-muted);font-weight:600}.range-visualization{margin-bottom:20px}.range-track{height:24px;background:var(--border);border-radius:6px;position:relative;overflow:hidden;margin-bottom:8px}.range-fill{position:absolute;height:100%;background:linear-gradient(90deg,#27ae60,#2ecc71);opacity:.6}.range-indicator{position:absolute;top:0;width:4px;height:100%;background:var(--primary);transform:translate(-50%)}.range-indicator.status-low{background:#e74c3c}.range-indicator.status-high{background:#f39c12}.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);font-weight:600}.info-content{margin-bottom:16px}.info-section{margin-bottom:16px;padding:12px;background:rgba(0,0,0,.2);border-radius:6px;border-left:4px solid var(--border)}.info-section h3{margin:0 0 8px;font-size:14px;font-weight:700;color:var(--text)}.info-section p{margin:0;font-size:13px;line-height:1.5;color:var(--text)}.info-section.warning{background:rgba(231,76,60,.1);border-left-color:#e74c3c}.info-section.success{background:rgba(39,174,96,.1);border-left-color:#27ae60}.additive-list{list-style:none;margin:0;padding:0}.additive-list li{padding:8px 0;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px}.additive-icon{color:var(--primary);font-weight:700}.additive-list li:not(:last-child){border-bottom:1px solid rgba(0,0,0,.2)}.modal-close-btn{width:100%;padding:12px;background:var(--primary);color:#000;border:none;border-radius:6px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease}.modal-close-btn:hover{background:#27ae60;transform:translateY(-2px);box-shadow:0 4px 12px #2ecc714d}@media (max-width: 768px){.metric-info-modal{max-width:90vw;max-height:90vh}.info-header h2{font-size:18px}.current-value{font-size:20px}.range-track{height:20px}.info-section{padding:10px}.info-section h3{font-size:13px}.info-section p{font-size:12px}}.metric-card{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px;transition:all .3s ease}.metric-card.metric-optimal{border-color:#27ae60;background:rgba(39,174,96,.02)}.metric-card.metric-warning{border-color:#f39c12;background:rgba(243,156,18,.02)}.metric-card.metric-critical{border-color:#e74c3c;background:rgba(231,76,60,.02);animation:pulse-card 1.5s ease-in-out infinite}@keyframes pulse-card{0%,to{box-shadow:0 0 #e74c3c4d}50%{box-shadow:0 0 0 6px #e74c3c00}}.metric-header{display:flex;justify-content:space-between;align-items:center;gap:8px;position:relative}.metric-header-right{display:flex;align-items:center;gap:6px}.metric-info-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:4px;transition:transform .2s ease,filter .2s ease;display:flex;align-items:center;justify-content:center}.metric-info-btn:hover{transform:scale(1.2);filter:drop-shadow(0 0 4px rgba(46,204,113,.5))}.metric-label-area{display:flex;align-items:center;gap:6px}.metric-icon{font-size:16px;line-height:1}.metric-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.metric-status-badge{font-size:14px;padding:2px 6px;border-radius:4px;display:flex;align-items:center;justify-content:center}.metric-status-badge.status-optimal{background:rgba(39,174,96,.1)}.metric-status-badge.status-warning{background:rgba(243,156,18,.1);animation:pulse-badge 1.5s ease-in-out infinite}.metric-status-badge.status-critical{background:rgba(231,76,60,.1);animation:pulse-badge 1s ease-in-out infinite}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.5}}.metric-value-area{display:flex;align-items:baseline;gap:6px}.metric-value{font-size:18px;font-weight:700;color:var(--primary)}.metric-value.value-optimal{color:#27ae60}.metric-value.value-warning{color:#f39c12}.metric-value.value-critical{color:#e74c3c}.metric-delta{font-size:11px;font-weight:600;padding:2px 4px;border-radius:3px}.metric-delta.delta-positive{color:#27ae60;background:rgba(39,174,96,.15)}.metric-delta.delta-negative{color:#e74c3c;background:rgba(231,76,60,.15)}.metric-threshold-slider{display:flex;flex-direction:column;gap:4px}.slider-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden;position:relative}.slider-fill{height:100%;transition:width .3s ease}.slider-fill-optimal{background:linear-gradient(90deg,#27ae60,#2ecc71)}.slider-fill-warning{background:linear-gradient(90deg,#f39c12,#e67e22)}.slider-fill-critical{background:linear-gradient(90deg,#e74c3c,#c0392b)}.slider-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--text-muted);padding:0 2px}.slider-optimal{font-weight:600;color:var(--primary)}.metric-sparkline{display:flex;align-items:center;gap:4px}.sparkline-chart{flex:1;height:20px;opacity:.7}.sparkline-point{transition:all .2s ease}.sparkline-label{font-size:11px;font-weight:600;min-width:12px;text-align:center;color:var(--text-muted)}@media (max-width: 768px){.metric-card{padding:10px;gap:6px}.metric-value{font-size:16px}.slider-labels{font-size:8px}}.health-bar-container{background:var(--card);border:2px solid var(--border);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:all .3s ease}.health-bar-container.status-thriving{border-color:#27ae60;background:rgba(39,174,96,.03)}.health-bar-container.status-healthy{border-color:#3498db;background:rgba(52,152,219,.03)}.health-bar-container.status-stressed{border-color:#f39c12;background:rgba(243,156,18,.03)}.health-bar-container.status-critical{border-color:#e74c3c;background:rgba(231,76,60,.03)}.health-bar-container.is-critical{animation:pulse-health-container 1s ease-in-out infinite}@keyframes pulse-health-container{0%,to{box-shadow:0 0 #e74c3c66}50%{box-shadow:0 0 0 8px #e74c3c00}}.health-header{display:flex;justify-content:space-between;align-items:center}.health-label-area{display:flex;align-items:center;gap:8px}.health-emoji{font-size:24px;line-height:1}.health-label{font-size:13px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.health-status-text{font-size:14px;font-weight:700;color:var(--primary)}.health-bar{height:24px;background:var(--border);border-radius:6px;overflow:hidden;position:relative}.health-fill{height:100%;transition:width .3s ease;display:flex;align-items:center;justify-content:center;position:relative}.health-fill-thriving{background:linear-gradient(90deg,#27ae60,#2ecc71);box-shadow:inset 0 0 4px #ffffff4d}.health-fill-healthy{background:linear-gradient(90deg,#3498db,#5dade2);box-shadow:inset 0 0 4px #ffffff4d}.health-fill-stressed{background:linear-gradient(90deg,#f39c12,#e67e22);box-shadow:inset 0 0 4px #fff3}.health-fill-critical{background:linear-gradient(90deg,#e74c3c,#c0392b);box-shadow:inset 0 0 4px #fff3}.health-footer{display:flex;justify-content:space-between;align-items:center}.health-percentage{font-size:16px;font-weight:700;color:var(--text)}.health-change{font-size:12px;font-weight:600;padding:4px 8px;border-radius:4px}.health-change.change-positive{color:#27ae60;background:rgba(39,174,96,.2)}.health-change.change-negative{color:#e74c3c;background:rgba(231,76,60,.2)}@media (max-width: 768px){.health-bar-container{padding:12px;gap:10px}.health-bar{height:20px}.health-emoji{font-size:20px}.health-label{font-size:12px}.health-percentage{font-size:14px}}.dashboard-panel{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--bg);border-radius:8px}.dashboard-section{display:flex;flex-direction:column;gap:12px;background:var(--card);border:2px solid var(--border);border-radius:8px;padding:16px;transition:all .3s ease}.dashboard-section-title{font-size:13px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;display:flex;align-items:center;gap:8px;margin:0 0 4px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}@media (max-width: 1024px){.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (max-width: 768px){.dashboard-panel{gap:12px;padding:12px}.dashboard-section{gap:10px;padding:12px}.dashboard-section-title{font-size:12px;margin-bottom:2px}.metrics-grid{grid-template-columns:repeat(2,1fr);gap:10px}}@media (max-width: 480px){.dashboard-panel{gap:10px;padding:10px}.dashboard-section{gap:8px;padding:10px}.dashboard-section-title{font-size:11px}.metrics-grid{grid-template-columns:1fr;gap:8px}}.control-panel{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--card);border:2px solid var(--border);border-radius:8px}.control-title{margin:0 0 8px;font-size:13px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.control-section{display:flex;flex-direction:column;gap:8px}.control-label{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:12px;font-weight:600}.label-text{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.value-display{color:var(--primary);font-weight:700;font-size:13px}.control-slider{width:100%;height:6px;border-radius:3px;background:var(--border);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 0 4px #00000080;transition:all .2s ease}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px #2ecc7199}.control-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 0 4px #00000080;transition:all .2s ease}.control-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px #2ecc7199}.range-hints{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);padding:0 2px}.additives-section{border-top:2px solid var(--border);padding-top:12px}.loading-text,.no-additives{font-size:12px;color:var(--text-muted);text-align:center;padding:12px;font-style:italic}.additives-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.additive-card{display:flex;gap:8px;padding:10px;background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:6px;transition:all .2s ease}.additive-card.selected{background:rgba(46,204,113,.1);border-color:#27ae60}.additive-card:hover{background:rgba(46,204,113,.15)}.additive-toggle{background:none;border:2px solid var(--border);border-radius:4px;width:28px;height:28px;padding:0;cursor:pointer;font-weight:700;font-size:14px;color:var(--text);transition:all .2s ease;flex-shrink:0}.additive-card.selected .additive-toggle{background:#27ae60;border-color:#27ae60;color:#000}.additive-toggle:hover{transform:scale(1.1);border-color:var(--primary)}.additive-info{display:flex;flex-direction:column;gap:6px;flex:1}.additive-name{font-size:11px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.3px}.additive-dose{display:flex;align-items:center;gap:4px;font-size:10px}.additive-dose label{color:var(--text-muted);font-weight:600;min-width:fit-content}.dose-input{width:50px;padding:2px 4px;border:1px solid var(--border);background:rgba(0,0,0,.2);color:var(--text);border-radius:3px;font-size:10px}.dose-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2ecc711a}.control-summary{display:flex;flex-direction:column;gap:6px;padding:12px;background:rgba(46,204,113,.05);border:1px solid rgba(46,204,113,.2);border-radius:6px}.summary-row{display:flex;justify-content:space-between;font-size:12px;font-weight:600}.summary-row span:first-child{color:var(--text-muted)}.summary-value{color:var(--primary)}@media (max-width: 768px){.control-panel{padding:12px;gap:12px}.control-section{gap:6px}.additives-grid{grid-template-columns:1fr}.additive-card{padding:8px}}.plant-visual{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,rgba(45,80,22,.1) 0%,rgba(76,175,80,.05) 100%);border-radius:12px;border:1px solid rgba(76,175,80,.2)}.plant-container{width:140px;height:200px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.3);border-radius:8px;padding:1rem;animation:plant-glow 4s ease-in-out infinite}@keyframes plant-glow{0%,to{box-shadow:0 0 8px #4caf501a}50%{box-shadow:0 0 16px #4caf5033}}.plant-svg{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.plant-info{width:100%;display:flex;flex-direction:column;gap:.75rem}.stage-label{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:rgba(45,80,22,.15);border-radius:6px}.stage-icon{font-size:1.5rem;line-height:1}.stage-text{flex:1;display:flex;flex-direction:column;gap:.25rem}.stage-name{font-weight:600;color:#2d5016;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.height-info{font-size:.8rem;color:#558b2f;font-weight:500}.stage-progress{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:rgba(45,80,22,.08);border-radius:6px}.progress-bar{flex:1;height:6px;background:rgba(45,80,22,.2);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#66bb6a 0%,#4caf50 100%);transition:width .3s ease-out;border-radius:3px}.progress-text{min-width:2.5rem;font-size:.75rem;font-weight:600;color:#2d5016;text-align:right}@media (max-width: 480px){.plant-visual{padding:1rem;gap:1rem}.plant-container{width:120px;height:170px;padding:.75rem}.stage-label{padding:.5rem .75rem;gap:.75rem}.stage-icon{font-size:1.25rem}.stage-name{font-size:.8rem}.height-info{font-size:.75rem}}.plant-status-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:16px}.plant-status-card.status-excellent{border-left:4px solid #27ae60}.plant-status-card.status-good{border-left:4px solid #3498db}.plant-status-card.status-warning{border-left:4px solid #f39c12}.plant-status-card.status-critical{border-left:4px solid #e74c3c}.status-header{display:flex;justify-content:space-between;align-items:flex-start}.status-display{display:flex;gap:12px;align-items:flex-start}.status-emoji{font-size:32px;line-height:1}.status-display h3{font-size:14px;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin:0 0 4px;letter-spacing:.5px}.status-label{font-size:18px;font-weight:700;color:var(--primary);margin:0}.stage-badge{display:flex;flex-direction:column;align-items:flex-end;gap:4px;background:var(--bg);padding:8px 12px;border-radius:6px;font-size:12px}.stage-text{text-transform:capitalize;font-weight:600;color:var(--text)}.day-text{color:var(--text-muted);font-size:11px}.status-metrics{background:var(--bg);padding:12px;border-radius:6px}.metric-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric-item{display:flex;flex-direction:column;gap:4px}.metric-item .label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.metric-item .value{font-size:16px;font-weight:700;color:var(--primary)}.metric-item .value.positive{color:#27ae60}.metric-item .value.negative{color:#e74c3c}.recommendations{background:var(--bg);padding:12px;border-radius:6px}.recommendations h4{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin:0 0 8px;letter-spacing:.5px}.recommendations ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.recommendations li{font-size:13px;color:var(--text);padding-left:0}.milestones{background:var(--bg);padding:12px;border-radius:6px}.milestones h4{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin:0 0 8px;letter-spacing:.5px}.milestones-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.milestone{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 10px;background:var(--border);border-radius:4px;white-space:nowrap;flex-shrink:0;opacity:.5;transition:all .3s ease}.milestone.passed{background:rgba(39,174,96,.1);border:1px solid #27ae60;opacity:1}.milestone-day{font-size:10px;color:var(--text-muted);font-weight:600}.milestone-emoji{font-size:16px;line-height:1}.milestone-label{font-size:11px;color:var(--text);font-weight:500}@media (max-width: 768px){.status-header{flex-direction:column;gap:12px}.metric-pair{grid-template-columns:1fr}.stage-badge{align-items:flex-start}}.trichome-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:flex-end;z-index:1000}.trichome-modal{width:100%;max-width:500px;background:var(--card);border-radius:16px 16px 0 0;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.trichome-visual{display:flex;flex-direction:column;gap:20px;align-items:center}.trichome-display{width:200px;height:200px;background:var(--bg);border-radius:50%;padding:8px;box-shadow:0 4px 16px #00000080}.trichome-circle{width:100%;height:100%}.trichome-legend{width:100%;display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:12px;padding:10px;background:var(--bg);border-radius:6px;font-size:13px}.legend-color{width:24px;height:24px;border-radius:4px;border:1px solid var(--border)}.trichome-controls{display:flex;flex-direction:column;gap:16px;background:var(--bg);padding:16px;border-radius:8px}.control-item{display:flex;flex-direction:column;gap:8px}.control-item label{font-size:13px;font-weight:600;color:var(--text-muted)}.control-item .slider{cursor:pointer}.amber-display{background:var(--card);padding:10px;border-radius:6px;text-align:center;font-weight:600;color:var(--text-muted);border:1px solid var(--border)}.recommendation-box{background:rgba(46,204,113,.1);border:1px solid rgba(46,204,113,.3);padding:16px;border-radius:8px}.recommendation-box h4{margin:0 0 8px;font-size:13px;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.recommendation-box p{margin:0;font-size:13px;color:var(--text-muted)}.modal-buttons{display:flex;gap:12px}.cancel-btn,.harvest-btn{flex:1;padding:12px;font-weight:600;font-size:14px;border-radius:6px}.cancel-btn{background:var(--bg);border:1px solid var(--border);color:var(--text)}.cancel-btn:hover{border-color:var(--text-muted)}.harvest-btn{background:var(--warning);color:#000}.harvest-btn:hover:not(:disabled){background:#e67e22}.harvest-btn:disabled{opacity:.5}@media (max-width: 480px){.trichome-modal{border-radius:12px 12px 0 0}.modal-header{padding:16px}.modal-content{padding:16px;gap:16px}.trichome-display{width:160px;height:160px}}.session-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:flex-end;z-index:1000}.session-modal{width:100%;max-width:500px;background:var(--card);border-radius:16px 16px 0 0;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card)}.modal-header h2{margin:0;font-size:18px}.close-btn{width:32px;height:32px;padding:0;background:var(--bg);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px}.close-btn:hover{background:rgba(255,255,255,.1)}.modal-content{padding:20px;display:flex;flex-direction:column;gap:20px}.session-section{display:flex;flex-direction:column;gap:12px}.session-section h3{margin:0;font-size:14px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.session-section .description{margin:0;font-size:13px;color:var(--text-muted);line-height:1.4}.code-display,.link-display{display:flex;gap:8px;background:var(--bg);padding:8px;border-radius:6px;border:1px solid var(--border)}.code-display input,.link-display input{flex:1;background:transparent;border:none;padding:8px;font-family:Courier New,monospace;font-size:12px;color:var(--primary)}.code-display input:focus,.link-display input:focus{outline:none}.copy-btn{padding:8px 12px;background:var(--secondary);color:#fff;font-size:12px;white-space:nowrap}.copy-btn:hover{background:#2980b9}.email-input-group{display:flex;gap:8px}.email-input-group input{flex:1;padding:12px}.send-btn{padding:12px;background:var(--primary);color:#000;font-weight:600;white-space:nowrap}.send-btn:hover:not(:disabled){background:#27ae60}.send-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{background:rgba(231,76,60,.1);border:1px solid var(--danger);color:#ff7675;padding:12px;border-radius:6px;font-size:13px}.instructions{background:rgba(52,152,219,.1);border:1px solid rgba(52,152,219,.3);padding:16px;border-radius:6px}.instructions h4{margin:0 0 12px;font-size:13px;color:var(--secondary);text-transform:uppercase;letter-spacing:.5px}.instructions ol{margin:0;padding-left:20px}.instructions li{font-size:13px;color:var(--text-muted);margin-bottom:8px}.instructions li:last-child{margin-bottom:0}@media (max-width: 480px){.session-modal{border-radius:12px 12px 0 0}.modal-header,.modal-content{padding:16px}.code-display,.link-display,.email-input-group{flex-wrap:wrap}.copy-btn,.send-btn{flex:0 0 auto}}.harvest-screen-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.harvest-screen{background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 40px #66bb6a33;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;border:1px solid rgba(76,175,80,.3)}.harvest-header{background:linear-gradient(135deg,rgba(76,175,80,.2) 0%,rgba(45,80,22,.2) 100%);padding:2rem 1.5rem;text-align:center;border-bottom:1px solid rgba(76,175,80,.2)}.harvest-title{font-size:2rem;font-weight:700;color:#66bb6a;margin-bottom:.5rem}.harvest-subtitle{font-size:.9rem;color:#aaa;text-transform:uppercase;letter-spacing:1px}.harvest-quality{padding:1.5rem;display:flex;justify-content:center}.quality-badge{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:rgba(45,80,22,.2);border:2px solid #66bb6a;border-radius:12px;flex-direction:column;text-align:center;min-width:200px}.quality-emoji{font-size:2.5rem;line-height:1}.quality-text{display:flex;flex-direction:column;gap:.25rem}.quality-label{font-size:1.1rem;font-weight:600;color:#66bb6a}.quality-desc{font-size:.8rem;color:#aaa}.harvest-tabs{display:flex;gap:0;border-bottom:1px solid rgba(76,175,80,.2);padding:0 1.5rem}.tab-button{flex:1;padding:1rem;background:none;border:none;color:#aaa;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .3s ease;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}.tab-button:hover{color:#66bb6a}.tab-button.active{color:#66bb6a;border-bottom-color:#66bb6a}.harvest-summary,.harvest-breakdown{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.stat-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:rgba(45,80,22,.15);border-radius:8px;border:1px solid rgba(76,175,80,.2)}.stat-icon{font-size:1.75rem;line-height:1}.stat-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;color:#aaa;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.3rem;font-weight:600;color:#66bb6a}.profit-card{padding:1.5rem;background:rgba(76,175,80,.1);border-radius:8px;border-left:4px solid #66bb6a;text-align:center;display:flex;flex-direction:column;gap:.75rem}.profit-label{font-size:.9rem;color:#aaa;text-transform:uppercase;letter-spacing:.5px}.profit-value{font-size:2rem;font-weight:700;color:#66bb6a}.profit-sentiment{font-size:.9rem;color:#aaa;margin-top:.5rem}.trichome-section{display:flex;flex-direction:column;gap:1rem}.trichome-section h3{font-size:1rem;font-weight:600;color:#66bb6a;margin:0;text-transform:uppercase;letter-spacing:.5px}.trichome-bars{display:flex;flex-direction:column;gap:1rem}.trichome-bar{display:flex;flex-direction:column;gap:.5rem}.trichome-label{display:flex;justify-content:space-between;font-size:.85rem;color:#ccc}.bar-container{height:20px;background:rgba(45,80,22,.2);border-radius:10px;overflow:hidden}.bar-fill{height:100%;border-radius:10px;transition:width .3s ease}.bar-fill.clear{background:#90CAF9}.bar-fill.cloudy{background:#E1BEE7}.bar-fill.amber{background:#FFB74D}.insights{display:flex;flex-direction:column;gap:.75rem}.insights h3{font-size:1rem;font-weight:600;color:#66bb6a;margin:0;text-transform:uppercase;letter-spacing:.5px}.insights-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.insights-list li{padding:.75rem;background:rgba(76,175,80,.1);border-left:2px solid #66bb6a;border-radius:4px;font-size:.9rem;color:#ccc}.harvest-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem;border-top:1px solid rgba(76,175,80,.2)}.action-button{padding:1rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;font-size:.9rem;transition:all .3s ease}.action-button.primary{background:linear-gradient(135deg,#66bb6a 0%,#4caf50 100%);color:#fff;box-shadow:0 4px 12px #66bb6a4d}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #66bb6a66}.action-button.secondary{background:rgba(45,80,22,.2);color:#66bb6a;border:1px solid rgba(76,175,80,.3)}.action-button.secondary:hover{background:rgba(45,80,22,.3);border-color:#4caf5080}@media (max-width: 600px){.harvest-screen{max-width:100%;border-radius:12px}.harvest-header{padding:1.5rem 1rem}.harvest-title{font-size:1.75rem}.stat-group,.harvest-actions{grid-template-columns:1fr}.quality-badge{min-width:150px}}.day-summary-footer{display:flex;align-items:center;justify-content:space-around;padding:12px 16px;background:var(--card);border-top:2px solid var(--border);border-radius:0;gap:0}.footer-item{display:flex;align-items:center;gap:6px;flex:1;justify-content:center}.footer-icon{font-size:16px;line-height:1}.footer-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.footer-value{font-size:12px;font-weight:700;padding:2px 4px;border-radius:3px;margin-left:2px}.footer-value.value-positive{color:#27ae60;background:rgba(39,174,96,.15)}.footer-value.value-negative{color:#e74c3c;background:rgba(231,76,60,.15)}.footer-value.value-neutral{color:#3498db;background:rgba(52,152,219,.15)}.footer-divider{width:1px;height:20px;background:var(--border);margin:0 4px}@media (max-width: 768px){.day-summary-footer{padding:10px 12px;gap:0}.footer-item{gap:4px}.footer-icon{font-size:14px}.footer-label{font-size:10px}.footer-value{font-size:11px}.footer-divider{margin:0 2px}}@media (max-width: 480px){.day-summary-footer{padding:8px 10px}.footer-item{gap:3px}.footer-icon{font-size:12px}.footer-label{font-size:9px}.footer-value{display:none}.footer-divider{height:16px;margin:0 2px}}.harvest-button-container{display:flex;gap:16px;align-items:center;padding:16px;background:var(--card);border:2px solid var(--border);border-radius:12px;margin:16px 0}.yield-estimate{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:rgba(0,0,0,.2);border-radius:8px;min-width:120px}.yield-value{font-size:32px;font-weight:700;color:var(--primary);line-height:1}.yield-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.quality-tier{padding:6px 12px;border-radius:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.quality-tier.tier-S{background:#FFD700;color:#000}.quality-tier.tier-A{background:#90EE90;color:#000}.quality-tier.tier-B{background:#87CEEB;color:#000}.quality-tier.tier-C{background:#FFB6C1;color:#000}.harvest-info{display:flex;flex-direction:column;gap:8px;flex:1}.days-in-flower{font-size:14px;color:var(--text);font-weight:600}.status{font-size:13px;font-weight:600;padding:6px 8px;border-radius:4px;display:inline-block;width:fit-content}.status-gray{background:rgba(128,128,128,.2);color:gray}.status-blue{background:rgba(0,120,215,.2);color:#0078d7}.status-orange{background:rgba(243,156,18,.2);color:#f39c12}.status-green{background:rgba(39,174,96,.2);color:#27ae60}.quality-loss-warning{font-size:12px;color:#f39c12;font-weight:600;display:flex;align-items:center;gap:6px}.harvest-btn{padding:12px 20px;background:var(--primary);color:#000;border:none;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:140px}.harvest-btn.active{background:#2ecc71;box-shadow:0 4px 12px #2ecc714d}.harvest-btn.active:hover{background:#27ae60;transform:translateY(-2px);box-shadow:0 6px 16px #2ecc7166}.harvest-btn.disabled{background:#ccc;color:#666;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.harvest-button-container{flex-direction:column;gap:12px}.yield-estimate{width:100%;min-width:unset}.harvest-btn{width:100%}.yield-value{font-size:28px}}.harvest-assessment-modal{max-width:700px;max-height:90vh;overflow-y:auto}.assessment-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:2px solid var(--border);margin-bottom:20px}.assessment-header h2{margin:0;font-size:22px;color:var(--text)}.quality-section{display:flex;gap:24px;align-items:center;padding:20px;background:rgba(0,0,0,.2);border-radius:12px;margin-bottom:20px}.quality-tier-display{display:flex;flex-direction:column;align-items:center;gap:8px}.tier-letter{font-size:64px;font-weight:700;line-height:1;font-weight:900}.tier-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.quality-score{font-size:14px;color:var(--text);line-height:1.6}.quality-score strong{font-size:16px;color:var(--primary)}.yield-section,.cannabinoid-section,.revenue-section,.optimal-section,.advice-section{margin-bottom:20px}.yield-section h3,.cannabinoid-section h3,.revenue-section h3,.optimal-section h3,.advice-section h3{margin:0 0 12px;font-size:16px;font-weight:700;color:var(--text)}.yield-grid,.profile-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.yield-stat,.profile-stat{padding:12px;background:rgba(0,0,0,.2);border-radius:8px;border:1px solid var(--border)}.yield-stat .label,.profile-stat .label{display:block;font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.yield-stat .value,.profile-stat .value{display:block;font-size:18px;font-weight:700;color:var(--primary)}.revenue-breakdown{display:flex;flex-direction:column;gap:8px;padding:16px;background:rgba(0,0,0,.2);border-radius:8px;border:1px solid var(--border)}.revenue-line{display:flex;justify-content:space-between;font-size:14px;padding:8px 0;color:var(--text);border-bottom:1px solid rgba(0,0,0,.1)}.revenue-line:last-child{border-bottom:none}.revenue-line .value{font-weight:700;color:var(--primary)}.revenue-line.penalty .value{color:#e74c3c}.revenue-line.total{background:rgba(0,0,0,.1);padding:12px 8px;border-radius:4px;font-weight:700;border-bottom:none;font-size:16px}.revenue-line.total .value{font-size:16px;font-weight:700}.optimal-text{margin:0 0 12px;font-size:13px;color:var(--text-muted);line-height:1.5}.optimal-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.optimal-stats .stat{padding:12px;background:rgba(39,174,96,.1);border-radius:8px;border:1px solid rgba(39,174,96,.3)}.optimal-stats .stat .label{display:block;font-size:12px;color:var(--text-muted);font-weight:600;margin-bottom:6px}.optimal-stats .stat .value{display:block;font-size:18px;font-weight:700;color:#27ae60}.advice-subsection{margin-bottom:16px;padding:12px;background:rgba(0,0,0,.2);border-radius:8px;border-left:4px solid var(--border)}.advice-subsection h4{margin:0 0 8px;font-size:14px;font-weight:700;color:var(--text)}.advice-subsection ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.advice-subsection li{font-size:13px;color:var(--text);line-height:1.5;padding-left:20px;position:relative}.advice-subsection li:before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700}.close-button{width:100%;padding:14px;background:var(--primary);color:#000;border:none;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease;margin-top:16px}.close-button:hover{background:#27ae60;transform:translateY(-2px);box-shadow:0 4px 12px #2ecc714d}@media (max-width: 768px){.harvest-assessment-modal{max-width:90vw;max-height:85vh}.quality-section{flex-direction:column;gap:12px}.tier-letter{font-size:48px}.yield-grid,.profile-grid,.optimal-stats{grid-template-columns:1fr}.assessment-header h2{font-size:18px}}.payment-screen{max-width:600px;max-height:90vh;overflow-y:auto}.payment-header{text-align:center;padding-bottom:20px;border-bottom:2px solid var(--border);margin-bottom:20px}.payment-header h1{margin:0 0 8px;font-size:28px;color:var(--text)}.harvest-summary{margin:0;font-size:13px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.payment-message{padding:20px;border-radius:12px;margin-bottom:20px;border-left:4px solid var(--border)}.payment-message h2{margin:0 0 8px;font-size:18px;color:var(--text)}.payment-message p{margin:0;font-size:13px;color:var(--text-muted);line-height:1.6}.payment-message.excellent{background:rgba(255,215,0,.1);border-left-color:gold}.payment-message.excellent h2{color:gold}.payment-message.good{background:rgba(144,238,144,.1);border-left-color:#90ee90}.payment-message.good h2{color:#27ae60}.payment-message.average{background:rgba(135,206,235,.1);border-left-color:#87ceeb}.payment-message.average h2{color:#0078d7}.payment-message.poor{background:rgba(255,182,193,.1);border-left-color:#ffb6c1}.payment-message.poor h2{color:#e74c3c}.payment-breakdown{display:flex;flex-direction:column;gap:12px;padding:16px;background:rgba(0,0,0,.2);border-radius:12px;border:1px solid var(--border);margin-bottom:20px}.breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:13px}.breakdown-row .label{color:var(--text-muted);font-weight:600}.breakdown-row .amount{font-weight:700;color:var(--text);font-size:14px}.breakdown-row.base{border-bottom:1px solid rgba(0,0,0,.1);padding-bottom:12px;margin-bottom:12px}.breakdown-row.base .amount{color:var(--primary);font-size:16px}.breakdown-section{padding:12px 0}.breakdown-section h3{margin:0 0 8px;font-size:12px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.breakdown-row.modifier{font-size:12px;padding:6px 0}.breakdown-row.modifier .amount{color:var(--primary);font-weight:700}.breakdown-row.adjusted{background:rgba(0,0,0,.1);padding:8px;border-radius:4px;margin-top:6px;font-weight:600}.breakdown-row.adjusted .amount{color:#27ae60;font-size:14px}.breakdown-section.penalties{background:rgba(231,76,60,.1);padding:10px 8px;border-radius:4px;border:1px solid rgba(231,76,60,.3)}.breakdown-section.penalties h3{color:#e74c3c}.breakdown-row.deduction{font-size:12px;padding:6px 0}.breakdown-row.deduction .amount{color:#e74c3c;font-weight:700}.breakdown-row.final-payment{background:rgba(46,204,113,.15);padding:14px 10px;border-radius:8px;border-top:2px solid #2ecc71;font-weight:700;font-size:15px;margin-top:12px}.breakdown-row.final-payment .label{color:var(--text);font-weight:700;font-size:15px}.breakdown-row.final-payment .amount.final{color:#2ecc71;font-size:18px;font-weight:900}.cash-update{display:flex;flex-direction:column;gap:10px;padding:16px;background:rgba(0,0,0,.2);border-radius:12px;border:1px solid var(--border);margin-bottom:20px}.cash-stat{display:flex;justify-content:space-between;align-items:center;font-size:13px}.cash-stat .label{color:var(--text-muted);font-weight:600}.cash-stat .amount{font-weight:700;color:var(--text);font-size:14px}.cash-stat .amount.positive{color:#2ecc71}.cash-stat.total{background:rgba(46,204,113,.1);padding:12px;border-radius:6px;border:1px solid rgba(46,204,113,.3);margin-top:4px;font-weight:700;font-size:14px}.cash-stat.total .amount{color:#2ecc71;font-size:16px;font-weight:900}.next-steps{padding:16px;background:rgba(0,120,215,.1);border-radius:12px;border:1px solid rgba(0,120,215,.3);margin-bottom:20px}.next-steps h3{margin:0 0 8px;font-size:14px;font-weight:700;color:var(--text)}.next-steps p{margin:0 0 4px;font-size:13px;color:var(--text-muted);line-height:1.5}.next-steps p.subtext{margin-top:4px;font-size:12px;color:#0078d7;font-weight:600}.continue-button{width:100%;padding:14px;background:var(--primary);color:#000;border:none;border-radius:8px;font-weight:700;font-size:15px;cursor:pointer;transition:all .2s ease}.continue-button:hover{background:#27ae60;transform:translateY(-2px);box-shadow:0 4px 12px #2ecc714d}@media (max-width: 768px){.payment-screen{max-width:90vw;max-height:85vh}.payment-header h1{font-size:24px}.payment-message h2{font-size:16px}.breakdown-row{font-size:12px}.breakdown-row .amount{font-size:13px}.cash-update{gap:8px}.cash-stat{font-size:12px}}.seed-shop{max-width:800px;max-height:90vh;overflow-y:auto}.shop-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:2px solid var(--border);margin-bottom:16px}.shop-header h2{margin:0;font-size:22px;color:var(--text)}.shop-intro{padding:12px;background:rgba(0,120,215,.1);border-radius:8px;border:1px solid rgba(0,120,215,.3);margin-bottom:16px}.shop-intro p{margin:0;font-size:13px;color:var(--text);line-height:1.5}.shop-intro strong{color:#2ecc71;font-weight:700}.strain-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:16px}.strain-card{padding:16px;background:rgba(0,0,0,.2);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:12px}.strain-card:not(.disabled):hover{background:rgba(0,0,0,.3);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #2ecc7133}.strain-card.selected{border-color:var(--primary);background:rgba(46,204,113,.1);box-shadow:0 4px 12px #2ecc7133}.strain-card.selected:after{content:"✓";position:absolute;top:12px;right:12px;font-size:20px;color:var(--primary);font-weight:700}.strain-card.disabled{opacity:.6;cursor:not-allowed}.strain-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.4}.strain-stats{display:flex;flex-direction:column;gap:6px}.stat-row{display:flex;justify-content:space-between;align-items:center;font-size:12px}.stat-label{color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-weight:700;color:var(--primary);font-size:13px}.strain-meta{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid rgba(0,0,0,.1)}.difficulty{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.cost{font-size:14px;font-weight:700;color:var(--primary)}.cost.unaffordable{color:#e74c3c}.insufficient-funds{font-size:11px;color:#e74c3c;font-weight:600;text-align:center;padding-top:4px}.purchase-button{width:100%;padding:14px;background:var(--primary);color:#000;border:none;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease}.purchase-button:hover:not(.disabled){background:#27ae60;transform:translateY(-2px);box-shadow:0 4px 12px #2ecc714d}.purchase-button.disabled{background:#ccc;color:#666;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.seed-shop{max-width:90vw;max-height:85vh}.strain-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.strain-card{padding:12px;gap:10px}.strain-name{font-size:13px}.shop-header h2{font-size:18px}}.game-screen{width:100%;height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.game-header{background:var(--card);border-bottom:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:12px}.game-header h2{margin:0;font-size:20px}.header-stats{display:flex;justify-content:space-between;font-size:14px;font-weight:600}.day-counter{color:var(--primary)}.cash{color:var(--secondary)}.header-buttons{display:flex;gap:8px}.session-btn,.quit-btn{padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;flex:1}.session-btn:hover{border-color:var(--secondary);background:rgba(52,152,219,.1)}.quit-btn:hover{border-color:var(--danger);background:rgba(231,76,60,.1)}.quit-btn{flex:0 0 auto}.game-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:0}.game-body{flex:1;display:grid;grid-template-columns:55% 45%;gap:16px;padding:16px;overflow-y:auto;background:var(--bg)}.left-panel{display:flex;flex-direction:column;gap:16px;overflow-y:auto}.right-panel{display:flex;flex-direction:column;overflow-y:auto}.error-panel{background:rgba(231,76,60,.1);border:1px solid var(--danger);color:#ff7675;padding:16px;border-radius:var(--radius);margin:16px}.action-panel{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--card);border-top:1px solid var(--border);overflow-y:auto;max-height:300px}.day-control-buttons{display:flex;gap:12px;flex-wrap:wrap}.day-control-buttons .primary-btn,.day-control-buttons .secondary-btn{flex:1;min-width:100px}.primary-btn{background:var(--primary);color:#000;font-weight:700;padding:12px;font-size:15px;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.primary-btn:hover:not(:disabled){background:#27ae60;transform:translateY(-2px);box-shadow:0 4px 12px #2ecc714d}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:var(--secondary);color:#fff;font-weight:600;padding:12px;font-size:15px;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.secondary-btn:hover:not(:disabled){background:#2980b9}.secondary-btn:disabled{opacity:.6;cursor:not-allowed}.harvest-btn{flex:1;min-width:150px;background:var(--warning);color:#000;font-weight:700;padding:12px;font-size:15px}.harvest-btn:hover:not(:disabled){background:#e67e22;transform:translateY(-2px);box-shadow:0 4px 12px #f39c124d}@media (max-width: 1024px){.game-body{grid-template-columns:1fr;gap:12px;padding:12px}}@media (max-width: 768px){.game-header{padding:12px}.game-header h2{font-size:18px}.game-body{gap:10px;padding:10px}.action-panel{padding:12px;gap:8px}.primary-btn,.secondary-btn,.harvest-btn{min-width:auto;font-size:14px;padding:10px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-content{background:var(--card);border:2px solid var(--border);border-radius:12px;padding:20px;max-width:100%;box-shadow:0 8px 32px #0003;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:scale(.95) translateY(-20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.close-btn{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);padding:0;transition:color .2s ease}.close-btn:hover{color:var(--text)}@media (max-width: 768px){.modal-overlay{padding:12px}.modal-content{padding:16px}}:root{--primary: #2ecc71;--secondary: #3498db;--danger: #e74c3c;--warning: #f39c12;--bg: #1a1a1a;--card: #2d2d2d;--text: #ecf0f1;--text-muted: #95a5a6;--border: #404040;--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}#root{width:100%;height:100vh;overflow:hidden}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:var(--text-muted)}input[type=text],input[type=email],input[type=password],select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--text);font-size:16px;font-family:inherit}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2ecc711a}button{cursor:pointer;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s;font-family:inherit}button:disabled{opacity:.5;cursor:not-allowed}input[type=range]{width:100%;height:6px;border-radius:3px;background:var(--border);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 0 4px #00000080}input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 0 4px #00000080}@media (max-width: 768px){:root{--radius: 6px}button{padding:12px 14px;font-size:16px}input[type=range]{height:8px}}
