:root{--bg-gradient:linear-gradient(135deg, #090b11 0%, #0f1322 50%, #1e152a 100%);--glass-bg:#ffffff06;--glass-border:#ffffff12;--glass-hover-bg:#ffffff0f;--glass-hover-border:#ffffff26;--text-main:#f8fafc;--text-muted:#94a3b8;--color-ha:#03a9f4;--color-ha-glow:#03a9f426;--color-potager:#10b981;--color-potager-glow:#10b98126;--color-sorties:#ec4899;--color-sorties-glow:#ec489926;--color-maintenance:#f59e0b;--color-maintenance-glow:#f59e0b26;--danger-color:#ef4444;--danger-glow:#ef444433;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;font-family:var(--font-sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#090b11}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-gradient);min-height:100vh;font-family:var(--font-sans);position:relative;overflow-x:hidden}.orb{filter:blur(140px);z-index:0;pointer-events:none;opacity:.45;border-radius:50%;transition:all 1s;position:absolute}.orb-1{background:radial-gradient(circle, var(--color-sorties) 0%, transparent 70%);width:500px;height:500px;top:-150px;left:-150px}.orb-2{background:radial-gradient(circle, var(--color-potager) 0%, transparent 70%);width:600px;height:600px;bottom:-200px;right:-150px}.orb-3{background:radial-gradient(circle, var(--color-ha) 0%, transparent 70%);opacity:.25;width:450px;height:450px;top:40%;left:50%;transform:translate(-50%,-50%)}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.app-container{flex-direction:column;flex-grow:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:flex}header{text-align:center;margin-bottom:2.5rem;position:relative}.header-top{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.logo-section h1{letter-spacing:-.03em;background:linear-gradient(135deg,#fff 0%,#cbd5e1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:2.2rem;font-weight:800}.logo-section p{color:var(--text-muted);margin-top:.25rem;font-size:.95rem;font-weight:300}.glass-panel{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(24px);border-radius:24px;padding:2rem;transition:all .4s cubic-bezier(.16,1,.3,1)}.glass-panel:hover{background:var(--glass-hover-bg);border-color:var(--glass-hover-border)}.nav-menu{border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff05;border-radius:16px;gap:.75rem;padding:.4rem;display:flex}.nav-btn{color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.nav-btn:hover{color:var(--text-main);background:#ffffff0d}.nav-btn.active{color:var(--text-main);background:#ffffff1a;box-shadow:0 4px 12px #0000001a}.logout-btn{color:var(--danger-color);font-family:var(--font-sans);cursor:pointer;background:#ef44441a;border:1px solid #ef444433;border-radius:12px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .3s;display:flex}.logout-btn:hover{background:var(--danger-color);color:#fff;box-shadow:0 0 15px var(--danger-glow)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.animate-fade{animation:.6s both fadeIn}.animate-slide-up{animation:.6s cubic-bezier(.16,1,.3,1) both slideUp}.shake{animation:.4s shake}.pin-screen-container{flex-grow:1;justify-content:center;align-items:center;min-height:85vh;display:flex}.pin-card{text-align:center;border-radius:28px;width:100%;max-width:380px;padding:2.5rem 2rem}.pin-logo{color:var(--color-ha);filter:drop-shadow(0 0 15px var(--color-ha-glow));margin-bottom:1.5rem;font-size:3.5rem}.pin-card h2{margin-bottom:.5rem;font-size:1.6rem;font-weight:700}.pin-card p{color:var(--text-muted);margin-bottom:2rem;font-size:.9rem}.pin-dots-container{justify-content:center;gap:1.25rem;margin-bottom:2rem;display:flex}.pin-dot{border:2px solid #fff3;border-radius:50%;width:16px;height:16px;transition:all .2s}.pin-dot.filled{background:var(--text-main);border-color:var(--text-main);box-shadow:0 0 10px #fffc}.pin-dot.error{background:var(--danger-color);border-color:var(--danger-color);box-shadow:0 0 10px var(--danger-glow)}.pin-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.pin-key{border:1px solid var(--glass-border);color:var(--text-main);font-size:1.5rem;font-family:var(--font-sans);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto;font-weight:500;transition:all .2s;display:flex}.pin-key:hover{background:#ffffff14;border-color:#fff3;transform:scale(1.05)}.pin-key:active{background:#ffffff26;transform:scale(.95)}.pin-key.action{color:var(--text-muted);background:0 0;border-color:#0000;font-size:1.1rem}.pin-key.action:hover{color:var(--text-main);background:#ffffff0a}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.dashboard-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.toggle-container{border:1px solid var(--glass-border);background:#ffffff05;border-radius:16px;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.toggle-label{color:var(--text-muted);font-size:.85rem;font-weight:600;transition:color .3s}.toggle-label.active{color:var(--text-main)}.switch{width:50px;height:26px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;border:1px solid var(--glass-border);background-color:#ffffff1a;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 5px #0000004d}input:checked+.slider{background-color:var(--color-ha)}input:checked+.slider:before{transform:translate(24px)}.service-card{color:inherit;flex-direction:column;height:100%;text-decoration:none;display:flex;position:relative;overflow:hidden}.service-card:before{content:"";background:radial-gradient(600px circle at var(--x,0px) var(--y,0px), #ffffff09, transparent 45%);pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.service-card .card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.service-icon-wrapper{border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.8rem;transition:all .4s;display:flex}.status-badge{border:1px solid var(--glass-border);background:#ffffff08;border-radius:20px;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.online{background:var(--color-potager);box-shadow:0 0 8px var(--color-potager);animation:2s ease-in-out infinite pulse-dot}.status-dot.offline{background:var(--danger-color);box-shadow:0 0 8px var(--danger-color)}.status-dot.checking{background:var(--color-maintenance);box-shadow:0 0 8px var(--color-maintenance)}.service-card h2{text-align:left;margin-bottom:.5rem;font-size:1.4rem;font-weight:700}.service-card .card-desc{color:var(--text-muted);text-align:left;flex-grow:1;margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.service-card .card-footer{color:var(--text-muted);border-top:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-top:1rem;font-size:.8rem;display:flex}.url-text{text-overflow:ellipsis;white-space:nowrap;max-width:70%;font-family:monospace;overflow:hidden}.btn-enter-service{align-items:center;gap:.3rem;font-size:.85rem;font-weight:700;transition:all .3s;display:flex}.service-card.ha:hover{border-color:var(--color-ha);box-shadow:0 15px 30px -10px var(--color-ha-glow);transform:translateY(-6px)}.service-card.ha .service-icon-wrapper{color:var(--color-ha);background:#03a9f414;border:1px solid #03a9f426}.service-card.ha:hover .service-icon-wrapper{background:var(--color-ha);color:#fff;transform:scale(1.05)rotate(2deg)}.service-card.ha .btn-enter-service{color:var(--color-ha)}.service-card.potager:hover{border-color:var(--color-potager);box-shadow:0 15px 30px -10px var(--color-potager-glow);transform:translateY(-6px)}.service-card.potager .service-icon-wrapper{color:var(--color-potager);background:#10b98114;border:1px solid #10b98126}.service-card.potager:hover .service-icon-wrapper{background:var(--color-potager);color:#fff;transform:scale(1.05)rotate(2deg)}.service-card.potager .btn-enter-service{color:var(--color-potager)}.service-card.sorties:hover{border-color:var(--color-sorties);box-shadow:0 15px 30px -10px var(--color-sorties-glow);transform:translateY(-6px)}.service-card.sorties .service-icon-wrapper{color:var(--color-sorties);background:#ec489914;border:1px solid #ec489926}.service-card.sorties:hover .service-icon-wrapper{background:var(--color-sorties);color:#fff;transform:scale(1.05)rotate(2deg)}.service-card.sorties .btn-enter-service{color:var(--color-sorties)}.maint-container{flex-direction:column;gap:1.5rem;display:flex}.maint-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.maint-title-group h2{align-items:center;gap:.5rem;font-size:1.6rem;font-weight:700;display:flex}.maint-title-group p{color:var(--text-muted);margin-top:.2rem;font-size:.9rem}.maint-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.maint-card{flex-direction:column;gap:1rem;padding:1.5rem;display:flex;position:relative}.maint-card-header{justify-content:space-between;align-items:flex-start;display:flex}.maint-card-icon{width:44px;height:44px;color:var(--color-maintenance);background:#f59e0b14;border:1px solid #f59e0b26;border-radius:12px;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.maint-actions{gap:.25rem;display:flex}.icon-btn{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.icon-btn:hover{color:var(--text-main);background:#ffffff0d}.icon-btn.danger:hover{color:var(--danger-color);background:#ef44441a}.maint-card h3{font-size:1.15rem;font-weight:700;line-height:1.3}.maint-card .maint-meta{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.8rem;display:flex}.maint-progress-container{flex-direction:column;gap:.4rem;margin-top:.5rem;display:flex}.maint-progress-bar{background:#ffffff0d;border-radius:4px;width:100%;height:8px;overflow:hidden}.maint-progress-fill{border-radius:4px;height:100%;transition:width .5s ease-in-out}.maint-progress-fill.safe{background:var(--color-potager)}.maint-progress-fill.warning{background:var(--color-maintenance)}.maint-progress-fill.danger{background:var(--danger-color);box-shadow:0 0 10px var(--danger-glow)}.maint-status-text{justify-content:space-between;font-size:.75rem;font-weight:600;display:flex}.maint-status-text.overdue{color:var(--danger-color)}.maint-done-btn{color:var(--color-potager);font-family:var(--font-sans);cursor:pointer;background:#10b9811a;border:1px solid #10b98133;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;margin-top:auto;padding:.6rem;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.maint-done-btn:hover{background:var(--color-potager);color:#fff;box-shadow:0 0 10px var(--color-potager-glow)}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:24px;width:100%;max-width:450px;padding:2rem;animation:.3s cubic-bezier(.16,1,.3,1) both slideUp}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-header h3{font-size:1.3rem;font-weight:700}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-muted);font-size:.85rem;font-weight:600}.form-input{border:1px solid var(--glass-border);color:var(--text-main);font-family:var(--font-sans);background:#ffffff08;border-radius:12px;padding:.75rem 1rem;font-size:.95rem;transition:all .3s}.form-input:focus{border-color:var(--color-ha);box-shadow:0 0 10px var(--color-ha-glow);background:#ffffff0d;outline:none}.form-actions{justify-content:flex-end;gap:.75rem;margin-top:1.75rem;display:flex}.btn{font-family:var(--font-sans);cursor:pointer;border:none;border-radius:12px;align-items:center;gap:.4rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:700;transition:all .2s;display:flex}.btn-secondary{border:1px solid var(--glass-border);color:var(--text-main);background:#ffffff0d}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-primary{background:var(--color-ha);color:#fff}.btn-primary:hover{box-shadow:0 0 12px var(--color-ha-glow);background:#009be0}.btn-add{color:var(--color-maintenance);background:#f59e0b1a;border:1px solid #f59e0b33}.btn-add:hover{background:var(--color-maintenance);color:#fff;box-shadow:0 0 12px var(--color-maintenance-glow)}.guide-container{flex-direction:column;gap:1.5rem;display:flex}.guide-panel{padding:2.5rem}.guide-panel h2{align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.6rem;font-weight:700;display:flex}.guide-panel>p{color:var(--text-muted);margin-bottom:2rem}.guide-step{border-left:3px solid var(--color-ha);margin-bottom:2rem;padding-left:1.25rem}.guide-step h3{margin-bottom:.5rem;font-size:1.15rem;font-weight:700}.guide-step p{color:var(--text-muted);margin-bottom:.75rem;font-size:.95rem;line-height:1.6}.code-block-wrapper{border:1px solid var(--glass-border);color:#e2e8f0;background:#0000004d;border-radius:12px;margin:.5rem 0;padding:1rem;font-family:monospace;font-size:.85rem;position:relative;overflow-x:auto}.code-block-wrapper pre{margin:0}.copy-badge{border:1px solid var(--glass-border);font-family:var(--font-sans);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff0d;border-radius:6px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;transition:all .2s;position:absolute;top:.5rem;right:.5rem}.copy-badge:hover{color:var(--text-main);background:#ffffff1a}footer{text-align:center;color:var(--text-muted);border-top:1px solid #ffffff05;margin-top:auto;padding:2rem 0 1rem;font-size:.85rem;font-weight:300}@media (width<=768px){.header-top{flex-direction:column;align-items:stretch;gap:1rem}.nav-menu{justify-content:center}.dashboard-controls{flex-direction:column;align-items:stretch}.toggle-container{justify-content:space-between}}
