.card{background:var(--card);border:1px solid var(--border);padding:2rem;margin-bottom:1.5rem;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.card-title{margin-top:0;margin-bottom:1.5rem;color:var(--fg);font-size:1.5rem;font-weight:600}.card-subtitle{margin-top:0;margin-bottom:1rem;color:var(--fg);font-size:1.1rem;font-weight:600}.error-card{border-left:4px solid #c00;background:#fee}.error-text{color:#c00;font-weight:500}.form-error-message{color:#c33;margin-top:.5rem;font-size:.9rem;display:none}.form-error-message.show{display:block}.btn,button{border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease;text-decoration:none;display:inline-block}button:not([class*=btn-]):not(.delete-session-btn):not(.btn){width:100%;padding:.8rem;margin-top:.8rem;font-size:1rem}.btn{padding:.8rem 1.2rem;font-size:1rem;width:auto}.btn-sm{padding:.5rem 1rem;font-size:.85rem;width:auto;margin:0}.btn-success,.start{background:#0a3;color:#fff}.btn-danger,.stop{background:#c00;color:#fff}.btn-primary,.refresh{background:#006bb3;color:#fff}.btn-toggle{background:#006bb3;color:#fff}.btn-toggle.inactive{background:#888}.btn-delete{background:#c00;color:#fff}.btn-secondary{background:#e5e7eb;color:#1f2937}.btn-secondary:hover{background:#d1d5db}.btn-danger:hover,.btn-delete:hover,.btn-primary:hover,.btn-success:hover,.btn-toggle:hover:not(.inactive),.refresh:hover,.start:hover,.stop:hover{opacity:.9;transform:translateY(-1px)}.btn:hover{transform:translateY(-2px)}.btn-secondary:hover{transform:translateY(-2px)}.delete-session-btn{width:auto;padding:.4rem .8rem;font-size:.85rem;background:#ddd;color:#333;border:none;border-radius:4px;cursor:pointer;margin-top:.5rem;transition:all .2s ease}.delete-session-btn:hover{background:#ccc}.delete-session-btn:disabled{background:#999;color:#fff;cursor:not-allowed}.buymeacoffee-button{display:flex;justify-content:center;align-items:center;width:100%}.buymeacoffee-button a,.buymeacoffee-button button{width:auto;margin:0!important;padding:20px!important}.buymeacoffee-button img{display:block;margin:0!important}#donate-div,#sponsor-div{display:flex;justify-content:center;align-items:center;width:100%;text-align:center}#sponsor-div a{display:flex;justify-content:center;align-items:center}.sponsor-img{max-height:65px;height:auto;width:auto;object-fit:contain}input[type=email],input[type=number],input[type=password],input[type=text]{width:100%;padding:.6rem;margin-top:.4rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--fg)}input[type=range]{width:100%;margin-top:.6rem;margin-bottom:.4rem}select{width:100%;padding:.75rem;margin-top:.5rem;border:2px solid var(--border-color,#ddd);border-radius:6px;background-color:var(--bg-secondary,#fafafa);color:var(--text-primary,#000);font-size:1rem;cursor:pointer;transition:border-color .2s,box-shadow .2s}select:hover{border-color:var(--accent-color,#0a3)}select:focus{outline:0;border-color:var(--accent-color,#0a3);box-shadow:0 0 0 3px rgba(0,170,51,.1)}.error{background:#fee;border:1px solid #f88;color:#800;padding:.5rem;margin:.5rem 0;border-radius:4px}.field-error{color:#a00;font-size:.9rem;margin-top:.25rem;display:block}.heating-zone-warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:1rem;margin-bottom:1rem;color:#856404}.password-group{position:relative;display:flex;align-items:center}.password-group input{flex:1}.toggle-password{display:none;position:absolute;right:.6rem;background:0 0;border:none;cursor:pointer;padding:.4rem;font-size:.9rem;width:auto;margin-top:0}.control-group{margin-bottom:1.5rem}.control-group:last-child{margin-bottom:0}.control-label{display:block;font-weight:600;margin-bottom:.6rem;color:var(--fg)}.control-value{display:block;font-size:1rem;color:#0a3;margin-bottom:.8rem;font-weight:500}.inline-control{display:flex;gap:.5rem;align-items:center;margin-top:.8rem}.inline-control input[type=range]{flex:1 1 auto;min-width:0;margin-top:0}.inline-control .set-button{flex:0 0 auto;width:auto;padding:.6rem 1rem;font-size:.85rem;min-width:50px;height:auto}.radio-group{display:flex;gap:.8rem;margin-top:.8rem;flex-wrap:wrap}.radio-group label{display:flex;align-items:center;gap:.6rem;cursor:pointer;color:var(--fg);padding:.6rem .6rem;border:2px solid var(--border);border-radius:6px;transition:all .2s ease;user-select:none;min-height:44px;min-width:44px}.radio-group label:hover{border-color:#0a3;background:var(--nav)}.radio-group label:active{transform:scale(.98)}.radio-group input[type=radio]{cursor:pointer;width:15px;height:15px;accent-color:#0a3;flex-shrink:0}.radio-group input[type=radio]:focus-visible{outline:2px solid #0a3;outline-offset:2px}.radio-group input[type=radio]:checked+label,.radio-group label:has(input[type=radio]:checked){border-color:#0a3;background:rgba(0,170,51,.1);font-weight:600}.language-selector{margin-top:1rem}.language-selector label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.language-selector button{background:var(--accent-color,#0a3);color:#fff;font-weight:600}.language-selector button:hover{opacity:.9}body.error-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.error-container{background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.3);padding:60px 40px;text-align:center;max-width:500px;width:100%}.error-code{font-size:120px;font-weight:700;margin-bottom:20px;line-height:1}.error-title{font-size:28px;font-weight:600;color:#1f2937;margin-bottom:15px}.error-message{font-size:16px;color:#6b7280;margin-bottom:40px;line-height:1.6}.error-actions{display:flex;gap:12px;flex-direction:column}.error-403 .error-code{color:#f59e0b}.error-403 .btn-primary{background:#f59e0b}.error-403 .btn-primary:hover{background:#d97706;box-shadow:0 4px 12px rgba(245,158,11,.4)}.error-404 .error-code{color:#10b981}.error-404 .btn-primary{background:#10b981}.error-404 .btn-primary:hover{background:#059669;box-shadow:0 4px 12px rgba(16,185,129,.4)}.error-500 .error-code{color:#ef4444}.error-500 .btn-primary{background:#ef4444}.error-500 .btn-primary:hover{background:#dc2626;box-shadow:0 4px 12px rgba(239,68,68,.4)}@media (max-width:600px){.error-container{padding:40px 20px}.error-code{font-size:80px}.error-title{font-size:24px}}.checkbox-item{display:flex;align-items:center;width:100%;padding:1rem;margin-bottom:.75rem;border-radius:.5rem;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:all .2s ease;min-height:48px}.checkbox-item:hover{background:var(--bg);border-color:var(--primary)}.checkbox-item:active{transform:scale(.98)}.checkbox-item input[type=checkbox]{width:20px;height:20px;min-width:20px;min-height:20px;margin:0;margin-right:1rem;cursor:pointer;accent-color:var(--primary)}.checkbox-item label,.checkbox-item span{flex:1;margin:0;cursor:pointer;font-size:1rem;line-height:1.4;color:var(--fg);font-weight:500}.checkbox-group{margin-bottom:1.5rem;width:100%}.control-group .checkbox-group{margin-bottom:0}.checkbox-group-title{font-size:.9rem;font-weight:600;text-transform:uppercase;color:var(--fg);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border);opacity:.8}.checkbox-group-subtitle{font-size:.85rem;font-weight:500;color:var(--fg);margin-bottom:.75rem;padding-left:1rem;opacity:.7}.checkbox-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}@media (max-width:480px){.checkbox-item{padding:.875rem}.checkbox-item input[type=checkbox]{width:18px;height:18px}.checkbox-item label{font-size:.95rem}}