*{touch-action:manipulation}
.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,0.12);transition:.3s;border-radius:24px}
.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.3s;border-radius:50%}
.toggle-switch input:checked + .toggle-slider{background:var(--c-green,#58C45A)}
.toggle-switch input:checked + .toggle-slider:before{transform:translateX(20px)}
.card .card{margin-left:0;margin-right:0}
#card-body{padding-left:10px}
.row.mb-3.align-items-end .col-6.text-right.p-0{text-align:left !important;padding-left:0 !important}
@media (max-width:575.98px){.row.mb-3.align-items-end .col-6.text-right.p-0{display:flex;gap:0.5rem;align-items:center}
}
#taskStart,#taskPause,#taskStop{margin-right:0.5rem}
.navbar{flex-wrap:nowrap;display:none !important}
.topbar{position:fixed;top:0;left:0;right:0;height:40px;z-index:1030;background:rgba(15,17,23,0.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,0.04)}
.topbar-inner{display:flex;align-items:center;height:100%;padding:0 16px;gap:8px}
#topbar-logo{display:block;height:28px;width:auto}
.logo-accent{transition:fill 0.5s ease}
.topbar-offline{font-size:10px;color:#71717a;display:none}
.topbar-offline.visible{display:inline}
#mainNav{flex:1 1 auto}
#mainNavList{display:flex;justify-content:center;width:100%}
.value-big,.countdown{min-width:0;overflow:hidden;text-overflow:ellipsis}
.d-flex>*{min-width:0;flex-wrap:nowrap}
.page .row{margin-left:0;margin-right:0}
.page .col-6{padding-left:0;padding-right:0;min-width:0}
#container{display:flex;flex-direction:row;width:500vw;transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);will-change:transform;margin:0;padding:0;padding-top:40px;position:relative;z-index:1;height:calc(100vh - 40px)}
.page{width:100vw;flex-shrink:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;margin:0;padding:0;padding-bottom:56px;border:none;outline:none;box-shadow:none;height:100%}
section.page{border:none;outline:none}
.container-fluid{padding:0 !important;margin:0 !important}
html{overflow:hidden;width:100%;max-width:100%;margin:0;padding:0;height:100%}
body{overflow:hidden;width:100%;max-width:100%;margin:0;padding:0;height:100%}
.row{flex-wrap:wrap}
table{width:100%;table-layout:fixed}
.modal{max-width:100vw;overflow-x:hidden}
#confirmStopModal,#plantDetailModal,#preSoakModal,#propagatorModal,#harvestModal,#wifiModal,#customPresetModal,#growMethodModal,#domeModal{z-index:3000 !important}
.modal-backdrop{z-index:2950 !important;width:100% !important;height:100% !important}
#conn-banners{position:fixed;top:56px;left:0;right:0;z-index:1998}
@font-face {font-family:'Inter';src:url('/Inter-Regular.ttf') format('truetype');font-weight:100 900;font-style:normal;font-display:swap}
:root{--bg:#0f1117;--surface:rgba(255,255,255,0.04);--surface-hi:rgba(255,255,255,0.05);--border:rgba(255,255,255,0.06);--border-hi:rgba(255,255,255,0.08);--blur:blur(12px);--blur-hi:blur(20px);--t1:#e4e4e7;--t2:#9ca3af;--t3:#71717a;--c-green:#58C45A;--c-red:#ef4444;--c-yellow:#f59e0b;--c-blue:#3b82f6;--c-orange:#f97316;--c-cyan:#06b6d4;--c-purple:#a855f7;--accent:#3b82f6;--accent-dim:rgba(59,130,246,0.15);--accent-glow:rgba(59,130,246,0.30)}
#glow-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.glow{position:absolute;border-radius:50%;filter:blur(40px)}
.glow-a{width:260px;height:260px;top:-60px;left:-60px;background:radial-gradient(circle,rgba(59,130,246,0.22) 0%,transparent 70%)}
.glow-b{width:220px;height:220px;top:40%;right:-50px;background:radial-gradient(circle,rgba(16,185,129,0.16) 0%,transparent 70%)}
.glow-c{width:200px;height:200px;bottom:80px;left:-40px;background:radial-gradient(circle,rgba(168,85,247,0.14) 0%,transparent 70%)}
html{background:var(--bg)}
body{background:var(--bg);font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--t1);-webkit-font-smoothing:antialiased}
.bg-light{background:transparent !important}
.bg-info{background:transparent !important}
.bg-primary{background:transparent !important}
.bg-warning{background:transparent !important}
.bg-secondary{background:transparent !important}
.bg-success{background:transparent !important}
.bg-danger{background:transparent !important}
.text-dark{color:var(--t1) !important}
.text-muted{color:var(--t2) !important}
.text-white{color:var(--t1) !important}
label{color:var(--t2);font-size:0.82rem;margin-bottom:0.2rem}
strong,b{color:inherit}
small{color:var(--t3)}
.alert-warning{background:rgba(245,158,11,0.10) !important;color:var(--c-yellow) !important;border-color:rgba(245,158,11,0.20) !important}
.alert-secondary{background:rgba(255,255,255,0.05) !important;color:#a1a1aa !important;border-color:rgba(255,255,255,0.08) !important}
.navbar.navbar-light.bg-light,.navbar.fixed-top,.navbar{display:none !important}
.navbar-brand{display:none !important}
#conn-banners{display:none !important}
.ob-logo{display:block;margin:0 auto 16px}
.navbar-text,.navbar-text *{color:var(--t1) !important}
#datetime{font-size:12px;color:var(--t2);font-variant-numeric:tabular-nums}
.conn-dot{display:block;width:6px;height:6px;min-width:6px;min-height:6px;border-radius:50%;flex-shrink:0;transition:background-color 0.5s ease,box-shadow 0.5s ease}
.conn-loading{background:var(--c-yellow);box-shadow:0 0 6px rgba(245,158,11,0.5)}
.conn-online{background:var(--c-green);box-shadow:0 0 6px rgba(88,196,90,0.5)}
.conn-offline{background:var(--c-red);box-shadow:0 0 6px rgba(239,68,68,0.5)}
.conn-ap{background:var(--c-yellow);box-shadow:0 0 6px rgba(245,158,11,0.5)}
.conn-banner{font-size:0.82rem;border-radius:0 !important;border:none !important;position:relative}
#drift-sync-btn{font-size:0.75rem;padding:0.1rem 0.5rem}
.conn-banner .conn-banner-close{position:absolute;right:0.5rem;top:50%;transform:translateY(-50%);font-size:1.1rem;line-height:1;opacity:0.5;color:inherit}
.card{background:var(--surface) !important;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:1px solid var(--border) !important;border-radius:14px !important;box-shadow:0 4px 24px rgba(0,0,0,0.35);color:var(--t1)}
.card-header{background:transparent !important;border-bottom:1px solid var(--border) !important;border-radius:14px 14px 0 0 !important;color:var(--t1) !important;padding:0.6rem 1rem}
.card-header h5{color:var(--t1) !important;font-size:14px;font-weight:500}
.card-header.bg-info{border-left:3px solid var(--c-blue)   !important}
.card-header.bg-primary{border-left:3px solid var(--accent)   !important}
.card-header.bg-warning{border-left:3px solid var(--c-yellow) !important}
.card-body{color:var(--t1)}
.card-footer{background:transparent !important;border-top:1px solid var(--border) !important;border-radius:0 0 14px 14px !important}
.task-ctrl{background:var(--surface-hi);backdrop-filter:var(--blur-hi);-webkit-backdrop-filter:var(--blur-hi);border:1px solid var(--border-hi);border-radius:16px;padding:12px 14px;margin-bottom:1rem}
.section-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#6b7280;margin-bottom:4px}
#taskSelectLabel{font-size:17px;font-weight:500;color:var(--t1);display:block;margin-bottom:2px}
#taskStatusLabel{font-size:12px;color:var(--t2);min-height:18px;display:flex;align-items:center;gap:5px}
@keyframes pulse-dot{0%,100%{opacity:1}
50%{opacity:0.3}
}
#taskStatusLabel.task-running::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--c-green);flex-shrink:0;animation:pulse-dot 1.6s ease-in-out infinite}
#taskStatusLabel.task-paused::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--c-yellow);flex-shrink:0}
.btn-small{width:38px;height:38px;padding:0;font-size:0.8rem;line-height:1;border-radius:12px !important;display:inline-flex;align-items:center;justify-content:center;transition:filter 0.15s ease,transform 0.12s ease,box-shadow 0.15s ease;transform:translateZ(0)}
.btn-small:hover:not(:disabled){filter:brightness(1.2)}
.btn-small:active,.btn-small:focus:not(:disabled){transform:translateY(1px) scale(0.96);outline:none}
.btn-small:disabled,.btn-small[disabled]{opacity:0.25;cursor:not-allowed;filter:none;transform:none}
#taskStart{background:rgba(88,196,90,0.15)  !important;border:1px solid rgba(88,196,90,0.25)  !important;color:var(--c-green) !important}
#taskPause{background:rgba(245,158,11,0.15) !important;border:1px solid rgba(245,158,11,0.25) !important;color:var(--c-yellow) !important}
#taskStop{background:rgba(239,68,68,0.15)  !important;border:1px solid rgba(239,68,68,0.25)  !important;color:var(--c-red) !important}
#taskStart:hover:not(:disabled){background:rgba(88,196,90,0.25)  !important}
#taskPause:hover:not(:disabled){background:rgba(245,158,11,0.25) !important}
#taskStop:hover:not(:disabled){background:rgba(239,68,68,0.25)  !important}
.hero-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:16px;padding:16px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);margin-bottom:12px}
.hero-header{display:flex;align-items:center;margin-bottom:12px}
.hero-icon{width:36px;height:36px;color:var(--c-green);flex-shrink:0;margin-right:12px}
.hero-icon svg{width:100%;height:100%}
.hero-header-text{flex:1;min-width:0}
.hero-name{font-size:18px;font-weight:600;color:var(--t1);line-height:1.2}
.hero-status-line{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;margin-top:2px}
.hero-header-right{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:8px}
.hero-ctrl-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:10px;color:var(--t2);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background 0.15s}
.hero-ctrl-btn:active{background:rgba(255,255,255,0.12)}
.hero-ctrl-stop{color:#ef4444;border-color:rgba(239,68,68,0.3)}
.hero-debug-bar{display:flex;align-items:center;gap:6px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}
.hero-debug-label{font-size:9px;font-weight:700;letter-spacing:0.08em;color:var(--c-orange);opacity:0.7;margin-right:2px}
.hero-debug-btn{font-size:11px;font-weight:600;color:var(--c-blue);background:rgba(59,130,246,0.10);border:1px solid rgba(59,130,246,0.25);border-radius:8px;padding:4px 10px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.hero-debug-btn:active{background:rgba(59,130,246,0.20)}
.hero-top-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2px}
.hero-top-left{flex:1;min-width:0}
.hero-top-right{font-size:12px;color:#9ca3af;flex-shrink:0;margin-left:8px;padding-top:2px}
.hero-stop-x{position:absolute;top:12px;right:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#71717a;cursor:pointer;border-radius:6px;font-size:16px;line-height:1;padding:0;transition:color 0.15s,background 0.15s;-webkit-tap-highlight-color:transparent;z-index:2}
.hero-stop-x:hover,.hero-stop-x:active{color:#ef4444;background:rgba(239,68,68,0.1)}
.hero-ubar{margin:10px 0 4px;position:relative}
.hero-ubar-track{display:flex;height:8px;border-radius:4px;overflow:hidden;position:relative}
.hero-ubar-seg{height:100%;position:relative;transition:opacity 0.3s}
.hero-ubar-seg-fill{position:absolute;top:0;left:0;height:100%;border-radius:0}
.hero-ubar-sep{position:absolute;top:0;width:1px;height:100%;background:rgba(0,0,0,0.3);z-index:1}
.hero-ubar-marker{position:absolute;top:10px;font-size:8px;color:#fff;line-height:1;transition:left 0.5s ease;transform:translateX(-50%);z-index:2}
.hero-ubar-label{font-size:13px;color:#9ca3af;margin-top:6px}
@keyframes seg-flash{0%{filter:brightness(1.8)}100%{filter:brightness(1)}}
.hero-ubar-seg.flash{animation:seg-flash 0.3s ease}
.hero-harvest-line{font-size:14px;margin-top:4px}
.hero-method-line{font-size:12px;color:var(--t3);margin-top:2px}
.hero-row{display:flex;justify-content:space-between;align-items:center;font-size:12px}
.hero-row-label{color:var(--t3)}
.hero-row-value{color:var(--t2);font-weight:500}
.hero-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.hero-status-dot.st-running{background:#58C45A;animation:pulse-dot 1.5s ease infinite}
.hero-status-dot.st-harvest{background:#f59e0b;animation:pulse-dot 1.5s ease infinite}
@keyframes pulse-dot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(88,196,90,0.4)}
50%{opacity:0.6;box-shadow:0 0 0 4px rgba(88,196,90,0)}
}
.hero-empty{background:rgba(255,255,255,0.04);border:1px dashed var(--border);border-radius:16px;padding:28px 16px;text-align:center;margin-bottom:12px}
.hero-empty-title{font-size:18px;font-weight:600;color:var(--t1);margin-bottom:6px}
.hero-empty-text{font-size:13px;color:var(--t2);margin-bottom:16px;line-height:1.5}
.hero-quickstart-btn{display:block;width:100%;padding:12px 20px;background:var(--c-green);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-bottom:8px;-webkit-tap-highlight-color:transparent}
.hero-quickstart-btn:active{opacity:0.85}
.hero-choose-btn{display:block;width:100%;padding:10px 20px;background:transparent;border:1px solid var(--border-hi);border-radius:12px;color:var(--t2);font-size:13px;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent}
.hero-choose-btn:active{opacity:0.85}
.gm-grid{display:flex;gap:12px;margin-bottom:12px}
.gm-card{flex:1;background:var(--surface);border:1px solid var(--border-hi);border-radius:14px;padding:20px 12px;text-align:center;cursor:pointer;transition:border-color 0.2s,background 0.2s;-webkit-tap-highlight-color:transparent}
.gm-card:active{opacity:0.85}
.gm-card.gm-dimmed{opacity:0.45}
.gm-card.gm-dimmed:hover{opacity:0.7}
.gm-icon{margin-bottom:10px}
.gm-label{font-size:15px;font-weight:600;color:var(--t1);margin-bottom:4px}
.gm-desc{font-size:12px;color:var(--t2);line-height:1.4}
.gm-hint{font-size:11px;color:var(--c-yellow);margin-top:8px}
.gm-warn{font-size:11px;color:var(--t3);text-align:center;line-height:1.4;display:none}
.dome-steps{list-style:none;padding:0;margin:0 0 16px}
.dome-step{display:flex;align-items:flex-start;gap:10px;padding:8px 0}
.dome-step-num{width:24px;height:24px;border-radius:50%;background:rgba(88,196,90,0.15);color:var(--c-green);font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dome-step-text{font-size:13px;color:var(--t1);line-height:1.4;padding-top:2px}
.dome-note{font-size:12px;color:var(--t2);text-align:center;line-height:1.5}
.hero-preparing{border-color:rgba(88,196,90,0.2)}
.st-preparing{font-size:11px;font-weight:500;color:var(--c-green)}
.prop-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:12px 14px}
.prop-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#a855f7;flex-shrink:0}
.prop-icon svg{width:24px;height:24px}
.prop-name{font-size:13px;font-weight:600;color:var(--t1)}
.prop-detail{font-size:11px;color:var(--t2);margin-top:2px}
.prop-badge{font-size:10px;font-weight:600;color:var(--c-green);background:rgba(88,196,90,0.15);border-radius:6px;padding:3px 8px;flex-shrink:0}
.env-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.env-card.env-water-low{border-color:rgba(239,68,68,0.3);background:rgba(239,68,68,0.06)}
#env-water .env-val span:first-child{font-size:20px}
.env-card{position:relative;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:14px;padding:14px 12px 12px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}
.env-dot{position:absolute;top:12px;right:12px;width:8px;height:8px;border-radius:50%;background:var(--t3)}
.env-dot.env-ok{background:#58C45A}
.env-dot.env-warn{background:#f59e0b}
.env-dot.env-bad{background:#ef4444}
.env-val{display:flex;align-items:baseline;gap:2px;margin-bottom:4px}
.env-val span:first-child{font-size:28px;font-weight:500;letter-spacing:-0.5px;line-height:1;color:var(--t1)}
.env-unit{font-size:14px;color:var(--t2)}
.env-label{font-size:11px;color:var(--t2)}
.water-alert{display:flex;align-items:center;background:rgba(239,68,68,0.10);border:1px solid rgba(239,68,68,0.25);border-radius:12px;padding:10px 14px;color:#ef4444;font-size:13px;font-weight:500}
.qs-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.qs-item{display:flex;flex-direction:column;align-items:center;gap:4px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:14px;padding:14px 12px 12px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);position:relative}
.qs-icon{color:var(--t2);width:16px;height:16px}
.qs-icon svg{width:100%;height:100%}
.qs-label{font-size:11px;color:var(--t2);text-align:center}
.qs-dot{width:8px;height:8px;border-radius:50%;background:var(--t3)}
.qs-dot.qs-on{background:#58C45A}
.qs-dot.qs-off{background:var(--t3)}
.out-card{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border)}
.out-card:last-child{border-bottom:none}
.out-pic{width:32px !important;height:32px !important;border-radius:8px;flex-shrink:0}
.out-label{font-size:13px;font-weight:500;color:var(--t1);line-height:1.2}
.out-value{font-size:20px;font-weight:500;color:var(--t1);text-align:right}
.out-value-wrap{text-align:right}
.countdown{font-size:10px;color:var(--t3);font-variant-numeric:tabular-nums}
.pic{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pic img{display:block;margin:0;max-width:70%;max-height:70%;filter:brightness(0) invert(1) opacity(0.85)}
.btn svg{vertical-align:middle}
.sc-header{font-size:15px;font-weight:600;color:var(--t1);margin-bottom:12px}
.sc-empty{color:var(--t2);font-size:13px;text-align:center;padding:40px 0}
.sc-tl-wrap{position:relative;margin-bottom:16px}
.sc-tl{display:flex;gap:2px;border-radius:8px;overflow:hidden;height:52px}
.sc-tl-seg{display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:opacity 0.2s,border-color 0.2s;border:2px solid transparent;border-radius:6px;min-width:0}
.sc-tl-seg:hover{opacity:0.9 !important}
.sc-tl-label{font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;padding:0 4px}
.sc-tl-days{font-size:9px;color:rgba(255,255,255,0.7)}
.sc-tl-marker{position:absolute;bottom:-8px;transform:translateX(-50%);font-size:10px;color:#3b82f6;line-height:1;filter:drop-shadow(0 0 2px rgba(59,130,246,0.5))}
.sc-phase-info{font-size:12px;color:var(--t2);margin-bottom:14px}
.sc-preview-banner{display:flex;align-items:center;gap:6px;font-size:12px;color:#71717a;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:10px;padding:8px 12px;margin-bottom:12px}
.sc-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}
.sc-card-title{font-size:13px;font-weight:600;color:var(--t1);display:flex;align-items:center;gap:6px;margin-bottom:10px}
.sc-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px;font-size:12px;color:var(--t2)}
.sc-row label{font-size:11px;color:var(--t3);margin:0;white-space:nowrap}
.sc-row span{font-size:11px;color:var(--t3)}
.sc-time{background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:8px;color:var(--t1);font-size:13px;padding:4px 8px;width:110px;font-family:'Inter',monospace}
.sc-time::-webkit-calendar-picker-indicator{filter:invert(0.7)}
.sc-num{background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:8px;color:var(--t1);font-size:13px;padding:4px 6px;width:60px;text-align:center;font-family:'Inter',monospace}
.sc-num:focus,.sc-time:focus{outline:none;border-color:var(--accent)}
.sc-hint{font-size:11px;color:var(--t3);margin-bottom:4px}
.sc-slider-row{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.sc-slider-label{font-size:11px;color:var(--t2);width:52px;flex-shrink:0}
.sc-slider-val{font-size:11px;color:var(--t2);width:32px;text-align:right;flex-shrink:0}
.sc-slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:2px;background:rgba(255,255,255,0.08);outline:none}
.sc-slider::-webkit-slider-runnable-track{height:4px;border-radius:2px}
.sc-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,0.3);margin-top:-7px}
.sc-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;cursor:pointer;border:none}
.sc-slider::-moz-range-track{height:4px;border-radius:2px}
.sc-spectrum-sliders{margin:8px 0}
.sc-spectrum-sliders .sc-slider-row:last-child{margin-bottom:20px}
.sc-spectrum-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;margin-bottom:10px}
.sc-sb-seg{min-width:0;transition:flex 0.2s}
.sc-toggle-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.sc-toggle-label{font-size:12px;color:var(--t2)}
.sc-toggle{width:40px;height:22px;border-radius:11px;background:rgba(255,255,255,0.12);cursor:pointer;position:relative;transition:background 0.2s}
.sc-toggle.active{background:var(--c-green)}
.sc-toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:left 0.2s;box-shadow:0 1px 3px rgba(0,0,0,0.3)}
.sc-toggle.active .sc-toggle-knob{left:20px}
.sc-seg-ctrl{display:flex;background:rgba(255,255,255,0.06);border-radius:8px;padding:2px;margin-bottom:10px}
.sc-seg-btn{flex:1;padding:6px 0;font-size:11px;font-weight:600;color:var(--t3);background:none;border:none;border-radius:6px;cursor:pointer;transition:all 0.15s}
.sc-seg-btn.active{background:rgba(124,58,237,0.2);color:#a78bfa}
.sc-save-btn{width:100%;padding:12px;background:rgba(88,196,90,0.15);color:#58C45A;border:1px solid rgba(88,196,90,0.25);border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;margin-bottom:8px;transition:background 0.15s}
.sc-save-btn:active{background:rgba(88,196,90,0.25)}
.sc-reset-btn{width:100%;padding:8px;background:none;color:var(--t3);border:1px solid var(--border);border-radius:10px;font-size:12px;cursor:pointer;margin-bottom:20px}
#add-btn{margin-right:0.5rem}
#apply-btn{margin-right:0.5rem}
.badge{font-weight:500;letter-spacing:0.02em;border-radius:6px;padding:0.25em 0.55em;font-size:10px}
.badge-info{background:rgba(6,182,212,0.12)   !important;color:var(--c-cyan)   !important}
.badge-warning{background:rgba(245,158,11,0.12)  !important;color:var(--c-yellow) !important}
.badge-secondary{background:rgba(255,255,255,0.08) !important;color:var(--t2)       !important}
.badge-success{background:rgba(88,196,90,0.12)   !important;color:var(--c-green)  !important}
.badge-danger{background:rgba(239,68,68,0.12)   !important;color:var(--c-red)    !important}
.badge-primary{background:rgba(59,130,246,0.12)  !important;color:var(--c-blue)   !important}
.play-slider-value{font-weight:600;font-size:13px;min-width:38px;text-align:right;color:var(--c-blue);font-variant-numeric:tabular-nums}
.play-header{cursor:pointer;user-select:none;padding:10px 14px}
.play-btn{width:36px;height:36px;border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:filter 0.15s ease;margin-left:6px}
.play-btn.play-on{background:rgba(88,196,90,0.15);border:1px solid rgba(88,196,90,0.25);color:var(--c-green)}
.play-btn.play-off{background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.25);color:var(--c-red)}
.play-btn:hover{filter:brightness(1.25)}
.play-btn.play-active{filter:brightness(1.4);box-shadow:0 0 12px rgba(255,255,255,0.2)}
input[type=range]{-webkit-appearance:none;appearance:none;height:4px;background:rgba(255,255,255,0.08);border-radius:2px;outline:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#ffffff;cursor:pointer;box-shadow:0 0 6px rgba(59,130,246,0.35);transition:transform 0.1s ease}
input[type=range]::-webkit-slider-thumb:active{transform:scale(1.15)}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#ffffff;border:none;cursor:pointer}
input[type=range]::-webkit-slider-runnable-track{height:4px;background:rgba(255,255,255,0.08);border-radius:2px}
.btn{border-radius:10px !important;font-weight:500;transition:transform 0.12s ease,filter 0.15s ease,background 0.15s ease,opacity 0.15s ease}
.btn:active:not(:disabled){transform:scale(0.95)}
.btn-primary{background:var(--c-blue)  !important;border-color:var(--c-blue) !important;color:#fff !important}
.btn-success{background:rgba(88,196,90,0.15)  !important;border:1px solid rgba(88,196,90,0.30)  !important;color:var(--c-green) !important}
.btn-warning{background:rgba(245,158,11,0.15) !important;border:1px solid rgba(245,158,11,0.30) !important;color:var(--c-yellow) !important}
.btn-danger{background:var(--c-red)   !important;border-color:var(--c-red) !important;color:#fff !important}
.btn-secondary{background:rgba(255,255,255,0.07) !important;border:1px solid rgba(255,255,255,0.12) !important;color:var(--t1) !important}
.btn-primary:hover:not(:disabled){filter:brightness(1.12)}
.btn-success:hover:not(:disabled){background:rgba(88,196,90,0.25)  !important}
.btn-warning:hover:not(:disabled){background:rgba(245,158,11,0.25) !important}
.btn-danger:hover:not(:disabled){filter:brightness(1.12)}
.btn-secondary:hover:not(:disabled){background:rgba(255,255,255,0.12) !important}
.form-control,.form-control:focus{background:rgba(255,255,255,0.06) !important;border:1px solid rgba(255,255,255,0.10) !important;color:var(--t1) !important;border-radius:8px !important;box-shadow:none !important}
.form-control:focus{border-color:var(--c-blue) !important;box-shadow:0 0 0 2px rgba(59,130,246,0.20) !important}
.form-control::placeholder{color:var(--t3) !important}
select.form-control option{background:#1a1d23;color:var(--t1)}
.custom-control-label{color:var(--t1) !important;font-size:0.9rem}
.custom-control-input:checked~.custom-control-label::before{background-color:var(--c-blue) !important;border-color:var(--c-blue) !important}
.custom-control-label::before{background-color:rgba(255,255,255,0.12) !important;border-color:rgba(255,255,255,0.20) !important}
.progress{background:rgba(255,255,255,0.06) !important;border-radius:99px;overflow:hidden;height:3px !important}
.progress-bar{border-radius:99px;transition:width 0.5s ease}
.progress-bar.bg-info{background:linear-gradient(90deg,#1d4ed8,var(--c-blue))   !important}
.progress-bar.bg-danger{background:linear-gradient(90deg,#c2410c,var(--c-orange)) !important}
.progress-bar.bg-success{background:linear-gradient(90deg,#15803d,var(--c-green))  !important}
.progress-bar.bg-secondary{background:linear-gradient(90deg,#3a4555,#71717a)       !important}
.modal-content{background:#1a1d23 !important;border:1px solid var(--border-hi) !important;border-radius:16px !important;box-shadow:0 8px 48px rgba(0,0,0,0.55);color:var(--t1)}
.modal-header{border-bottom:1px solid var(--border) !important;padding:0.85rem 1.1rem}
.modal-footer{border-top:1px solid var(--border) !important;padding:0.7rem 1.1rem}
.modal-title{color:var(--t1) !important;font-size:15px;font-weight:600}
.modal .close{color:var(--t2) !important;opacity:1;text-shadow:none}
.modal .close:hover{color:var(--t1) !important}
.modal-backdrop{background:rgba(0,0,0,0.72) !important}
.modal-group{background:rgba(255,255,255,0.025);border:1px solid rgba(255,255,255,0.07);border-radius:10px;padding:0.75rem;margin-bottom:0.65rem}
.modal-group-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--t3);font-weight:600;margin-bottom:0.5rem}
.footer-nav{position:fixed;bottom:0;left:0;right:0;height:56px;background:rgba(15,17,23,0.90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,0.06);z-index:2000;display:flex;flex-direction:row;align-items:stretch}
.tab-item{flex:1;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;padding:0;color:var(--t3);font-size:10px;font-weight:500;letter-spacing:0.02em;line-height:1.2;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color 0.15s ease}
.tab-item.active{color:var(--c-blue)}
.tab-item.active::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:32px;height:3px;background:var(--c-blue);border-radius:0 0 3px 3px}
.tab-item svg{display:block;flex-shrink:0;stroke-width:1.5;transition:stroke-width 0.15s ease}
.tab-item.active svg{stroke-width:2}
.tab-item:focus,.tab-item:active{outline:none;box-shadow:none;-webkit-tap-highlight-color:transparent}
button.tab-item{outline:none;border:none}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);border-radius:2px}
.task-name-big{font-size:17px;font-weight:500;color:var(--t1);line-height:1.3}
.settings-card{background:var(--surface-hi);backdrop-filter:var(--blur-hi);-webkit-backdrop-filter:var(--blur-hi);border:1px solid var(--border-hi);border-radius:16px;overflow:hidden}
.settings-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px}
.border-bottom-row{border-bottom:1px solid var(--border)}
.settings-row-title{font-size:14px;color:var(--t1);font-weight:500}
.settings-row-sub{font-size:12px;color:var(--t2);margin-top:2px}
.settings-row-value{font-size:13px;color:var(--t2);font-variant-numeric:tabular-nums;font-weight:500}
.seg-control{display:flex;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:10px;padding:3px;gap:3px}
.seg-btn{flex:1;padding:8px 0;border:none;border-radius:8px;background:transparent;color:var(--t2);font-size:13px;font-weight:500;cursor:pointer;transition:all 0.2s ease;-webkit-tap-highlight-color:transparent}
.seg-btn.active{background:var(--c-blue);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,0.35)}
.seg-btn:not(.active):hover{background:rgba(255,255,255,0.06);color:var(--t1)}
.mode-list{background:var(--card);border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.mode-row{display:flex;align-items:center;padding:12px 16px;gap:12px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.06);min-height:56px;transition:background 0.15s;-webkit-tap-highlight-color:transparent}
.mode-row:last-child{border-bottom:none}
.mode-row:active{background:rgba(255,255,255,0.04)}
.mode-row-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.mode-row-icon.simple{background:rgba(127,201,127,0.2)}
.mode-row-icon.advanced{background:rgba(148,163,184,0.2)}
.mode-row-icon.kids{background:rgba(216,191,232,0.2)}
.mode-row-icon.student{background:rgba(165,216,230,0.2)}
.mode-row-text{flex:1;display:flex;flex-direction:column;gap:2px}
.mode-row-name{font-size:16px;font-weight:500;color:var(--t1)}
.mode-row-desc{font-size:12px;color:var(--t3)}
.mode-row-check{color:var(--c-green,#22c55e);font-size:18px;font-weight:700;display:none}
.mode-row-disabled{opacity:0.5;cursor:default}
.mode-row-soon{background:rgba(148,163,184,0.15);color:var(--t3);padding:2px 8px;border-radius:10px;font-size:11px;text-transform:uppercase;letter-spacing:0.3px}
.signal-bars{display:flex;align-items:flex-end;gap:2px;height:16px}
.signal-bar{width:3px;border-radius:1px;background:rgba(255,255,255,0.12);transition:background 0.3s ease}
.signal-bar:nth-child(1){height:4px}
.signal-bar:nth-child(2){height:7px}
.signal-bar:nth-child(3){height:11px}
.signal-bar:nth-child(4){height:16px}
.signal-bars.signal-1 .signal-bar:nth-child(1),.signal-bars.signal-2 .signal-bar:nth-child(1),.signal-bars.signal-2 .signal-bar:nth-child(2),.signal-bars.signal-3 .signal-bar:nth-child(1),.signal-bars.signal-3 .signal-bar:nth-child(2),.signal-bars.signal-3 .signal-bar:nth-child(3),.signal-bars.signal-4 .signal-bar{background:var(--c-green)}
.signal-bars.signal-1 .signal-bar:nth-child(1){background:var(--c-yellow)}
.preview-row{border-bottom:1px solid var(--border);font-size:12px}
.preview-row:last-child{border-bottom:none}
.preview-time{font-variant-numeric:tabular-nums;font-size:13px;font-weight:500;color:var(--t1);min-width:54px;white-space:nowrap}
.manual-card{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border)}
.manual-card:last-child{border-bottom:none}
.manual-btn{padding:6px 14px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.06);color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;transition:all 0.15s ease;margin-left:6px}
.manual-btn:hover{background:rgba(255,255,255,0.10)}
.manual-btn-auto.active{background:rgba(88,196,90,0.18);border-color:rgba(88,196,90,0.35);color:var(--c-green)}
.manual-btn-on.active{background:rgba(59,130,246,0.18);border-color:rgba(59,130,246,0.35);color:#3b82f6}
.manual-btn-off.active{background:rgba(239,68,68,0.18);border-color:rgba(239,68,68,0.35);color:var(--c-red)}
.manual-slider{min-width:80px}
.currently-growing{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-left:3px solid #58C45A;border-radius:14px;padding:14px 14px 12px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}
.cg-header{display:flex;align-items:center;margin-bottom:12px}
.cg-icon{width:28px;height:28px;color:var(--c-green);flex-shrink:0;margin-right:10px}
.cg-icon svg{width:100%;height:100%}
.cg-name{font-size:15px;font-weight:600;color:var(--t1);line-height:1.2}
.cg-phase{font-size:12px;color:var(--t2);margin-top:1px}
.cg-progress-wrap{margin-bottom:10px}
.cg-progress-bar{height:6px;background:rgba(255,255,255,0.08);border-radius:3px;overflow:hidden;margin-bottom:4px}
.cg-progress-fill{height:100%;background:#58C45A;border-radius:3px;transition:width 0.4s ease}
.cg-progress-label{font-size:11px;color:var(--t2)}
.cg-next{font-size:12px;color:var(--t3)}
.cg-next-value{color:var(--t2);font-weight:500}
.plant-search-wrap{position:relative}
.plant-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--t3);pointer-events:none;z-index:1}
.plant-search-input{padding-left:36px !important;background:rgba(255,255,255,0.04) !important;border:1px solid var(--border) !important;border-radius:12px !important;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);color:var(--t1) !important;font-size:14px;height:42px}
.plant-search-input::placeholder{color:var(--t3)}
.plant-search-input:focus{border-color:rgba(59,130,246,0.4) !important;box-shadow:0 0 0 2px rgba(59,130,246,0.10) !important;background:rgba(255,255,255,0.06) !important}
.plant-filter-row{display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.plant-filter-row::-webkit-scrollbar{display:none}
.cat-pill{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:rgba(255,255,255,0.08);color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;transition:all 0.15s ease;-webkit-tap-highlight-color:transparent;white-space:nowrap}
.cat-pill.active{background:#3b82f6;border-color:#3b82f6;color:#fff}
.cat-pill:not(.active):active{background:rgba(255,255,255,0.12)}
.plant-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.plant-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:14px;padding:14px 12px 12px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);cursor:pointer;transition:background 0.15s ease,border-color 0.15s ease,transform 0.12s ease;-webkit-tap-highlight-color:transparent;display:flex;flex-direction:column;align-items:center;text-align:center}
.plant-card:active{transform:scale(0.97);background:rgba(59,130,246,0.06);border-color:rgba(59,130,246,0.20)}
.plant-icon{width:32px;height:32px;margin-bottom:8px;color:var(--c-green)}
.plant-icon svg{width:100%;height:100%}
.plant-name{font-size:14px;font-weight:500;color:var(--t1);line-height:1.2;margin-bottom:6px}
.plant-badges{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;margin-bottom:6px}
.plant-badge{display:inline-block;padding:2px 7px;border-radius:6px;font-size:10px;font-weight:500;line-height:1.5}
.plant-badge-herbs{background:rgba(168,85,247,0.12);color:#a855f7}
.plant-badge-greens{background:rgba(88,196,90,0.12);color:#58C45A}
.plant-badge-microgreens{background:rgba(6,182,212,0.12);color:#06b6d4}
.plant-badge-flowers{background:rgba(236,72,153,0.12);color:#ec4899}
.plant-badge-mixes{background:rgba(212,160,83,0.14);color:#b8860b}
.plant-badge-easy{background:rgba(88,196,90,0.12);color:#58C45A}
.plant-badge-medium{background:rgba(245,158,11,0.12);color:#f59e0b}
.plant-badge-advanced{background:rgba(239,68,68,0.12);color:#ef4444}
.plant-grow-time{font-size:11px;color:var(--t3);margin-top:2px}
.plant-detail-header{display:flex;align-items:center;margin-bottom:16px}
.plant-detail-icon{width:44px;height:44px;margin-right:14px;color:var(--c-green);flex-shrink:0}
.plant-detail-icon svg{width:100%;height:100%}
.plant-detail-desc{font-size:13px;color:var(--t2);line-height:1.5;margin-bottom:16px}
.phase-timeline{margin-bottom:16px}
.phase-timeline-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--t3);font-weight:600;margin-bottom:8px}
.phase-timeline-bar{display:flex;height:28px;border-radius:8px;overflow:hidden;margin-bottom:6px;gap:2px}
.phase-segment{display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;color:#fff;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 4px;border-radius:6px}
.phase-timeline-legend{display:flex;flex-wrap:wrap;gap:6px 12px}
.phase-legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--t2)}
.phase-legend-dot{width:8px;height:8px;border-radius:3px;flex-shrink:0}
.plant-params{padding:12px;background:rgba(255,255,255,0.03);border-radius:10px;border:1px solid var(--border);margin-bottom:16px}
.plant-params-title{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--t3);font-weight:600;margin-bottom:8px}
.plant-param-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.plant-param-row:last-child{border-bottom:none}
.plant-param-label{color:var(--t2)}
.plant-param-value{color:var(--t1);font-weight:500;text-align:right}
.btn-start-growing{display:block;width:100%;padding:12px;background:#58C45A;border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background 0.15s ease,transform 0.12s ease;-webkit-tap-highlight-color:transparent}
.btn-start-growing:active{transform:scale(0.95);background:#16a34a}
.btn-start-growing:hover:not(:active){animation:glow-pulse 2s ease-in-out infinite}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 8px rgba(88,196,90,0.3)}
50%{box-shadow:0 0 20px rgba(88,196,90,0.5)}
}
#notification-cards:empty{display:none}
#notification-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.notif-card{display:flex;align-items:flex-start;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-left:3px solid var(--t3);border-radius:12px;padding:10px 12px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);gap:10px;position:relative;animation:notif-in 0.3s ease both}
@keyframes notif-in{from{opacity:0;transform:translateY(-12px)}
to{opacity:1;transform:translateY(0)}
}
.notif-card.notif-critical{border-left-color:#ef4444}
.notif-card.notif-warning{border-left-color:#f59e0b}
.notif-card.notif-info{border-left-color:#3b82f6}
.notif-card.notif-success{border-left-color:#58C45A}
.notif-card.notif-confirm{border-left:4px solid #58C45A;background:rgba(88,196,90,0.08)}
.notif-confirm .notif-icon{color:#58C45A;width:24px;height:24px}
.notif-confirm .notif-action{display:block;width:100%;height:44px;font-size:16px;font-weight:600;background:#58C45A;color:#fff;border-radius:10px;margin-top:10px;text-align:center;line-height:44px;padding:0}
.notif-confirm .notif-action:active{background:#16a34a}
.notif-icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}
.notif-icon svg{width:100%;height:100%}
.notif-critical .notif-icon{color:#ef4444}
.notif-warning  .notif-icon{color:#f59e0b}
.notif-info     .notif-icon{color:#3b82f6}
.notif-success  .notif-icon{color:#58C45A}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:600;color:var(--t1);line-height:1.3}
.notif-msg{font-size:12px;color:var(--t2);line-height:1.4;margin-top:2px}
.notif-dismiss{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--t3);font-size:18px;cursor:pointer;padding:0;line-height:1;-webkit-tap-highlight-color:transparent;border-radius:6px}
.notif-dismiss:active{background:rgba(255,255,255,0.06)}
.notif-action{display:inline-block;margin-top:6px;padding:4px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;border:none;-webkit-tap-highlight-color:transparent}
.notif-critical .notif-action{background:rgba(239,68,68,0.12);color:#ef4444}
.notif-warning  .notif-action{background:rgba(245,158,11,0.12);color:#f59e0b}
.notif-info     .notif-action{background:rgba(59,130,246,0.12);color:#3b82f6}
.notif-success  .notif-action{background:rgba(88,196,90,0.12);color:#58C45A}
.toast-stack{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:4000;display:flex;flex-direction:column-reverse;align-items:center;gap:8px;pointer-events:none;max-width:92vw}
.toast-item{background:rgba(26,29,35,0.92);border:1px solid var(--border);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);color:var(--t1);font-size:13px;font-weight:500;padding:10px 18px;border-radius:12px;opacity:0;transform:translateY(12px);transition:opacity 0.25s ease,transform 0.25s ease;pointer-events:auto;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis;text-align:center}
.toast-item.show{opacity:1;transform:translateY(0)}
.toast-item.toast-success{border-color:var(--c-green);color:var(--c-green)}
.toast-item.toast-error{border-color:var(--c-red);color:var(--c-red)}
.toast-item.toast-info{border-color:var(--c-blue);color:var(--c-blue)}
.field-error{color:var(--c-red);font-size:11px;margin-top:2px;min-height:0;display:none}
.field-error.visible{display:block}
.cpw-input.invalid{border-color:var(--c-red) !important}
.soak-banner{background:rgba(59,130,246,0.08);border:1px solid rgba(59,130,246,0.20);border-radius:12px;padding:12px 14px;margin-bottom:12px}
.soak-banner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.soak-banner-title{font-size:13px;font-weight:600;color:var(--c-blue)}
.soak-banner-cancel{background:none;border:none;color:var(--t3);font-size:20px;line-height:1;padding:0 2px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.soak-banner-cancel:active{color:var(--t1)}
.soak-banner-time{font-size:22px;font-weight:600;color:var(--t1);font-variant-numeric:tabular-nums}
.soak-banner-sub{font-size:11px;color:var(--t2);margin-top:2px}
.wifi-modal-dialog{max-width:400px}
.wifi-subtitle{font-size:13px;color:var(--t2);text-align:center;margin-bottom:16px;line-height:1.5}
.wifi-network-list{max-height:320px;overflow-y:auto;margin-bottom:16px;-webkit-overflow-scrolling:touch}
.wifi-net-card{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:12px;margin-bottom:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background 0.15s}
.wifi-net-card:active{background:rgba(255,255,255,0.08)}
.wifi-net-info{flex:1;min-width:0}
.wifi-net-name{font-size:14px;font-weight:500;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wifi-net-detail{font-size:11px;color:var(--t3);margin-top:2px}
.wifi-net-icons{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:12px}
.wifi-lock{color:var(--t3);display:flex}
.wifi-signal{color:var(--t2);display:flex}
.wifi-actions{padding-top:4px}
.wifi-connect-header{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.wifi-connect-ssid{font-size:16px;font-weight:600;color:var(--t1)}
.wifi-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;background:rgba(255,255,255,0.08);color:var(--t3);text-transform:uppercase;letter-spacing:0.04em}
.wifi-input-group{position:relative;margin-bottom:16px}
.wifi-input{width:100%;padding:12px 44px 12px 14px;background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:12px;color:var(--t1);font-size:14px;outline:none;transition:border-color 0.2s;box-sizing:border-box}
.wifi-input:focus{border-color:var(--accent)}
.wifi-input::placeholder{color:var(--t3)}
.wifi-eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;display:flex;-webkit-tap-highlight-color:transparent}
.wifi-eye-btn:active{color:var(--t1)}
.wifi-connect-btn{width:100%;padding:12px;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;margin-bottom:8px}
.wifi-connect-btn:active{opacity:0.85}
.wifi-back-btn{width:100%;padding:10px;background:none;border:none;color:var(--t3);font-size:13px;cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent}
.wifi-back-btn:active{color:var(--t1)}
.wifi-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0}
.wifi-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,0.1);border-top-color:var(--accent);border-radius:50%;animation:wifi-spin 0.8s linear infinite}
@keyframes wifi-spin{to{transform:rotate(360deg)}
}
.wifi-result{text-align:center;padding:16px 0}
.wifi-result-title{font-size:18px;font-weight:600;color:var(--t1);margin-bottom:8px}
.wifi-result-msg{font-size:13px;color:var(--t2);line-height:1.5;margin-bottom:16px}
.wifi-result-ip{display:inline-block;padding:6px 16px;background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:500;font-family:monospace;color:var(--t1);margin-bottom:20px}
.wifi-check-wrap,.wifi-fail-wrap{width:56px;height:56px;margin:0 auto 16px}
.wifi-checkmark,.wifi-failmark{width:56px;height:56px}
.wifi-check-circle{stroke:#58C45A;stroke-width:2;stroke-dasharray:166;stroke-dashoffset:166;animation:wifi-circle-draw 0.6s ease forwards}
.wifi-check-path{stroke:#58C45A;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:wifi-path-draw 0.4s 0.4s ease forwards}
.wifi-fail-circle{stroke:#ef4444;stroke-width:2;stroke-dasharray:166;stroke-dashoffset:166;animation:wifi-circle-draw 0.6s ease forwards}
.wifi-fail-path{stroke:#ef4444;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:56;stroke-dashoffset:56;animation:wifi-path-draw 0.4s 0.4s ease forwards}
@keyframes wifi-circle-draw{to{stroke-dashoffset:0}
}
@keyframes wifi-path-draw{to{stroke-dashoffset:0}
}
.plant-card-grow-next{margin-top:6px;padding:6px 12px;background:rgba(88,196,90,0.12);color:#58C45A;border:1px solid rgba(88,196,90,0.2);border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:background 0.15s}
.plant-card-grow-next:hover,.plant-card-grow-next:active{background:rgba(88,196,90,0.2)}
.btn-grow-next{display:inline-block;font-size:11px;font-weight:600;color:var(--c-green);background:rgba(88,196,90,0.10);border:1px solid rgba(88,196,90,0.25);border-radius:8px;padding:4px 10px;cursor:pointer;transition:background 0.2s;width:100%;text-align:center}
.btn-grow-next:hover,.btn-grow-next:active{background:rgba(88,196,90,0.20);color:var(--c-green);text-decoration:none}
.push-status-on{color:var(--c-green);font-weight:600}
.push-status-off{color:var(--t3)}
.push-toggle{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;cursor:pointer;transition:background 0.25s;flex-shrink:0}
.push-toggle.active{background:var(--c-green)}
.push-toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform 0.25s}
.push-toggle.active .push-toggle-knob{transform:translateX(20px)}
.wifi-push-prompt{text-align:center;margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}
.wifi-push-title{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:4px}
.wifi-push-msg{font-size:11px;color:var(--t2);margin-bottom:12px}
.wifi-push-btns{display:flex;gap:8px;justify-content:center}
.wifi-push-btns .btn{font-size:12px;padding:6px 16px;border-radius:8px;font-weight:600}
.cpw-dialog{max-width:460px;margin:12px auto}
.cpw-dialog .modal-content{max-height:92vh;display:flex;flex-direction:column}
.cpw-dialog .modal-body{overflow-y:auto;flex:1 1 auto;padding:12px 16px}
.cpw-steps{display:flex;justify-content:center;gap:8px;padding:10px 16px 4px}
.cpw-step-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.15);transition:background 0.25s,transform 0.25s}
.cpw-step-dot.current{background:var(--accent);transform:scale(1.25)}
.cpw-step-dot.done{background:var(--c-green)}
.cpw-footer{display:flex;gap:8px;padding:10px 16px}
.cpw-footer .btn{flex:1}
.cpw-label{display:block;font-size:12px;font-weight:600;color:var(--t2);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.3px}
.cpw-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--t1);font-size:14px;padding:8px 12px;outline:none;transition:border-color 0.2s}
.cpw-input:focus{border-color:var(--accent)}
.cpw-input::placeholder{color:var(--t3)}
select.cpw-input{appearance:auto}
textarea.cpw-input{resize:vertical;min-height:56px}
.cpw-row{display:flex;gap:10px;align-items:flex-end}
.cpw-row>*{flex:1}
.cpw-group{margin-bottom:14px}
.cpw-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}
.cpw-toggle-label{font-size:13px;color:var(--t1);font-weight:500}
.cpw-phase-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:10px;position:relative}
.cpw-phase-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cpw-phase-num{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase}
.cpw-phase-del{background:none;border:none;color:var(--c-red);font-size:18px;cursor:pointer;padding:0 4px;line-height:1;opacity:0.6;transition:opacity 0.2s}
.cpw-phase-del:hover{opacity:1}
.cpw-add-phase{width:100%;padding:10px;background:rgba(59,130,246,0.08);border:1px dashed var(--accent);border-radius:10px;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:background 0.2s;margin-bottom:10px}
.cpw-add-phase:hover{background:rgba(59,130,246,0.15)}
.cpw-phase-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}
.cpw-phase-tab{padding:5px 12px;font-size:12px;font-weight:600;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--t2);cursor:pointer;transition:all 0.2s}
.cpw-phase-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.cpw-slider-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.cpw-slider-label{font-size:12px;color:var(--t2);width:58px;flex-shrink:0}
.cpw-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:var(--border);outline:none}
.cpw-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--surface);box-shadow:0 0 4px rgba(0,0,0,0.3)}
.cpw-slider-val{font-size:13px;font-weight:600;color:var(--t1);width:36px;text-align:right;flex-shrink:0}
.cpw-spectrum{display:flex;height:8px;border-radius:4px;overflow:hidden;margin:6px 0 14px}
.cpw-spectrum-seg{transition:flex 0.3s;min-width:0}
.cpw-preview-text{font-size:12px;color:var(--t2);margin-top:4px;padding:6px 10px;background:var(--surface);border-radius:6px}
.cpw-review-section{margin-bottom:16px}
.cpw-review-title{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:8px}
.cpw-review-row{display:flex;justify-content:space-between;padding:5px 0;font-size:12px;border-bottom:1px solid var(--border)}
.cpw-review-row:last-child{border-bottom:none}
.cpw-review-label{color:var(--t2)}
.cpw-review-value{color:var(--t1);font-weight:600}
.cpw-review-phase{background:var(--surface);border-radius:8px;padding:10px 12px;margin-bottom:8px}
.cpw-review-phase-name{font-size:13px;font-weight:700;color:var(--accent);margin-bottom:6px}
.cpw-create-btn{width:100%;padding:12px;background:rgba(59,130,246,0.08);border:1px dashed var(--accent);border-radius:12px;color:var(--accent);font-size:14px;font-weight:600;cursor:pointer;margin-bottom:12px;transition:background 0.2s}
.cpw-create-btn:hover{background:rgba(59,130,246,0.15)}
.cpw-radio-group{display:flex;gap:8px}
.cpw-radio{flex:1;padding:6px 10px;font-size:12px;font-weight:600;text-align:center;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--t2);cursor:pointer;transition:all 0.2s}
.cpw-radio.active{background:var(--accent);border-color:var(--accent);color:#fff}
.plant-badge-custom{background:rgba(59,130,246,0.15);color:var(--accent)}
.plant-badge-method{background:rgba(88,196,90,0.12);color:var(--c-green);font-size:10px}
.plant-badge-method-sm{background:rgba(88,196,90,0.10);color:var(--c-green);font-size:9px;padding:1px 5px}
.plant-card-method-icons{position:absolute;top:6px;right:6px;display:flex;gap:2px;opacity:0.6}
.plant-card{position:relative}
.cg-method{font-size:11px;color:var(--t3);font-weight:400;margin-left:4px;display:inline-flex;align-items:center;gap:2px;vertical-align:middle}
.cg-method svg{vertical-align:middle}
.hero-row-value svg{vertical-align:middle;margin-right:2px}
.plan-next-banner{padding:12px 14px;background:rgba(59,130,246,0.08);border:1px solid rgba(59,130,246,0.20);border-radius:12px}
.plan-next-banner-text{font-size:13px;color:var(--c-blue);font-weight:500;text-align:center}
.cg-plan-next-btn{background:rgba(88,196,90,0.12);color:#58C45A;border:1px solid rgba(88,196,90,0.2);border-radius:8px;padding:5px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:background 0.15s}
.cg-plan-next-btn:hover,.cg-plan-next-btn:active{background:rgba(88,196,90,0.2)}
.cg-cancel-next{background:none;border:none;color:var(--t3);font-size:16px;line-height:1;padding:0 0 0 8px;cursor:pointer;opacity:0.6;transition:opacity 0.15s}
.cg-cancel-next:hover,.cg-cancel-next:active{opacity:1;color:var(--c-red)}
.cg-timeline{font-size:11px;color:var(--t3);margin-top:4px;padding:4px 0}
#onboardingOverlay{position:fixed;inset:0;z-index:4000;background:#0f1117;display:flex;flex-direction:column}
.ob-skip{position:absolute;top:calc(env(safe-area-inset-top,0px) + 16px);right:16px;z-index:4010;background:none;border:none;color:#6b7280;font-size:14px;font-weight:500;padding:8px 0;cursor:pointer}
.ob-viewport{flex:1;position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch}
.ob-slides-track{width:100%;height:100%}
.ob-slide{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;padding:60px 32px 120px;text-align:center;box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch}
.ob-slide.active{display:flex}
.ob-icon-wrap{margin-bottom:32px;width:200px;height:200px;display:flex;align-items:center;justify-content:center}
.ob-logo-main{display:block;width:200px;height:auto;margin:0 auto 24px}
.ob-h{font-size:28px;font-weight:400;color:var(--t1);margin:0 0 12px;font-family:Georgia,'Times New Roman',serif;letter-spacing:-0.3px}
.ob-p{font-size:16px;color:#9ca3af;line-height:1.6;margin:0 0 8px;max-width:320px}
.ob-sub{font-size:14px;color:#6b7280;margin:0 0 20px}
.ob-nav{position:absolute;bottom:0;left:0;right:0;padding:0 32px calc(env(safe-area-inset-bottom,0px) + 24px);display:flex;flex-direction:column;align-items:center;gap:16px;z-index:4005}
.ob-dots{display:flex;gap:8px}
.ob-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.15);transition:background 0.25s,width 0.25s;cursor:pointer}
.ob-dot.active{background:#58C45A;width:24px;border-radius:4px}
.ob-continue{width:100%;max-width:320px;height:48px;border:none;border-radius:14px;background:#58C45A;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .12s}
.ob-continue:active{transform:scale(0.96)}
.ob-continue:disabled{opacity:0.4;cursor:default}
.ob-continue:disabled:active{transform:none}
.ob-exp-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid rgba(255,255,255,0.08);border-radius:14px;text-align:left;cursor:pointer;margin-bottom:10px;transition:border-color .2s,background .2s;position:relative;width:100%;max-width:360px;box-sizing:border-box}
.ob-exp-card.selected{background:rgba(255,255,255,0.04)}
.ob-exp-card[data-mode="simple"].selected{border-left:3px solid #58C45A}
.ob-exp-card[data-mode="expert"].selected{border-left:3px solid #94a3b8}
.ob-exp-card[data-mode="premium"].selected{border-left:3px solid #d4a053}
.ob-exp-card[data-mode="student"].selected{border-left:3px solid #3b82f6}
.ob-exp-card[data-mode="kids"].selected{border-left:3px solid #a855f7}
.ob-exp-card.ob-coming-soon{opacity:0.6}
.ob-exp-tag.tag-soon{background:rgba(156,163,175,0.12);color:#9ca3af;margin-left:4px}
.ob-modes-scroll{max-height:52vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-right:4px}

/* Language selection cards */
.ob-lang-card{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border:1px solid rgba(255,255,255,0.08);border-radius:12px;cursor:pointer;transition:border-color .2s,background .2s;font-size:16px;color:var(--t1)}
.ob-lang-card:active{background:rgba(255,255,255,0.04)}
.ob-lang-card.selected{border-color:#58C45A;background:rgba(88,196,90,0.06)}
.ob-lang-check{color:#58C45A;font-size:18px;display:none}
.ob-lang-card.selected .ob-lang-check{display:inline}
.ob-exp-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px}
.ob-exp-name{font-size:15px;font-weight:600;color:var(--t1)}
.ob-exp-desc{font-size:12px;color:#9ca3af;line-height:1.4;margin-top:2px}
.ob-exp-tag{display:inline-block;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;margin-top:4px}
.ob-exp-tag.tag-free{background:rgba(88,196,90,0.12);color:#58C45A}
.ob-exp-tag.tag-premium{background:rgba(212,160,83,0.12);color:#d4a053}
.ob-text-btn{background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:8px 0;margin-top:8px}
.ob-text-btn:active{color:#9ca3af}
.ob-fade-out{animation:ob-overlay-out 0.35s ease forwards}
@keyframes ob-overlay-out{to{opacity:0;transform:scale(1.02)}}
@keyframes ob-logo-fade{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}
.ob-logo-main.ob-anim{animation:ob-logo-fade 0.6s ease forwards}
@media(max-height:667px){
.ob-icon-wrap{width:140px;height:140px;margin-bottom:20px}
.ob-icon-wrap svg{width:140px;height:140px}
.ob-logo-main{width:150px}
.ob-h{font-size:24px}
.ob-p{font-size:14px}
.ob-slide{padding:40px 24px 110px}
.ob-exp-card{padding:10px 12px}
}
.skeleton{background:linear-gradient(90deg,rgba(255,255,255,0.04) 25%,rgba(255,255,255,0.08) 50%,rgba(255,255,255,0.04) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:4px;color:transparent !important}
.skeleton *{visibility:hidden}
@keyframes shimmer{0%{background-position:200% 0}
100%{background-position:-200% 0}
}
.opacity-40{opacity:0.4}
.tab-item{min-height:44px}
.ob-skip{min-height:44px;min-width:44px}
.ob-continue{min-height:48px}
.plant-card{min-height:44px}
.cpw-phase-tab{min-height:36px;min-width:44px}
.cpw-phase-del{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.push-toggle{min-width:48px;min-height:28px}
.ob-dots{gap:8px}
.ob-dot{position:relative;padding:0}
.ob-dot::after{content:'';position:absolute;top:-16px;left:-10px;right:-10px;bottom:-16px}
.ob-text-btn{min-height:44px}
.hero-ubar-track{max-width:100%}
@media (max-width:575px){.plant-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.tab-item{font-size:10px;gap:2px}
.tab-item svg{width:20px;height:20px}
.navbar-brand{font-size:13px}
#datetime{font-size:11px}
.hero-card{padding:14px}
.hero-name{font-size:16px}
.cpw-dialog{max-width:100%;margin:8px}
.cpw-slider-row{gap:6px}
.cpw-slider-label{width:48px;font-size:11px}
.cpw-slider-val{width:32px;font-size:12px}
.cpw-row{flex-direction:column;gap:0}
.modal-dialog{margin:8px !important;max-width:calc(100% - 16px) !important}
#plantDetailModal .modal-content{max-height:95vh}
#plantDetailModal .modal-body{overflow-y:auto}
}
@media (max-width:374px){.plant-grid{grid-template-columns:1fr}
#datetime{display:none !important}
.tab-item{font-size:8px;gap:1px}
.tab-item svg{width:20px;height:20px}
.page{padding-left:10px !important;padding-right:10px !important}
.hero-name{font-size:14px}
.hero-status-line{font-size:11px}
.hero-ubar-label{font-size:11px}
.cpw-dialog .modal-body{padding:10px 12px}
.cpw-input{padding:7px 10px;font-size:13px}
}
@media (max-width:420px){.tab-item{font-size:9px;letter-spacing:0}
.tab-item svg{width:18px;height:18px}
}
@media (min-width:768px){.plant-grid{grid-template-columns:repeat(3,1fr);gap:14px}
.page{max-width:600px;margin:0 auto}
.modal-dialog{max-width:500px}
.cpw-dialog{max-width:480px}
.hero-card{padding:20px}
}
@keyframes fog-dot{0%{opacity:.05}20%{opacity:var(--fog-max-opacity,.4)}80%{opacity:var(--fog-max-opacity,.4)}100%{opacity:.05}}
.fog-dot{animation:fog-dot 3s ease-in-out infinite}
.footer-expert .tab-item{gap:0;font-size:0}
.footer-expert .tab-item span{display:none}
.shop-grid{display:flex;flex-direction:column;gap:10px}
.shop-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:14px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.shop-card-inner{display:flex;align-items:flex-start;gap:12px}
.shop-card-icon{flex-shrink:0;width:28px;height:28px}
.shop-card-info{flex:1;min-width:0}
.shop-card-title{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:2px}
.shop-card-desc{font-size:11px;color:var(--t3);margin-bottom:4px;line-height:1.4}
.shop-card-price{font-size:13px;font-weight:700;color:#d4a053}
.shop-order-btn{display:block;width:100%;height:36px;margin-top:10px;border:1.5px solid #d4a053;border-radius:10px;background:transparent;color:#d4a053;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}
.shop-order-btn:active,.shop-order-btn:hover{background:#d4a053;color:#fff}

/* Bottom Sheet generic */
.bs-overlay{position:fixed;inset:0;z-index:9998;background:rgba(0,0,0,0.5);opacity:0;transition:opacity .3s}
.bs-sheet{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:rgba(26,29,35,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top-left-radius:20px;border-top-right-radius:20px;padding:20px 24px 32px;max-height:85vh;overflow-y:auto;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.bs-handle{width:40px;height:4px;border-radius:2px;background:#6b7280;margin:0 auto 16px}
.bs-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#9ca3af;font-size:22px;cursor:pointer;padding:4px}
.bs-title{font-size:18px;font-weight:700;color:var(--t1);margin-bottom:4px}
.bs-subtitle{font-size:13px;color:var(--t3);margin-bottom:16px}

/* Farm Actions menu */
.farm-action-item{display:flex;align-items:center;gap:12px;padding:14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:12px;cursor:pointer;margin-bottom:8px}
.farm-action-item:active{background:rgba(255,255,255,0.08)}
.farm-action-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.farm-action-title{font-size:14px;font-weight:600;color:var(--t1)}
.farm-action-desc{font-size:12px;color:var(--t3);margin-top:1px}
.farm-action-item.danger .farm-action-title{color:#ef4444}

/* Movie Mode hero */
.movie-countdown{font-size:48px;font-weight:200;color:var(--t1);text-align:center;letter-spacing:2px;font-variant-numeric:tabular-nums}
.movie-label{font-size:14px;color:var(--t3);text-align:center;margin-top:4px}

/* Pause Mode hero */
.pause-info{font-size:14px;color:var(--t2);text-align:center}

/* Duration picker buttons */
.dur-btn{flex:1;height:40px;border:1px solid rgba(255,255,255,0.12);border-radius:10px;background:transparent;color:var(--t2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.dur-btn.selected{background:var(--c-green);border-color:var(--c-green);color:#fff}
.dur-btn:active{opacity:0.8}

/* Hero menu button */
.hero-menu-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:#9ca3af;font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;z-index:2}
.hero-menu-btn:active{color:var(--t1)}

/* Sparklines */
.sparkline-wrap{height:24px;margin-top:4px;opacity:0.6}
.sparkline-wrap svg{width:100%;height:100%}

/* Sensor detail chart */
.sensor-chart{width:100%;height:120px;margin:12px 0}
.sensor-chart svg{width:100%;height:100%}
.sensor-stat{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06);font-size:13px;color:var(--t2)}
.sensor-stat-label{color:var(--t3)}

/* Pull-to-refresh */
.ptr-bar{height:0;overflow:hidden;transition:height .2s;background:rgba(88,196,90,0.15);display:flex;align-items:center;justify-content:center}
.ptr-bar.pulling{height:40px}
.ptr-bar.refreshing{height:40px}
.ptr-bar-text{font-size:12px;color:var(--c-green);font-weight:500}

/* Quick Actions */
.quick-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.qa-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;border:none;background:rgba(88,196,90,0.1);color:var(--c-green);font-size:14px;font-weight:600;cursor:pointer;width:100%}
.qa-btn:active{opacity:0.8}
.qa-btn.qa-warning{background:rgba(245,158,11,0.1);color:#f59e0b}
.qa-btn.qa-danger{background:rgba(239,68,68,0.1);color:#ef4444}

/* Last harvest card */
.last-harvest-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:14px;margin-top:12px}
.last-harvest-title{font-size:12px;color:var(--t3);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px}

/* v2.4.4 — Plant Detail: benefits, nutrition, harvest */
.pd-section{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,0.06)}
.pd-section-title{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.5px}
.pd-benefit{display:flex;gap:10px;margin-bottom:10px}
.pd-benefit-icon{font-size:16px;flex-shrink:0;width:24px;text-align:center;line-height:1.4}
.pd-benefit-label{font-size:12px;font-weight:600;color:var(--t1)}
.pd-benefit-text{font-size:11px;color:var(--t3);line-height:1.4;margin-top:2px}
.nutri-grid{display:flex;gap:16px}
.nutri-col{flex:1;min-width:0}
.nutri-col-title{font-size:11px;font-weight:600;color:var(--t2);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px}
.nutri-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0}
.nutri-label{font-size:11px;color:var(--t2)}
.nutri-stars{display:flex;gap:2px}
.nutri-star{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.1)}
.nutri-star.filled{background:#d4a053}
.nutri-extras{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:11px;color:var(--t2)}
.nutri-extras span{display:flex;align-items:center;gap:4px}
.pd-harvest-row{font-size:12px;color:var(--t2);margin-bottom:6px}
.pd-harvest-badge{display:inline-block;padding:3px 10px;border-radius:20px;background:rgba(88,196,90,0.12);color:#58C45A;font-size:11px;font-weight:600}
.plant-badge-premium{background:rgba(212,160,83,0.15);color:#d4a053}

/* Sort button + sheet */
.sort-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);color:var(--t2);font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0}
.sort-btn:active{background:rgba(255,255,255,0.08)}
.sort-options-list{display:flex;flex-direction:column;gap:2px}
.sort-option{padding:12px 14px;border-radius:10px;font-size:14px;color:var(--t2);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.sort-option:active,.sort-option.active{background:rgba(255,255,255,0.04)}
.sort-option.active{color:var(--t1);font-weight:600}
.sort-section-label{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:1px;padding:16px 14px 6px;font-weight:600}
.sort-section-divider{height:1px;background:rgba(255,255,255,0.06);margin:4px 0}

/* Pre-flight checklist */
.pf-checklist{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.pf-check-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);cursor:pointer;-webkit-tap-highlight-color:transparent}
.pf-checkbox{position:absolute;opacity:0;width:0;height:0}
.pf-check-custom{width:24px;height:24px;border-radius:6px;border:1.5px solid #4b5563;background:transparent;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s ease}
.pf-checkbox:checked+.pf-check-custom{background:#58C45A;border-color:#58C45A;animation:pf-pop .2s ease}
.pf-checkbox:checked+.pf-check-custom::after{content:'';display:block;width:10px;height:6px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg);margin-top:-2px}
@keyframes pf-pop{0%{transform:scale(0.85)}50%{transform:scale(1.1)}100%{transform:scale(1)}}
.pf-check-label{font-size:14px;color:var(--t1)}
.pf-start-btn:disabled{opacity:0.35;cursor:default}
.pf-method-label{font-size:13px;font-weight:600;color:var(--t1);margin:0 0 8px;letter-spacing:0.2px}
.pf-method-pick{display:flex;gap:10px;margin-bottom:14px}
.pf-method-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border-radius:12px;border:1.5px solid rgba(255,255,255,0.22);background:rgba(255,255,255,0.04);cursor:pointer;font-size:13px;color:var(--t2);transition:border-color .15s, background .15s, color .15s, transform .1s;-webkit-tap-highlight-color:transparent}
.pf-method-opt:active{transform:scale(0.97);opacity:0.85}
.pf-method-opt.selected{border:2px solid #58C45A;background:rgba(88,196,90,0.10);color:#58C45A;box-shadow:0 0 0 1px rgba(88,196,90,0.25) inset}
.pf-method-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center}

/* Hero card animation */
.hero-card{animation:heroFadeIn .3s ease}
@keyframes heroFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Sensor card stagger fade-in */
.env-card{transition:transform .15s ease;animation:sensorFadeIn .3s ease both}
.env-card:nth-child(1){animation-delay:0s}
.env-card:nth-child(2){animation-delay:.05s}
.env-card:nth-child(3){animation-delay:.1s}
@keyframes sensorFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.env-card:active{transform:scale(0.97)}

/* Hero card tap feedback */
.hero-card:active{transform:scale(0.98);transition:transform .1s ease}

/* Favorites star */
.fav-star{position:absolute;top:6px;right:6px;background:none;border:none;font-size:18px;color:#6b7280;cursor:pointer;z-index:2;padding:2px 4px;line-height:1}
.fav-star.fav-active{color:#d4a053}
@keyframes starBounce{0%{transform:scale(1)}40%{transform:scale(1.3)}100%{transform:scale(1)}}
.fav-star.bounce{animation:starBounce .3s ease-out}

/* Settings help rows */
#settings-help-section .settings-row{cursor:pointer;transition:background .15s}
#settings-help-section .settings-row:active{background:rgba(255,255,255,0.04)}

/* Sensor period pills */
.sh-period-bar{display:flex;gap:6px;justify-content:center;margin-bottom:14px}
.sh-period-pill{padding:6px 16px;border-radius:20px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.04);color:var(--t3);font-size:12px;cursor:pointer}
.sh-period-pill.active{background:rgba(88,196,90,0.12);color:#58C45A;border-color:rgba(88,196,90,0.3)}

/* Wi-Fi home banner */
.wifi-home-banner{display:flex;align-items:center;gap:12px;padding:14px;background:rgba(245,158,11,0.08);border:1px solid rgba(245,158,11,0.2);border-radius:14px;margin-bottom:12px}
.wifi-home-icon{flex-shrink:0}
.wifi-home-text{flex:1;min-width:0}
.wifi-home-btn{padding:8px 16px;border:none;border-radius:10px;background:rgba(245,158,11,0.15);color:#f59e0b;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}
.wifi-home-btn:active{opacity:0.8}

/* Plant card export button */
.plant-card-export{position:absolute;top:6px;left:6px;background:rgba(212,160,83,0.12);border:none;border-radius:6px;padding:4px 6px;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center}
.plant-card-export:active{background:rgba(212,160,83,0.25)}

/* Shop card highlight */
.shop-card{transition:box-shadow .3s ease,border-color .3s ease}
.shop-highlight{border-color:rgba(212,160,83,0.5) !important;box-shadow:0 0 16px rgba(212,160,83,0.2) !important;animation:shopPulse 1s ease 2}
@keyframes shopPulse{0%,100%{box-shadow:0 0 16px rgba(212,160,83,0.2)}50%{box-shadow:0 0 24px rgba(212,160,83,0.35)}}

/* Plant Detail — Mat | Pot segmented control */
.pd-method-tabs{display:flex;width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:10px;padding:3px;margin:14px 0 10px;gap:3px}
.pd-method-tab{flex:1 1 0;background:transparent;border:none;color:var(--t2,#a1a1aa);font-size:13px;font-weight:600;line-height:1;padding:9px 12px;border-radius:7px;cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease;letter-spacing:0.2px}
.pd-method-tab:hover{color:var(--t1,#fafafa)}
.pd-method-tab.active{background:#58C45A;color:#fff;box-shadow:0 1px 2px rgba(0,0,0,0.18)}
.pd-method-tab:focus{outline:none}
.pd-method-tab:focus-visible{box-shadow:0 0 0 2px rgba(88,196,90,0.45)}

/* Pilot photo imagery for plant presets that ship a `image` field. */
.plant-card-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 8px;
  display: block;
}
.plant-detail-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 12px 12px 0 0;
  display: block;
}

/* Captive-portal device setup flow (v4.3.1.0+). Hidden by default; shown only
   when isOnDevice() detects we're being served by the ESP32 itself. */
#setup-flow {
  position: fixed;
  inset: 0;
  background: #0b1220;
  z-index: 5000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  overflow-y: auto;
}
#setup-flow.active { display: flex; }
.setup-screen {
  max-width: 420px;
  width: 100%;
  text-align: center;
  color: #fafafa;
}
.setup-screen h1 { font-size: 1.5rem; margin-bottom: 0.5rem; font-weight: 700; }
.setup-screen .subtitle { color: #a1a1aa; margin-bottom: 1.5rem; font-size: 14px; line-height: 1.5; }
.setup-screen .setup-emoji { font-size: 64px; margin-bottom: 16px; line-height: 1; }
.setup-screen button.primary {
  width: 100%; padding: 0.8rem 1rem; background: #58C45A; color: #fff;
  border: none; border-radius: 10px; font-size: 15px; font-weight: 600;
  cursor: pointer; margin-top: 0.5rem;
}
.setup-screen button.primary:disabled { opacity: 0.5; cursor: not-allowed; }
.setup-screen button.setup-link {
  background: transparent; border: none; color: #a1a1aa; font-size: 13px;
  text-decoration: underline; cursor: pointer; padding: 8px; margin-top: 4px;
}
.wifi-network-list {
  max-height: 280px; overflow-y: auto; margin: 0.75rem 0; text-align: left;
}
.wifi-network-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.6rem 0.8rem; border-radius: 8px; margin-bottom: 4px;
  cursor: pointer; background: rgba(255,255,255,0.04);
  border: 1px solid transparent; color: #fafafa;
}
.wifi-network-item:hover { background: rgba(255,255,255,0.08); }
.wifi-network-item.selected { background: rgba(88,196,90,0.15); border-color: rgba(88,196,90,0.5); }
.wifi-network-item .ssid { font-size: 14px; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.signal-bars { display: inline-flex; gap: 2px; align-items: flex-end; height: 14px; margin-right: 4px; }
.signal-bar { width: 3px; background: currentColor; border-radius: 1px; opacity: 0.3; }
.signal-bar.on { opacity: 1; }
.signal-bar.h1 { height: 4px; } .signal-bar.h2 { height: 7px; }
.signal-bar.h3 { height: 10px; } .signal-bar.h4 { height: 14px; }
.setup-wifi-connect {
  margin-top: 1rem; padding: 1rem; background: rgba(255,255,255,0.04); border-radius: 10px;
}
.setup-wifi-selected { font-size: 13px; color: #a1a1aa; margin-bottom: 8px; text-align: left; }
.setup-wifi-connect input {
  width: 100%; padding: 0.6rem 0.7rem; border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.06); color: #fafafa; border-radius: 8px;
  font-size: 14px; margin-bottom: 0.75rem;
}
.setup-error {
  margin-top: 0.75rem; padding: 0.6rem 0.8rem; background: rgba(239,68,68,0.15);
  color: #fca5a5; border-radius: 8px; font-size: 13px;
}
.setup-loading { color: #6b7280; font-size: 13px; padding: 1rem; text-align: center; }
.setup-screen > input[type="password"],
.setup-screen > input[type="text"] {
  width: 100%; padding: 0.7rem 0.8rem; border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.06); color: #fafafa; border-radius: 8px;
  font-size: 14px; margin-bottom: 0.6rem; box-sizing: border-box;
}
.setup-screen > input[type="password"]:focus,
.setup-screen > input[type="text"]:focus { outline: none; border-color: #58C45A; }
.setup-spinner {
  width: 32px; height: 32px; margin: 1rem auto;
  border: 3px solid rgba(255,255,255,0.15);
  border-top-color: #58C45A;
  border-radius: 50%;
  animation: setupSpin 0.8s linear infinite;
}
@keyframes setupSpin { to { transform: rotate(360deg); } }
.setup-summary {
  text-align: left;
  margin: 1rem 0 1.5rem;
  padding: 1rem;
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  font-size: 13px;
  color: #a1a1aa;
  line-height: 1.7;
}
.setup-summary .ok { color: #58C45A; margin-right: 6px; }
.setup-summary .skip { color: #f59e0b; margin-right: 6px; }

/* Change Wi-Fi modal (v4.3.2.0+) — Settings-level dialog reusing the dark
   setup-flow visual language. Lower z-index than the captive-portal flow. */
#change-wifi-modal {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6);
  display: none; align-items: center; justify-content: center;
  z-index: 1500; padding: 1rem;
}
#change-wifi-modal.active { display: flex; }
.change-wifi-modal-content {
  position: relative;
  max-width: 420px; width: 100%;
  background: #1a1f2e;
  color: #fafafa;
  border-radius: 14px;
  padding: 1.5rem; max-height: 90vh; overflow-y: auto;
  border: 1px solid rgba(255,255,255,0.08);
}
.change-wifi-close {
  position: absolute; top: 8px; right: 12px;
  background: transparent; border: none;
  color: #a1a1aa; font-size: 24px; line-height: 1;
  cursor: pointer; padding: 4px 8px;
}
.change-wifi-close:hover { color: #fafafa; }
.change-wifi-modal-content h2 {
  font-size: 1.2rem; margin: 0 0 8px; font-weight: 700;
}
.change-wifi-subtitle { color: #a1a1aa; font-size: 13px; margin: 0 0 12px; line-height: 1.5; text-align: center; }
.change-wifi-screen { display: none; }
.change-wifi-screen.active { display: block; }
.change-wifi-network-list {
  max-height: 320px; overflow-y: auto; margin: 0.75rem 0; text-align: left;
}
.change-wifi-network-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.65rem 0.8rem; border-radius: 8px; margin-bottom: 4px;
  cursor: pointer; background: rgba(255,255,255,0.04);
  border: 1px solid transparent; color: #fafafa;
}
.change-wifi-network-item:hover { background: rgba(255,255,255,0.08); }
.change-wifi-network-item.current {
  background: rgba(88,196,90,0.12); border-color: rgba(88,196,90,0.4);
}
.change-wifi-network-item .ssid { font-size: 14px; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.change-wifi-network-item .badge-connected {
  font-size: 10px; background: #58C45A; color: #fff;
  padding: 2px 8px; border-radius: 999px; margin-left: 6px;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.change-wifi-modal-content > #change-wifi-screen-password input[type="password"],
.change-wifi-modal-content > #change-wifi-screen-password input[type="text"] {
  width: 100%; padding: 0.7rem 0.8rem; border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.06); color: #fafafa; border-radius: 8px;
  font-size: 14px; margin-bottom: 0.6rem; box-sizing: border-box;
}
.change-wifi-show-toggle {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: #a1a1aa; margin-bottom: 12px; cursor: pointer;
}
.change-wifi-modal-content button.primary {
  width: 100%; padding: 0.7rem 1rem; background: #58C45A; color: #fff;
  border: none; border-radius: 10px; font-size: 14px; font-weight: 600;
  cursor: pointer; margin-top: 0.25rem;
}
.change-wifi-modal-content button.primary:disabled { opacity: 0.5; cursor: not-allowed; }
.change-wifi-modal-content button.setup-link {
  background: transparent; border: none; color: #a1a1aa; font-size: 13px;
  text-decoration: underline; cursor: pointer; padding: 8px; margin-top: 4px;
  display: block; width: 100%; text-align: center;
}

/* Settings → Firmware Updates (v4.3.4.0+) */
.firmware-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.5rem 0; border-bottom: 1px solid rgba(255,255,255,0.08);
}
.firmware-row:last-of-type { border-bottom: none; }
.firmware-label { color: var(--t2, #a1a1aa); font-size: 13px; }
.firmware-value { font-weight: 600; font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 13px; }
.firmware-changelog {
  background: rgba(255,255,255,0.04); padding: 0.75rem;
  border-radius: 8px; margin: 0.75rem 0; font-size: 13px;
}
.firmware-changelog p { margin: 0.4rem 0 0 0; line-height: 1.5; color: var(--t2, #a1a1aa); white-space: pre-wrap; }
.firmware-progress-state { font-weight: 600; margin-bottom: 0.5rem; }
.firmware-progress-bar {
  width: 100%; height: 8px; background: rgba(255,255,255,0.1);
  border-radius: 4px; overflow: hidden; margin: 0.5rem 0;
}
.firmware-progress-fill { height: 100%; background: #58C45A; transition: width 0.3s ease; }
.firmware-progress-percent { font-size: 12px; color: var(--t2, #a1a1aa); }
.firmware-progress-warning { color: #ff9500; font-size: 12px; margin-top: 1rem; line-height: 1.4; }
.firmware-done-message,
.firmware-error-message { font-size: 15px; font-weight: 600; margin-bottom: 0.5rem; }
.firmware-error-message { color: #ff3b30; }
.firmware-done-message { color: #58C45A; }