.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#87ceeb,#b8e6ff 40%,#90ee90 60%,#4ade80);position:relative;overflow:hidden}.login-scene{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.cloud{position:absolute;font-size:3rem;animation:cloud-drift linear infinite;opacity:.7}.c1{top:8%;left:-10%;animation-duration:25s;font-size:4rem}.c2{top:15%;left:-10%;animation-duration:35s;animation-delay:8s}.c3{top:5%;left:-10%;animation-duration:30s;animation-delay:15s;font-size:3.5rem}@keyframes cloud-drift{0%{transform:translate(-100px)}to{transform:translate(calc(100vw + 100px))}}.sun{position:absolute;top:6%;right:12%;font-size:4rem;animation:sun-pulse 3s ease-in-out infinite}@keyframes sun-pulse{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(10deg)}}.ground{position:absolute;bottom:0;left:0;right:0;height:35%;background:linear-gradient(180deg,#4ade80,#22c55e 30%,#86572c 50%,#6d4422);border-radius:50% 50% 0 0/15% 15% 0 0}.deco-tree{position:absolute;animation:tree-bob 4s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.t1{bottom:28%;left:5%;font-size:5rem;animation-delay:0s}.t2{bottom:30%;left:15%;font-size:4rem;animation-delay:.5s}.t3{bottom:26%;right:5%;font-size:5.5rem;animation-delay:1s}.t4{bottom:22%;right:18%;font-size:2.5rem;animation-delay:1.5s}.t5{bottom:24%;left:28%;font-size:2rem;animation-delay:2s}.t6{bottom:20%;right:30%;font-size:2.5rem;animation-delay:.8s}.t7{bottom:18%;left:40%;font-size:1.8rem;animation-delay:1.2s}@keyframes tree-bob{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(2deg)}}.butterfly{position:absolute;font-size:1.5rem;animation:butterfly-fly 8s ease-in-out infinite}.b1{top:35%;left:20%;animation-delay:0s}.b2{top:40%;right:25%;animation-delay:3s;font-size:1.2rem}@keyframes butterfly-fly{0%{transform:translate(0) rotate(0)}25%{transform:translate(40px,-30px) rotate(10deg)}50%{transform:translate(80px,-10px) rotate(-5deg)}75%{transform:translate(40px,20px) rotate(8deg)}to{transform:translate(0) rotate(0)}}.bird{position:absolute;top:18%;font-size:1.8rem;animation:bird-fly 12s linear infinite}@keyframes bird-fly{0%{left:-5%;transform:scaleX(1)}49%{transform:scaleX(1)}50%{left:105%;transform:scaleX(-1)}99%{transform:scaleX(-1)}to{left:-5%;transform:scaleX(1)}}.login-card{background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:28px;padding:36px 32px 28px;width:380px;max-width:90vw;box-shadow:0 20px 60px #0000001f,0 0 0 4px #4ade804d,inset 0 1px #fffc;text-align:center;position:relative;z-index:10;animation:card-arrive .6s ease-out}@keyframes card-arrive{0%{transform:translateY(40px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.login-avatar{margin-top:-60px;margin-bottom:8px;display:flex;justify-content:center}.login-avatar-ring{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#4ade80,#22c55e);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #22c55e66;animation:ring-breathe 3s ease-in-out infinite}@keyframes ring-breathe{0%,to{box-shadow:0 4px 20px #22c55e66}50%{box-shadow:0 4px 30px #22c55eb3}}.login-logo{font-size:2.8rem;animation:tree-sway 3s ease-in-out infinite}@keyframes tree-sway{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}.login-title{font-size:2rem;background:linear-gradient(135deg,#15803d,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:2px;letter-spacing:2px}.login-subtitle{color:#6b7280;font-size:.9rem;margin-bottom:20px}.login-error{background:linear-gradient(135deg,#fef2f2,#fff1f2);color:#dc2626;padding:10px 16px;border-radius:14px;margin-bottom:16px;font-size:.9rem;border:2px solid #fecaca;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.login-field{margin-bottom:14px;display:flex;align-items:center;background:#f0fdf4;border:2px solid #dcfce7;border-radius:16px;padding:0 14px;transition:border-color .3s,box-shadow .3s}.login-field:focus-within{border-color:#4ade80;box-shadow:0 0 0 4px #4ade8026}.login-field-icon{font-size:1.2rem;margin-right:10px;flex-shrink:0}.login-field input{flex:1;border:none;background:transparent;padding:14px 0;font-size:1rem;outline:none;color:#1e293b}.login-field input::placeholder{color:#94a3b8;opacity:.8}.login-btn{width:100%;padding:14px;font-size:1.15rem;margin-top:6px;border-radius:16px;background:linear-gradient(135deg,#4ade80,#22c55e)!important;box-shadow:0 4px #16a34a;letter-spacing:1px;transition:all .15s}.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px #16a34a}.login-btn:active{transform:translateY(3px)!important;box-shadow:0 1px #16a34a!important}.login-hint{margin-top:14px;font-size:.78rem;color:#94a3b8;background:#f8fafc;padding:6px 12px;border-radius:10px}.tree-card{background:#fff;border-radius:var(--card-radius);box-shadow:var(--card-shadow);border:3px solid #e8f5e9;aspect-ratio:3 / 4;display:flex;flex-direction:column;align-items:center;padding:6px;position:relative;transition:transform .25s,box-shadow .25s;cursor:default;overflow:hidden;min-width:0}.tree-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001f}.tc-status{position:absolute;top:4px;left:4px;font-size:.75rem;padding:2px 8px;border-radius:20px;font-weight:700;z-index:5}.tc-status-idle{background:#f1f5f9;color:#64748b}.tc-status-growing{background:#dcfce7;color:#166534}.tc-status-paused{background:#fef2f2;color:#991b1b}.tc-status-finished{background:#dbeafe;color:#1d4ed8}.tc-tree{flex:1;display:flex;align-items:center;justify-content:center;width:100%;position:relative;cursor:pointer}.tc-tree-img{max-width:75%;max-height:75%;object-fit:contain;transition:transform .3s;animation:tree-sway 4s ease-in-out infinite}@keyframes tree-sway{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}.tc-name{font-size:.85rem;font-weight:700;margin:2px 0;width:100%;text-align:center;color:#334155;line-height:1.2;word-break:break-all;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tc-progress-wrap{width:100%;height:6px;background:#f1f5f9;border-radius:3px;overflow:hidden;margin-bottom:2px}.tc-progress-bar{height:100%;background:linear-gradient(90deg,var(--green-light),var(--green-main));border-radius:4px;transition:width .6s ease}.tc-footer{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:.65rem;color:#94a3b8}.tc-pct{font-weight:700;color:var(--green-dark)}.tc-level{font-weight:600;color:var(--blue-main)}.tc-water-btn{width:22px;height:22px;border-radius:50%;border:2px solid #dbeafe;background:#eff6ff;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.tc-water-btn:hover{background:var(--blue-main);border-color:var(--blue-main);transform:scale(1.15)}.water-effect{position:absolute;top:0;left:50%;transform:translate(-50%);animation:water-fall .8s ease-in forwards;pointer-events:none;z-index:20}.water-drop{width:40px;height:40px;object-fit:contain}@keyframes water-fall{0%{top:-20%;opacity:1}70%{top:60%;opacity:1}to{top:70%;opacity:0}}.fertilize-effect{position:absolute;bottom:20%;left:50%;transform:translate(-50%);animation:fertilize-pop .8s ease-out forwards;pointer-events:none;z-index:20}.fertilize-icon{width:36px;height:36px;object-fit:contain}@keyframes fertilize-pop{0%{transform:translate(-50%) scale(.3);opacity:0}40%{transform:translate(-50%) scale(1.2);opacity:1}to{transform:translate(-50%) scale(1);opacity:0}}.punish-effect{position:absolute;font-size:2rem;animation:punish-shake .5s ease-out forwards;pointer-events:none;z-index:20}@keyframes punish-shake{0%{transform:scale(.5);opacity:0}30%{transform:scale(1.5);opacity:1}to{transform:scale(1);opacity:0}}.anim-water{animation:card-glow-blue .8s ease}.anim-fertilize{animation:card-glow-green .8s ease}.anim-punish{animation:card-shake .4s ease}@keyframes card-glow-blue{0%{box-shadow:0 0 #60a5fa80}50%{box-shadow:0 0 20px 8px #60a5fa4d}to{box-shadow:var(--card-shadow)}}@keyframes card-glow-green{0%{box-shadow:0 0 #4ecdc480}50%{box-shadow:0 0 20px 8px #4ecdc44d}to{box-shadow:var(--card-shadow)}}@keyframes card-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px) rotate(-2deg)}75%{transform:translate(6px) rotate(2deg)}}.tc-shield{position:absolute;top:4px;right:4px;font-size:1.2rem;z-index:10;filter:drop-shadow(0 2px 4px rgba(59,130,246,.4));animation:shield-idle 2s ease-in-out infinite}@keyframes shield-idle{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.tc-shield-appear{animation:shield-appear .6s ease-out!important}@keyframes shield-appear{0%{transform:scale(0) rotate(-180deg);opacity:0}60%{transform:scale(1.4) rotate(0);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.tc-shield-break{animation:shield-break .7s ease-out forwards!important}@keyframes shield-break{0%{transform:scale(1);opacity:1;filter:drop-shadow(0 2px 4px rgba(59,130,246,.4))}30%{transform:scale(1.3);opacity:1;filter:drop-shadow(0 0 12px rgba(239,68,68,.6))}to{transform:scale(0);opacity:0;filter:drop-shadow(0 0 0 transparent)}}.anim-shield{animation:card-glow-shield .8s ease}.anim-shield-break{animation:card-glow-red .7s ease}@keyframes card-glow-shield{0%{box-shadow:0 0 #3b82f680}50%{box-shadow:0 0 20px 8px #3b82f64d}to{box-shadow:var(--card-shadow)}}@keyframes card-glow-red{0%{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 20px 8px #ef44444d}to{box-shadow:var(--card-shadow)}}.desktop-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.desktop-no-class{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#64748b}.dt-header{background:#fff;padding:10px 16px;box-shadow:0 4px 12px #0000000f;border-bottom:4px solid var(--green-light);z-index:100;flex-shrink:0}.dt-header-inner{max-width:1600px;margin:0 auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center}.dt-logo{display:flex;align-items:center;gap:10px}.dt-logo-icon{font-size:2.2rem;animation:tree-sway 4s ease-in-out infinite}.dt-title{font-size:1.2rem;color:var(--green-dark);margin:0;white-space:nowrap}.dt-mode-switch{display:flex;gap:4px;margin-top:4px}.dt-mode-btn{border:2px solid #e2e8f0;padding:3px 10px;border-radius:20px;font-size:.8rem;cursor:pointer;font-weight:700;background:#f8fafc;transition:all .2s;font-family:var(--font-main)}.dt-mode-btn.active.quiet{background:#dcfce7;border-color:var(--green-main);color:var(--green-dark)}.dt-mode-btn.active.reading{background:#fff7ed;border-color:var(--orange-main);color:#c2410c}.dt-volume{background:#f8fafc;padding:8px 12px;border-radius:12px;border:2px solid #e2e8f0;min-width:200px}.dt-vol-label{font-size:.75rem;font-weight:700;color:#64748b;margin-bottom:4px;display:flex;align-items:center;gap:8px}.dt-mic-btn{font-size:.7rem;padding:2px 8px;border:2px solid #94a3b8;border-radius:12px;background:#fff;cursor:pointer;font-weight:700;transition:all .2s}.dt-mic-btn:hover{background:#dcfce7;border-color:var(--green-main)}.dt-mic-btn.active{background:#fef2f2;border-color:#ef4444;color:#ef4444}.dt-meter{height:12px;background:#e2e8f0;border-radius:6px;overflow:visible;position:relative}.dt-meter-fill{height:100%;background:linear-gradient(90deg,var(--green-light),var(--green-main));border-radius:6px;transition:width .15s}.dt-meter-threshold{position:absolute;top:-2px;bottom:-2px;width:3px;background:var(--red-main);border-radius:2px;z-index:5}.dt-meter-info{display:flex;align-items:center;gap:8px;font-size:.7rem;color:#64748b;margin-top:4px}.dt-meter-info input[type=range]{flex:1;padding:0;border:none;height:4px}.dt-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-left:auto}.dt-input-group{display:flex;align-items:center;gap:4px;background:#f0fdf4;padding:4px 8px;border-radius:10px;border:2px solid #dcfce7;font-size:.85rem}.dt-input-group label{font-weight:600;color:#64748b;font-size:.8rem}.dt-input-group input{border:1px solid #cbd5e1;border-radius:6px;text-align:center;padding:4px;font-weight:700}.dt-add-form{display:flex;gap:4px}.dt-main{flex:1;overflow-y:auto;padding:16px}.dt-grid{display:grid;gap:14px;padding-bottom:60px}.dt-empty{text-align:center;color:#94a3b8;margin-top:80px}.dt-empty-icon{font-size:5rem;display:block;margin-bottom:12px}.pause-bar{position:fixed;top:0;left:0;right:0;z-index:900;background:linear-gradient(90deg,#ef4444,#f97316);color:#fff;display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;font-size:.95rem;font-weight:700;box-shadow:0 4px 16px #ef44444d;animation:slide-down .3s ease}.pause-bar-icon{font-size:1.3rem}.pause-bar-sub{font-size:.8rem;opacity:.85;font-weight:500}@keyframes slide-down{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.dt-mobile-hint{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:8px 16px;text-align:center;font-size:.8rem;color:#64748b;border-top:2px solid #e2e8f0;z-index:50}.dt-mobile-hint code{background:#f1f5f9;padding:2px 8px;border-radius:6px;font-weight:700;color:var(--blue-main)}.dt-timer{font-size:1.1rem;font-weight:800;color:#ef4444;background:#fef2f2;padding:4px 12px;border-radius:8px;border:2px solid #fca5a5;font-variant-numeric:tabular-nums;white-space:nowrap}.finish-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.finish-box{background:#fff;border-radius:20px;padding:40px 50px;text-align:center;box-shadow:0 20px 60px #0003;animation:pop-in .4s cubic-bezier(.34,1.56,.64,1);max-width:460px;width:90%}@keyframes pop-in{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.finish-icon{font-size:4rem;margin-bottom:10px}.finish-box h2{font-size:1.8rem;color:#166534;margin:0 0 10px}.finish-box p{color:#64748b;margin:0 0 20px}.finish-stats{display:flex;gap:24px;justify-content:center;margin-bottom:24px;font-size:1.1rem;font-weight:700}.finish-actions{display:flex;gap:12px;justify-content:center}.finish-actions .btn{font-size:1rem;padding:10px 24px}.mob-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(160deg,#e8f5e9,#c8e6c9,#a5d6a7);-webkit-user-select:none;user-select:none}.mob-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:2px solid #c8e6c9;position:sticky;top:0;z-index:50}.mob-logo{font-size:1.5rem}.mob-title{font-size:1.05rem;font-weight:700;color:var(--green-dark);flex:1}.mob-timer{font-size:.85rem;font-weight:700;color:#e65100;background:#fff3e0;padding:3px 10px;border-radius:20px;white-space:nowrap}.mob-mic-btn{width:36px;height:36px;border-radius:50%;border:2px solid #c8e6c9;background:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.mob-mic-btn.mic-on{border-color:#ef5350;background:#ffebee;animation:mic-pulse 1.5s infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ef53504d}50%{box-shadow:0 0 0 6px #ef535000}}.mob-logout{font-size:.75rem;padding:4px 10px;border-radius:14px;border:1.5px solid #e0e0e0;background:#fff;color:#666;cursor:pointer;flex-shrink:0}.mob-mic-bar{display:flex;align-items:center;gap:8px;padding:6px 14px;background:#fff3e0;border-bottom:1px solid #ffe0b2}.mob-mic-label{font-size:.75rem;color:#e65100;white-space:nowrap;font-weight:600}.mob-mic-level{flex:1;height:6px;background:#ffe0b2;border-radius:3px;overflow:hidden;position:relative}.mob-mic-fill{height:100%;background:linear-gradient(90deg,#ff9800,#f44336);border-radius:3px;transition:width .1s}.mob-mic-threshold{position:absolute;top:-2px;width:2px;height:10px;background:#d32f2f;border-radius:1px;transform:translate(-1px)}.mob-mic-pct{font-size:.75rem;font-weight:700;color:#e65100;min-width:28px;text-align:right}.mob-pause-bar{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 14px;background:linear-gradient(135deg,#ffebee,#ffcdd2);border-bottom:1px solid #ef9a9a;font-size:.85rem;font-weight:600;color:#c62828}.mob-pause-sub{font-size:.7rem;color:#e57373}.mob-sound-settings{background:#ffffffb3;border-bottom:1px solid #c8e6c9}.mob-sound-toggle{padding:8px 14px;font-size:.8rem;font-weight:600;color:#2e7d32;cursor:pointer;display:flex;align-items:center;gap:6px;list-style:none}.mob-sound-toggle::-webkit-details-marker{display:none}.mob-sound-toggle:before{content:"▶";font-size:.6rem;transition:transform .2s}.mob-sound-settings[open] .mob-sound-toggle:before{transform:rotate(90deg)}.mob-sound-brief{font-size:.7rem;color:#888;font-weight:400;margin-left:auto}.mob-sound-settings[open] .mob-sound-brief{display:none}.mob-sound-body{padding:4px 14px 10px;display:flex;flex-direction:column;gap:6px}.mob-mode-row{display:flex;gap:8px}.mob-sound-mode-btn{flex:1;padding:6px 0;border:2px solid #e0e0e0;border-radius:20px;background:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.mob-sound-mode-btn.active.quiet{background:#e8eaf6;border-color:#7986cb;color:#283593}.mob-sound-mode-btn.active.reading{background:#fff3e0;border-color:#ffb74d;color:#e65100}.mob-slider-row{display:flex;align-items:center;gap:8px}.mob-slider-label{font-size:.75rem;font-weight:600;color:#555;min-width:40px}.mob-slider-row input[type=range]{flex:1;height:4px;accent-color:#4caf50}.mob-slider-val{font-size:.75rem;font-weight:700;color:#333;min-width:30px;text-align:right}.mob-controls{padding:10px 14px;background:#ffffffb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid #dcedc8}.mob-input-row{display:flex;gap:10px;margin-bottom:8px}.mob-input-row label{display:flex;align-items:center;gap:4px;font-size:.85rem;color:#555;flex:1}.mob-input-row input[type=number]{width:52px;padding:5px 6px;border:2px solid #c8e6c9;border-radius:10px;font-size:.9rem;text-align:center;background:#fff}.mob-btn{width:100%;padding:10px;font-size:1rem;border-radius:14px;margin-top:4px}.mob-action-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.mob-action-bar .mob-btn{flex:1;min-width:80px;width:auto;margin-top:0}.mob-mode-toggle{display:flex;width:100%;gap:0;border-radius:12px;overflow:hidden;border:2px solid #c8e6c9;margin-top:6px}.mob-mode-btn{flex:1;padding:8px 0;font-size:.9rem;border:none;background:#fff;color:#666;cursor:pointer;transition:all .2s;font-weight:600}.mob-mode-btn.active{color:#fff}.mob-mode-btn:first-child.active{background:#2196f3}.mob-mode-btn:last-child.active{background:#ef5350}.mob-layout-bar{display:flex;gap:8px;align-items:center;margin-top:8px;padding-top:8px;border-top:1px dashed #c8e6c9}.mob-layout-toggle,.mob-cols-picker{display:flex;gap:0;border-radius:8px;overflow:hidden;border:1.5px solid #c8e6c9}.mob-layout-toggle button,.mob-cols-picker button{padding:4px 10px;font-size:.75rem;border:none;background:#fff;color:#888;cursor:pointer;transition:all .15s;font-weight:600}.mob-layout-toggle button.active,.mob-cols-picker button.active{background:var(--green-dark, #2e7d32);color:#fff}.mob-cols-picker{margin-left:auto}.mob-forest{flex:1;padding:10px;overflow-y:auto}.mob-empty{text-align:center;padding:60px 20px;color:#888;font-size:1.1rem}.mob-grid{display:grid;gap:8px}.mob-tree{background:#ffffffd1;border-radius:14px;padding:8px 4px 6px;display:flex;flex-direction:column;align-items:center;border:2px solid transparent;transition:transform .15s,border-color .2s;cursor:default;position:relative}.mob-tree-active{cursor:pointer}.mob-tree-active:active{transform:scale(.92);border-color:#66bb6a}.mob-tree-img{width:80%;aspect-ratio:1;object-fit:contain;pointer-events:none}.mob-tree-bar{width:90%;height:5px;background:#e0e0e0;border-radius:3px;overflow:hidden;margin:4px 0 3px}.mob-tree-fill{height:100%;background:linear-gradient(90deg,#66bb6a,#43a047);border-radius:3px;transition:width .4s}.mob-tree-info{display:flex;flex-direction:column;align-items:center;gap:1px;width:100%}.mob-tree-name{font-size:.7rem;color:#444;text-align:center;line-height:1.2;max-height:2.4em;overflow:hidden;word-break:break-all;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.mob-tree-pct{font-size:.65rem;color:#888;font-weight:700}.mob-bar-list{display:flex;flex-direction:column;gap:6px}.mob-bar-item{display:flex;align-items:center;gap:10px;background:#ffffffd9;border-radius:12px;padding:8px 12px;border:2px solid transparent;transition:transform .15s,border-color .2s;cursor:default}.mob-bar-item.mob-tree-active{cursor:pointer}.mob-bar-item.mob-tree-active:active{transform:scale(.97);border-color:#66bb6a}.mob-bar-img{width:40px;height:40px;object-fit:contain;flex-shrink:0;pointer-events:none}.mob-bar-info{flex:1;min-width:0}.mob-bar-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.mob-bar-name{font-size:.85rem;font-weight:600;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mob-bar-pct{font-size:.8rem;font-weight:700;color:var(--green-dark, #2e7d32);flex-shrink:0;margin-left:8px}.mob-bar-track{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.mob-bar-fill{height:100%;background:linear-gradient(90deg,#66bb6a,#43a047);border-radius:3px;transition:width .4s}.mob-anim-water{animation:mob-water-pop .8s ease}.mob-anim-punish{animation:mob-punish-shake .6s ease}.mob-anim-fertilize{animation:mob-fert-glow .8s ease}@keyframes mob-water-pop{0%{transform:scale(1);box-shadow:0 0 0 transparent}40%{transform:scale(1.08);box-shadow:0 0 12px #2196f380}to{transform:scale(1);box-shadow:0 0 0 transparent}}@keyframes mob-punish-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}@keyframes mob-fert-glow{0%{box-shadow:0 0 0 transparent}50%{box-shadow:0 0 16px #4caf5080}to{box-shadow:0 0 0 transparent}}.mob-shield{position:absolute;top:2px;right:2px;font-size:.9rem;z-index:5;filter:drop-shadow(0 1px 3px rgba(59,130,246,.4));animation:mob-shield-pulse 2s ease-in-out infinite}.mob-bar-shield{font-size:.9rem;flex-shrink:0;filter:drop-shadow(0 1px 3px rgba(59,130,246,.4));animation:mob-shield-pulse 2s ease-in-out infinite}@keyframes mob-shield-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.mob-anim-shield{animation:mob-shield-appear .6s ease}.mob-anim-shield-break{animation:mob-shield-break .7s ease}@keyframes mob-shield-appear{0%{box-shadow:0 0 0 transparent}50%{box-shadow:0 0 16px #3b82f680}to{box-shadow:0 0 0 transparent}}@keyframes mob-shield-break{0%{box-shadow:0 0 0 transparent}40%{box-shadow:0 0 16px #ef444480}to{box-shadow:0 0 0 transparent}}.mob-switch-view{padding:12px;text-align:center}.mob-switch-view button{background:transparent;border:1px dashed #aaa;color:#888;padding:6px 16px;border-radius:20px;font-size:.75rem;cursor:pointer}.admin-page{min-height:100vh;background:linear-gradient(135deg,#f0fdf4,#f0f9ff)}.admin-header{background:#fff;padding:12px 20px;box-shadow:0 2px 12px #0000000f;border-bottom:4px solid var(--green-light)}.admin-header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.admin-logo{display:flex;align-items:center;gap:10px}.admin-logo span{font-size:2rem}.admin-logo h1{font-size:1.3rem;color:var(--green-dark);margin:0}.admin-tabs{max-width:1200px;margin:20px auto 0;padding:0 20px;display:flex;gap:8px}.admin-tab{padding:10px 20px;border:2px solid #e2e8f0;border-bottom:none;border-radius:14px 14px 0 0;background:#fff;font-weight:700;font-size:.95rem;cursor:pointer;color:#64748b;transition:all .2s;font-family:var(--font-main)}.admin-tab.active{background:var(--green-light);color:var(--green-dark);border-color:var(--green-main)}.admin-main{max-width:1200px;margin:0 auto;padding:0 20px 40px}.admin-section{background:#fff;border-radius:0 16px 16px;padding:24px;box-shadow:var(--card-shadow);border:2px solid #e2e8f0}.admin-form-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:separate;border-spacing:0}.admin-table th{background:#f8fafc;text-align:left;padding:10px 14px;font-size:.85rem;color:#64748b;border-bottom:2px solid #e2e8f0}.admin-table td{padding:10px 14px;border-bottom:1px solid #f1f5f9;font-size:.9rem}.admin-table tr:hover td{background:#f0fdf4}.admin-table td .btn{margin-right:4px}.history-page{min-height:100vh;background:linear-gradient(180deg,#f0fdf4,#ecfdf5,#f8fafc)}.hs-header{background:#fff;border-bottom:3px solid #e8f5e9;padding:12px 24px;position:sticky;top:0;z-index:100}.hs-header-inner{display:flex;align-items:center;justify-content:space-between;max-width:900px;margin:0 auto}.hs-logo{display:flex;align-items:center;gap:10px}.hs-logo-icon{font-size:1.8rem}.hs-title{font-size:1.3rem;color:var(--green-dark);margin:0}.hs-main{max-width:900px;margin:0 auto;padding:24px 16px}.hs-empty{text-align:center;color:#94a3b8;margin-top:80px}.hs-empty-icon{font-size:4rem;display:block;margin-bottom:12px}.hs-list{display:flex;flex-direction:column;gap:12px}.hs-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:2px solid #e8f5e9;overflow:hidden;transition:box-shadow .2s}.hs-card:hover{box-shadow:0 4px 16px #0000001a}.hs-card.expanded{border-color:var(--green-main)}.hs-card-header{display:flex;align-items:center;padding:14px 18px;cursor:pointer;gap:16px}.hs-card-time{display:flex;align-items:center;gap:6px;flex-shrink:0}.hs-card-date{font-size:.85rem;font-weight:600;color:#475569}.hs-card-arrow{color:#94a3b8;font-size:.8rem}.hs-card-info{display:flex;align-items:center;gap:8px;flex:1}.hs-badge{font-size:.8rem;padding:2px 8px;border-radius:12px;font-weight:700}.hs-badge-green{background:#dcfce7;color:#166534}.hs-badge-red{background:#fef2f2;color:#991b1b}.hs-card-setting{font-size:.75rem;color:#94a3b8;margin-left:auto}.hs-card-actions{display:flex;align-items:center;gap:8px}.hs-expand-icon{color:#94a3b8;font-size:.8rem}.hs-detail{border-top:1px solid #e2e8f0;padding:16px 18px;animation:slide-detail .3s ease}@keyframes slide-detail{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.hs-table{width:100%;border-collapse:collapse;font-size:.85rem}.hs-table th{text-align:left;padding:8px 10px;background:#f8fafc;color:#64748b;font-weight:700;border-bottom:2px solid #e2e8f0}.hs-table td{padding:8px 10px;border-bottom:1px solid #f1f5f9}.row-completed td:last-child{color:#166534;font-weight:700}.row-failed td:last-child{color:#991b1b;font-weight:700}.hs-progress-wrap{width:100%;height:18px;background:#f1f5f9;border-radius:9px;position:relative;overflow:hidden}.hs-progress-bar{height:100%;background:linear-gradient(90deg,var(--green-light),var(--green-main));border-radius:9px;transition:width .3s}.hs-progress-text{position:absolute;top:0;left:0;right:0;text-align:center;font-size:.7rem;line-height:18px;font-weight:700;color:#334155}*{margin:0;padding:0;box-sizing:border-box}:root{--green-light: #a8e6cf;--green-main: #4ecdc4;--green-dark: #2d6a4f;--blue-light: #87ceeb;--blue-main: #60a5fa;--orange-main: #ff8c42;--red-main: #ff6b6b;--pink-light: #ffd3e0;--yellow-light: #fff3bf;--bg-gradient: linear-gradient(135deg, #e0f7e9 0%, #f0f9ff 50%, #fef9ef 100%);--card-shadow: 0 4px 15px rgba(0, 0, 0, .08);--card-radius: 16px;--font-main: "Microsoft YaHei", "PingFang SC", "Hiragino Sans GB", sans-serif}body{font-family:var(--font-main);background:var(--bg-gradient);min-height:100vh;color:#334155}.btn{border:none;padding:10px 20px;border-radius:25px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-main);box-shadow:0 3px #00000026;position:relative;top:0}.btn:active{top:3px;box-shadow:0 0 #00000026}.btn-green{background:var(--green-main);color:#fff}.btn-orange{background:var(--orange-main);color:#fff}.btn-red{background:var(--red-main);color:#fff}.btn-blue{background:var(--blue-main);color:#fff}.btn-yellow{background:#f59e0b;color:#fff}.btn-gray{background:#94a3b8;color:#fff}.btn-sm{padding:6px 14px;font-size:.85rem}input,select{font-family:var(--font-main);font-size:.95rem;padding:8px 14px;border:2px solid #e2e8f0;border-radius:12px;outline:none;transition:border-color .2s}input:focus,select:focus{border-color:var(--green-main)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
