:root{--bg: #F8F7F4;--card-bg: #FFFFFF;--sidebar-bg: #F0EFEA;--border: #E2DFD8;--border-focus: #C4BFB5;--text-primary: #1A1918;--text-secondary: #5F5E5B;--text-tertiary: #8A8884;--terracotta: #C85A32;--terracotta-hover: #B34D28;--terracotta-light: #F5E8E2;--sage: #5F7A61;--sage-light: #E8F0E8;--blue: #4A6C8C;--blue-light: #E3EBF3;--danger: #AB3B3A;--danger-light: #F5E5E5;--warning: #8A6A20;--warning-light: #F5EDD8;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 4px rgba(26,25,24,.06);--shadow-card: 0 4px 20px rgba(26,25,24,.05);--shadow-hover: 0 8px 30px rgba(26,25,24,.09);--t-fast: .15s ease;--t-mid: .25s cubic-bezier(.2,.8,.2,1);--sidebar-w: 220px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text-primary);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit}.serif{font-family:Newsreader,Georgia,serif;font-weight:500;letter-spacing:-.02em}.mono{font-family:SF Mono,Menlo,Consolas,monospace;font-size:.85em}.text-muted{color:var(--text-secondary)}.text-sm{font-size:.8rem}.text-xs{font-size:.72rem}.text-danger{color:var(--danger)}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;overflow-y:auto}.sidebar-brand{padding:1.5rem 1.25rem 1rem;font-size:1.3rem;border-bottom:1px solid var(--border)}.sidebar-nav{flex:1;padding:.75rem .5rem;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:background var(--t-fast),color var(--t-fast)}.nav-item:hover{background:var(--border);color:var(--text-primary)}.nav-item.active{background:var(--card-bg);color:var(--text-primary);box-shadow:var(--shadow-sm)}.nav-icon{display:flex;align-items:center;opacity:.7;flex-shrink:0}.nav-item.active .nav-icon{opacity:1}.sub-nav{padding:.25rem 0 .25rem 2.25rem;display:flex;flex-direction:column;gap:1px}.sub-nav-item{padding:.35rem .6rem;border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary);transition:background var(--t-fast),color var(--t-fast)}.sub-nav-item:hover{background:var(--border);color:var(--text-primary)}.sub-nav-item.active{color:var(--text-primary);font-weight:500}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border)}.user-row{display:flex;align-items:center;gap:.75rem}.avatar{width:32px;height:32px;border-radius:50%;background:var(--terracotta);color:#fff;font-size:.85rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-name{font-size:.85rem;font-weight:500}.logout-btn{font-size:.75rem;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:0;transition:color var(--t-fast)}.logout-btn:hover{color:var(--danger)}.main-content{margin-left:var(--sidebar-w);flex:1;padding:2rem 2.5rem;max-width:1100px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.75rem;gap:1rem}.page-title{font-size:1.6rem}.page-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:.2rem}.header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem 1.5rem;box-shadow:var(--shadow-card)}.card.no-padding{padding:0}.stat-label{font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:2rem;font-weight:600;line-height:1.2;margin:.4rem 0 .3rem}.stat-sub{font-size:.8rem;color:var(--text-tertiary)}.section-block{margin-bottom:2rem}.block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-title{font-size:1rem;font-weight:600}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;transition:background var(--t-fast),box-shadow var(--t-fast),opacity var(--t-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--terracotta);color:#fff}.btn-primary:hover:not(:disabled){background:var(--terracotta-hover)}.btn-secondary{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:var(--border)}.btn-sm{padding:.3rem .65rem;font-size:.8rem}.btn-block{width:100%;justify-content:center}.text-link{font-size:.85rem;color:var(--terracotta)}.text-link:hover{text-decoration:underline}.input-group{display:flex;flex-direction:column;gap:.35rem}.input-group label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.input,select,textarea{width:100%;padding:.55rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--card-bg);color:var(--text-primary);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #c85a3214}.input.error{border-color:var(--danger)}textarea{resize:vertical;min-height:100px}.form-row{display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-stack{display:flex;flex-direction:column;gap:1rem}.form-error{font-size:.8rem;color:var(--danger);margin-top:.25rem}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);padding:.65rem 1rem;border-bottom:1px solid var(--border)}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:.875rem}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg)}.row-actions{display:flex;gap:.5rem;opacity:0;transition:opacity var(--t-fast)}.data-table tbody tr:hover .row-actions{opacity:1}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:99px;font-size:.72rem;font-weight:600;white-space:nowrap}.badge-allow{background:var(--sage-light);color:var(--sage)}.badge-block{background:var(--danger-light);color:var(--danger)}.badge-active{background:var(--sage-light);color:var(--sage)}.badge-disabled{background:var(--border);color:var(--text-secondary)}.badge-pending{background:var(--blue-light);color:var(--blue)}.badge-mutable{background:var(--border);color:var(--text-secondary)}.badge-cooldown{background:var(--blue-light);color:var(--blue)}.badge-partner{background:var(--warning-light);color:var(--warning)}.badge-locked{background:var(--danger-light);color:var(--danger)}.badge-system{background:var(--terracotta-light);color:var(--terracotta)}.dot{width:6px;height:6px;border-radius:50%;background:currentColor}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191859;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fadeIn .15s ease}.modal-box{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:0 20px 60px #1a191826;width:100%;max-width:480px;animation:slideUp .2s cubic-bezier(.2,.8,.2,1)}.modal-box.modal-sm{max-width:380px}.modal-box.modal-lg{max-width:620px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1rem;font-weight:600}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-close{color:var(--text-tertiary);padding:.25rem;border-radius:var(--radius-sm);transition:color var(--t-fast),background var(--t-fast)}.modal-close:hover{color:var(--text-primary);background:var(--border)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text-secondary);text-align:center;gap:.6rem}.empty-icon{font-size:2.2rem;opacity:.4}.empty-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.empty-sub{font-size:.85rem;max-width:300px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--terracotta);border-radius:50%;animation:spin .7s linear infinite}.spinner-lg{width:36px;height:36px;border-width:3px}.loading-wrap{display:flex;align-items:center;justify-content:center;padding:3rem}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.tab-btn{padding:.55rem .9rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--t-fast),border-color var(--t-fast)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--text-primary);border-bottom-color:var(--terracotta)}.system-status{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;color:var(--sage)}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1rem}.auth-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:400px;box-shadow:var(--shadow-card)}.auth-brand{text-align:center;margin-bottom:2rem}.auth-brand-title{font-size:1.75rem}.auth-brand-sub{color:var(--text-secondary);font-size:.88rem;margin-top:.25rem}.auth-footer{text-align:center;margin-top:1.25rem;font-size:.85rem;color:var(--text-secondary)}.auth-footer a{color:var(--terracotta)}.auth-footer a:hover{text-decoration:underline}.toast-stack{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:200}.toast{padding:.65rem 1.1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;box-shadow:0 4px 16px #1a19181f;animation:slideUp .2s ease;max-width:360px}.toast-info{background:var(--text-primary);color:#fff}.toast-success{background:var(--sage);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-warning{background:var(--warning);color:#fff}.inline-edit{display:flex;align-items:center;gap:.4rem}.inline-edit .input{padding:.3rem .6rem;font-size:.875rem}.notice{padding:.85rem 1.1rem;border-radius:var(--radius-md);font-size:.85rem;display:flex;gap:.75rem;align-items:flex-start}.notice-info{background:var(--blue-light);color:var(--blue);border:1px solid #C8D9E8}.notice-warning{background:var(--warning-light);color:var(--warning);border:1px solid #E0D0A8}.pane-header{padding-bottom:1.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.pane-title{font-family:Newsreader,Georgia,serif;font-size:1.5rem;font-weight:500;letter-spacing:-.02em}.policy-tabs{display:flex;gap:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.policy-tab{background:transparent;border:none;font-family:inherit;font-size:.9rem;color:var(--text-secondary);padding:.5rem 0;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--t-fast),border-color var(--t-fast)}.policy-tab:hover{color:var(--text-primary)}.policy-tab.active{color:var(--text-primary);font-weight:500;border-bottom-color:var(--text-primary)}.rules-stack{display:flex;flex-direction:column;gap:.6rem}.rule-row{display:flex;align-items:center;gap:1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem;box-shadow:var(--shadow-sm);transition:box-shadow var(--t-fast),transform var(--t-fast)}.rule-row:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}.rule-row.is-locked{opacity:.85}.rule-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.locked-icon{background:var(--sidebar-bg);border:1px solid var(--border);color:var(--text-primary)}.cooldown-icon{background:var(--blue-light);color:var(--blue)}.block-icon{background:var(--terracotta-light);color:var(--terracotta)}.allow-icon{background:var(--sage-light);color:var(--sage)}.schedule-icon{background:var(--blue-light);color:var(--blue)}.rule-content{flex:1;min-width:0}.rule-target{font-size:.9rem;font-weight:500;margin:0 0 .15rem}.rule-desc{font-size:.78rem;color:var(--text-secondary);margin:0}.rule-actions{display:flex;align-items:center;gap:.4rem}.policy-empty{padding:2rem;text-align:center;font-size:.875rem;color:var(--text-secondary);background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius-md)}.blocklist-picker{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);max-height:220px;overflow-y:auto;padding:.25rem}.blocklist-row{display:flex;justify-content:space-between;align-items:center;padding:.55rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:background var(--t-fast)}.blocklist-row:hover{background:#00000008}.blocklist-row.selected{background:var(--text-primary);color:#fff;font-weight:500}.blocklist-row.selected .text-muted{color:#ffffffa6}.device-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.device-card{display:flex;flex-direction:column;gap:0}.device-card-suspended{opacity:.7;background:var(--bg)}.device-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.device-identity{flex:1;min-width:0}.device-name{font-size:1rem;font-weight:500;margin:0}.device-uuid{font-size:.72rem;margin-top:.2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border);margin-top:auto}.status-dot{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:500;white-space:nowrap;flex-shrink:0}.status-dot-active{color:var(--sage)}.status-dot-suspended{color:var(--text-tertiary)}.status-dot-active .dot{background:var(--sage)}.status-dot-suspended .dot{background:var(--text-tertiary)}.os-selection-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:520px;margin:0 auto}.os-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.25rem;border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;background:var(--card-bg);transition:border-color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast)}.os-card:hover{border-color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-hover)}.os-icon{color:var(--text-primary);margin-bottom:.75rem}.os-guide-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.code-block{font-family:SF Mono,Menlo,Consolas,monospace;font-size:.82rem;background:var(--sidebar-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.85rem 1rem;word-break:break-all}.page-animate{animation:viewEnter .3s cubic-bezier(.2,.8,.2,1)}@keyframes viewEnter{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}
