@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:#fff;--bg2:#fff;--bg3:#f7f5fb;--bg-soft:#ede7f9;--border:#7c3aed1a;--text:#1a1a2e;--text2:#6b6b80;--text3:#a0a0b5;--accent:#7c3aed;--accent2:#6d28d9;--accent-soft:#c9beed;--accent-pale:#ede7f9;--pink-soft:#f5d5f0;--green:#10b981;--orange:#ea580c;--red:#ef4444;--yellow:#f59e0b;--card-shadow:0 2px 12px #7c3aed0f;--card-shadow-hover:0 8px 24px #7c3aed1f;--radius:20px;--radius-sm:14px;--radius-pill:999px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto}body{background:#fff;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 #7c3aed1a;border-right:1px solid var(--border);flex-direction:column;left:0;padding:28px 16px;position:fixed;top:0;width:240px;z-index:10}.sidebar-logo{font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:36px;padding:0 12px}.sidebar-logo,.sidebar-logo span{color:#c9beed;color:var(--accent-soft)}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:6px}.nav-item{align-items:center;background:none;border:none;border-radius:999px;border-radius:var(--radius-pill);color:#6b6b80;color:var(--text2);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;transition:all .15s;width:100%}.nav-item:hover{background:#ede7f9;background:var(--accent-pale);color:#7c3aed;color:var(--accent)}.nav-item.active{background:#7c3aed;background:var(--accent);color:#fff;font-weight:600}.nav-item.active:hover{background:#6d28d9;background:var(--accent2);color:#fff}.nav-item .nav-icon{font-size:16px;text-align:center;width:20px}.sidebar-bottom{border-top:1px solid #7c3aed1a;border-top:1px solid var(--border);padding-top:16px}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:240px;min-height:100vh}.topbar{align-items:center;background:#fff;background:var(--bg2);border-bottom:1px solid #7c3aed1a;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 32px;position:sticky;top:0;z-index:9}.topbar-left{display:flex;flex-direction:column;gap:2px}.topbar-title{color:#1a1a2e;color:var(--text);font-size:22px;font-weight:700;letter-spacing:-.5px}.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{background:#ede7f9;background:var(--accent-pale);border:none;border-radius:999px;border-radius:var(--radius-pill);color:#7c3aed;color:var(--accent);cursor:pointer;font-size:18px;height:42px;justify-content:center;position:relative;transition:all .15s;width:42px}.notif-btn:hover{background:#c9beed;background:var(--accent-soft);color:#6d28d9;color:var(--accent2)}.notif-count{background:#ef4444;background:var(--red);border:2px solid #fff;border-radius:20px;color:#fff;font-size:10px;font-weight:700;min-width:18px;padding:2px 5px;position:absolute;right:-2px;text-align:center;top:-2px}.page-content{flex:1 1;padding:32px}.card{background:#fff;background:var(--bg2);border:1px solid #7c3aed1a;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius);box-shadow:0 2px 12px #7c3aed0f;box-shadow:var(--card-shadow);margin-bottom:16px;padding:24px}.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 #7c3aed1a;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius);box-shadow:0 2px 12px #7c3aed0f;box-shadow:var(--card-shadow);overflow:hidden;padding:22px;position:relative;transition:transform .15s,box-shadow .15s}.stat-card:hover{box-shadow:0 8px 24px #7c3aed1f;box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.stat-card:before{border-radius:20px 20px 0 0;border-radius:var(--radius) var(--radius) 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card.accent:before{background:linear-gradient(90deg,#7c3aed,#c9beed);background:linear-gradient(90deg,var(--accent),var(--accent-soft))}.stat-card.green:before{background:linear-gradient(90deg,#10b981,#6ee7b7)}.stat-card.orange:before{background:linear-gradient(90deg,#ea580c,#fb923c)}.stat-card.red:before{background:linear-gradient(90deg,#ef4444,#fca5a5)}.stat-icon{display:block;font-size:24px;margin-bottom:12px}.stat-value{color:#1a1a2e;color:var(--text);font-size:30px;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 #7c3aed1a;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius);box-shadow:0 2px 12px #7c3aed0f;box-shadow:var(--card-shadow);padding:22px;transition:transform .15s,box-shadow .2s}.will-card:hover{box-shadow:0 8px 24px #7c3aed1f;box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.will-card.online{border-left:4px solid #10b981;border-left:4px solid var(--green)}.will-card.offline{border-left:4px solid #ef4444;border-left:4px solid var(--red)}.will-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.will-name{font-size:17px;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:#ede7f9;background:var(--accent-pale);border-radius:999px;border-radius:var(--radius-pill);color:#7c3aed;color:var(--accent);font-family:DM Mono,monospace;font-size:11px;font-weight:600;padding:5px 12px}.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:#10b981;background:var(--green)}.hw-dot-circle.err{background:#ef4444;background:var(--red)}.will-metrics{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.will-metric{background:#f7f5fb;background:var(--bg3);border-radius:14px;border-radius:var(--radius-sm);padding:12px;text-align:center}.will-metric-val{color:#1a1a2e;color:var(--text);font-size:17px;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 #7c3aed1a;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:22px;position:relative;width:40px}.toggle input{display:none}.toggle-track{background:#e2e2ea;border-radius:20px;inset:0;position:absolute;transition:all .2s}.toggle input:checked+.toggle-track{background:#7c3aed;background:var(--accent)}.toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:16px;left:3px;position:absolute;top:3px;transition:all .2s;width:16px}.toggle input:checked~.toggle-thumb{left:21px}.badge{border-radius:999px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;padding:5px 12px}.badge-ok{background:#10b9811f;color:#10b981;color:var(--green)}.badge-err{background:#ef44441f;color:#ef4444;color:var(--red)}.badge-off{background:#f7f5fb;background:var(--bg3);color:#a0a0b5;color:var(--text3)}.badge-warn{background:#f59e0b1f;color:#f59e0b;color:var(--yellow)}.btn{align-items:center;background:#f7f5fb;background:var(--bg3);border:1px solid #7c3aed1a;border:1px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);color:#6b6b80;color:var(--text2);cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:10px 18px;transition:all .15s}.btn:hover{background:#ede7f9;background:var(--accent-pale);border-color:#0000;color:#7c3aed;color:var(--accent)}.btn:disabled{cursor:not-allowed;opacity:.4}.btn-primary{background:#7c3aed;background:var(--accent);border-color:#7c3aed;border-color:var(--accent);color:#fff}.btn-primary:hover{background:#6d28d9;background:var(--accent2);border-color:#6d28d9;border-color:var(--accent2);color:#fff}.btn-soft{background:#ede7f9;background:var(--accent-pale);border-color:#0000;color:#7c3aed;color:var(--accent)}.btn-soft:hover{background:#c9beed;background:var(--accent-soft);color:#6d28d9;color:var(--accent2)}.btn-danger{background:#ef444414;border-color:#0000}.btn-danger,.btn-danger:hover{color:#ef4444;color:var(--red)}.btn-danger:hover{background:#ef444429}.btn-sm{font-size:12px;padding:6px 12px}.btn-icon{border-radius:50%;height:36px;justify-content:center;padding:8px;width:36px}label{color:#6b6b80;color:var(--text2);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}input,select,textarea{background:#f7f5fb;background:var(--bg3);border:1.5px solid #0000;border-radius:14px;border-radius:var(--radius-sm);color:#1a1a2e;color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;outline:none;padding:11px 16px;transition:border-color .15s,background .15s;width:100%}input:focus,select:focus,textarea:focus{background:#fff;border-color:#7c3aed;border-color:var(--accent)}input::placeholder,textarea::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:#f7f5fb;background:var(--bg3);border-radius:14px;border-radius:var(--radius-sm);cursor:pointer;overflow:hidden;position:relative;transition:transform .15s,box-shadow .15s}.photo-thumb:hover{box-shadow:0 8px 24px #7c3aed1f;box-shadow:var(--card-shadow-hover);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 #7c3aed1a;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-sm);box-shadow:0 2px 12px #7c3aed0f;box-shadow:var(--card-shadow);overflow:hidden}.folder-header{align-items:center;cursor:pointer;display:flex;gap:10px;padding:14px 18px;transition:background .1s}.folder-header:hover{background:#ede7f9;background:var(--accent-pale)}.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:#f7f5fb;background:var(--bg3);border-top:1px solid #7c3aed1a;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px;padding:4px 8px 8px}.date-row{align-items:center;border-radius:14px;border-radius:var(--radius-sm);display:flex;gap:10px;padding:10px 14px;transition:background .1s}.date-row:hover{background:#7c3aed0f}.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:20px;border-radius:var(--radius);box-shadow:0 2px 12px #7c3aed0f;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:#ef4444;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:20px;border-radius:var(--radius);box-shadow:0 2px 12px #7c3aed0f;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:#f7f5fb;background:var(--bg3);border:1.5px solid #7c3aed1a;border:1.5px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);color:#6b6b80;color:var(--text2);cursor:pointer;font-size:13px;font-weight:500;padding:8px 18px;transition:all .15s;-webkit-user-select:none;user-select:none}.will-chip:hover{background:#ede7f9;background:var(--accent-pale);border-color:#0000;color:#7c3aed;color:var(--accent)}.will-chip.selected{background:#7c3aed;background:var(--accent);border-color:#7c3aed;border-color:var(--accent);color:#fff;font-weight:600}.notif-panel{background:#fff;background:var(--bg2);border:1px solid #7c3aed1a;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius);box-shadow:0 12px 36px #7c3aed2e;overflow:hidden;position:absolute;right:0;top:56px;width:340px;z-index:100}.notif-header{font-size:14px;font-weight:700;padding:16px 18px}.notif-header,.notif-item{border-bottom:1px solid #7c3aed1a;border-bottom:1px solid var(--border)}.notif-item{align-items:flex-start;display:flex;gap:12px;padding:14px 18px}.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:13px;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:18px;font-weight:700;letter-spacing:-.4px;margin-bottom:16px}.divider{background:#7c3aed1a;background:var(--border);height:1px;margin:24px 0}.empty-state{color:#a0a0b5;color:var(--text3);padding:64px 24px;text-align:center}.empty-state-icon{font-size:40px;margin-bottom:16px;opacity:.6}.empty-state-text{font-size:14px}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#c9beed;background:var(--accent-soft);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#7c3aed;background:var(--accent)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1a2ed9;cursor:zoom-out;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.gallery-public{background:#fff;background:var(--bg);min-height:100vh;padding:32px}.gallery-header{margin-bottom:32px;text-align:center}.gallery-title{color:#c9beed;color:var(--accent-soft);font-size:36px;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:16px 20px}.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.e63a58cc.css.map*/