*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#be58e3;--primary-hover:#aa53d4;--danger:#dc2626;--danger-hover:#b91c1c;--bg:#faf5ff;--sidebar-bg:#3d1152;--sidebar-text:#e9d5f5;--sidebar-active:#be79df;--text:#1e1028;--text-muted:#7c5b8e;--border:#e9d5f5;--card-bg:#fff;--header-bg:#fff}html{min-height:100%;overflow-x:hidden}body{background:var(--sidebar-bg);min-height:100dvh;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;overflow-x:hidden}#root{background:var(--sidebar-bg);min-height:100dvh}.app-layout{min-height:100dvh;display:flex}.sidebar{background:var(--sidebar-bg);z-index:100;width:240px;min-height:100vh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{color:#fff;letter-spacing:.05em;border-bottom:1px solid #ffffff1a;align-items:center;gap:.6rem;padding:1.25rem;font-size:1.4rem;font-weight:700;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem 0;display:flex}.sidebar-link{color:var(--sidebar-text);border-left:3px solid #0000;align-items:center;gap:.55rem;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-link:hover{color:#fff;background:#ffffff12}.sidebar-link.active{color:#fff;border-left-color:var(--sidebar-active);background:#be79df33}.main-wrapper{background:var(--bg);flex-direction:column;flex:1;max-width:calc(100vw - 240px);min-height:100dvh;margin-left:240px;display:flex}.header{background:var(--header-bg);border-bottom:1px solid var(--border);z-index:50;padding-top:env(safe-area-inset-top);position:sticky;top:0;box-shadow:0 1px 3px #0000000d}.header-inner{justify-content:space-between;align-items:center;height:60px;padding:0 2rem;display:flex}.header:before{content:"";top:calc(-1 * env(safe-area-inset-top));height:env(safe-area-inset-top);background:var(--header-bg);pointer-events:none;position:absolute;left:0;right:0}.header-title{color:var(--text);font-size:1.1rem;font-weight:600}.main-content{padding:2rem;padding-bottom:max(2rem, calc(env(safe-area-inset-bottom) + 1rem));flex:1;overflow-x:hidden}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-title{color:var(--text);font-size:1.5rem;font-weight:700}.btn{cursor:pointer;touch-action:manipulation;border:none;border-radius:6px;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-secondary{color:var(--text);border:1px solid var(--border);background:#f1f5f9}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-sm{padding:.3rem .625rem;font-size:.8rem}.table-container{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{border-collapse:collapse;table-layout:auto;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;background:#f8fafc;max-width:min(34vw,420px);padding:.6rem .8rem;font-size:.76rem;font-weight:600}.table td{border-bottom:1px solid var(--border);color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:min(38vw,480px);padding:.55rem .8rem;font-size:.83rem;overflow:hidden}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f8fafc}.table.table-compact th{padding:.48rem .64rem;font-size:.72rem}.table.table-compact td{padding:.42rem .64rem;font-size:.79rem}.action-cell{white-space:nowrap;max-width:none;overflow:visible}.badge{border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-success{color:#16a34a;background:#dcfce7}.badge-danger{color:#dc2626;background:#fee2e2}.badge-gray{color:#64748b;background:#f1f5f9}.form-group{flex:1;margin-bottom:1rem}.form-row{flex-wrap:wrap;gap:1rem;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.375rem;font-size:.8rem;font-weight:600;display:block}.form-input{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:6px;outline:none;padding:.5rem .75rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #be58e326}.form-input:disabled{opacity:.55;cursor:not-allowed;background:#f5f3f7}textarea.form-input{resize:vertical}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;width:100%;max-width:560px;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.modal-title{color:var(--text);font-size:1.1rem;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;touch-action:manipulation;background:0 0;border:none;padding:.25rem;font-size:1.4rem;line-height:1}.modal-close:hover{color:var(--text)}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.login-page{overscroll-behavior-y:none;min-height:100dvh;padding:max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));background:linear-gradient(135deg,#3d1152 0%,#be58e3 100%);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.login-card{background:#fff;border-radius:12px;width:100%;max-width:400px;padding:2.5rem;box-shadow:0 20px 60px #0003}.login-logo{justify-content:center;margin-bottom:.75rem;display:flex}.login-title{color:var(--primary);text-align:center;margin-bottom:.25rem;font-size:2rem;font-weight:800}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:2rem;font-size:.9rem}.login-form{flex-direction:column;gap:0;display:flex}.login-info-error{border:1px solid var(--danger);text-align:center;background:#fee2e2;border-radius:8px;padding:1rem}.login-info-error p{margin:0}.login-lang{justify-content:center;gap:.5rem;display:flex}.login-lang-btn{color:#ffffffd9;cursor:pointer;touch-action:manipulation;background:#ffffff1f;border:1px solid #ffffff59;border-radius:5px;padding:.3rem .875rem;font-size:.82rem;transition:all .15s}.login-lang-btn:hover{color:#fff;background:#ffffff38}.login-lang-btn-active{color:var(--primary);background:#ffffffe6;border-color:#fff;font-weight:600}.toast-container{top:calc(1.25rem + env(safe-area-inset-top,0px));right:calc(1.25rem + env(safe-area-inset-right,0px));z-index:9999;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed}.toast{pointer-events:all;border-radius:8px;justify-content:space-between;align-items:center;gap:.75rem;min-width:260px;max-width:380px;padding:.75rem 1rem;font-size:.875rem;font-weight:500;animation:.25s slideIn;display:flex;box-shadow:0 4px 16px #0000001f}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{color:#fff;background:#16a34a}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--primary);color:#fff}.toast-close{color:inherit;cursor:pointer;opacity:.8;touch-action:manipulation;background:0 0;border:none;font-size:1.1rem}.toast-close:hover{opacity:1}.history-list{flex-direction:column;gap:.75rem;display:flex}.history-item{border:1px solid var(--border);border-radius:6px;overflow:hidden}.history-date{color:var(--text-muted);border-bottom:1px solid var(--border);background:#f8fafc;padding:.375rem .75rem;font-size:.78rem;font-weight:600}.history-record{white-space:pre-wrap;word-break:break-all;color:var(--text);background:#fff;padding:.75rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.78rem}.text-error{color:var(--danger)}.status-col{text-align:center;width:2rem;padding:.75rem .5rem!important}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.status-dot-active{background:#16a34a;box-shadow:0 0 0 2px #16a34a33}.status-dot-inactive{background:#dc2626;box-shadow:0 0 0 2px #dc262633}.header-brand{align-items:center;gap:.5rem;display:flex}.action-buttons-desktop{flex-wrap:nowrap;gap:.375rem;display:flex}.action-buttons-mobile{display:none;position:relative}.actions-dropdown{border:1px solid var(--border);background:#fff;border-radius:8px;min-width:180px;overflow:hidden;box-shadow:0 8px 24px #0000001f}.actions-dropdown-item{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;touch-action:manipulation;background:0 0;align-items:center;gap:.625rem;padding:.625rem .875rem;font-size:.875rem;transition:background .12s;display:flex}.actions-dropdown-item:last-child{border-bottom:none}.actions-dropdown-item:hover:not(:disabled){background:#faf5ff}.actions-dropdown-item:disabled{opacity:.5;cursor:not-allowed}.actions-dropdown-item-danger{color:var(--danger)}.actions-dropdown-item-danger:hover:not(:disabled){background:#fee2e2}.actions-dropdown-icon{flex-shrink:0;align-items:center;display:flex}.mobile-nav-link{color:var(--sidebar-text);border-left:3px solid #0000;border-radius:5px;align-items:center;gap:.55rem;padding:.6rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.mobile-nav-link:hover{color:#fff;background:#ffffff12}.mobile-nav-link.active{color:#fff;border-left-color:var(--sidebar-active);background:#be79df33}.sidebar-bottom{border-top:1px solid #ffffff1a;flex-direction:column;gap:.25rem;padding:1rem;display:flex}.sidebar-quick-row{gap:.25rem;display:flex}.sidebar-quick-row .lang-btn{flex:1}.sidebar-bottom-sep{background:#ffffff1a;height:1px;margin:.375rem 0}.dev-menu-panel{background:#ffffff14;border:1px solid #ffffff1f;border-radius:8px;flex-direction:column;gap:.4rem;margin:0 .5rem .5rem;padding:.5rem;display:flex}.dev-menu-panel-drawer{margin:0 1rem .5rem}.dev-menu-row{align-items:center;gap:.25rem;display:flex}.dev-menu-row .lang-btn,.dev-menu-row .btn{flex:1}.dev-menu-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 .25rem;font-size:1.1rem;line-height:1}.dev-menu-close:hover{color:#fff}.dev-menu-device-id{flex-direction:column;gap:2px;padding:.25rem .125rem .125rem;display:flex}.dev-menu-label{text-transform:uppercase;letter-spacing:.06em;color:#ffffff73;font-size:.625rem}.dev-menu-value{color:#ffffffbf;word-break:break-all;cursor:pointer;font-family:monospace;font-size:.7rem}.dev-menu-value:hover{color:#fff}.login-dev-menu{flex-direction:column;align-items:center;gap:2px;margin-bottom:.75rem;display:flex}.login-dev-menu .dev-menu-label{color:var(--text-muted)}.dev-menu-value-dark{color:var(--text-muted);word-break:break-all;cursor:pointer;font-family:monospace;font-size:.7rem}.dev-menu-value-dark:hover{color:var(--text)}.sidebar-lang-row{gap:.25rem;display:flex}.sidebar-lang{border-top:1px solid #ffffff1a;flex-direction:column;gap:.25rem;padding:1rem;display:flex}.lang-btn{text-align:left;width:100%;color:var(--sidebar-text);cursor:pointer;touch-action:manipulation;background:0 0;border:1px solid #ffffff26;border-radius:5px;padding:.4rem .75rem;font-size:.82rem;transition:all .15s;display:block}.lang-btn:hover{color:#fff;background:#ffffff12}.lang-btn-active{border-color:var(--sidebar-active);color:#fff;background:#be79df4d;font-weight:600}.history-changes{background:#fff;flex-direction:column;gap:.375rem;padding:.5rem .75rem;display:flex}.history-change-row{flex-direction:column;gap:.2rem;display:flex}.history-field-name{color:var(--text);font-family:JetBrains Mono,Fira Code,monospace;font-size:.78rem;font-weight:700}.history-change-values{flex-direction:column;gap:.15rem;padding-left:.75rem;display:flex}.history-val-old,.history-val-new,.history-val-removed,.history-val-added{border-radius:3px;padding:.15rem .4rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.78rem}.history-val-old{color:#dc2626;background:#fee2e2;text-decoration:line-through}.history-val-new{color:#16a34a;background:#dcfce7}.history-val-removed{color:#dc2626;background:#fee2e2}.history-val-added{color:#16a34a;background:#dcfce7}.history-action{text-transform:uppercase;letter-spacing:.04em;color:var(--text);background:#f1f5f9;border-radius:4px;margin-left:.5rem;padding:.1rem .45rem;font-size:.72rem;font-weight:700;display:inline-block}.history-action-create{color:#16a34a;background:#dcfce7}.history-action-update{color:#9333ea;background:#f3e8ff}.history-action-delete{color:#dc2626;background:#fee2e2}.history-by{color:#64748b;margin-left:.5rem;font-size:.78rem}.btn-icon{border:1px solid var(--border);width:2rem;height:2rem;color:var(--text);cursor:pointer;touch-action:manipulation;background:#f1f5f9;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:1rem;line-height:1;transition:background .15s,border-color .15s;display:inline-flex}.btn-icon:hover:not(:disabled){background:#e2e8f0}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-icon-danger{color:var(--danger);background:#fee2e2;border-color:#fca5a5}.btn-icon-danger:hover:not(:disabled){background:#fecaca}.header-actions{align-items:center;gap:.5rem;display:flex}.header-version{color:var(--text-muted);opacity:.75;font-variant-numeric:tabular-nums;letter-spacing:.03em;font-size:.72rem}.mobile-only{display:none}.mobile-overlay{z-index:1200;background:#00000080;position:fixed;inset:0}.mobile-drawer{background:var(--sidebar-bg);z-index:1201;width:260px;height:100dvh;padding:max(1.25rem, env(safe-area-inset-top)) 1rem max(2.5rem, env(safe-area-inset-bottom));flex-direction:column;gap:.5rem;display:flex;position:fixed;top:0;right:0;overflow-y:auto}.mobile-drawer-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.mobile-drawer-title{color:#fff;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;display:flex}.mobile-drawer-section{border-top:1px solid #ffffff1a;flex-direction:column;gap:.375rem;padding-top:.75rem;display:flex}.mobile-drawer-label{color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem;font-size:.72rem;font-weight:600}.mobile-drawer-bottom{flex-direction:column;gap:0;margin-top:auto;display:flex}.col-picker{border:1px solid var(--border);background:#fff;border-radius:8px;min-width:180px;padding:.5rem 0;box-shadow:0 8px 24px #0000001f}.col-picker-item{color:var(--text);cursor:pointer;align-items:center;gap:.5rem;padding:.5rem .875rem;font-size:.875rem;transition:background .12s;display:flex}.col-picker-item:hover{background:#faf5ff}.col-picker-item input[type=checkbox]{width:auto;accent-color:var(--primary)}.col-picker-order-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem .75rem;font-size:.83rem;display:flex}.col-picker-order-item:last-child{border-bottom:none}.col-picker-order-actions{gap:.25rem;display:flex}.btn-icon-xs{width:1.5rem;height:1.5rem;font-size:.78rem}.col-picker-th{text-align:center;vertical-align:middle;width:2.5rem;padding:.25rem!important}.col-picker-btn{background:0 0;border:none;width:1.75rem;height:1.75rem}.col-picker-btn:hover{background:#e2e8f0}.rights-row{align-items:flex-end;gap:1rem;display:flex}.action-col{white-space:nowrap;width:1px}.datetime-row{align-items:center;gap:.5rem;display:flex}.locks-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.ble-bt-off{justify-content:center;align-items:center;min-height:calc(100dvh - 200px);padding:1rem;display:flex}.ble-bt-off-card{background:var(--card-bg);border:1px solid var(--border);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:380px;padding:2rem 1.75rem;display:flex;box-shadow:0 1px 3px #0000000a}.ble-bt-off-icon{color:var(--primary);background:#be58e31a;border-radius:999px;justify-content:center;align-items:center;width:52px;height:52px;line-height:1;display:inline-flex}.ble-bt-off-title{color:var(--text);margin:0;font-size:1.15rem;font-weight:700}.ble-bt-off-desc{color:var(--text-muted);margin:0 0 .5rem;font-size:.9rem}.ble-search-state{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:.85rem;margin-bottom:.75rem;padding:.9rem 1rem;display:flex}.ble-search-state-error{background:#fff7f7;border-color:#fecaca}.ble-search-loader{align-items:center;gap:.3rem;margin-right:.15rem;display:inline-flex}.ble-search-loader span{background:var(--primary);opacity:.28;border-radius:999px;width:.42rem;height:.42rem;animation:1.2s ease-in-out infinite ble-dot-pulse}.ble-search-loader span:nth-child(2){animation-delay:.18s}.ble-search-loader span:nth-child(3){animation-delay:.36s}.ble-search-title{color:var(--text);flex:1;margin:0;font-size:.9rem;font-weight:600}.ble-search-hint{color:#991b1b;flex:1;margin:0;font-size:.82rem}@keyframes ble-dot-pulse{0%,80%,to{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}.lock-open-btn{justify-content:center;align-items:center;width:100%;min-height:4.25rem;padding:.85rem 1rem;font-size:1.08rem;overflow:hidden}.lock-open-btn-label{justify-content:center;align-items:center;gap:.5rem;width:100%;min-width:0;display:flex}.lock-open-btn-name{text-overflow:ellipsis;white-space:nowrap;font-size:1.04em;font-weight:600;overflow:hidden}.ble-signal{flex-shrink:0;align-items:center;gap:.3rem;display:inline-flex}.ble-signal-icon{color:#9ca3af;width:22px;height:15px}.ble-signal-good .ble-signal-icon{color:#15803d}.ble-signal-normal .ble-signal-icon{color:#f59e0b}.ble-signal-bad .ble-signal-icon{color:#b91c1c}.ble-signal-bar{rx:1;opacity:.2}.ble-signal-bar-filled{opacity:1}.lock-open-btn-denied{color:#6b7280;background:#e5e7eb;border:1px solid #d1d5db}.lock-open-btn-denied:hover:not(:disabled){color:#4b5563;background:#d1d5db}.ble-rssi{opacity:.75;font-variant-numeric:tabular-nums;font-size:.9em}.sessions-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.55rem;display:grid}.session-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.4rem;padding:.65rem;display:flex;box-shadow:0 1px 3px #0000000a}.session-card-head{justify-content:flex-end;display:flex}.session-badge{color:#475569;background:#f1f5f9;border:1px solid #dbe3ee;border-radius:999px;align-items:center;padding:.15rem .4rem;font-size:.7rem;font-weight:600;display:inline-flex}.session-badge-current{color:#166534;background:#dcfce7;border-color:#86efac}.session-card-row{flex-direction:column;gap:.12rem;display:flex}.session-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.session-card-value{color:var(--text);word-break:break-word;font-size:.82rem;line-height:1.3}.session-card-actions{justify-content:flex-end;margin-top:.1rem;display:flex}.open-logs-filter{flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:1rem;display:flex}.open-logs-filter-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.open-logs-filter-grid .form-group{margin-bottom:0}.open-logs-filter-actions{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.method-chip-row{flex-wrap:wrap;gap:.35rem;display:flex}.method-chip{border:1px solid var(--border);cursor:pointer;color:var(--text);touch-action:manipulation;background:#fff;border-radius:999px;padding:.3rem .7rem;font-size:.85rem}.method-chip-active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.ms-dropdown{position:relative}.ms-dropdown-trigger{cursor:pointer;text-align:left;background:#fff;justify-content:space-between;align-items:center;width:100%;display:flex}.ms-dropdown-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ms-dropdown-label-empty{color:var(--text-muted)}.ms-dropdown-caret{color:var(--text-muted);margin-left:.5rem;font-size:.75rem}.ms-dropdown-menu{border:1px solid var(--border);z-index:800;background:#fff;border-radius:8px;flex-direction:column;max-height:280px;display:flex;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 6px 20px #0000001f}.ms-dropdown-search{border-bottom:1px solid var(--border);padding:.5rem}.ms-dropdown-clear{color:var(--primary);text-align:left;cursor:pointer;border:none;border-bottom:1px solid var(--border);background:0 0;padding:.4rem .75rem;font-size:.82rem}.ms-dropdown-list{flex:1;overflow-y:auto}.ms-dropdown-item{cursor:pointer;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.9rem;display:flex}.ms-dropdown-item:hover{background:var(--bg)}.ms-dropdown-empty{color:var(--text-muted);text-align:center;padding:.75rem;font-size:.85rem}.open-logs-summary{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.open-logs-stat{border:1px solid var(--border);background:#fff;border-radius:10px;justify-content:space-between;align-items:baseline;padding:.75rem .9rem;display:flex}.open-logs-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem}.open-type-chip{background:#fff;border:1px solid #0000;border-radius:999px;align-items:center;gap:.25rem;padding:.2rem .55rem;font-size:.78rem;font-weight:600;line-height:1.2;display:inline-flex}.open-type-chip-success{color:#166534;background:#dcfce7;border-color:#16a34a}.open-type-chip-danger{color:#b91c1c;background:#fee2e2;border-color:#dc2626}.pass-cell{text-align:center}.pass-mark{font-size:1rem;font-weight:700;line-height:1}.pass-mark-yes{color:#15803d}.pass-mark-no{color:#b91c1c}.logs-draggable-th-sortable{cursor:pointer}.pagination-controls{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.75rem;padding:.6rem .25rem;font-size:.85rem;display:flex}.pagination-info{font-variant-numeric:tabular-nums}.pagination-buttons{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.pagination-page-size{color:var(--text-muted);align-items:center;gap:.35rem;margin:0;font-size:.85rem;display:inline-flex}.pagination-page-size-select{width:auto;padding:.25rem .4rem;font-size:.85rem}.logs-draggable-th{cursor:grab;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation;transition:background .12s,box-shadow .12s}.table-sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none}.device-name-cell{white-space:normal;min-width:160px}.logs-draggable-th:active{cursor:grabbing}.logs-draggable-th-over{box-shadow:inset 0 -2px 0 var(--primary);background:#f3e8ff!important}.logs-draggable-th-dragging{opacity:.65}.logs-th-content{align-items:center;gap:.35rem;display:inline-flex}.logs-th-sort-indicator{color:var(--primary);font-weight:700}.at-time:before{content:" "}.open-logs-col-picker{min-width:220px}.open-logs-col-picker-item{justify-content:space-between;align-items:center;gap:.5rem;padding:.2rem .3rem .2rem 0;display:flex}.open-logs-col-picker-move{gap:.25rem;padding-right:.15rem;display:flex}.splash-screen{z-index:9999;background:linear-gradient(135deg,#3d1152 0%,#be58e3 100%);flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;display:flex;position:fixed;inset:0}.splash-title{color:#fff;letter-spacing:.05em;font-size:2rem;font-weight:800}.splash-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:2rem;height:2rem;animation:.8s linear infinite splash-spin}@keyframes splash-spin{to{transform:rotate(360deg)}}.server-input-row{align-items:center;gap:.5rem;display:flex}.server-suffix-hint{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.85rem}.server-list{flex-direction:column;gap:.375rem;display:flex}.server-list-item{align-items:center;gap:.375rem;display:flex}.server-list-btn{border:1px solid var(--border);cursor:pointer;text-align:left;touch-action:manipulation;background:#f8fafc;border-radius:6px;flex:1;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.875rem;transition:background .12s,border-color .12s;display:flex}.server-list-btn:hover{border-color:var(--primary);background:#f3e8ff}.server-list-btn-active{border-color:var(--primary);background:#f3e8ff;font-weight:600}.server-list-prefix{color:var(--text);font-weight:600}.server-list-suffix{color:var(--text-muted);font-size:.8em}.server-list-check{color:var(--primary);margin-left:auto;font-weight:700}.server-indicator-btn{border:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;touch-action:manipulation;background:#f8fafc;border-radius:6px;align-items:center;gap:.4rem;margin-top:1.25rem;padding:.45rem .75rem;font-size:.8rem;transition:background .12s,border-color .12s;display:flex}.server-indicator-btn:hover{border-color:var(--primary);color:var(--text);background:#f3e8ff}.server-indicator-sidebar{align-items:center;gap:.4rem;display:flex;overflow:hidden}.server-indicator-sidebar-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.server-indicator-drawer{gap:.4rem;font-size:.8rem;overflow:hidden}.server-indicator-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 0 2px #4ade804d}.server-indicator-dot-dark{box-shadow:0 0 0 2px #4ade8033}@media (width<=768px){.sidebar{display:none}body,#root{background:var(--bg)}.main-wrapper{max-width:100vw;padding-bottom:env(safe-area-inset-bottom,0px);margin-left:0}.desktop-only{display:none!important}.mobile-only{display:inline-flex!important}.main-content{padding:calc(60px + env(safe-area-inset-top) + 1rem) 1rem 1rem;padding-bottom:max(1rem, env(safe-area-inset-bottom))}.header{z-index:250;padding-top:env(safe-area-inset-top);position:fixed;top:0;left:0;right:0}.header-inner{padding:0 1rem}.header-version{opacity:.65;font-size:.68rem}.ble-search-state{flex-direction:column;align-items:flex-start}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.table th{max-width:min(38vw,180px);padding:.48rem .58rem;font-size:.69rem}.table td{max-width:min(42vw,200px);padding:.4rem .58rem;font-size:.76rem}.form-input,select.form-input{font-size:16px}.form-row{flex-direction:column;gap:0}.modal{max-height:95vh;padding-bottom:max(1.5rem, env(safe-area-inset-bottom));border-radius:10px 10px 0 0;margin:0;position:fixed;bottom:0;left:0;right:0;max-width:100%!important}.modal-overlay{align-items:flex-end;padding:0}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.action-buttons-desktop{display:none}.action-buttons-mobile{display:block}.rights-row{flex-flow:row}.rights-row .form-group{min-width:0}.datetime-row{flex-direction:column;align-items:stretch}.datetime-row>span{display:none}.open-logs-filter{flex-direction:column;align-items:stretch}.mobile-drawer-quick-row{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.logs-draggable-th{cursor:default}.device-name-cell{min-width:120px}.at-cell{white-space:normal}.at-time{display:block}.at-time:before{content:none}.login-card{padding:2rem 1.5rem}.update-banner{width:calc(100vw - 1rem);left:.5rem;bottom:calc(1.5rem + env(safe-area-inset-bottom));transform:none}}@media (width<=768px) and (display-mode:standalone){.main-wrapper,.mobile-drawer{padding-bottom:max(env(safe-area-inset-bottom,0px), 34px)}}.modal--sm{max-width:400px}.modal--md{max-width:480px}.modal--lg{max-width:640px}.modal--xl{max-width:920px}.modal--w-360{max-width:360px}.modal--w-420{max-width:420px}.modal--w-440{max-width:440px}.modal--w-520{max-width:520px}.modal--w-700{max-width:700px}.checklist{border:1px solid #cbd5e1;border-radius:.375rem;max-height:180px;padding:.5rem;overflow-y:auto}.checklist--tall{max-height:240px}.checklist-item{cursor:pointer;align-items:center;gap:.5rem;padding:.25rem 0;display:flex}.checklist-empty{color:#94a3b8;margin:0}.text-muted{color:#64748b}.text-mute-soft{color:#475569}.text-danger-hint{color:var(--danger);margin-bottom:.5rem;font-size:.8rem}.list-block{margin-bottom:1rem;padding-left:1.5rem}.list-block--last{margin-bottom:1.5rem}.section-heading{margin-bottom:.25rem;font-weight:600}.modal-subsection{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:.5rem;margin-top:1rem;padding:1rem}.modal-subsection-head{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.modal-subsection-line{margin:.25rem 0;font-size:.875rem}.modal-subsection-line--muted{color:#64748b}.mini-time-preview{cursor:pointer;background:#e2e8f0;border-radius:4px;min-width:120px;height:10px;margin-top:4px;transition:height .15s;position:relative;overflow:visible}.mini-time-preview--expanded{height:24px}.mini-time-preview-bar{opacity:.7;background:#3b82f6;border-radius:2px;height:10px;transition:height .15s;position:absolute}.mini-time-preview--expanded .mini-time-preview-bar{height:24px}.mini-time-preview-label{color:#475569;white-space:nowrap;font-size:.6rem;position:absolute;top:100%}.mini-time-preview-label--start{left:0;transform:translate(-25%)}.mini-time-preview-label--end{right:0;transform:translate(25%)}.week-day-row{flex-wrap:nowrap;align-items:flex-start;gap:.5rem;margin-bottom:.75rem;display:flex}.week-day-row-label{flex-shrink:0;width:36px;padding-top:.5rem;font-size:.875rem;font-weight:600}.week-day-row-field{flex:1;min-width:0;margin-bottom:0}.device-card-header{border-bottom:1px solid var(--border);background:#f8fafc;padding:.85rem 1rem}.device-card-header-row{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.device-card-meta{color:#64748b;font-size:.85rem}.device-card-empty{color:#64748b;padding:.85rem 1rem}.device-list{gap:1rem;display:grid}.table-container--clip{overflow:hidden}.button-stack{gap:.5rem;display:grid}.modal-table-scroll{max-height:60vh}.btn-block{justify-content:center;width:100%}.btn-block--start{justify-content:flex-start;width:100%}.datetime-cell{flex:1;align-items:center;gap:.375rem;min-width:0;display:flex}.datetime-cell .form-input{flex:1;min-width:0}.datetime-row-sep{color:#64748b;flex-shrink:0}.datetime-input--invalid{border-color:var(--danger);box-shadow:0 0 0 1px var(--danger)}.action-col-label-spacer{margin-right:.35rem}.server-add-divider{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.server-error-text{margin-top:.3rem;font-size:.8rem}.touch-manip{touch-action:manipulation}.btn-link{color:var(--primary);background:0 0;border:none;padding:.25rem .5rem;font-weight:500}.btn-link:hover:not(:disabled){text-decoration:underline}.update-banner{left:50%;bottom:calc(2rem + env(safe-area-inset-bottom));background:var(--card-bg);color:var(--text);border:1px solid var(--border);z-index:100;border-radius:999px;align-items:center;gap:.7rem;max-width:calc(100vw - 2rem);padding:.5rem .5rem .5rem .95rem;animation:.24s ease-out update-banner-in;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 12px 28px #3d11522e,0 2px 6px #3d115214}@keyframes update-banner-in{0%{opacity:0}to{opacity:1}}.update-banner__dot{background:#16a34a;border-radius:999px;flex-shrink:0;width:.5rem;height:.5rem;box-shadow:0 0 0 4px #22c55e2e}.update-banner__text{align-items:baseline;gap:.45rem;min-width:0;display:inline-flex}.update-banner__msg{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;line-height:1.2;overflow:hidden}.update-banner__version{color:var(--text-muted);font-variant-numeric:tabular-nums;background:#7d5aa014;border-radius:999px;flex-shrink:0;padding:.1rem .45rem;font-size:.72rem;font-weight:500;line-height:1.3}.update-banner__actions{flex-shrink:0;align-items:center;gap:.3rem;display:inline-flex}.update-banner__reload{border-radius:999px;padding-left:.85rem;padding-right:.85rem}.update-banner__close{width:1.85rem;height:1.85rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;font-size:1.1rem;line-height:1;transition:background .12s,color .12s;display:inline-flex}.update-banner__close:hover{color:var(--text);background:#7d5aa01a}.perms-tree{border:1px solid var(--border);background:#fff;border-radius:8px;max-height:60vh;padding:.25rem 0;overflow-y:auto}.perms-tree-row{padding:.2rem .5rem}.perms-tree-label{flex-wrap:wrap;align-items:center;gap:.55rem;font-size:.9rem;display:flex}.perms-tree-title{color:var(--text)}.perms-tree-title--muted{color:var(--text-muted)}.perms-tree-code{color:var(--text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.75rem}.perm-toggle{appearance:none;cursor:pointer;color:#fff;background:#fff;border:1.5px solid #c9b6d8;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;gap:1px;width:22px;height:22px;padding:0;transition:background .12s,border-color .12s;display:inline-flex}.perm-toggle:hover:not(:disabled){border-color:var(--primary)}.perm-toggle:disabled{cursor:not-allowed}.perm-toggle-none{background:#fff}.perm-toggle-direct{background:var(--primary);border-color:var(--primary)}.perm-toggle-inherited{border-color:var(--primary);color:var(--primary);background:#fff}.perm-toggle-both{background:var(--primary);border-color:var(--primary);color:#fff}.perm-toggle-ancestor{color:#7c5b8e;background:#e9d5f5;border-color:#c9b6d8}.perm-toggle-dual{gap:2px;width:32px}.perm-toggle-dual .perm-toggle-check,.perm-toggle-dual .perm-toggle-groups{width:11px;height:11px}.perm-toggle-legend{cursor:default}.perm-toggle-legend:hover{border-color:#c9b6d8}.perm-toggle-legend.perm-toggle-inherited:hover,.perm-toggle-legend.perm-toggle-direct:hover{border-color:var(--primary)}.perms-tree-legend{border:1px solid var(--border);background:#faf5ff;border-radius:8px;margin-bottom:.5rem;padding:.5rem .65rem;font-size:.78rem}.perms-tree-legend-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.7rem;font-weight:600}.perms-tree-legend-items{flex-wrap:wrap;gap:.75rem 1rem;display:flex}.perms-legend-item{color:var(--text);align-items:center;gap:.4rem;display:inline-flex}.person-picker-list{border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;gap:.25rem;max-height:320px;margin-bottom:.5rem;padding:.35rem;display:flex;overflow-y:auto}.person-picker-item{text-align:left;cursor:pointer;touch-action:manipulation;background:0 0;border:1px solid #0000;border-radius:6px;flex-direction:column;align-items:flex-start;gap:.1rem;padding:.5rem .65rem;transition:background .12s,border-color .12s;display:flex}.person-picker-item:hover{border-color:var(--border);background:#faf5ff}.person-picker-item-name{color:var(--text);font-size:.9rem;font-weight:500}.person-picker-item-meta{color:var(--text-muted);font-size:.78rem}.selected-person-chip{border:1px solid var(--border);background:#faf5ff;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem;display:flex}.selected-person-chip-info{flex:1;min-width:0}.selected-person-chip-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:600;display:block}.selected-person-chip-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:500;display:block;overflow:hidden}.perms-tree-category{color:var(--text);padding:.35rem 0 .2rem;font-size:.92rem;font-weight:600}.perms-groups-list{border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;gap:.35rem;max-height:30vh;padding:.5rem;display:flex;overflow-y:auto}.perms-groups-row{align-items:center;gap:.5rem;font-size:.9rem;display:flex}.help-button{width:30px;height:30px;color:var(--text-muted);cursor:pointer;opacity:.7;touch-action:manipulation;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s,opacity .15s;display:inline-flex}.help-button:hover{background:var(--bg);color:var(--primary);opacity:1}.help-drawer-overlay{z-index:1300;background:#00000059;justify-content:flex-end;display:flex;position:fixed;inset:0}.help-drawer{width:420px;max-width:92vw;height:100dvh;padding-top:env(safe-area-inset-top);background:#fff;flex-direction:column;animation:.18s ease-out help-slide-in;display:flex;box-shadow:-8px 0 30px #0000002e}@keyframes help-slide-in{0%{opacity:.3;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.help-drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.help-drawer-title{color:var(--text);font-size:1.05rem;font-weight:700}.help-drawer-body{flex:1;padding:1.25rem;overflow-y:auto}.help-drawer-footer{border-top:1px solid var(--border);padding:.75rem 1.25rem max(.75rem, env(safe-area-inset-bottom))}.help-empty{color:var(--text-muted)}.markdown-body{color:var(--text);line-height:1.6}.markdown-body>:first-child{margin-top:0}.markdown-body h1{color:var(--text);margin:0 0 .75rem;font-size:1.5rem;font-weight:700}.markdown-body h2{border-bottom:1px solid var(--border);margin:1.6rem 0 .6rem;padding-bottom:.3rem;scroll-margin-top:80px;font-size:1.2rem;font-weight:700}.markdown-body h3{margin:1.1rem 0 .4rem;scroll-margin-top:80px;font-size:1.02rem;font-weight:600}.markdown-body p{margin:.55rem 0}.markdown-body ul,.markdown-body ol{margin:.55rem 0 .55rem 1.3rem}.markdown-body li{margin:.25rem 0}.markdown-body a{color:var(--primary);text-decoration:none}.markdown-body a:hover{text-decoration:underline}.markdown-body code{background:var(--bg);border-radius:4px;padding:.1rem .35rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.85em}.markdown-body pre{background:var(--bg);border-radius:8px;padding:.75rem 1rem;overflow-x:auto}.markdown-body pre code{background:0 0;padding:0}.markdown-body blockquote{border-left:3px solid var(--primary);background:var(--bg);color:var(--text-muted);border-radius:0 6px 6px 0;margin:.75rem 0;padding:.5rem 1rem}.markdown-body table{border-collapse:collapse;width:100%;margin:.75rem 0;font-size:.9rem}.markdown-body th,.markdown-body td{border:1px solid var(--border);text-align:left;padding:.4rem .6rem}.markdown-body th{background:var(--bg)}.markdown-body img{border-radius:8px;max-width:100%}.markdown-body hr{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.doc-demo{background:var(--bg);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.6rem;margin:.85rem 0;padding:.85rem;display:flex}.doc-demo-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.doc-demo-caption{color:var(--text-muted);font-size:.8rem}.doc-demo-openbtn{background:var(--primary);color:#fff;cursor:default;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;min-width:210px;min-height:3.1rem;padding:.6rem 1rem;font-size:1rem;font-weight:600;display:inline-flex}.doc-demo-openbtn--denied{color:#6b7280;background:#e5e7eb;border:1px solid #d1d5db}.doc-demo-signal{align-items:flex-end;gap:2px;height:13px;display:inline-flex}.doc-demo-signal i{opacity:.25;background:currentColor;border-radius:1px;width:4px}.doc-demo-signal i:first-child{height:5px}.doc-demo-signal i:nth-child(2){height:9px}.doc-demo-signal i:nth-child(3){height:13px}.doc-demo-signal--good{color:#15803d}.doc-demo-signal--good i:nth-child(-n+3){opacity:1}.doc-demo-signal--normal{color:#f59e0b}.doc-demo-signal--normal i:nth-child(-n+2){opacity:1}.doc-demo-signal--bad{color:#b91c1c}.doc-demo-signal--bad i:nth-child(-n+1){opacity:1}.doc-demo-iconbtn{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);letter-spacing:1px;background:#fff;border-radius:6px;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.doc-demo-btn{background:var(--primary);color:#fff;cursor:default;border:none;border-radius:6px;align-items:center;gap:.3rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;display:inline-flex}.docs-page{background:var(--bg);flex-direction:column;min-height:100dvh;display:flex}.docs-topbar{z-index:10;background:var(--header-bg);border-bottom:1px solid var(--border);padding:.6rem 1.25rem;padding-top:max(.6rem, env(safe-area-inset-top));align-items:center;gap:.75rem;display:flex;position:sticky;top:0}.docs-brand{background:var(--sidebar-bg);color:#fff;letter-spacing:.04em;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.4rem .7rem;font-size:1.05rem;font-weight:700;display:inline-flex}.docs-topbar-spacer{flex:1}.docs-search{border:1px solid var(--border);width:min(320px,40vw);color:var(--text);background:#fff;border-radius:8px;padding:.45rem .7rem;font-size:.875rem}.docs-search:focus{border-color:var(--primary);outline:none}.docs-lang{gap:.25rem;display:inline-flex}.docs-lang-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:#fff;border-radius:6px;padding:.3rem .5rem;font-size:.75rem;font-weight:600}.docs-lang-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.docs-body{flex:1;gap:2rem;width:100%;max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem 3rem;display:flex}.docs-nav{flex-direction:column;flex:0 0 240px;align-self:flex-start;gap:.15rem;max-height:calc(100dvh - 100px);display:flex;position:sticky;top:80px;overflow-y:auto}.docs-nav-link{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.5rem .75rem;font-size:.9rem}.docs-nav-link:hover{background:#fff}.docs-nav-link.active{background:var(--primary);color:#fff;font-weight:600}.docs-article{border:1px solid var(--border);background:#fff;border-radius:12px;flex:1;min-width:0;padding:1.75rem 2rem;box-shadow:0 1px 3px #0000000a}.docs-results{flex-direction:column;gap:.25rem;display:flex}.docs-results-head{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.25rem .5rem;font-size:.7rem}.docs-results-empty{color:var(--text-muted);padding:.5rem;font-size:.85rem}.docs-result{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-direction:column;gap:.15rem;padding:.5rem .6rem;display:flex}.docs-result:hover{background:#fff}.docs-result-title{color:var(--text);font-size:.88rem;font-weight:600}.docs-result-snippet{color:var(--text-muted);font-size:.76rem;line-height:1.35}.docs-print-section+.docs-print-section{page-break-before:always;margin-top:2rem}@media (width<=768px){.docs-topbar{flex-wrap:wrap}.docs-search{order:3;width:100%}.docs-body{flex-direction:column;gap:1rem;padding:1rem}.docs-nav{flex-flow:wrap;flex:none;gap:.4rem;max-height:none;padding-bottom:.25rem;position:static}.docs-nav-link{white-space:nowrap}.docs-article{padding:1.25rem}.help-drawer{width:100vw;max-width:100vw}}@page{margin:0}@media print{html,body,#root{background:#fff}.docs-no-print{display:none!important}.docs-page{background:#fff}.docs-body{max-width:none;margin:0;padding:0;display:block}.docs-article{box-shadow:none;border:none;border-radius:0;padding:0 16mm}.docs-print-section{padding:16mm 0}.docs-print-section+.docs-print-section{page-break-before:always;margin-top:0}}.time-range-container{background:linear-gradient(to bottom right,#f8fafc,#f1f5f9);min-height:100vh;padding:1rem}@media (width>=768px){.time-range-container{padding:2rem}}.time-range-card{background:#fff;border-radius:.75rem;max-width:56rem;margin:0 auto;padding:1.25rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}@media (width>=768px){.time-range-card{padding:2rem}}.time-range-title{color:#1e293b;margin-bottom:1rem;font-size:1.5rem;font-weight:700}@media (width>=768px){.time-range-title{margin-bottom:1.5rem;font-size:1.875rem}}.time-range-header{z-index:20;flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex;position:relative}@media (width>=768px){.time-range-header{flex-direction:row;justify-content:space-between;align-items:center}}.time-range-instructions{color:#475569;font-size:.875rem}.clear-button{color:#dc2626;cursor:pointer;touch-action:manipulation;z-index:20;background:0 0;border:none;align-self:flex-start;padding:.25rem .5rem;font-size:.875rem;font-weight:500;transition:color .2s;position:relative}@media (width>=768px){.clear-button{align-self:auto}}.clear-button:hover{color:#b91c1c}.clear-button:active{color:#991b1b}.time-labels{color:#64748b;justify-content:space-between;margin-bottom:.5rem;font-size:.75rem;display:flex}.time-labels-overlay{pointer-events:none;z-index:1;justify-content:space-between;align-items:center;padding:0 .25rem;display:flex;position:absolute;inset:0}.time-labels-overlay span{color:#64748bcc;-webkit-user-select:none;user-select:none;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.65rem}.timeline-wrapper{touch-action:none;-webkit-user-select:none;user-select:none;padding:1.5rem 0;position:relative}.timeline-bar{cursor:crosshair;touch-action:none;background-color:#e2e8f0;border:2px solid #cbd5e1;border-radius:.5rem;height:3rem;transition:border-color .2s;position:relative}@media (width>=768px){.timeline-bar{height:3rem}}.timeline-bar:hover{border-color:#60a5fa}.timeline-bar:active{border-color:#3b82f6}.time-interval{opacity:.7;touch-action:none;background-color:#3b82f6;border-radius:.25rem;height:100%;transition:opacity .2s;position:absolute;top:0}.time-interval:hover{opacity:.9}.time-interval.current-selecting{opacity:.5;background-color:#4ade80}.time-interval.has-overlap{opacity:.5;background-color:#f87171}.delete-button{opacity:0;cursor:pointer;z-index:20;background:#fff;border:none;border-radius:9999px;justify-content:center;align-items:center;width:2rem;height:2rem;transition:opacity .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}@media (width<=767px){.delete-button{opacity:.8;width:2.5rem;height:2.5rem}}.time-interval:hover .delete-button{opacity:1}.delete-button:hover{background-color:#fef2f2}.delete-button:active{background-color:#fee2e2}.delete-button-icon{color:#dc2626;font-size:1rem}.resize-handle{cursor:ew-resize;z-index:25;touch-action:none;width:10px;height:100%;position:absolute;top:0}.resize-handle-left{border-radius:.25rem 0 0 .25rem;left:0}.resize-handle-right{border-radius:0 .25rem .25rem 0;right:0}.resize-handle:hover{background:#ffffff4d}@media (width<=767px){.resize-handle{width:16px}}.time-marker{white-space:nowrap;z-index:10;touch-action:none;background:#fff;border:1px solid #e2e8f0;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;transition:transform .2s ease-out;position:absolute;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}@media (width>=768px){.time-marker{padding:.125rem .5rem}}.marker-connector{z-index:5;pointer-events:none;border-left:2px dashed #94a3b8;width:0;position:absolute}.time-marker.marker-start{bottom:-1.5rem}.time-marker.marker-end{top:-1.5rem;transform:translate(-100%)}.time-marker.current-marker{border-color:#cbd5e1}.time-input{text-align:center;background:#fff;border:1px solid #60a5fa;border-radius:.25rem;outline:none;width:3rem;padding:.125rem .25rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem}@media (width<=767px){.time-input{width:3.5rem;padding:.25rem;font-size:.875rem}}.time-input:focus{ring:1px;ring-color:#3b82f6}.time-button{cursor:pointer;background:0 0;border:none;border-radius:.25rem;padding:.125rem .25rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem;transition:background-color .2s}@media (width<=767px){.time-button{padding:.25rem .5rem;font-size:.875rem}}.time-button:hover{background-color:#ffffff80}.time-button:active{background-color:#fffc}.intervals-list{margin-top:1.5rem}.intervals-title{color:#334155;margin-bottom:.75rem;font-size:1.125rem;font-weight:600}.interval-item{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.875rem;display:flex}@media (width>=768px){.interval-item{padding:1rem}}.interval-info{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}@media (width>=768px){.interval-info{gap:1rem}}.interval-dot{background-color:#3b82f6;border-radius:9999px;flex-shrink:0;width:.75rem;height:.75rem}.interval-time{color:#1e293b;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875rem;font-weight:600}@media (width>=768px){.interval-time{font-size:1rem}}.interval-duration{color:#64748b;font-size:.875rem}.interval-delete{color:#dc2626;cursor:pointer;background:0 0;border:none;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.25rem;transition:all .2s;display:flex}@media (width<=767px){.interval-delete{width:2.5rem;height:2.5rem;font-size:1.5rem}}.interval-delete:hover{color:#b91c1c;background-color:#fee2e2}.interval-delete:active{color:#991b1b;background-color:#fecaca}.empty-state{text-align:center;color:#cbd5e1;padding:2rem 0}.empty-state p:first-child{margin-bottom:.25rem}.empty-state p:last-child{font-size:.875rem}
