:root,:root[data-theme=dark]{--bg: #070a12;--surface: rgba(22, 30, 44, .55);--surface-strong: rgba(18, 24, 36, .78);--surface-2: rgba(255, 255, 255, .05);--surface-input: rgba(10, 14, 22, .55);--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .18);--text: #eef1f6;--text-dim: #9ba8bd;--accent: #4a7fb5;--accent-hover: #6a9fd5;--success: #34d399;--danger: #f87171;--warning: #fbbf24;--shadow: 0 8px 32px rgba(0, 0, 0, .45);--shadow-soft: 0 4px 16px rgba(0, 0, 0, .25);--glass-blur: blur(22px) saturate(160%);--th-bg: #111827;--glow-1: hsla(213, 50%, 30%, .32);--glow-2: hsla(213, 40%, 25%, .24);--glow-3: hsla(200, 45%, 30%, .2);color-scheme:dark}:root[data-theme=light]{--bg: #e8eef7;--surface: rgba(255, 255, 255, .55);--surface-strong: rgba(255, 255, 255, .78);--surface-2: rgba(255, 255, 255, .7);--surface-input: rgba(255, 255, 255, .85);--border: rgba(255, 255, 255, .5);--border-strong: rgba(31, 38, 135, .18);--text: #1a2233;--text-dim: #4d5867;--accent: #1a3a5c;--accent-hover: #244b73;--success: #15803d;--danger: #dc2626;--warning: #b45309;--shadow: 0 8px 32px rgba(31, 38, 135, .2);--shadow-soft: 0 4px 16px rgba(31, 38, 135, .1);--glass-blur: blur(22px) saturate(180%);--th-bg: #dde3ed;--glow-1: hsla(213, 50%, 75%, .35);--glow-2: hsla(213, 40%, 80%, .25);--glow-3: hsla(200, 45%, 75%, .2);color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text);font-size:14px;overflow:hidden}body{background:var(--bg);position:relative}body:before{content:"";position:fixed;top:-10vmax;right:-10vmax;bottom:-10vmax;left:-10vmax;z-index:-1;pointer-events:none;background:radial-gradient(circle at 18% 22%,var(--glow-1) 0,transparent 42%),radial-gradient(circle at 82% 18%,var(--glow-2) 0,transparent 45%),radial-gradient(circle at 50% 95%,var(--glow-3) 0,transparent 50%),radial-gradient(circle at 92% 75%,var(--glow-1) 0,transparent 38%);filter:blur(60px);animation:float-bg 24s ease-in-out infinite alternate}@keyframes float-bg{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(2vmax,-2vmax,0) scale(1.05)}}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;font-size:13px;padding:8px 14px;border:1px solid var(--border);background:var(--surface-2);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text);border-radius:8px;cursor:pointer;transition:all .2s ease}button:hover{background:var(--border-strong);border-color:var(--border-strong);transform:translateY(-1px)}button.primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-color:transparent;color:#fff;box-shadow:0 4px 12px #0d6efd40}button.primary:hover{filter:brightness(1.08);box-shadow:0 6px 16px #0d6efd59}button.danger{background:transparent;border-color:var(--danger);color:var(--danger)}button.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}input,select,textarea{font-family:inherit;font-size:13px;padding:8px 10px;background:var(--surface-input);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);color:var(--text);border-radius:8px;width:100%;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6db4ff26}.layout{display:grid;grid-template-columns:220px 1fr;height:100vh;overflow:hidden;transition:grid-template-columns .25s ease}.layout.sidebar-collapsed{grid-template-columns:60px 1fr}.sidebar{background:var(--surface-strong);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-right:1px solid var(--border);padding:20px 0;box-shadow:var(--shadow-soft);overflow-x:hidden;overflow-y:auto;transition:width .25s ease;display:flex;flex-direction:column;height:100vh;position:sticky;top:0}.sidebar-collapsed .sidebar-title,.sidebar-collapsed .sidebar-project,.sidebar-collapsed .nav-text,.sidebar-collapsed .nav-section-text,.sidebar-collapsed .nav-badge,.sidebar-collapsed .user strong,.sidebar-collapsed .user .nav-text{display:none}.sidebar-collapsed .nav-section{justify-content:center;padding:4px 0;min-height:0;border:none;margin-bottom:2px}.sidebar-collapsed .nav-section:before{display:none}.sidebar-collapsed .sidebar .nav-link{justify-content:center;padding:10px 4px}.sidebar-collapsed .sidebar .nav-link .nav-icon{width:auto;font-size:18px;opacity:.85}.sidebar-collapsed .sidebar-header{justify-content:center;padding:0 6px 12px;gap:4px;flex-wrap:wrap}.sidebar-collapsed .sidebar-header h1{display:none}.sidebar-collapsed .sidebar-logo{width:28px;height:28px}.sidebar-collapsed .theme-toggle{width:28px;height:28px;font-size:13px}.sidebar-collapsed .user{padding:10px 6px;text-align:center}.sidebar-collapsed .user .badge{font-size:9px;padding:2px 4px}.sidebar-collapsed .user button{padding:4px;font-size:10px}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:200;width:40px;height:40px;padding:0;font-size:20px;border-radius:10px;background:var(--surface-strong);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);color:var(--text);align-items:center;justify-content:center}.sidebar-overlay{display:none}.sidebar-collapse-btn{display:flex}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.sidebar{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 20px 20px;border-bottom:1px solid var(--border)}.sidebar-logo{width:32px;height:32px;object-fit:contain;flex-shrink:0}.sidebar-header h1{font-size:14px;font-weight:600;margin:0;flex:1}.theme-toggle{width:34px;height:34px;padding:0;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface-2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.theme-toggle:hover{transform:rotate(15deg)}.sidebar-project{padding:14px 20px;border-bottom:1px solid var(--border)}.sidebar-project label{display:block;font-size:10px;text-transform:uppercase;color:var(--text-dim);letter-spacing:.05em;margin-bottom:4px}.sidebar-project select{padding:6px 8px;font-size:12px}.subproject-toggle{margin-top:8px;width:100%;display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);font-size:11px;font-weight:500;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease;text-align:left}.subproject-toggle:hover{border-color:var(--accent);color:var(--text)}.subproject-toggle.on{border-color:var(--accent);background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 22%,transparent),color-mix(in srgb,var(--accent) 8%,transparent));color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent) inset}.subproject-toggle-switch{position:relative;width:26px;height:14px;border-radius:999px;background:var(--border);flex-shrink:0;transition:background .18s ease}.subproject-toggle.on .subproject-toggle-switch{background:var(--accent)}.subproject-toggle-knob{position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #0000004d;transition:transform .18s ease}.subproject-toggle.on .subproject-toggle-knob{transform:translate(12px)}.subproject-toggle-label{display:inline-flex;align-items:center;gap:6px;line-height:1.2}.subproject-toggle-icon{font-size:13px;opacity:.9}.sidebar-collapsed .subproject-toggle{padding:7px 4px;justify-content:center}.sidebar-collapsed .subproject-toggle-label{display:none}.sidebar nav{display:flex;flex-direction:column;padding:14px 12px;gap:18px;flex:1}.nav-group{display:flex;flex-direction:column}.sidebar .nav-section{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text);letter-spacing:.09em;padding:6px 10px 8px;margin-bottom:6px;border-bottom:1px solid var(--border-strong);display:flex;align-items:center;gap:8px;opacity:.85}.sidebar .nav-section:before{content:"";display:inline-block;width:3px;height:13px;background:var(--accent);border-radius:2px;box-shadow:0 0 8px var(--accent)}.sidebar .nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;margin:1px 0;color:var(--text-dim);font-size:13px;border-radius:8px;border:1px solid transparent;transition:all .18s ease}.sidebar .nav-link .nav-icon{font-size:15px;opacity:.7;transition:all .18s ease;width:22px;text-align:center;flex-shrink:0}.sidebar .nav-link:hover{background:var(--surface-2);color:var(--text)}.sidebar .nav-link:hover .nav-icon{color:var(--accent);opacity:1}.sidebar .nav-link.active{background:linear-gradient(135deg,#6db4ff38,#6db4ff14);color:var(--accent);border-color:#6db4ff4d;font-weight:500;box-shadow:0 2px 8px #6db4ff1f}.sidebar .nav-link.active .nav-icon{color:var(--accent);opacity:1}.sidebar .nav-link{position:relative}.sidebar .nav-link .nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:700;line-height:1;padding:3px 7px;border-radius:10px;min-width:18px;text-align:center;box-shadow:0 0 #f87171b3;animation:pulse-badge 2.5s infinite}@keyframes pulse-badge{0%{box-shadow:0 0 #f8717199}70%{box-shadow:0 0 0 8px #f8717100}to{box-shadow:0 0 #f8717100}}.sidebar .nav-link-primary{font-weight:600;font-size:14px;padding:11px 12px}.sidebar .nav-link-primary .nav-icon{font-size:14px;opacity:.7}.sidebar .user{padding:16px 20px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim)}.sidebar .user strong{color:var(--text);display:block}.sidebar .user button{margin-top:8px;width:100%;font-size:12px;padding:6px}.main{padding:28px 36px;overflow-y:auto;height:100vh}.main header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.main header h2{margin:0;font-size:22px;font-weight:600}.table-wrap{background:var(--surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:12px;overflow-x:auto;overflow-y:auto;max-height:70vh;box-shadow:var(--shadow-soft);-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:separate;border-spacing:0;min-width:700px}th{text-align:left;padding:12px 16px;background:var(--th-bg);font-weight:600;font-size:12px;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border);letter-spacing:.04em;position:sticky;top:0;z-index:2}td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:13px;max-width:320px}td>.cell-clamp,td.cell-clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.35;word-break:break-word}tr.row-expanded td.cell-clamp,tr.row-expanded td>.cell-clamp{-webkit-line-clamp:unset;overflow:visible;white-space:normal}td.cell-wide{min-width:220px;max-width:420px}td.amount{max-width:none;white-space:nowrap}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2)}.actions{display:inline-flex;gap:6px;align-items:center;flex-wrap:wrap;vertical-align:middle}td button{padding:2px 9px;font-size:11px;line-height:1.5;border-radius:4px}.empty{padding:40px;text-align:center;color:var(--text-dim)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface-strong);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:14px;padding:24px;width:460px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}.modal.modal-wide{width:860px}.modal.modal-xl{width:1200px}.payroll-table th,.payroll-table td{padding:6px 8px;font-size:12px}.day-cell{width:100%;padding:5px 6px;font-size:12px;text-align:center;text-transform:uppercase}.modal h3{margin:0 0 16px;font-size:18px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:4px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.login-wrap{height:100vh;overflow-y:auto;display:flex;align-items:center;justify-content:center}.login-card{background:var(--surface-strong);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:16px;padding:32px;width:360px;box-shadow:var(--shadow)}.login-card h1{margin:0 0 6px;font-size:22px}.login-card p{margin:0 0 24px;color:var(--text-dim);font-size:13px}.error-msg{background:#ef444426;border:1px solid var(--danger);color:var(--danger);padding:10px;border-radius:6px;font-size:12px;margin-bottom:14px}.alert-banner{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#f871712e,#fbbf241f);border:1px solid rgba(248,113,113,.45);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:12px;padding:14px 18px;margin-bottom:18px;font-size:13px;color:var(--text);box-shadow:0 4px 20px #f8717133;animation:alert-pulse 3s ease-in-out infinite}.alert-banner .alert-icon{font-size:22px;filter:drop-shadow(0 0 6px rgba(248,113,113,.6))}@keyframes alert-pulse{0%,to{box-shadow:0 4px 20px #f8717133}50%{box-shadow:0 4px 28px #f8717159}}.link-button{background:transparent;border:none;color:var(--accent);padding:0;font-size:inherit;font-weight:600;cursor:pointer;text-decoration:underline;border-radius:0}.link-button:hover{color:var(--accent-hover);background:transparent;transform:none}.project-pending-chips{display:flex;flex-wrap:wrap;gap:8px}.pending-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;background:var(--surface);border:1px solid rgba(248,113,113,.45);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:8px;font-size:12px;font-weight:500;color:var(--text);cursor:pointer;transition:all .18s ease}.pending-chip:hover{background:#f871711f;border-color:var(--danger);transform:translateY(-1px)}.pending-chip.current{background:#22c55e26;border-color:#22c55e80;color:var(--success)}.pending-chip .chip-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:var(--danger);color:#fff;font-weight:700;font-size:11px;border-radius:11px}.pending-chip.current .chip-count{background:var(--success)}.badge{display:inline-block;padding:2px 8px;font-size:11px;border-radius:4px;background:var(--surface-2);color:var(--text-dim)}.badge.activo{background:#22c55e26;color:var(--success)}.badge.pausado{background:#f59e0b26;color:var(--warning)}.badge.terminado{background:#9aa4b226}.badge.role-admin{background:#f871712e;color:var(--danger);border:1px solid rgba(248,113,113,.3)}.badge.role-capturista{background:#6db4ff2e;color:var(--accent);border:1px solid rgba(109,180,255,.3)}.badge.role-viewer{background:#9aa4b226;color:var(--text-dim);border:1px solid rgba(154,164,178,.25)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:var(--surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.kpi-card .label{font-size:11px;text-transform:uppercase;color:var(--text-dim);letter-spacing:.05em;margin-bottom:6px}.kpi-card .value{font-size:22px;font-weight:600}.kpi-card .sub{font-size:12px;color:var(--text-dim);margin-top:4px}.kpi-card.accent .value{color:var(--accent)}.kpi-card.success .value{color:var(--success)}.kpi-card.warning .value{color:var(--warning)}.kpi-card.danger .value{color:var(--danger)}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}@media (max-width: 1100px){.chart-grid{grid-template-columns:1fr}}.chart-card{background:var(--surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-soft)}.chart-card h3{margin:0 0 12px;font-size:14px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.amount{text-align:right;font-variant-numeric:tabular-nums}.bar-cell{position:relative;background:var(--surface-2);border-radius:3px;height:6px;overflow:hidden}.bar-cell>div{height:100%;background:var(--accent)}.project-select-row{display:flex;align-items:center;gap:12px}.project-select-row select{width:auto;min-width:240px}.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.filters select,.filters input{width:auto;min-width:160px}.tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border)}.tab{background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;padding:10px 16px;color:var(--text-dim);font-size:13px}.tab:hover{background:var(--surface-2);color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.filter-card{background:var(--surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:20px;box-shadow:var(--shadow-soft)}.filter-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:10px;text-transform:uppercase;color:var(--text-dim);letter-spacing:.05em}.filter-group input[type=date]{width:150px}.toggle-group{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.toggle-group button{background:transparent;border:none;border-radius:0;padding:8px 16px;font-size:12px;color:var(--text-dim)}.toggle-group button:hover{background:var(--surface-2);color:var(--text)}.toggle-group button.active{background:var(--accent);color:#fff}.cat-toggle{text-align:left;min-width:220px}.cat-panel{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.cat-chips{display:flex;flex-wrap:wrap;gap:6px}.cat-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface-2);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:20px;font-size:12px;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-dim);transition:all .2s ease}.cat-chip input{width:auto;margin:0;pointer-events:none}.cat-chip:hover{border-color:var(--accent);color:var(--text)}.cat-chip.active{background:#4c9aff26;border-color:var(--accent);color:var(--text)}.dropzone{border:2px dashed var(--border-strong);border-radius:14px;padding:32px 20px;text-align:center;background:var(--surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);cursor:pointer;margin-bottom:20px;transition:all .2s ease;box-shadow:var(--shadow-soft)}.dropzone:hover,.dropzone.drag-over{border-color:var(--accent);background:#6db4ff14;transform:translateY(-1px)}.dropzone .dz-icon{font-size:34px;margin-bottom:8px}.sum-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px dotted var(--border)}.sum-row:last-child{border-bottom:none}@media (max-width: 1024px){.main{padding:20px}.main header{flex-wrap:wrap;gap:10px}.main header h2{font-size:18px}.filters{gap:8px}.filters select,.filters input{min-width:130px;font-size:12px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.chart-grid{grid-template-columns:1fr}}@media (max-width: 768px){.layout,.layout.sidebar-collapsed{grid-template-columns:1fr}.mobile-menu-btn{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:300;transform:translate(-100%);transition:transform .3s ease}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:299}.main{padding:60px 14px 20px;min-width:0}.main header{flex-direction:column;align-items:flex-start;gap:10px}.main header h2{font-size:16px}.filters{flex-direction:column;gap:8px}.filters select,.filters input{min-width:unset;width:100%}table{min-width:600px}th,td{padding:8px 10px;font-size:12px}td button{padding:2px 6px;font-size:10px}.modal{width:100vw;max-width:100vw;max-height:100vh;border-radius:0;padding:20px 16px}.modal.modal-wide,.modal.modal-xl{width:100vw;max-width:100vw}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi-card{padding:12px 14px}.kpi-card .value{font-size:18px}.login-card{width:90vw;padding:24px 20px}.project-select-row{flex-direction:column;align-items:stretch}.project-select-row select{width:100%;min-width:unset}.dropzone{padding:20px 14px}.dropzone .dz-icon{font-size:26px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:8px 12px;font-size:12px;white-space:nowrap}}@media (max-width: 480px){.main{padding:56px 10px 16px}.kpi-grid{grid-template-columns:1fr}.kpi-card .value{font-size:16px}th,td{padding:6px 8px;font-size:11px}.sidebar{width:100vw}.modal{padding:16px 12px}.modal h3{font-size:15px}button{padding:6px 10px;font-size:12px}input,select,textarea{font-size:14px;padding:10px}}.perm-matrix{display:flex;flex-direction:column;gap:14px;margin-bottom:10px}.perm-group{border:1px solid var(--border);border-radius:10px;background:var(--surface-2);overflow:hidden}.perm-group-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:color-mix(in srgb,var(--accent) 10%,transparent);border-bottom:1px solid var(--border)}.perm-group-title{font-weight:600;font-size:13px;color:var(--text)}.perm-group-controls{display:flex;gap:6px}.perm-pill{font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;transition:all .15s ease}.perm-pill:hover{border-color:var(--accent);color:var(--text)}.perm-pill.on{background:color-mix(in srgb,var(--accent) 22%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 50%,transparent)}.perm-rows{display:flex;flex-direction:column}.perm-row{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent)}.perm-row:last-child{border-bottom:none}.perm-row-label{display:flex;align-items:center;gap:8px;font-size:13px}.perm-row-icon{font-size:15px}.perm-row-checks{display:flex;gap:6px}.perm-check{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:5px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;transition:all .12s ease;font-weight:500}.perm-check span{font-size:13px}.perm-check:hover{border-color:var(--accent);color:var(--text)}.perm-check.on.view{background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:color-mix(in srgb,var(--accent) 55%,transparent);color:var(--accent)}.perm-check.on.edit{background:color-mix(in srgb,var(--success, #22c55e) 22%,transparent);border-color:color-mix(in srgb,var(--success, #22c55e) 55%,transparent);color:var(--success, #22c55e)}
