:root{--ca-yellow: #ffcc00;--ca-yellow-dark: #e7b800;--ca-black: #1f1f1f;--ca-graphite: #2f2f2f;--ca-light: #f6f7fb;--ca-border: #dadde8;--ca-danger: #bf1d1d;--ca-danger-soft: rgba(191, 29, 29, .12);--ca-danger-border: rgba(191, 29, 29, .42);--ca-success: #116611;--page-bg: radial-gradient(circle at 12% 18%, rgba(255, 204, 0, .22), transparent 35%), radial-gradient(circle at 85% 5%, rgba(0, 0, 0, .05), transparent 42%), linear-gradient(180deg, #fefdf8 0%, #f1f2f7 100%)}*{box-sizing:border-box}body{margin:0;color:var(--ca-black);font-family:Segoe UI,Trebuchet MS,sans-serif;background:var(--ca-light)}.page-shell{min-height:100vh;padding:20px;background:var(--page-bg);background-size:170% 170%;background-attachment:fixed;transition:background .22s ease,color .22s ease}.hero{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;padding:20px;border:1px solid var(--ca-border);border-radius:14px;background:linear-gradient(110deg,#fc03,#ffffffe0)}.hero h1{margin:4px 0 0}.hero-eyebrow{margin:0;color:var(--ca-graphite);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.hero-right{display:flex;align-items:center;gap:10px}.hero-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px}.version-badge{margin:0;display:inline-flex;flex-wrap:wrap;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--ca-border);border-radius:9px;background:#fffc}.version-badge span{font-size:12px;color:var(--ca-graphite)}.version-link{font-size:12px;font-weight:700;color:var(--ca-black);text-decoration:underline;text-underline-offset:2px}.version-error{color:var(--ca-danger)}.theme-switch{margin:0;display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ca-graphite)}.theme-switch select{min-width:220px}.identity{margin:0;font-size:14px}.page-shell.theme-cyberpunk{--ca-yellow: #35f3ff;--ca-yellow-dark: #03b6ff;--ca-black: #e8ebff;--ca-graphite: #9fd8ff;--ca-light: #060512;--ca-border: #5a2bff;--ca-danger: #ff5a99;--ca-danger-soft: rgba(255, 90, 153, .14);--ca-danger-border: rgba(255, 90, 153, .48);--ca-success: #35ffcf;--page-bg: radial-gradient(circle at 12% 8%, rgba(255, 0, 204, .4), transparent 32%), radial-gradient(circle at 88% 12%, rgba(0, 255, 255, .35), transparent 34%), radial-gradient(circle at 50% 92%, rgba(123, 0, 255, .34), transparent 40%), linear-gradient(135deg, #060612 0%, #111039 48%, #180729 100%);color:var(--ca-black);animation:cyber-drift 14s ease-in-out infinite alternate}.page-shell.theme-cyberpunk .hero{background:linear-gradient(120deg,#220758db,#081447cc);border-color:#6f42ffd9;box-shadow:0 0 0 1px #35f3ff59,0 0 26px #a332ff59}.page-shell.theme-cyberpunk .hero h1{color:#f4ecff;text-shadow:0 0 10px rgba(255,0,238,.6)}.page-shell.theme-cyberpunk .version-badge{border-color:#5a2bffd9;background:#080a23b8}.page-shell.theme-cyberpunk .version-badge span{color:#b8c7ff}.page-shell.theme-cyberpunk .version-link{color:#35f3ff}.page-shell.theme-cyberpunk .login-card,.page-shell.theme-cyberpunk .card{background:#0c0a23d1;border-color:#5a2bffd9;box-shadow:0 0 0 1px #35f3ff38,inset 0 0 24px #35f3ff0f}.page-shell.theme-cyberpunk input,.page-shell.theme-cyberpunk select,.page-shell.theme-cyberpunk button{color:#e8ebff;background:#070a26db;border-color:#6a46fff2}.page-shell.theme-cyberpunk input:focus,.page-shell.theme-cyberpunk select:focus{outline:2px solid rgba(53,243,255,.7);border-color:#35f3ff}.page-shell.theme-cyberpunk .primary-btn{background:linear-gradient(135deg,#ff2fd1,#35f3ff);color:#0a0420;border-color:#35f3ff}.page-shell.theme-cyberpunk .primary-btn:hover{filter:brightness(1.08)}.page-shell.theme-cyberpunk .secondary-btn:hover{background:#35f3ff29}.page-shell.theme-cyberpunk .ticket-table-wrapper,.page-shell.theme-cyberpunk .week-range,.page-shell.theme-cyberpunk .weekly-chart-wrapper,.page-shell.theme-cyberpunk .modal{background:#080a23b8;border-color:#5a2bffd9}.page-shell.theme-cyberpunk .ticket-table thead tr.sort-row th,.page-shell.theme-cyberpunk .recap-table thead tr.sort-row th{background:#131145}.page-shell.theme-cyberpunk .ticket-table thead tr.filter-row th,.page-shell.theme-cyberpunk .recap-table thead tr.filter-row th{background:#1b1656}.page-shell.theme-cyberpunk .ticket-table th,.page-shell.theme-cyberpunk .ticket-table td,.page-shell.theme-cyberpunk .recap-table th,.page-shell.theme-cyberpunk .recap-table td{border-bottom-color:#647dff47}.page-shell.theme-cyberpunk .chart-legend,.page-shell.theme-cyberpunk .chart-weeks-picker,.page-shell.theme-cyberpunk .empty-state,.page-shell.theme-cyberpunk .muted-note,.page-shell.theme-cyberpunk .duration-unit{color:#b8c7ff}.page-shell.theme-cyberpunk .warning-box{background:var(--ca-danger-soft);border-color:var(--ca-danger-border);color:#ffd8ea}@keyframes cyber-drift{0%{background-position:0% 8%}to{background-position:100% 92%}}.login-card,.dashboard{display:grid;gap:16px}.login-card,.card{padding:18px;border-radius:14px;border:1px solid var(--ca-border);background:#fffffff0}.admin-section{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--ca-border)}.admin-settings-grid{margin-bottom:10px}.warning-box{margin:0 0 12px;padding:12px 14px;border:1px solid var(--ca-danger-border);border-radius:10px;background:var(--ca-danger-soft);color:#6c3a00;font-size:14px;line-height:1.45}.sensitive-input{letter-spacing:.04em}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:12px}label{display:grid;gap:6px;font-size:14px}input,select,button{border-radius:9px;border:1px solid #c7ccdb;padding:9px 10px;font-size:14px}input:focus,select:focus{outline:2px solid rgba(255,204,0,.6);border-color:var(--ca-yellow-dark)}.primary-btn{background:var(--ca-yellow);color:var(--ca-black);font-weight:700;border-color:var(--ca-yellow-dark);cursor:pointer}.primary-btn:hover{background:#ffd83d}.secondary-btn{background:#fff;color:var(--ca-black);cursor:pointer}.secondary-btn:hover{background:#f7f8fc}.danger-btn{background:#fff1f1;border-color:#d95a5a;color:#9d1f1f;cursor:pointer}.danger-btn:hover{background:#ffe5e5}.controls{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.dashboard-nav{display:flex;justify-content:flex-end}.dashboard-nav-actions{display:flex;flex-wrap:wrap;gap:8px}.dashboard-nav-btn{min-width:210px}.dashboard-nav-btn-active{background:var(--ca-yellow);border-color:var(--ca-yellow-dark);color:#11131f;font-weight:700}.page-shell.theme-cyberpunk .dashboard-nav-btn-active{background:linear-gradient(135deg,#ff2fd1,#35f3ff);border-color:#35f3ff;color:#0a0420}.period-picker,.period-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:end}.impersonation-controls{display:grid;gap:6px;min-width:320px}.impersonation-controls select{min-width:320px}.week-range{padding:8px 10px;border:1px solid var(--ca-border);border-radius:9px;background:#fff;min-width:260px;font-size:14px}.week-nav{display:flex;flex-wrap:wrap;gap:8px}.toolbar{display:grid;grid-template-columns:minmax(220px,1fr) auto auto auto;gap:10px;align-items:end;margin-bottom:10px}.search{min-width:220px}.bulk-editor{display:flex;gap:8px}.bulk-editor input{width:90px}.page-duration-toggle{min-width:160px}.page-duration-toggle select{min-width:130px}.totals{justify-self:end;font-weight:700;color:var(--ca-graphite)}.header-sort-btn{width:100%;border:none;background:transparent;padding:0;text-align:left;font-weight:700;color:inherit;cursor:pointer}.header-sort-btn:hover{color:var(--ca-black)}.ticket-table thead tr.sort-row th,.recap-table thead tr.sort-row th{position:sticky;top:0;background:#fcfdff;z-index:3}.ticket-table thead tr.filter-row th,.recap-table thead tr.filter-row th{position:sticky;top:38px;background:#f9fbff;z-index:2;padding:6px 8px}.ticket-table thead tr.filter-row input,.recap-table thead tr.filter-row input{width:100%;font-size:12px;padding:6px 7px}.mini-range{display:grid;grid-template-columns:1fr 1fr;gap:6px}.inline-password-form,.inline-profile-form{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.inline-profile-form input,.inline-password-form input{min-width:170px}.muted-note{margin:0;color:#555d70;font-size:13px}.ticket-table-wrapper{max-height:70vh;overflow:auto;border:1px solid var(--ca-border);border-radius:10px}.ticket-table,.recap-table{width:100%;border-collapse:collapse}.ticket-table{min-width:1320px}.ticket-table th,.ticket-table td,.recap-table th,.recap-table td{padding:10px;border-bottom:1px solid #eceef6;text-align:left;font-size:14px;vertical-align:middle}.ticket-key{font-weight:700;color:var(--ca-graphite)}.ticket-key a{color:inherit;text-decoration:underline;text-underline-offset:2px}.ticket-key a:hover{color:var(--ca-black)}.ticket-table td input[type=number]{width:95px}.ticket-table td input[type=number][aria-invalid=true],.ticket-table td input[type=text][aria-invalid=true],.ticket-table td input[type=number].is-invalid,.ticket-table td input[type=text].is-invalid,.ticket-table td input[type=number].has-error,.ticket-table td input[type=text].has-error,.ticket-table td input[type=number].validation-error,.ticket-table td input[type=text].validation-error{border-color:var(--ca-danger);background:#ffcccc8c;box-shadow:0 0 0 1px #bf1d1d24}.ticket-table tbody tr.row-error,.ticket-table tbody tr.ticket-row-invalid,.ticket-table tbody tr.has-error{background:var(--ca-danger-soft)}.ticket-table tbody tr.row-error td,.ticket-table tbody tr.ticket-row-invalid td,.ticket-table tbody tr.has-error td{border-bottom-color:var(--ca-danger-border)}.ticket-table td.cell-error,.ticket-table td.has-error,.ticket-table td.validation-error{background:var(--ca-danger-soft);box-shadow:inset 0 0 0 1px #bf1d1d14}.ticket-table td.cell-error input,.ticket-table td.has-error input,.ticket-table td.validation-error input{border-color:var(--ca-danger)}.duration-editor{display:grid;gap:6px}.duration-mode-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px}.duration-mode-toggle input[type=checkbox]{width:auto;padding:0}.duration-input-row{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.duration-unit{font-size:12px;color:#555d70;min-width:16px}.duration-editor input[type=number]{width:88px}.weekly-duration-input{width:96px;text-align:right}.daily-duration-input{width:72px;text-align:right}.weekly-column-header,.daily-column-header{white-space:nowrap}.weekly-column-header{min-width:104px}.daily-column-header{min-width:84px}.ticket-table tbody tr.ticket-row-active{background:#ffcc0029}.ticket-table tbody tr.ticket-row-active td{border-bottom-color:#ecd98a}.ticket-table td a{color:inherit;text-decoration:underline;text-underline-offset:2px}.chart-controls{display:flex;justify-content:flex-end;margin:2px 0 6px}.chart-weeks-picker{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:#555d70}.chart-weeks-picker input{width:90px}.chart-legend{margin:4px 0 10px;color:#555d70;font-size:13px}.weekly-chart-wrapper{overflow-x:auto;border:1px solid var(--ca-border);border-radius:10px;padding:8px;background:#fff}.weekly-chart{width:100%;min-width:720px;height:auto;display:block}.weekly-grid-line{stroke:#e6e9f2;stroke-width:1}.weekly-axis{stroke:#a9afc2;stroke-width:1.2}.weekly-target-line{fill:none;stroke:var(--ca-black);stroke-width:2;stroke-dasharray:6 5;opacity:.86}.weekly-bar{fill:var(--ca-yellow);stroke:var(--ca-yellow-dark);stroke-width:1}.weekly-bar-value{font-size:11px;font-weight:600;fill:var(--ca-graphite);text-anchor:middle}.weekly-axis-label{font-size:10px;fill:#555d70;text-anchor:middle}.weekly-tick-label{font-size:10px;fill:#555d70;text-anchor:end}.actions{margin-top:14px}.error{color:var(--ca-danger);margin:8px 0 0}.success{color:var(--ca-success);margin:8px 0 0}.empty-state{margin:10px;color:#555d70}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;padding:16px}.modal{width:min(480px,95vw);background:#fff;border-radius:12px;border:1px solid var(--ca-border);padding:18px}@media(prefers-reduced-motion:reduce){.page-shell.theme-cyberpunk{animation:none}}@media(max-width:860px){.hero{flex-direction:column;align-items:flex-start}.hero-controls{width:100%;justify-content:space-between}.theme-switch,.version-badge{width:100%}.theme-switch select{min-width:0;width:100%}.toolbar{grid-template-columns:1fr}.totals{justify-self:start}.period-picker,.impersonation-controls,.period-actions{width:100%}.impersonation-controls select{min-width:0;width:100%}.dashboard-nav-actions{width:100%}.dashboard-nav-btn{flex:1 1 220px}}
