@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";:root,[data-theme=light]{--bg: #f5f0e1;--card: #faf6eb;--border: #c4b998;--border-accent: #8b7e5a;--shadow: #b3a67a;--text: #3a3520;--text-secondary: #7a6f52;--primary: #5a9e3e;--primary-light: #7bc25a;--primary-dark: #3d7a28;--danger: #c44830;--danger-light: #e05a40;--scene-bg: #d8efc8;--scene-ground: #8B7332;--moisture-track: #d4ccb0;--input-bg: #faf6eb;--btn-face: #e8e0c8;--btn-highlight: #faf6eb;--btn-shadow: #a09070;--btn-pressed: #d4ccb0;--hud-bg: #4a6a30;--hud-text: #e8f0d8;--hud-border: #3a5220;--hud-accent: #8bc34a;--log-bg: #f0ead4;--log-border: #c4b998;--log-row-alt: #ebe4cc}[data-theme=dark]{--bg: #0a0a14;--card: #12121f;--border: #2a2a40;--border-accent: #00ffaa;--shadow: #000000;--text: #e0ffe8;--text-secondary: #78a090;--primary: #00ff88;--primary-light: #44ffaa;--primary-dark: #00cc66;--danger: #ff4466;--danger-light: #ff6688;--scene-bg: #080818;--scene-ground: #1a2a18;--moisture-track: #1a1a30;--input-bg: #0e0e1a;--btn-face: #1a1a30;--btn-highlight: #2a2a48;--btn-shadow: #050510;--btn-pressed: #0e0e1a;--hud-bg: #0a0a18;--hud-text: #00ff88;--hud-border: #00ff88;--hud-accent: #ff44aa;--log-bg: #0e0e1a;--log-border: #1a1a30;--log-row-alt: #12121f}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;transition:background-color .3s,color .3s;image-rendering:pixelated}h1,h2,h3{font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;letter-spacing:.5px}.retro-border{border:3px solid var(--border-accent);box-shadow:inset 2px 2px 0 var(--btn-highlight),inset -2px -2px 0 var(--btn-shadow),4px 4px 0 var(--shadow)}.login-top-actions{position:absolute;top:1rem;right:1rem;z-index:2;display:flex;gap:.5rem}.login-theme-btn{background:var(--btn-face);border:2px solid var(--border);padding:.35rem .65rem;cursor:pointer;font-size:1rem;box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow);transition:all .15s}.login-theme-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.login-theme-btn:active{box-shadow:inset 1px 1px 0 var(--btn-shadow),inset -1px -1px 0 var(--btn-highlight);transform:translate(1px,1px)}[data-theme=dark] .login-theme-btn{background:transparent;border-color:var(--primary);color:var(--primary)}[data-theme=dark] .login-theme-btn:hover{background:var(--primary);color:#0a0a14;box-shadow:0 0 10px #00ff884d}.login-page{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;overflow:hidden}.login-hero{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:640px;padding:2rem 1rem}.login-card{background:#faf6ebeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:3px solid var(--border-accent);box-shadow:inset 2px 2px 0 var(--btn-highlight),inset -2px -2px 0 var(--btn-shadow),6px 6px #00000026;padding:3rem 2.25rem;width:560px;max-width:calc(100vw - 2rem);text-align:center}[data-theme=dark] .login-card{background:#12121fe0;box-shadow:inset 2px 2px #00ff881a,inset -2px -2px #0000004d,0 0 20px #00ff8814,6px 6px #0000004d}.login-card h1{margin-bottom:2rem;font-size:1.1rem;line-height:1.8;color:var(--primary)}[data-theme=dark] .login-card h1{text-shadow:0 0 10px var(--primary),0 0 20px rgba(0,255,136,.3)}.login-card form{display:flex;flex-direction:column;gap:1rem}.token-input-wrap{position:relative}.token-input-wrap input{width:100%;padding-right:2.8rem;box-sizing:border-box}.login-card .token-toggle{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:transparent;border:none;outline:none;box-shadow:none;cursor:pointer;padding:0;margin:0;color:var(--text-secondary);font-family:inherit;font-size:inherit;letter-spacing:normal;display:flex;align-items:center;justify-content:center;transition:color .2s}.login-card .token-toggle:hover{color:var(--primary);background:transparent;box-shadow:none}.login-card .token-toggle:active{box-shadow:none;transform:translateY(-50%)}.login-card input{padding:1rem 1.1rem;border:2px solid var(--border);background:var(--input-bg);color:var(--text);font-family:monospace;font-size:1rem;letter-spacing:1px;outline:none;transition:border-color .2s}.login-card input:focus{border-color:var(--primary)}[data-theme=dark] .login-card input:focus{border-color:var(--primary);box-shadow:0 0 8px #0f83}.login-card button{padding:1rem;background:var(--btn-face);color:var(--primary-dark);border:2px solid var(--border-accent);font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:1rem;cursor:pointer;box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow);transition:all .1s;letter-spacing:1px}.login-card button:hover{background:var(--primary);color:#fff}[data-theme=dark] .login-card button{background:transparent;color:var(--primary);border-color:var(--primary)}[data-theme=dark] .login-card button:hover{background:var(--primary);color:#0a0a14;box-shadow:0 0 12px #00ff884d}.login-card button:active{box-shadow:inset 1px 1px 0 var(--btn-shadow),inset -1px -1px 0 var(--btn-highlight);transform:translate(1px,1px)}.login-card button:disabled{opacity:.5;cursor:not-allowed}.error{color:var(--danger);margin-top:.75rem;font-size:.8rem;font-family:monospace}[data-theme=dark] .error{text-shadow:0 0 6px rgba(255,68,102,.4)}.login-guide{text-align:center;font-size:.85rem;color:#fffc;line-height:1.6;text-shadow:0 1px 4px rgba(0,0,0,.5)}[data-theme=dark] .login-guide{color:#e0ffe8b3;text-shadow:0 1px 4px rgba(0,0,0,.6)}.login-guide p{margin-bottom:.4rem}.login-guide a{color:#fff;text-decoration:none;border-bottom:1px dashed rgba(255,255,255,.6);text-shadow:0 1px 4px rgba(0,0,0,.5)}[data-theme=dark] .login-guide a{color:var(--primary);border-bottom-color:#0f86}.login-guide a:hover{border-bottom-style:solid}.garden-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.garden-label{font-family:"Press Start 2P",monospace;font-size:5px;color:#ffffffd9;background:#00000073;padding:2px 4px;border-radius:1px;white-space:nowrap;-webkit-user-select:none;user-select:none}.header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.2rem;background:var(--card);color:var(--text);border-bottom:3px solid var(--border-accent);box-shadow:0 3px 0 var(--shadow)}[data-theme=dark] .header{border-bottom-color:var(--border-accent);box-shadow:0 3px 0 var(--shadow),0 0 15px #00ff880f}.header h1{font-size:.75rem;color:var(--primary);line-height:1.6}[data-theme=dark] .header h1{text-shadow:0 0 8px var(--primary)}.header-actions{display:flex;align-items:center;gap:.5rem}.header-actions button{padding:.35rem .65rem;background:var(--btn-face);color:var(--text);border:2px solid var(--border);font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:.7rem;cursor:pointer;transition:all .15s;box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow)}.header-actions button:hover{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.header-actions button:active{box-shadow:inset 1px 1px 0 var(--btn-shadow),inset -1px -1px 0 var(--btn-highlight);transform:translate(1px,1px)}[data-theme=dark] .header-actions button{background:transparent;color:var(--primary);border-color:var(--primary)}[data-theme=dark] .header-actions button:hover{background:var(--primary);color:#0a0a14;box-shadow:0 0 10px #00ff884d}.polling-toggle{display:flex;align-items:center;gap:.4rem;font-size:.8rem;cursor:pointer;color:var(--text);font-family:monospace;padding:.3rem .5rem;background:var(--btn-face);border:2px solid var(--border);box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow)}[data-theme=dark] .polling-toggle{background:transparent;color:var(--primary);border-color:var(--primary)}.polling-toggle input[type=checkbox]{accent-color:var(--primary)}.lang-select{padding:.35rem .5rem;background:var(--btn-face);color:var(--text);border:2px solid var(--border);cursor:pointer;font-size:.85rem;font-family:monospace;box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow)}[data-theme=dark] .lang-select{background:transparent;color:var(--primary);border-color:var(--primary)}.lang-select option{background:var(--card);color:var(--text)}.agent-view{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem 1.2rem}.agent-3d{aspect-ratio:1;background:var(--scene-bg);border:3px solid var(--border-accent);box-shadow:inset 2px 2px 0 var(--btn-highlight),inset -2px -2px 0 var(--btn-shadow),4px 4px 0 var(--shadow);overflow:hidden}[data-theme=dark] .agent-3d{box-shadow:inset 2px 2px #00ff880d,inset -2px -2px #0000004d,0 0 15px #00ff880d,4px 4px 0 var(--shadow)}.info-panel{background:var(--card);border:3px solid var(--border-accent);box-shadow:inset 2px 2px 0 var(--btn-highlight),inset -2px -2px 0 var(--btn-shadow),4px 4px 0 var(--shadow);padding:1.2rem}[data-theme=dark] .info-panel{box-shadow:inset 2px 2px #00ff880d,inset -2px -2px #0000004d,0 0 15px #00ff880d,4px 4px 0 var(--shadow)}.info-panel h2{margin-bottom:1rem;font-size:1rem;color:var(--primary);padding-bottom:.5rem;border-bottom:2px dashed var(--border)}[data-theme=dark] .info-panel h2{text-shadow:0 0 8px var(--primary)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px dotted var(--border);font-size:.85rem}.info-row:last-child{border-bottom:none}.info-row span:first-child{font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:.9rem;color:var(--text-secondary)}.info-row span:last-child{font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:.8rem}.moisture-bar{position:relative;width:130px;height:18px;background:var(--moisture-track);border:2px solid var(--border-accent);overflow:hidden}.moisture-bar-fill{height:100%;transition:width .5s steps(10);image-rendering:pixelated;background-image:repeating-linear-gradient(90deg,transparent,transparent 11px,rgba(0,0,0,.15) 11px,rgba(0,0,0,.15) 13px)}.moisture-bar-label{position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.65rem;font-family:"Press Start 2P",monospace;font-weight:700;color:var(--text);text-shadow:1px 1px 0 rgba(255,255,255,.5)}[data-theme=dark] .moisture-bar{border-color:var(--primary);box-shadow:0 0 6px #00ff8826}[data-theme=dark] .moisture-bar-label{text-shadow:0 0 4px rgba(0,255,136,.5)}.event-wall{padding:1rem 1.2rem}.event-wall-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.event-wall-header h3{font-size:.8rem;color:var(--primary)}[data-theme=dark] .event-wall-header h3{text-shadow:0 0 6px var(--primary)}.event-wall-header select{padding:.3rem .5rem;border:2px solid var(--border);background:var(--input-bg);color:var(--text);font-family:monospace;font-size:.8rem}.event-list{background:var(--log-bg);border:3px solid var(--border-accent);box-shadow:inset 2px 2px 0 var(--btn-shadow),inset -2px -2px 0 var(--btn-highlight);max-height:300px;overflow-y:auto;font-family:monospace}[data-theme=dark] .event-list{box-shadow:inset 2px 2px #0006,inset -2px -2px #00ff8808,0 0 10px #00ff880d}[data-theme=dark] .event-list::-webkit-scrollbar{width:8px}[data-theme=dark] .event-list::-webkit-scrollbar-track{background:var(--log-bg)}[data-theme=dark] .event-list::-webkit-scrollbar-thumb{background:var(--primary);border:1px solid var(--log-bg)}.event-row{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-bottom:1px solid var(--log-border);font-size:.8rem}.event-row:nth-child(2n){background:var(--log-row-alt)}.event-row:last-child{border-bottom:none}.event-time{color:var(--text-secondary);min-width:80px;font-size:.7rem;font-family:monospace}.event-plant{color:var(--primary);min-width:80px;font-weight:600;font-family:monospace;font-size:.8rem}.event-icon{font-size:1rem}.event-empty{padding:1.5rem;text-align:center;color:var(--text-secondary);font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:.75rem}.supervisor-view{padding:1rem 1.2rem}.plant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.plant-card{background:var(--card);border:3px solid var(--border-accent);box-shadow:inset 2px 2px 0 var(--btn-highlight),inset -2px -2px 0 var(--btn-shadow),4px 4px 0 var(--shadow);overflow:hidden;transition:transform .15s,box-shadow .15s}.plant-card:hover{transform:translate(-2px,-2px);box-shadow:inset 2px 2px 0 var(--btn-highlight),inset -2px -2px 0 var(--btn-shadow),6px 6px 0 var(--shadow)}[data-theme=dark] .plant-card{box-shadow:inset 2px 2px #00ff880d,inset -2px -2px #0000004d,0 0 8px #00ff880d,4px 4px 0 var(--shadow)}[data-theme=dark] .plant-card:hover{box-shadow:inset 2px 2px #00ff8814,inset -2px -2px #0000004d,0 0 15px #00ff881a,6px 6px 0 var(--shadow)}.plant-card-3d{height:160px;background:var(--scene-bg);border-bottom:2px solid var(--border)}.plant-card-info{padding:.75rem;display:flex;flex-direction:column;gap:.4rem}.plant-card-info h3{font-size:.8rem;color:var(--primary);line-height:1.6}[data-theme=dark] .plant-card-info h3{text-shadow:0 0 6px var(--primary)}.plant-card-info span{font-size:.85rem;color:var(--text-secondary);font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif}.btn-toggle-actions{padding:.3rem .6rem;background:var(--btn-face);color:var(--text-secondary);border:2px solid var(--border);cursor:pointer;font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:.65rem;align-self:flex-start;box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow);transition:all .1s}.btn-toggle-actions:hover{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.btn-toggle-actions:active{box-shadow:inset 1px 1px 0 var(--btn-shadow),inset -1px -1px 0 var(--btn-highlight);transform:translate(1px,1px)}.plant-actions{display:flex;flex-wrap:wrap;gap:.4rem;padding-top:.5rem;border-top:2px dashed var(--border)}.plant-actions button,.plant-actions select{padding:.3rem .5rem;background:var(--btn-face);color:var(--text);border:2px solid var(--border);cursor:pointer;font-family:monospace;font-size:.75rem;box-shadow:inset 1px 1px 0 var(--btn-highlight),inset -1px -1px 0 var(--btn-shadow);transition:all .1s}.plant-actions button:hover,.plant-actions select:hover{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.plant-actions button:active{box-shadow:inset 1px 1px 0 var(--btn-shadow),inset -1px -1px 0 var(--btn-highlight);transform:translate(1px,1px)}.plant-actions button:disabled,.plant-actions select:disabled{opacity:.4;cursor:not-allowed}.plant-actions .btn-danger{color:var(--danger);border-color:var(--danger)}.plant-actions .btn-danger:hover{background:var(--danger);color:#fff}[data-theme=dark] .plant-actions button{background:transparent;border-color:var(--border-accent);color:var(--primary)}[data-theme=dark] .plant-actions button:hover{background:var(--primary);color:#0a0a14;box-shadow:0 0 8px #0f83}[data-theme=dark] .plant-actions .btn-danger{border-color:var(--danger);color:var(--danger)}[data-theme=dark] .plant-actions .btn-danger:hover{background:var(--danger);color:#fff;box-shadow:0 0 8px #ff44664d}.loading{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--text-secondary);font-family:"Press Start 2P",Segoe UI,Noto Sans TC,Noto Sans JP,sans-serif;font-size:.85rem}[data-theme=dark] .loading{color:var(--primary);text-shadow:0 0 8px var(--primary);animation:blink-loading 1.2s steps(2) infinite}@keyframes blink-loading{0%,to{opacity:1}50%{opacity:.3}}@media(max-width:1023px){.agent-view{grid-template-columns:1fr}}@media(max-width:767px){.agent-3d{aspect-ratio:4/3}.plant-grid{grid-template-columns:1fr}.header{flex-direction:column;gap:.5rem;padding:.5rem .8rem}.header h1{font-size:.55rem}.login-card{width:100%}.login-hero{margin-top:2vh}}
