@import url(https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap);:root{--bg:#f4f3ef;--bg2:#fff;--bg3:#f0efe9;--border:#00000012;--text:#1a1a2e;--text2:#6b6b80;--text3:#a0a0b5;--accent:#6366f1;--accent2:#7c6af7;--green:#059669;--orange:#ea580c;--red:#dc2626;--yellow:#d97706;--card-shadow:0 2px 12px #0000000f;--radius:16px;--radius-sm:10px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto}body{background:#f4f3ef;background:var(--bg);color:#1a1a2e;color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;line-height:1.5;min-height:100vh}.app,.sidebar{display:flex;min-height:100vh}.sidebar{background:#fff;background:var(--bg2);border-right:1px solid #00000012;border-right:1px solid var(--border);box-shadow:2px 0 12px #0000000a;flex-direction:column;left:0;padding:24px 16px;position:fixed;top:0;width:220px;z-index:10}.sidebar-logo{color:#1a1a2e;color:var(--text);font-size:22px;font-weight:700;letter-spacing:-.5px;margin-bottom:32px;padding:0 8px}.sidebar-logo span{color:#6366f1;color:var(--accent)}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px}.nav-item{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius-sm);color:#6b6b80;color:var(--text2);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:10px;padding:10px 12px;text-align:left;transition:all .15s;width:100%}.nav-item:hover{background:#f0efe9;background:var(--bg3);color:#1a1a2e;color:var(--text)}.nav-item.active{background:#6366f114;color:#6366f1;color:var(--accent);font-weight:600}.nav-item .nav-icon{font-size:16px;text-align:center;width:20px}.sidebar-bottom{border-top:1px solid #00000012;border-top:1px solid var(--border);padding-top:16px}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:220px;min-height:100vh}.topbar{align-items:center;background:#fff;background:var(--bg2);border-bottom:1px solid #00000012;border-bottom:1px solid var(--border);box-shadow:0 2px 8px #0000000a;display:flex;justify-content:space-between;padding:16px 32px;position:sticky;top:0;z-index:9}.topbar-left{display:flex;flex-direction:column;gap:2px}.topbar-title{font-size:18px;font-weight:700;letter-spacing:-.3px}.topbar-sub{color:#6b6b80;color:var(--text2);font-size:12px}.topbar-right{gap:12px}.notif-btn,.topbar-right{align-items:center;display:flex}.notif-btn{border:1px solid #00000012;border:1px solid var(--border);border-radius:10px;color:#6b6b80;color:var(--text2);cursor:pointer;font-size:16px;height:38px;justify-content:center;position:relative;transition:all .15s;width:38px}.notif-btn,.notif-btn:hover{background:#f0efe9;background:var(--bg3)}.notif-btn:hover{color:#1a1a2e;color:var(--text)}.notif-count{background:#dc2626;background:var(--red);border-radius:20px;color:#fff;font-size:9px;font-weight:700;min-width:16px;padding:2px 4px;position:absolute;right:-4px;text-align:center;top:-4px}.page-content{flex:1 1;padding:28px 32px}.card{background:#fff;background:var(--bg2);border:1px solid #00000012;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);box-shadow:0 2px 12px #0000000f;box-shadow:var(--card-shadow);margin-bottom:16px;padding:20px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-title{color:#6b6b80;color:var(--text2);font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase}.stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{background:#fff;background:var(--bg2);border:1px solid #00000012;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);box-shadow:0 2px 12px #0000000f;box-shadow:var(--card-shadow);overflow:hidden;padding:20px;position:relative;transition:transform .15s,box-shadow .15s}.stat-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.stat-card:before{border-radius:16px 16px 0 0;border-radius:var(--radius) var(--radius) 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.stat-card.accent:before{background:linear-gradient(90deg,#6366f1,#a78bfa)}.stat-card.green:before{background:linear-gradient(90deg,#059669,#34d399)}.stat-card.orange:before{background:linear-gradient(90deg,#ea580c,#fb923c)}.stat-card.red:before{background:linear-gradient(90deg,#dc2626,#f87171)}.stat-icon{display:block;font-size:24px;margin-bottom:12px}.stat-value{color:#1a1a2e;color:var(--text);font-size:28px;font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:6px}.stat-label{color:#6b6b80;color:var(--text2);font-size:12px;font-weight:600}.stat-sub{color:#a0a0b5;color:var(--text3);font-size:11px;margin-top:4px}.will-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));margin-bottom:24px}.will-card{background:#fff;background:var(--bg2);border:1px solid #00000012;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);box-shadow:0 2px 12px #0000000f;box-shadow:var(--card-shadow);padding:20px;transition:border-color .2s,box-shadow .2s}.will-card.online{border-left:3px solid #059669;border-left:3px solid var(--green)}.will-card.offline{border-left:3px solid #dc2626;border-left:3px solid var(--red)}.will-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.will-name{font-size:16px;font-weight:700;letter-spacing:-.3px}.will-event-label{color:#a0a0b5;color:var(--text3);font-size:10px;letter-spacing:.5px;margin-top:2px;text-transform:uppercase}.will-event-badge{background:#6366f114;border-radius:20px;color:#6366f1;color:var(--accent);font-family:DM Mono,monospace;font-size:11px;font-weight:600;padding:4px 10px}.hw-indicators{display:flex;gap:14px;margin-bottom:16px}.hw-dot{align-items:center;color:#6b6b80;color:var(--text2);display:flex;font-size:12px;gap:5px}.hw-dot-circle{border-radius:50%;height:7px;width:7px}.hw-dot-circle.ok{background:#059669;background:var(--green)}.hw-dot-circle.err{background:#dc2626;background:var(--red)}.will-metrics{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.will-metric{background:#f0efe9;background:var(--bg3);border-radius:10px;border-radius:var(--radius-sm);padding:10px;text-align:center}.will-metric-val{color:#1a1a2e;color:var(--text);font-size:16px;font-weight:700;letter-spacing:-.5px}.will-metric-key{color:#a0a0b5;color:var(--text3);font-size:10px;letter-spacing:.5px;margin-top:2px;text-transform:uppercase}.will-footer{align-items:center;border-top:1px solid #00000012;border-top:1px solid var(--border);display:flex;justify-content:space-between;padding-top:14px}.will-ping{color:#a0a0b5;color:var(--text3);font-family:DM Mono,monospace;font-size:11px}.toggle{cursor:pointer;display:inline-block;height:20px;position:relative;width:36px}.toggle input{display:none}.toggle-track{background:#e2e2ea;border-radius:20px;inset:0;position:absolute;transition:all .2s}.toggle input:checked+.toggle-track{background:#6366f1;background:var(--accent)}.toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:14px;left:3px;position:absolute;top:3px;transition:all .2s;width:14px}.toggle input:checked~.toggle-thumb{left:19px}.badge{border-radius:20px;font-size:11px;font-weight:600;padding:4px 10px}.badge-ok{background:#0596691a;color:#059669;color:var(--green)}.badge-err{background:#dc26261a;color:#dc2626;color:var(--red)}.badge-off{background:#f0efe9;background:var(--bg3);color:#a0a0b5;color:var(--text3)}.badge-warn{background:#d977061a;color:#d97706;color:var(--yellow)}.btn{align-items:center;background:#f0efe9;background:var(--bg3);border:1px solid #00000012;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#6b6b80;color:var(--text2);cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .15s}.btn:hover{background:#e8e7e1;color:#1a1a2e;color:var(--text)}.btn:disabled{cursor:not-allowed;opacity:.4}.btn-primary{background:#6366f1;background:var(--accent);border-color:#6366f1;border-color:var(--accent);color:#fff}.btn-primary:hover{background:#7c6af7;background:var(--accent2);border-color:#7c6af7;border-color:var(--accent2);color:#fff}.btn-danger{background:#dc26260f;border-color:#dc262633;color:#dc2626;color:var(--red)}.btn-danger:hover{background:#dc26261f}.btn-sm{font-size:12px;padding:5px 10px}.btn-icon{border-radius:8px;padding:7px}label{color:#6b6b80;color:var(--text2);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}input,select{background:#f0efe9;background:var(--bg3);border:1px solid #00000012;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#1a1a2e;color:var(--text);font-family:DM Sans,sans-serif;font-size:13px;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}input:focus,select:focus{background:#fff;border-color:#6366f1;border-color:var(--accent)}input::placeholder{color:#a0a0b5;color:var(--text3)}.photo-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.photo-thumb{aspect-ratio:3/2;background:#f0efe9;background:var(--bg3);border-radius:10px;cursor:pointer;overflow:hidden;position:relative;transition:transform .15s,box-shadow .15s}.photo-thumb:hover{box-shadow:0 6px 16px #00000026;transform:scale(1.02)}.photo-thumb img{height:100%;object-fit:cover;width:100%}.folder-tree{display:flex;flex-direction:column;gap:10px}.folder-row{background:#fff;background:var(--bg2);border:1px solid #00000012;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);box-shadow:0 2px 12px #0000000f;box-shadow:var(--card-shadow);overflow:hidden}.folder-header{align-items:center;cursor:pointer;display:flex;gap:10px;padding:14px 16px;transition:background .1s}.folder-header:hover{background:#f0efe9;background:var(--bg3)}.folder-icon{font-size:18px}.folder-name{flex:1 1;font-size:14px;font-weight:700}.folder-count{color:#a0a0b5;color:var(--text3);font-family:DM Mono,monospace;font-size:12px;margin-right:8px}.folder-children{background:#f0efe9;background:var(--bg3);border-top:1px solid #00000012;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px;padding:4px 8px 8px}.date-row{align-items:center;border-radius:8px;display:flex;gap:10px;padding:8px 12px;transition:background .1s}.date-row:hover{background:#0000000a}.date-icon{font-size:14px}.date-name{color:#6b6b80;color:var(--text2);flex:1 1;font-family:DM Mono,monospace;font-size:13px}.date-count{color:#a0a0b5;color:var(--text3);font-size:12px;margin-right:8px}.live-container{background:#111;border-radius:16px;border-radius:var(--radius);box-shadow:0 2px 12px #0000000f;box-shadow:var(--card-shadow);margin-bottom:16px;overflow:hidden}.live-container img{display:block;max-height:480px;object-fit:contain;width:100%}.live-bar{align-items:center;background:#1a1a1a;display:flex;gap:8px;padding:10px 16px}.live-dot{background:#dc2626;background:var(--red);border-radius:50%;height:7px;width:7px}.live-dot.active{animation:pulse 2s infinite;background:#22c55e}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.log-container{background:#1e1e2e;border-radius:16px;border-radius:var(--radius);box-shadow:0 2px 12px #0000000f;box-shadow:var(--card-shadow);font-family:DM Mono,monospace;font-size:12px;height:320px;overflow-y:auto;padding:16px}.log-line{display:flex;gap:12px;padding:3px 0}.log-time{color:#55556a;min-width:70px}.new-event-form{display:flex;flex-direction:column;gap:16px}.will-selector{display:flex;flex-wrap:wrap;gap:8px}.will-chip{background:#f0efe9;background:var(--bg3);border:1.5px solid #00000012;border:1.5px solid var(--border);border-radius:20px;color:#6b6b80;color:var(--text2);cursor:pointer;font-size:13px;font-weight:500;padding:7px 16px;transition:all .15s;-webkit-user-select:none;user-select:none}.will-chip.selected{background:#6366f114;border-color:#6366f1;border-color:var(--accent);color:#6366f1;color:var(--accent);font-weight:600}.notif-panel{background:#fff;background:var(--bg2);border:1px solid #00000012;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);box-shadow:0 8px 32px #0000001f;overflow:hidden;position:absolute;right:0;top:56px;width:320px;z-index:100}.notif-header{font-size:13px;font-weight:700;padding:14px 16px}.notif-header,.notif-item{border-bottom:1px solid #00000012;border-bottom:1px solid var(--border)}.notif-item{align-items:flex-start;display:flex;gap:12px;padding:12px 16px}.notif-item:last-child{border-bottom:none}.notif-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:4px;width:8px}.notif-text{color:#6b6b80;color:var(--text2);font-size:12px;line-height:1.4}.notif-time{color:#a0a0b5;color:var(--text3);font-size:11px;margin-top:2px}.section-title{color:#1a1a2e;color:var(--text);font-size:17px;font-weight:700;letter-spacing:-.4px;margin-bottom:16px}.divider{background:#00000012;background:var(--border);height:1px;margin:24px 0}.empty-state{color:#a0a0b5;color:var(--text3);padding:48px 24px;text-align:center}.empty-state-icon{font-size:32px;margin-bottom:12px}.empty-state-text{font-size:14px}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#00000012;background:var(--border);border-radius:3px}.modal-overlay{align-items:center;background:#000c;cursor:zoom-out;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.gallery-public{background:#f4f3ef;background:var(--bg);min-height:100vh;padding:32px}.gallery-header{margin-bottom:32px;text-align:center}.gallery-title{font-size:32px;font-weight:700;letter-spacing:-1px;margin-bottom:8px}.gallery-sub{color:#6b6b80;color:var(--text2);font-size:14px}.config-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:900px){.sidebar{display:none}.main-content{margin-left:0}.stats-row{grid-template-columns:repeat(2,1fr)}.page-content{padding:20px 16px}.topbar{padding:14px 16px}.config-grid{grid-template-columns:1fr}}@media (max-width:600px){.stats-row{grid-template-columns:1fr 1fr}.will-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.e17e5ed8.css.map*/