@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary: #10b981;--primary-hover: #059669;--primary-glow: rgba(16, 185, 129, .4);--secondary: #0d9488;--danger: #ef4444;--warning: #fbbf24;--success: #22c55e;--font-inter: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif;--transition-fast: .15s ease;--transition-normal: .3s cubic-bezier(.4, 0, .2, 1)}html,html[data-theme=dark]{--bg-page: #0d0e1a;--bg-sidebar: #13141f;--bg-card: #13141f;--bg-elevated: rgba(255, 255, 255, .05);--bg-hero: linear-gradient(135deg, rgba(16, 185, 129, .1) 0%, rgba(13, 14, 26, .6) 100%);--text-primary: #f8fafc;--text-secondary: #e2e4f0;--text-muted: #94a3b8;--text-dim: #64748b;--text-bright: #ffffff;--text-inverse: #0f172a;--nav-active-bg: rgba(16, 185, 129, .15);--nav-active-text: #34d399;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--scrollbar: rgba(255, 255, 255, .15);--badge-student-bg: rgba(16, 185, 129, .15);--badge-student-text: #34d399;--badge-coordinator-bg: rgba(13, 148, 136, .15);--badge-coordinator-text: #0d9488;--badge-admin-bg: rgba(245, 158, 11, .15);--badge-admin-text: #fbbf24;color-scheme:dark;color:var(--text-secondary);background-color:var(--bg-page)}html[data-theme=light]{--bg-page: #f8fafc;--bg-sidebar: #ffffff;--bg-card: #ffffff;--bg-elevated: #f1f5f9;--bg-hero: linear-gradient(135deg, rgba(16, 185, 129, .07) 0%, rgba(13, 148, 136, .04) 100%);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #475569;--text-dim: #64748b;--text-bright: #000000;--text-inverse: #ffffff;--nav-active-bg: rgba(16, 185, 129, .08);--nav-active-text: #059669;--border: #e2e8f0;--border-strong: #cbd5e1;--scrollbar: #cbd5e1;--badge-student-bg: #dcfce7;--badge-student-text: #166534;--badge-coordinator-bg: #ccfbf1;--badge-coordinator-text: #115e59;--badge-admin-bg: #fef3c7;--badge-admin-text: #92400e;color-scheme:light;color:var(--text-primary);background-color:var(--bg-page)}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;overflow-y:auto;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus{outline:none}button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.primary{width:100%;padding:.9rem;border-radius:10px;border:none;font-size:.95rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));color:var(--text-inverse);cursor:pointer;transition:all .2s;box-shadow:0 4px 15px var(--primary-glow);font-family:var(--font-inter)}.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px var(--primary-glow);opacity:.9}.primary:disabled{opacity:.6;cursor:not-allowed}.primary-glow{box-shadow:0 0 20px var(--primary-glow)}.skeleton{position:relative;overflow:hidden;background:var(--bg-elevated);border-radius:4px}.skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,#fff0 0,#ffffff08 20%,#ffffff0f 60%,#fff0);animation:shimmer 1.8s infinite}html[data-theme=light] .skeleton:after{background:linear-gradient(90deg,#0000 0,#00000008 20%,#0000000d 60%,#0000)}@keyframes shimmer{to{transform:translate(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.skeleton-text{height:12px;width:100%;margin-bottom:8px}.skeleton-title{height:24px;width:60%;margin-bottom:12px}.skeleton-circle{border-radius:50%}.preview-modal-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem;animation:fadeIn .25s ease}.preview-modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:18px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 48px #0006;animation:modal-pop .3s cubic-bezier(.175,.885,.32,1.15)}@keyframes modal-pop{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.preview-modal-header{padding:1.25rem 1.75rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.preview-modal-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.preview-modal-body{flex:1;overflow:auto;padding:1.5rem;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated)}.preview-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px;box-shadow:0 4px 12px #0003}.preview-pdf{width:100%;height:70vh;border:none;border-radius:8px}.preview-unsupported{text-align:center;padding:3rem;color:var(--text-muted)}@media(max-width:600px){.preview-modal-overlay{padding:1rem}.preview-modal-content{max-height:95vh}.preview-modal-body{padding:1rem}.preview-pdf{height:60vh}}html,body,#root{height:100%;width:100%;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg-page);color:var(--text-secondary);overflow-y:auto;overflow-x:hidden}#root{min-height:100vh;width:100%;display:flex;overflow:hidden}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.auth-page{--bg: #0d0e1a;--surface: #13141f;--border: rgba(255, 255, 255, .07);--border-focus: var(--primary);--accent: var(--primary);--accent-2: #2563eb;--text: #f8fafc;--muted: #94a3b8;--muted-light: #64748b;--error: #ef4444;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background:var(--bg);width:100%}.auth-card{display:flex;width:100%;max-width:880px;background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:0 12px 60px #00000080,inset 0 1px #ffffff0d}.auth-card-left{flex:1;position:relative;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;min-height:400px}.auth-card-left .left-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.5) brightness(.45);transition:transform 10s ease}.auth-card:hover .auth-card-left .left-img{transform:scale(1.05)}.auth-card-left:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#0d0e1a,#0d0e1a66,#0d0e1a1a);z-index:1}.auth-left-overlay{position:relative;z-index:2;padding:2.5rem}.left-title{font-size:2rem;font-weight:800;margin:0 0 .35rem;line-height:1.1}.left-title .asian{color:#ef4444}.left-title .college{color:#60a5fa}.left-sub{font-size:.9rem;color:#ffffffb3;font-weight:400}.auth-card-right{flex:1;display:flex;flex-direction:column;background:var(--surface);position:relative;border-left:1px solid var(--border);justify-content:center;align-items:center;padding:2rem}.auth-form-wrapper{width:100%;max-width:380px;display:flex;flex-direction:column}.auth-form{display:flex;flex-direction:column}.card-header{text-align:center;margin-bottom:1.5rem}.card-header h1,.card-header h2{font-size:1.35rem;font-weight:700;color:var(--text);margin:0;letter-spacing:-.02em}.subtitle{margin-top:.5rem;color:var(--muted-light);font-size:.85rem}.form-scrollable{display:flex;flex-direction:column;gap:1rem;overflow-y:auto;padding:0 2px}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.form-row label,.full-width{display:flex;flex-direction:column;gap:.4rem;font-size:.8rem;font-weight:500;color:var(--muted-light)}input{padding:.65rem .8rem;border-radius:8px;border:1px solid var(--border);background:#ffffff08;color:var(--text);font-size:.85rem;font-family:inherit;outline:none;transition:all .2s;width:100%}input:focus{border-color:var(--primary);background:#ffffff14;box-shadow:0 0 0 3px var(--primary-glow)}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{padding-right:2.5rem}.password-toggle-btn{position:absolute;right:.5rem;background:transparent;border:none;color:var(--muted-light);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.4rem;border-radius:6px;transition:all .2s cubic-bezier(.16,1,.3,1)}.password-toggle-btn:hover{color:var(--text);background:#ffffff14}.password-toggle-btn svg.eye-icon{transition:transform .25s cubic-bezier(.175,.885,.32,1.275)}.password-toggle-btn:active svg.eye-icon{transform:scale(.65)}.eye-icon{animation:eyePop .35s cubic-bezier(.175,.885,.32,1.275)}@keyframes eyePop{0%{transform:scale(.4);opacity:0}50%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.email-row{display:flex;gap:.6rem}.verify-btn{padding:0 1rem;border-radius:9px;border:1px solid rgba(16,185,129,.35);background:#10b9811f;color:#34d399;font-weight:600;font-size:.8rem;cursor:pointer;transition:all .2s}.verify-btn:hover{background:#10b98138;border-color:#10b9818c;color:#6ee7b7}.verification-line{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem;gap:1rem;flex-wrap:wrap}.verify-indicator{padding:.35rem .75rem;border-radius:99px;font-size:.75rem;font-weight:500;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);color:var(--muted-light)}.verify-indicator.ok{background:#22c55e1a;color:var(--success);border-color:#22c55e33}.account-type{display:flex;gap:1.25rem}.account-type label{display:flex;flex-direction:row;align-items:center;gap:.5rem;cursor:pointer}.account-type input[type=radio]{width:16px;height:16px;accent-color:var(--accent);margin:0}.cta-row{margin-top:.5rem}.auth-footer{text-align:center;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem}.muted{color:var(--muted-light);font-size:.75rem}.switch-btn{background:none;border:none;font-family:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:4px;opacity:.8;transition:opacity .2s}.switch-btn:hover{opacity:1;color:var(--text)}.error{color:var(--error);font-size:.75rem}.info-msg{text-align:center;font-size:.85rem;color:var(--success);background:#22c55e14;border:1px solid rgba(34,197,94,.18);border-radius:8px;padding:.75rem}@media(max-width:860px){.auth-page{padding:.5rem;min-height:100vh;height:auto;display:block;overflow-y:auto}.auth-card{margin:1rem auto;flex-direction:column;width:100%;max-width:500px;height:auto;max-height:none;overflow:visible}.auth-card-left{height:140px;min-height:140px;flex:none}.auth-left-overlay{padding:1.25rem}.left-title{font-size:1.4rem}.auth-card-right{border-left:none;border-top:1px solid var(--border)}.auth-form{padding:1.25rem}.card-header{margin-bottom:1.25rem}.card-header h1,.card-header h2{font-size:1.35rem}.form-scrollable{gap:1rem}.form-row{grid-template-columns:1fr}.email-row{flex-direction:column;gap:.5rem}.verify-btn{padding:.75rem}.verification-line{flex-direction:column;align-items:stretch;gap:.75rem}.verify-indicator{align-self:flex-start}.account-type{flex-direction:column;gap:.6rem}}.dtr-container{display:flex;flex-direction:column;align-items:center;padding:10px}.dtr-card{width:460px;background:#fff;color:#111;font-family:Arial,Helvetica,sans-serif;font-size:11px;box-sizing:border-box;border:1.5px solid #333}.tc-header{padding:6px 10px 4px;border-bottom:1.5px solid #333}.tc-header-row{display:flex;align-items:flex-end;margin-bottom:6px;gap:4px;font-size:11px}.tc-header-row:last-child{margin-bottom:2px}.tc-lbl{white-space:nowrap;font-weight:400}.tc-line{flex:1;border:none;border-bottom:1px solid #111;border-radius:0;background:transparent;outline:none;font-family:inherit;font-size:11px;color:#111;padding:0 4px;min-width:30px;height:22px;line-height:1.2;box-sizing:border-box;overflow:visible!important}.tc-middle{display:flex;border-bottom:1.5px solid #333}.tc-left-table{flex:1.2;border-right:1.5px solid #333}.tc-left-table table{width:100%;border-collapse:collapse;font-size:10px}.tc-left-table th,.tc-left-table td{border:1px solid #333;padding:2px 4px;height:16px;font-weight:400;text-align:left}.tc-left-table thead th{text-align:center;font-weight:700;font-size:9px}.tc-left-table td.label-cell{font-size:10px}.tc-left-table td.label-cell.net-pay{font-weight:700;font-size:11px}.tc-left-table td input{width:100%;border:none;border-radius:0;background:transparent;outline:none;font-family:inherit;font-size:10px;padding:0;text-align:center}.tc-left-table table{border-collapse:collapse}.tc-left-table tr:first-child th:first-child{border-left:none;border-top:none}.tc-left-table tr:first-child th{border-top:none}.tc-left-table tr td:first-child{border-left:none}.tc-left-table tr:last-child td{border-bottom:none}.tc-deductions-label{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-size:10px;font-weight:700;letter-spacing:normal;padding:4px 3px;border-right:1.5px solid #333;min-width:20px;text-transform:uppercase;gap:1.5px;line-height:1}.tc-right-table{flex:1}.tc-right-table table{width:100%;border-collapse:collapse;font-size:10px}.tc-right-table th,.tc-right-table td{border:1px solid #333;padding:2px 4px;height:16px;font-weight:400;text-align:left}.tc-right-table thead th{font-weight:700;text-align:center;font-size:10px;text-transform:uppercase}.tc-right-table tfoot td{font-weight:700;text-align:center}.tc-right-table td input{width:100%;border:none;border-radius:0;background:transparent;outline:none;font-family:inherit;font-size:10px;padding:0;text-align:center}.tc-right-table tr:first-child th{border-top:none}.tc-right-table tr:last-child td{border-bottom:none}.tc-right-table tr td:first-child,.tc-right-table tr th:first-child{border-left:none}.tc-right-table tr td:last-child,.tc-right-table tr th:last-child{border-right:none}.tc-grid-section{border-top:none}.tc-grid{width:100%;border-collapse:collapse;table-layout:fixed;font-size:10px}.tc-grid th,.tc-grid td{border:1px solid #333;text-align:center;padding:0;height:20px;font-weight:400}.tc-grid thead th{font-weight:700;font-size:9px;height:16px}.tc-grid th:first-child,.tc-grid td:first-child{border-left:none}.tc-grid tr:last-child td{border-bottom:none}.tc-grid td.day-num{font-size:9px;background:transparent}.tc-grid-input{width:100%;height:100%;border:none;border-radius:0;background:transparent;outline:none;text-align:center;font-family:monospace;font-size:9px;padding:0;color:#111;line-height:1.2;box-sizing:border-box;overflow:visible!important}.tc-grid-input:focus{background:#0064ff0d}.tc-cert{border-top:1.5px solid #333;padding:6px 10px;font-size:9px;display:flex;align-items:flex-end;gap:10px}.tc-cert-text{flex:1;font-style:italic;line-height:1.4}.tc-sig-line{width:150px;border-top:1px solid #111;text-align:center;font-size:8px;padding-top:2px}.dtr-actions{margin-top:16px;display:flex;gap:10px}.dtr-btn{padding:8px 18px;border:none;border-radius:5px;cursor:pointer;font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px;transition:background .2s}.dtr-btn-primary{background:#2563eb;color:#fff}.dtr-btn-primary:hover{background:#1d4ed8}.dtr-btn-secondary{background:#e5e7eb;color:#374151}.dtr-btn-secondary:hover{background:#d1d5db}@media print{.dtr-actions{display:none}.dtr-container{padding:0}.dtr-card{border:none;width:100%}}.timesheet-view{display:flex;flex-direction:column;gap:1.5rem;width:100%;animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}.timesheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.header-text h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.header-subtitle{font-size:.85rem;color:var(--text-dim);margin:.2rem 0 0}.refresh-btn{display:flex;align-items:center;gap:.6rem;padding:.6rem 1.25rem;border-radius:10px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.refresh-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:#10b9810d}.timesheet-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.ts-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.25rem;display:flex;flex-direction:column;gap:.25rem;transition:transform .2s ease}.ts-stat-card:hover{transform:translateY(-2px);border-color:var(--primary-glow)}.ts-stat-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.ts-stat-value{font-size:1.5rem;font-weight:800;color:var(--text-primary);line-height:1.2}.ts-stat-sub{font-size:.7rem;color:var(--text-muted)}.timesheet-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:0;overflow:hidden;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.timesheet-table-container{width:100%;overflow-x:auto}.timesheet-table{width:100%;border-collapse:collapse;text-align:center}.timesheet-table th{padding:1.25rem 1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);border-bottom:2px solid var(--border);background:#ffffff03;white-space:nowrap}.timesheet-table td{padding:1.15rem 1rem;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid var(--border)}.timesheet-table.flat-list th,.timesheet-table.flat-list td{text-align:left;padding-left:1rem}.new-day-row td{border-top:1px solid var(--border)}.date-group-header{display:flex;flex-direction:column;gap:.15rem}.date-main{font-size:.95rem;font-weight:700;color:var(--text-primary)}.date-detail{font-size:.7rem;font-weight:500;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.timesheet-table .duration-cell{text-align:left}.timesheet-table .status-cell{text-align:right;padding-right:1.5rem}.status-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .8rem;border-radius:99px;font-size:.7rem;font-weight:700;letter-spacing:.02em}.status-dot{width:6px;height:6px;border-radius:50%}.status-pill.completed{color:var(--text-dim)}.status-pill.completed .status-dot{display:none}.status-pill.working{background:#22c55e14;color:#4ade80;border:1px solid rgba(34,197,94,.15)}.status-pill.working .status-dot{background:#4ade80;box-shadow:0 0 8px #4ade8080;animation:blink 1.2s infinite}.status-pill.break{background:#10b9811a;color:#34d399;border:1px solid rgba(251,191,36,.15)}.timesheet-loading{padding:5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-dim)}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.timesheet-empty{padding:5rem;text-align:center}.timesheet-empty svg{margin-bottom:1rem;opacity:.3}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.timesheet-stats-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.timesheet-header{flex-direction:column;align-items:flex-start;gap:.75rem}.refresh-btn{width:100%;justify-content:center}.header-text h2{font-size:1.25rem}.timesheet-loading,.timesheet-empty{padding:3rem 1.5rem}}@media(max-width:640px){.timesheet-stats-row{grid-template-columns:repeat(2,1fr);gap:.75rem}.ts-stat-card{padding:1rem}.ts-stat-value{font-size:1.25rem}.timesheet-table th{padding:.75rem .5rem;font-size:.6rem}.timesheet-table td{padding:.75rem .5rem;font-size:.82rem}.date-cell{padding-left:.75rem!important}}@media(max-width:400px){.timesheet-stats-row{grid-template-columns:1fr}.ts-stat-card{flex-direction:row;align-items:center;gap:1rem}}.performance-view{display:flex;flex-direction:column;gap:2rem;width:100%;animation:fadeIn .3s ease-out}.performance-header{display:flex;justify-content:space-between;align-items:center}.performance-header h2{font-size:1.35rem;font-weight:500;margin:0;color:var(--text-primary)}.performance-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.kpi-card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:0 4px 20px #00000026;transition:transform .2s ease}.kpi-card:hover{transform:translateY(-2px)}.kpi-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;flex-shrink:0}.kpi-primary .kpi-icon{background:#10b9811a;color:#34d399}.kpi-warning .kpi-icon{background:#f59e0b1a;color:var(--warning)}.kpi-success .kpi-icon{background:#10b9811a;color:var(--success)}.kpi-danger .kpi-icon{background:#ef44441a;color:var(--danger)}.kpi-content{display:flex;flex-direction:column;gap:.25rem;flex-grow:1}.kpi-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.kpi-value{font-size:1.75rem;font-weight:600;color:var(--text-primary);line-height:1.2}.kpi-unit{font-size:.9rem;color:#94a3b8;font-weight:400}.kpi-subtext{font-size:.8rem;color:#64748b;margin-top:.25rem}.kpi-progress-bar-bg{height:6px;background:var(--bg-elevated);border-radius:4px;width:100%;margin-top:.75rem;overflow:hidden}.kpi-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:4px;transition:width .5s ease-out}.performance-section{display:flex;flex-direction:column;gap:1rem}.section-header h3{margin:0 0 .25rem;font-size:1.15rem;font-weight:500;color:var(--text-primary)}.section-subtitle{margin:0;font-size:.85rem;font-size:.9rem;color:var(--text-muted);font-weight:400}.performance-card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0003;min-height:300px}.performance-empty{display:flex;flex-direction:column;justify-content:center;align-items:center;height:250px;color:#64748b;gap:1rem;font-size:.95rem}.dtr-table-wrap{width:100%;overflow-x:auto}.dtr-table{width:100%;border-collapse:separate;border-spacing:0;text-align:left}.dtr-table th{color:var(--text-muted);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;padding:1rem;border-bottom:1px solid var(--border);white-space:nowrap}.dtr-table td{padding:1rem;font-size:.95rem;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.dtr-table tr:last-child td{border-bottom:none}.dtr-table tr:hover td{background-color:#ffffff05}.dtr-table .fw-500{font-weight:500;color:var(--text-primary)}.dtr-table .highlight-cell{color:#34d399;font-weight:500}@media(max-width:768px){.reports-header{flex-direction:column;align-items:flex-start;gap:1rem}.performance-kpi-grid{grid-template-columns:1fr}.performance-card{padding:1rem}.dtr-table td,.dtr-table th{padding:.75rem .5rem;font-size:.8rem}}.journal-container{display:flex;flex-direction:column;gap:2rem;animation:fadeIn .3s ease-out;color:#e2e8f0;max-width:1200px;margin:0 auto;padding-bottom:2rem}.journal-header{display:flex;justify-content:space-between;align-items:flex-start}.journal-title{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.02em;margin:0}.journal-subtitle{font-size:.95rem;color:#94a3b8;margin-top:.25rem}.journal-header-actions{display:flex;gap:1rem;align-items:center}.btn-filter{background:#1a1d27;border:1px solid #2d3748;color:#fff;padding:.6rem 1.2rem;border-radius:8px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:background .2s}.btn-filter:hover{background:#2d3748}.btn-new-entry{background:#34d399;color:#0f111a;border:none;padding:.6rem 1.2rem;border-radius:8px;font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:.5rem;cursor:pointer;box-shadow:0 4px 14px #34d39966;transition:transform .2s,background .2s}.btn-new-entry:hover{background:#10b981;transform:translateY(-2px)}.journal-main-grid{display:grid;grid-template-columns:1.8fr 1fr;gap:2rem}@media(max-width:1024px){.journal-main-grid{grid-template-columns:1fr}}.journal-history-section{display:flex;flex-direction:column;gap:1.5rem}.journal-history-header{display:flex;justify-content:space-between;align-items:center}.history-title-group{display:flex;align-items:center;gap:.75rem}.history-title-group h3{font-size:1.25rem;font-weight:700;color:#fff;margin:0}.badge-count{background:#10b98126;color:#10b981;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.history-legend{display:flex;gap:1.5rem;font-size:.85rem;font-weight:600;color:#cbd5e1}.legend-item{display:flex;align-items:center;gap:.5rem}.dot{width:8px;height:8px;border-radius:50%}.dot.approved{background:#34d399}.dot.draft{background:#60a5fa}.journal-card-list{display:flex;flex-direction:column;gap:1.25rem}.journal-card{background:#1e2230;border-radius:16px;padding:1.5rem;display:flex;gap:1.5rem;position:relative;border:1px solid transparent;transition:border-color .2s,transform .2s;cursor:pointer}.journal-card:hover{border-color:#34d3994d;transform:translateY(-2px)}.card-date-box{background:#064e3b;border:1px solid rgba(52,211,153,.3);border-radius:12px;width:64px;height:64px;display:flex;flex-direction:column;justify-content:center;align-items:center;flex-shrink:0}.date-month{font-size:.75rem;font-weight:700;color:#34d399;letter-spacing:.05em;text-transform:uppercase}.date-day{font-size:1.25rem;font-weight:800;color:#fff}.card-content{flex:1;min-width:0}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.card-title-area{display:flex;flex-direction:column;gap:.3rem}.card-title{font-size:1.15rem;font-weight:700;color:#fff;margin:0}.card-time{font-size:.8rem;color:#3b82f6;display:flex;align-items:center;gap:.4rem;font-weight:500}.card-actions{display:flex;align-items:center;gap:1rem}.status-badge{padding:.3rem .6rem;border-radius:6px;font-size:.65rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.status-badge.approved{background:#064e3b66;color:#34d399;border:1px solid rgba(52,211,153,.1)}.status-badge.draft{background:#1e3a8a66;color:#60a5fa;border:1px solid rgba(96,165,250,.1)}.card-icons{display:flex;gap:.75rem;color:#475569}.card-snippet{font-size:.9rem;color:#cbd5e1;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.reflective-card{background:#1e2230;border-radius:16px;padding:1.5rem;display:flex;gap:1.5rem;border:1px solid transparent}.reflection-icon{background:#10b981;color:#0f111a;width:64px;height:64px;border-radius:12px;display:flex;justify-content:center;align-items:center;flex-shrink:0}.reflection-title{font-size:1.15rem;font-weight:700;color:#fff;margin:0 0 .5rem}.reflection-quote{font-size:.95rem;color:#e2e8f0;font-style:italic;line-height:1.6;margin:0 0 1rem}.reflection-tip{font-size:.85rem;color:#94a3b8}.tip-label{color:#34d399;font-weight:800;margin-right:.5rem;letter-spacing:.05em}.journal-widgets{display:flex;flex-direction:column;gap:1.5rem}.widget-card{background:#1e2230;border-radius:16px;padding:1.5rem;border:1px solid transparent}.widget-title-area{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.widget-title{font-size:1.15rem;font-weight:700;color:#fff;margin:0;display:flex;align-items:center;gap:.5rem}.cal-nav{display:flex;gap:.75rem;color:#fff;cursor:pointer}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:.75rem;margin-bottom:1.5rem}.cal-day-name{font-size:.7rem;font-weight:700;color:#94a3b8;text-transform:uppercase;margin-bottom:.5rem}.cal-date{font-size:.9rem;font-weight:700;color:#fff;padding:.4rem;border-radius:8px;cursor:pointer;transition:all .2s}.cal-date:hover{background:#ffffff0d}.cal-date.active{background:transparent;border:1px solid #34d399;color:#34d399}.cal-date.muted{color:#475569}.completion-rate{margin-top:2rem}.completion-header{display:flex;justify-content:space-between;font-size:.75rem;font-weight:800;margin-bottom:.5rem;letter-spacing:.05em}.rate-label{color:#94a3b8}.rate-value{color:#34d399}.progress-bar-bg{width:100%;height:8px;background:#2d3748;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:#34d399;border-radius:4px}.insight-stat{display:flex;gap:1.25rem;align-items:center;margin-bottom:1.5rem}.insight-stat:last-child{margin-bottom:0}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;justify-content:center;align-items:center;flex-shrink:0}.stat-icon.time{background:#22c55e1a;color:#34d399}.stat-icon.verify{background:#3b82f61a;color:#60a5fa}.stat-content{display:flex;flex-direction:column}.stat-label{font-size:.75rem;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem}.stat-value{font-size:1.4rem;font-weight:800;color:#fff;display:flex;align-items:baseline;gap:.3rem}.stat-sub{font-size:.8rem;color:#64748b;font-weight:600}.feedback-card{border:1px solid rgba(16,185,129,.2);background:#1e2230;position:relative;overflow:hidden}.feedback-card:before{content:"";position:absolute;inset:0;background:linear-gradient(145deg,rgba(16,185,129,.05) 0%,transparent 100%);pointer-events:none}.feedback-title{color:#10b981;font-size:.95rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.feedback-quote{font-size:.95rem;color:#cbd5e1;font-style:italic;line-height:1.6;margin:0 0 1.25rem}.feedback-author{display:flex;align-items:center;gap:.75rem}.author-avatar{width:28px;height:28px;border-radius:50%;background:#ea580c;display:flex;justify-content:center;align-items:center;overflow:hidden}.author-avatar img{width:100%;height:100%;object-fit:cover}.author-name{font-size:.85rem;font-weight:700;color:#fff}.journal-modal-overlay{position:fixed;inset:0;background:#0f111ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;justify-content:center;align-items:center;padding:2rem;animation:fadeIn .2s ease-out}.journal-modal-content{background:#1e2230;border:1px solid rgba(255,255,255,.05);border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.journal-modal-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}.journal-modal-header h3{margin:0;font-size:1.25rem;color:#fff}.journal-modal-close{background:transparent;border:none;color:#94a3b8;cursor:pointer;transition:color .2s}.journal-modal-close:hover{color:#fff}.journal-sections{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem}.journal-textarea-wrapper .journal-textarea{width:100%;min-height:180px;background:#0f111a;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;color:#fff;font-size:.95rem;resize:vertical;outline:none}.journal-textarea:focus{border-color:#34d399}.section-title{font-size:.85rem;font-weight:700;color:#94a3b8;margin-bottom:.5rem;display:block}.journal-actions{padding:1.5rem;border-top:1px solid rgba(255,255,255,.05);display:flex;gap:1rem;justify-content:flex-end}.btn-primary{background:#34d399;color:#0f111a;border:none;padding:.6rem 1.2rem;border-radius:8px;font-weight:700;cursor:pointer}.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.6rem 1.2rem;border-radius:8px;font-weight:600;cursor:pointer}.preview-modal-overlay{z-index:2000}@media(max-width:900px){.journal-container{padding-bottom:2rem}.journal-header{flex-direction:column;gap:1rem;align-items:flex-start}.journal-title{font-size:1.6rem}.journal-header-actions{width:100%;flex-wrap:wrap}.btn-filter,.btn-new-entry{flex:1;justify-content:center}.history-legend{flex-wrap:wrap;gap:.75rem}.journal-card,.reflective-card{gap:1rem}}@media(max-width:640px){.journal-container{gap:1.25rem;padding-bottom:2rem}.journal-title{font-size:1.35rem}.journal-subtitle{font-size:.85rem}.journal-card{flex-direction:column;gap:.75rem;padding:1rem}.card-date-box{width:100%;height:auto;flex-direction:row;gap:.5rem;padding:.5rem .75rem;border-radius:8px}.date-month,.date-day{font-size:.9rem}.card-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.card-actions{flex-wrap:wrap;gap:.5rem}.card-title{font-size:1rem}.card-snippet{font-size:.82rem}.reflective-card{flex-direction:column;gap:.75rem;padding:1rem}.reflection-icon{width:48px;height:48px;border-radius:10px}.reflection-title{font-size:1rem}.reflection-quote{font-size:.88rem}.journal-history-header{flex-direction:column;align-items:flex-start;gap:.5rem}.history-legend{gap:.5rem;font-size:.78rem}.widget-card{padding:1rem}.widget-title{font-size:1rem}.calendar-grid{gap:.4rem}.cal-date{font-size:.78rem;padding:.3rem}.journal-modal-overlay{padding:0;align-items:flex-end}.journal-modal-content{max-height:95vh;border-radius:16px 16px 0 0}.journal-modal-header,.journal-sections{padding:1rem}.journal-actions{padding:1rem;flex-direction:column-reverse;gap:.5rem}.journal-actions .btn-primary,.journal-actions .btn-secondary{width:100%;text-align:center;justify-content:center}.fab-new-entry{bottom:1.25rem;right:1.25rem;width:52px;height:52px}.insight-stat{gap:.75rem}.stat-icon{width:40px;height:40px}}@media(max-width:400px){.journal-title{font-size:1.15rem}.btn-filter,.btn-new-entry{font-size:.82rem;padding:.5rem .75rem}.journal-card{padding:.75rem}}.lightbox-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0f172ae6;z-index:10000;display:flex;justify-content:center;align-items:center}.lightbox-image{max-width:90%;max-height:90vh;border-radius:8px;box-shadow:0 10px 25px #00000080;object-fit:contain}.lightbox-close{position:absolute;top:2rem;right:2rem;background:transparent;border:none;color:#fff;font-size:3rem;cursor:pointer;line-height:1;transition:color .2s}.lightbox-close:hover{color:#ef4444}.announcements-container{display:flex;flex-direction:column;gap:1.5rem;animation:fadeIn .3s ease-out}.view-header{margin-bottom:.5rem}.view-title{font-size:1.75rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.view-subtitle{font-size:.88rem;color:var(--text-muted);margin-top:.25rem}.announcements-list{display:flex;flex-direction:column;gap:1rem}.announcement-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;transition:transform .2s,border-color .2s}.announcement-card:hover{border-color:var(--primary);transform:translateY(-2px)}.announcement-card.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.announcement-card.clickable:active{transform:translateY(0);opacity:.92}.announcement-card.expanded{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),0 4px 24px #10b9811a}.announcement-header{display:flex;justify-content:space-between;align-items:center}.announcement-card-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.announcement-date{font-size:.75rem;color:var(--text-muted)}.announcement-author{font-size:.75rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.announcement-content{font-size:.95rem;line-height:1.6;color:var(--text-secondary)}.notification-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.25rem;display:flex;gap:1rem;position:relative;transition:all .2s}.notification-card.read{opacity:.7}.notification-icon{width:40px;height:40px;border-radius:10px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.notification-card.danger{border-left:4px solid #ef4444}.notification-card.warning{border-left:4px solid #f59e0b}.notification-card.success{border-left:4px solid #10b981}.notification-card.info{border-left:4px solid #3b82f6}.notification-content{flex:1}.notification-card-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.notification-message{font-size:.88rem;color:var(--text-secondary);line-height:1.4}.unread-dot{position:absolute;top:12px;right:12px;width:8px;height:8px;background:var(--primary);border-radius:50%;box-shadow:0 0 6px var(--primary-glow)}.empty-state,.loading-state{padding:4rem 2rem;text-align:center;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border);border-radius:16px}.reactions-container{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.reactions-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.reaction-btn{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:8px;border:1px solid transparent;background:var(--bg-elevated);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.reaction-btn:hover{background:var(--bg-card);border-color:var(--border-hover);color:var(--text-primary);transform:translateY(-1px)}.reaction-btn.active{border-color:var(--primary);background:#10b9811a;color:var(--primary)}.reaction-btn .emoji{font-size:1.1rem;transition:transform .2s}.reaction-btn.active .emoji{transform:scale(1.1)}.reaction-btn .count{font-size:.85rem;opacity:.9}.ack-btn{padding:.4rem 1rem}.reactions-summary{position:relative;cursor:pointer;font-size:.85rem;color:var(--text-primary);font-weight:500;transition:opacity .2s}.reactions-summary:hover{text-decoration:underline;opacity:.8}.reactions-summary:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;right:0;margin-bottom:8px;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-bright);font-size:.75rem;white-space:pre-wrap;z-index:10;box-shadow:0 4px 12px #00000026;pointer-events:none;min-width:max-content;text-align:right;line-height:1.4}.reactions-summary[data-tooltip=""]:hover:after,.reactions-summary:not([data-tooltip]):hover:after{display:none}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.reactions-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:90%;max-width:450px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.reactions-tabs{display:flex;padding:0 1rem;border-bottom:1px solid var(--border);overflow-x:auto}.reactions-tabs::-webkit-scrollbar{height:0}.tab-btn{padding:1rem;border:none;background:none;color:var(--text-muted);font-weight:600;font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.reactions-list{flex:1;overflow-y:auto;padding:.5rem 0}.reaction-user-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;transition:background .2s}.reaction-user-item:hover{background:var(--bg-elevated)}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--bg-elevated);flex-shrink:0}.user-name{font-weight:500;font-size:.95rem;color:var(--text-primary)}.user-reaction-emoji{font-size:1.2rem}@media(max-width:768px){.announcement-header{flex-wrap:wrap;gap:.5rem}.reactions-container{flex-direction:column;align-items:flex-start}.reactions-bar{width:100%}.notification-card{flex-direction:column;gap:.75rem}.notification-icon{width:36px;height:36px}}@media(max-width:600px){.view-title{font-size:1.4rem}.view-subtitle{font-size:.82rem}.announcement-card{padding:1rem;gap:.5rem}.announcement-card-title{font-size:1rem}.announcement-content{font-size:.88rem}.announcement-date{font-size:.7rem}.empty-state,.loading-state{padding:2.5rem 1rem}.reaction-btn{padding:.35rem .65rem;font-size:.8rem}.reactions-tabs{padding:0 .5rem}.tab-btn{padding:.75rem .5rem;font-size:.82rem}.reaction-user-item{padding:.65rem 1rem}}.documents-container{display:flex;flex-direction:column;gap:1.5rem;animation:fadeIn .3s ease-out}.upload-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.upload-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;font-weight:700;color:var(--text-secondary)}.form-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;color:var(--text-primary);font-family:inherit;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--primary)}.file-input{padding:.5rem;background:var(--bg-elevated);border:1px dashed var(--border);border-radius:8px;color:var(--text-muted)}.file-hint{font-size:.75rem;color:var(--text-dim)}.upload-message{padding:.75rem;border-radius:8px;font-size:.88rem;font-weight:600}.form-actions{display:flex;align-items:center;gap:1rem}.form-actions .btn{width:auto;padding-left:2rem;padding-right:2rem}.upload-message.success{background:#22c55e1a;color:#22c55e}.upload-message.error{background:#ef44441a;color:#ef4444}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1rem}.document-item-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .2s}.document-item-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.document-icon{width:48px;height:48px;border-radius:10px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.document-info{flex:1;min-width:0}.document-item-title{font-size:.95rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-filename{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.document-meta{display:flex;align-items:center;gap:.5rem;font-size:.7rem}.status-badge{text-transform:uppercase;font-weight:800;font-size:.6rem;padding:2px 6px;border-radius:4px}.status-badge.pending{background:#f59e0b1a;color:#f59e0b}.status-badge.approved{background:#10b9811a;color:#10b981}.status-badge.rejected{background:#ef44441a;color:#ef4444}.document-actions{display:flex;gap:.25rem}.action-btn{width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.action-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.action-btn.delete{width:36px;height:36px;border-radius:50%;border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#ff4d4d;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.175,.885,.32,1.275);padding:0}.action-btn.delete:hover{background:#ef444426;border-color:#ff4d4d;transform:translateY(-2px) scale(1.1);box-shadow:0 4px 12px #ef44444d}.action-btn.delete svg{stroke:#ff4d4d!important;display:block!important;overflow:visible!important}.action-btn.delete:hover svg{stroke:#ff4d4d!important}.action-btn.delete polyline,.action-btn.delete path,.action-btn.delete line{stroke:#ff4d4d!important}@media(max-width:768px){.upload-area{padding:1.5rem}.upload-area p{font-size:.88rem}.doc-meta{flex-wrap:wrap;gap:.5rem}.view-header{flex-direction:column;align-items:flex-start;gap:.75rem}}@media(max-width:640px){.documents-grid{grid-template-columns:1fr}.doc-card{padding:1rem}.doc-header{gap:.75rem}.doc-icon{width:40px;height:40px;font-size:1.2rem}.doc-title{font-size:.92rem}.doc-actions{flex-wrap:wrap;gap:.5rem}.action-btn{padding:.4rem .6rem;font-size:.78rem}}.chat-widget-container{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:1rem;font-family:Inter,sans-serif}.chat-toggle-btn{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#059669);border:none;color:#fff;cursor:pointer;box-shadow:0 8px 24px #10b98166;display:flex;align-items:center;justify-content:center;transition:transform .25s cubic-bezier(.175,.885,.32,1.275);position:relative}.chat-toggle-btn:hover{transform:scale(1.08)}.chat-toggle-btn:active{transform:scale(.95)}.chat-unread-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:.75rem;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-page);animation:bounce .5s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.chat-window{width:380px;height:550px;max-height:calc(100vh - 120px);background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 48px #00000080,0 0 0 1px #ffffff0d;display:flex;flex-direction:column;overflow:hidden;transform-origin:bottom right;animation:chat-pop .3s cubic-bezier(.175,.885,.32,1.15)}@keyframes chat-pop{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:768px){.chat-widget-container{bottom:1rem;right:1rem}.chat-window{position:fixed;bottom:50%;right:50%;transform:translate(50%,50%);width:90vw;max-width:400px;height:70vh;z-index:10000;animation:chat-pop-mobile .3s cubic-bezier(.175,.885,.32,1.15)}@keyframes chat-pop-mobile{0%{opacity:0;transform:translate(50%,50%) scale(.9)}to{opacity:1;transform:translate(50%,50%) scale(1)}}}.chat-header{background:var(--bg-elevated);padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.chat-header-title{font-weight:700;font-size:1.05rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.chat-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;transition:background .15s,color .15s}.chat-close-btn:hover{background:#ffffff0d;color:var(--text-primary)}.chat-back-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;margin-right:.5rem;display:flex;align-items:center;border-radius:5px;transition:background .15s}.chat-back-btn:hover{background:#ffffff0d}.chat-list{flex:1;overflow-y:auto;padding:.5rem}.chat-list-item{display:flex;align-items:center;padding:.75rem;border-radius:12px;cursor:pointer;transition:background .2s;gap:.75rem;border:1px solid transparent}.chat-list-item:hover{background:var(--bg-elevated)}.chat-list-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;position:relative;flex-shrink:0}.online-indicator{position:absolute;bottom:2px;right:2px;width:10px;height:10px;background:#10b981;border-radius:50%;border:2px solid var(--bg-card)}.online-indicator.offline{background:var(--text-muted)}.chat-list-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-list-name{font-weight:600;color:var(--text-bright);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-preview{font-size:.8rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis}.chat-conversation-options-btn{background:transparent;border:none;color:var(--text-muted);opacity:0;transition:opacity .2s,background .2s;padding:6px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-list-item:hover .chat-conversation-options-btn{opacity:1}.chat-conversation-options-btn:hover{background:#ffffff1a;color:var(--text-primary)}.chat-list-unread{width:8px;height:8px;background:var(--primary);border-radius:50%}.chat-thread{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.chat-message{max-width:80%;padding:.75rem 1rem;border-radius:16px;font-size:.9rem;line-height:1.4;position:relative}.chat-message.sent{align-self:flex-end;background:linear-gradient(135deg,var(--primary),#059669);color:#fff;border-bottom-right-radius:4px}.chat-message.received{align-self:flex-start;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-time{font-size:.65rem;opacity:.7;margin-top:.25rem;text-align:right;display:block}.chat-message-options-btn{background:transparent;border:none;color:var(--text-muted);opacity:0;transition:opacity .2s,background .2s;padding:2px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-message-container:hover .chat-message-options-btn{opacity:1}.chat-message-options-btn:hover{background:#ffffff1a;color:var(--text-primary)}.chat-menu-item{background:transparent;border:none;color:var(--text-primary);padding:6px 12px;text-align:left;font-size:.8rem;cursor:pointer;border-radius:4px;display:flex;align-items:center;gap:.4rem;transition:background .15s;width:100%}.chat-menu-item:hover{background:var(--bg-elevated)}.chat-menu-item.danger{color:var(--danger)}.chat-menu-item.danger:hover{background:#ef44441a}.chat-input-area{padding:1rem;border-top:1px solid var(--border);display:flex;gap:.5rem;background:var(--bg-card)}.chat-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;padding:.6rem 1rem;color:var(--text-primary);font-size:.9rem;outline:none;font-family:inherit;transition:border-color .2s}.chat-input:focus{border-color:var(--primary)}.chat-send-btn{width:40px;height:40px;border-radius:50%;border:1px solid rgba(16,185,129,.3);background:#10b9810d;color:#10b981;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);flex-shrink:0;padding:0}.chat-send-btn:hover:not(:disabled){background:#10b9811a;border-color:#10b981;transform:translateY(-2px);box-shadow:0 4px 12px #10b98133}.chat-send-btn svg{stroke:#10b981!important;display:block}.chat-send-btn line,.chat-send-btn polygon{stroke:#10b981!important}.chat-send-btn:disabled{opacity:.2;cursor:not-allowed;background:transparent;border-color:#ffffff1a}.chat-send-btn:disabled svg,.chat-send-btn:disabled line,.chat-send-btn:disabled polygon{stroke:var(--text-muted)!important}@media(max-width:500px){.chat-window{width:calc(100vw - 2rem);max-height:calc(100vh - 100px)}}:root{--admin-primary: #10b981;--admin-primary-glow: rgba(16, 185, 129, .2);--admin-secondary: #0d9488}html,html[data-theme=dark]{--admin-bg: #0d0e1a;--admin-card-bg: rgba(19, 20, 31, .8);--admin-border: rgba(255, 255, 255, .07);--admin-text-primary: #f8fafc;--admin-text-secondary: #94a3b8;--admin-sidebar-bg: #13141f}html[data-theme=light]{--admin-bg: var(--bg-page);--admin-card-bg: var(--bg-card);--admin-border: var(--border);--admin-text-primary: var(--text-primary);--admin-text-secondary: var(--text-secondary);--admin-sidebar-bg: var(--bg-sidebar)}.admin-dashboard-container{display:flex;width:100%;min-height:100vh;background-color:var(--admin-bg);color:var(--admin-text-primary);overflow:hidden;position:relative;font-family:Inter,sans-serif}.admin-mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90}.mobile-menu-open .admin-mobile-overlay{display:block}.admin-sidebar{width:240px;height:100vh;background:var(--admin-sidebar-bg);border-right:1px solid var(--admin-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100;transition:width .3s cubic-bezier(.4,0,.2,1);overflow:visible}@media(min-width:1025px){.sidebar-mode-hover:not(:hover){width:72px}.sidebar-mode-hover:not(:hover) .admin-logo-text-group,.sidebar-mode-hover:not(:hover) .admin-sidebar-user-info,.sidebar-mode-hover:not(:hover) .nav-text{display:none}.sidebar-mode-collapsed{width:72px}.sidebar-mode-collapsed .nav-icon{margin-right:0!important;margin:0}.sidebar-mode-collapsed .admin-nav-item{justify-content:center}.sidebar-mode-collapsed .admin-logo-text-group,.sidebar-mode-collapsed .admin-sidebar-user-info,.sidebar-mode-collapsed .nav-text{display:none}.sidebar-mode-expanded{width:240px}}.admin-sidebar-header{padding:1rem;display:flex;align-items:center;gap:.75rem;height:70px;border-bottom:1px solid var(--admin-border)}.admin-logo-icon{width:32px;height:32px;background:var(--secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-logo-text-group{display:flex;flex-direction:column;overflow:hidden}.admin-logo-text{font-weight:700;font-size:.88rem;color:var(--admin-text-primary);line-height:1.2;white-space:nowrap}.admin-logo-sub{font-size:.68rem;color:var(--text-muted);white-space:nowrap}.admin-nav{flex:1;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto;overflow-x:hidden}.admin-nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;border-radius:8px;cursor:pointer;transition:all .2s;color:var(--admin-text-secondary);font-weight:500;white-space:nowrap;position:relative;overflow:hidden}.admin-nav-item .nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:18px;height:18px}.admin-nav-item .nav-text{font-size:.85rem;white-space:nowrap;transition:opacity .2s}.admin-nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.admin-nav-item.active{background:var(--nav-active-bg);color:var(--nav-active-text);box-shadow:inset 0 0 0 1px var(--admin-primary-glow)}.admin-nav-item.active svg{color:#10b981;filter:drop-shadow(0 0 4px rgba(16,185,129,.4))}.nav-badge{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;box-shadow:0 2px 8px #ef444466;transition:opacity .2s;border:2px solid var(--admin-sidebar-bg)}.sidebar-mode-collapsed .nav-badge,.sidebar-mode-hover:not(:hover) .nav-badge{right:8px;top:8px;transform:none;width:8px;height:8px;min-width:0;padding:0;font-size:0;border:2px solid var(--admin-sidebar-bg)}.admin-sidebar-bottom{padding:1rem;border-top:1px solid var(--admin-border);display:flex;flex-direction:column;gap:.25rem;overflow-x:hidden}.admin-sidebar-control-menu{position:absolute;bottom:100%;left:.5rem;width:200px;margin-bottom:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 24px #0003;z-index:101;overflow:hidden}.admin-sidebar-control-header{padding:.75rem 1rem;font-size:.75rem;color:#64748b;border-bottom:1px solid var(--admin-border)}.admin-sidebar-control-options{padding:.25rem}.admin-sidebar-control-option{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;color:var(--text-primary);font-size:.85rem;cursor:pointer;border-radius:6px}.admin-sidebar-control-option:hover{background:var(--bg-elevated)}.admin-sidebar-control-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--admin-border);display:flex;align-items:center;justify-content:center}.admin-sidebar-control-radio-inner{width:8px;height:8px;border-radius:50%;background:#10b981}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;margin-left:240px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}@media(min-width:1025px){.sidebar-mode-collapsed~.admin-main,.sidebar-mode-hover:not(:hover)~.admin-main{margin-left:72px}}.admin-topbar{height:70px;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--admin-border);background:var(--admin-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:40}.admin-mobile-toggle{display:none;background:transparent;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;margin-left:-.5rem}.admin-topbar-title{font-size:1rem;font-weight:600;color:var(--admin-text-primary)}.admin-topbar-right,.admin-topbar-actions{display:flex;align-items:center;gap:.75rem}.admin-topbar-icon-btn{background:none;border:none;outline:none;color:var(--admin-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;transition:all .2s;position:relative}.admin-topbar-icon-btn:hover,.admin-topbar-icon-btn:focus{background:var(--bg-elevated);color:var(--admin-text-primary);outline:none}.admin-topbar-notification-dot{position:absolute;top:6px;right:8px;width:8px;height:8px;border-radius:50%;background:#f43f5e;border:2px solid var(--admin-bg)}.admin-topbar-divider{width:1px;height:24px;background:var(--admin-border);margin:0 .5rem}.admin-topbar-user-btn{display:flex;align-items:center;gap:.75rem;background:none;border:none;outline:none;cursor:pointer;padding:.25rem .5rem;border-radius:12px;transition:background .2s;text-align:right}.admin-topbar-user-btn:hover,.admin-topbar-user-btn:focus{background:var(--bg-elevated);outline:none}.admin-topbar-user-info{display:flex;flex-direction:column;align-items:flex-end}.admin-topbar-user-name{font-size:.85rem;font-weight:700;color:var(--admin-text-primary);line-height:1.2;white-space:nowrap}.admin-topbar-user-role{font-size:.65rem;font-weight:700;color:#10b981;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.admin-topbar-avatar{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #10b98133}.admin-page-content{flex:1;overflow-y:auto;padding:2rem;background:radial-gradient(circle at top right,rgba(16,185,129,.05),transparent 40%),radial-gradient(circle at bottom left,rgba(13,148,136,.05),transparent 40%);display:flex;flex-direction:column;gap:1.5rem}.admin-welcome-banner{position:relative;background:linear-gradient(135deg,#0d9488,#065f46 60%,#1e1b4b);border-radius:18px;padding:2rem 2.5rem;overflow:hidden;margin-bottom:.5rem}.admin-welcome-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(255,255,255,.08) 0%,transparent 60%),radial-gradient(ellipse at 10% 80%,rgba(16,185,129,.2) 0%,transparent 50%);pointer-events:none}.admin-welcome-content{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.admin-welcome-greeting{font-size:.85rem;color:#ffffffa6;margin-bottom:.25rem;letter-spacing:.03em}.admin-welcome-name{font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:.35rem;line-height:1.2}.admin-welcome-sub{font-size:.85rem;color:#ffffff8c}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:.5rem}.admin-stat-card{background:var(--admin-card-bg);border:1px solid var(--admin-border);padding:1.5rem;border-radius:16px;display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.admin-stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -10px #00000080;border-color:#ffffff1a}.admin-stat-icon-wrap{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-value{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:.25rem}.admin-stat-label{color:var(--admin-text-secondary);font-size:.875rem;font-weight:500}.admin-table-card{background:var(--admin-card-bg);border:1px solid var(--admin-border);border-radius:20px;overflow:hidden;box-shadow:0 20px 25px -5px #0003}.admin-table-header{padding:1.5rem;border-bottom:1px solid var(--admin-border);display:flex;justify-content:space-between;align-items:center}.admin-table-title{font-size:1.25rem;font-weight:600;color:var(--admin-text-primary)}.admin-table-wrapper{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:1rem 1.5rem;color:var(--admin-text-secondary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-elevated)}.admin-table td{padding:1rem 1.5rem;border-bottom:1px solid var(--admin-border);font-size:.875rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-hover, var(--bg-elevated))}.admin-user-cell{display:flex;align-items:center;gap:.75rem}.admin-badge{padding:.25rem .625rem;border-radius:20px;font-size:.75rem;font-weight:600}.badge-student{background:var(--badge-student-bg, rgba(16, 185, 129, .15));color:var(--badge-student-text, #10b981)}.badge-coordinator{background:var(--badge-coordinator-bg, rgba(13, 148, 136, .15));color:var(--badge-coordinator-text, #0d9488)}.badge-admin{background:var(--badge-admin-bg, rgba(245, 158, 11, .15));color:var(--badge-admin-text, #f59e0b)}.role-select{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);padding:.4rem .75rem;border-radius:8px;font-size:.8rem;cursor:pointer;outline:none}.role-select:focus{border-color:var(--admin-primary)}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.admin-page-content::-webkit-scrollbar{width:6px}.admin-page-content::-webkit-scrollbar-track{background:transparent}.admin-page-content::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:10px}.admin-page-content::-webkit-scrollbar-thumb:hover{background:#fff3}@media(max-width:1024px){.admin-sidebar{left:-240px;width:240px!important}.admin-sidebar.mobile-open{left:0;box-shadow:4px 0 24px #00000080}.admin-main{margin-left:0!important}.admin-mobile-toggle{display:block}.admin-welcome-name{font-size:1.4rem}}@media(max-width:640px){.admin-page-content{padding:1rem}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-welcome-banner{padding:1.25rem}.admin-welcome-name{font-size:1.3rem}.admin-topbar{padding:0 .75rem}.admin-topbar-user-info,.admin-topbar-divider{display:none}.admin-table th,.admin-table td{padding:.65rem .5rem;font-size:.8rem}.admin-stat-card{padding:1rem}.admin-stat-value{font-size:1.5rem}}@media(max-width:400px){.admin-stats-grid{grid-template-columns:1fr}}.clickable-row{cursor:pointer;transition:background .15s ease,transform .15s ease}.clickable-row:hover td{background:var(--bg-elevated)!important;color:var(--text-bright)!important}.clickable-row:active{transform:scale(.998)}*{box-sizing:border-box;margin:0;padding:0}.dashboard-container{display:flex;min-height:100vh;width:100vw;background:var(--bg-page);color:var(--text-secondary);font-family:var(--font-inter);overflow:hidden}.sidebar{width:240px;height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:110;transition:width .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1);will-change:width;overflow:visible}@media(min-width:1025px){.sidebar.sidebar-mode-hover:not(:hover){width:72px}.sidebar.sidebar-mode-hover:hover{box-shadow:4px 0 24px #00000026}.sidebar.sidebar-mode-hover:not(:hover) .sidebar-logo-text-group,.sidebar.sidebar-mode-hover:not(:hover) .sidebar-user-info,.sidebar.sidebar-mode-hover:not(:hover) .nav-text,.sidebar.sidebar-mode-hover:not(:hover) .sidebar-section-label{opacity:0;display:none}.sidebar.sidebar-mode-hover:not(:hover) .sidebar-logo,.sidebar.sidebar-mode-hover:not(:hover) .sidebar-user,.sidebar.sidebar-mode-hover:not(:hover) .sidebar-nav-item,.sidebar.sidebar-mode-hover:not(:hover) .logout-btn{justify-content:center}.sidebar.sidebar-mode-hover:not(:hover) .sidebar-logo{padding:1.25rem 0}.sidebar.sidebar-mode-hover:not(:hover) .sidebar-user{padding:1rem 0}.sidebar.sidebar-mode-hover:not(:hover) .sidebar-nav-item{padding:.75rem 0}.sidebar.sidebar-mode-hover:not(:hover) .nav-icon{margin-right:0!important;margin:0}.sidebar.sidebar-mode-hover:not(:hover) .logout-btn{padding:.75rem 0}.sidebar.sidebar-mode-collapsed{width:72px}.sidebar.sidebar-mode-collapsed .sidebar-logo-text-group,.sidebar.sidebar-mode-collapsed .sidebar-user-info,.sidebar.sidebar-mode-collapsed .nav-text,.sidebar.sidebar-mode-collapsed .sidebar-section-label{opacity:0;display:none}.sidebar.sidebar-mode-collapsed .sidebar-logo,.sidebar.sidebar-mode-collapsed .sidebar-user,.sidebar.sidebar-mode-collapsed .sidebar-nav-item,.sidebar.sidebar-mode-collapsed .logout-btn{justify-content:center}.sidebar.sidebar-mode-collapsed .sidebar-logo{padding:1.25rem 0}.sidebar.sidebar-mode-collapsed .sidebar-user{padding:1rem 0}.sidebar.sidebar-mode-collapsed .sidebar-nav-item{padding:.75rem 0}.sidebar.sidebar-mode-collapsed .nav-icon{margin-right:0!important;margin:0}.sidebar.sidebar-mode-collapsed .logout-btn{padding:.75rem 0}.sidebar.sidebar-mode-expanded{width:240px;box-shadow:4px 0 24px #00000026}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;gap:.25rem;border-bottom:1px solid var(--border);height:70px;position:relative}.sidebar-logo{display:flex;align-items:center;gap:.5rem;flex:1;overflow:hidden;padding-right:.25rem}.sidebar-logo-icon{width:32px;height:32px;background:var(--secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;transition:transform .2s}.sidebar-logo-text-group{display:flex;flex-direction:column;min-width:0;transition:opacity .2s}.sidebar-logo-text{font-size:.88rem;font-weight:700;color:var(--text-primary);line-height:1.2;white-space:nowrap}.sidebar-logo-sub{font-size:.68rem;color:var(--text-muted);font-weight:400;white-space:nowrap}.sidebar-toggle-btn{display:none}.sidebar-scrollable{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.sidebar-section-label{padding:1.25rem 1.25rem .4rem;font-size:.65rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;transition:opacity .2s;white-space:nowrap}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;padding:.5rem .75rem}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none;height:40px}.sidebar-nav-item:hover{background:var(--bg-elevated);color:var(--text-primary);transform:translate(4px)}.sidebar-nav-item.active{background:var(--nav-active-bg);color:var(--nav-active-text)}.sidebar-nav-item.active .nav-icon{color:var(--primary)}.nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:18px;height:18px}.nav-text{white-space:nowrap;transition:opacity .2s}.sidebar-bottom{margin-top:auto;padding:1rem .5rem;border-top:1px solid var(--border)}.logout-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .75rem;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--text-muted);background:transparent;border:none;cursor:pointer;font-family:Inter,sans-serif;transition:all .15s ease;text-align:left;height:40px}.logout-btn:hover{background:#ef44441a;color:#f87171;transform:translate(4px)}.sidebar-control-menu{position:absolute;bottom:100%;left:.5rem;width:200px;margin-bottom:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 24px #0003;z-index:101;overflow:hidden;animation:slideUp .15s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar-control-header{padding:.75rem 1rem;font-size:.75rem;color:var(--text-dim);border-bottom:1px solid var(--border)}.sidebar-control-options{display:flex;flex-direction:column;padding:.25rem}.sidebar-control-option{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;color:var(--text-primary);font-size:.85rem;cursor:pointer;border-radius:6px;transition:background .1s}.sidebar-control-option:hover{background:var(--bg-elevated)}.sidebar-control-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;transition:border-color .1s}.sidebar-control-option:hover .sidebar-control-radio{border-color:var(--text-muted)}.sidebar-control-radio:has(.sidebar-control-radio-inner){border-color:var(--text-bright)}.sidebar-control-radio-inner{width:8px;height:8px;border-radius:50%;background:var(--primary)}.dashboard-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow-y:auto;height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}@media(min-width:1025px){.dashboard-main{margin-left:72px}.dashboard-main.sidebar-expanded{margin-left:240px}}.topbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--bg-page);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}.topbar-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.topbar-date{font-size:.78rem;color:var(--text-muted);margin-top:2px}.topbar-right,.topbar-actions{display:flex;align-items:center;gap:.75rem}.topbar-icon-btn{background:none;border:none;outline:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;transition:all .2s;position:relative}.topbar-icon-btn:hover,.topbar-icon-btn:focus{background:var(--bg-elevated);color:var(--text-primary);outline:none}.topbar-notification-dot{position:absolute;top:6px;right:8px;width:8px;height:8px;border-radius:50%;background:#f43f5e;border:2px solid var(--bg-page)}.topbar-divider{width:1px;height:24px;background:var(--border);margin:0 .5rem}@media(max-width:480px){.topbar-divider,.topbar-user-info,.topbar-user-name,.topbar-user-role{display:none}}.topbar-user-btn{display:flex;align-items:center;gap:.75rem;background:none;border:none;outline:none;cursor:pointer;padding:.25rem .5rem;border-radius:12px;transition:background .2s;text-align:right}.topbar-user-btn:hover,.topbar-user-btn:focus{background:var(--bg-elevated);outline:none}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-end}.topbar-user-name{font-size:.85rem;font-weight:700;color:var(--text-bright);line-height:1.2;white-space:nowrap}.topbar-user-role{font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.topbar-avatar{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff;flex-shrink:0}.topbar-badge{font-size:.72rem;font-weight:600;padding:.3rem .8rem;border-radius:99px;background:var(--bg-elevated);color:var(--primary);border:1px solid var(--border)}.page-content{padding:2rem;display:flex;flex-direction:column;gap:1.5rem;flex:1}.timer-hero{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:stretch;isolation:isolate}.timer-main-card{background:var(--bg-hero);border:1px solid var(--border);border-radius:16px;padding:2.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;position:relative;overflow:hidden;min-height:280px}.timer-main-card:before{content:"";position:absolute;top:-60px;left:50%;transform:translate(-50%);width:400px;height:200px;background:radial-gradient(ellipse,rgba(16,185,129,.12) 0%,transparent 70%);pointer-events:none}.timer-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.timer-clock{font-size:5.5rem;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-3px;color:var(--text-primary);line-height:1;text-shadow:0 0 40px var(--primary-glow)}.timer-clock.on-break{font-size:2.5rem;color:var(--warning);text-shadow:0 0 30px rgba(251,191,36,.3);letter-spacing:-1px}.timer-controls{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.timer-side-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.side-card-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.info-row{display:flex;flex-direction:column;gap:.85rem}.info-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px}.info-item-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.info-item-value{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.progress-wrap{display:flex;flex-direction:column;gap:.5rem}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-title{font-size:.72rem;color:var(--text-muted);font-weight:500}.progress-pct{font-size:.72rem;font-weight:700;color:var(--primary)}.progress-bar-bg{height:6px;background:var(--bg-elevated);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:99px;transition:width 1s ease;box-shadow:0 0 8px var(--primary-glow)}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;transition:border-color .2s,transform .2s}.stat-card:hover{border-color:var(--primary);transform:translateY(-2px)}.stat-icon{font-size:1.2rem;margin-bottom:.25rem}.stat-label{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}html[data-theme=light] .stat-label{color:var(--text-muted)}.stat-value{font-size:1.8rem;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1}.stat-sub{font-size:.72rem;color:var(--text-muted)}.activity-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;flex:1}.activity-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.activity-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.activity-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 0;gap:.75rem;color:var(--text-dim)}.activity-empty-icon{font-size:2.5rem}.activity-empty p{font-size:.82rem;color:var(--text-dim)}.activity-list{margin-top:.5rem}.activity-items{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;transition:all .2s ease}.activity-item.active{border-color:var(--primary);background:#10b9810a}.activity-item-info{display:flex;flex-direction:column;gap:.25rem}.activity-item-time{font-size:.88rem;font-weight:600;color:var(--text-primary)}.activity-item-status{font-size:.72rem;color:var(--text-muted);font-weight:500}.activity-item-duration{font-size:.9rem;font-weight:700;color:var(--primary);background:var(--bg-page);padding:.4rem .8rem;border-radius:8px;border:1px solid var(--border)}.activity-item.active .activity-item-duration{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 12px var(--primary-glow)}.status-pill{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;padding:.3rem .85rem;border-radius:99px;font-size:.78rem;letter-spacing:.02em}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-pill.working{background:#22c55e1a;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.status-pill.working .status-dot{background:#4ade80;box-shadow:0 0 6px #4ade80;animation:blink 1.2s ease-in-out infinite}.status-pill.break{background:#fbbf241a;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.status-pill.break .status-dot{background:#fbbf24}.status-pill.inactive{background:#ffffff0a;color:#4b5068;border:1px solid rgba(255,255,255,.07)}.status-pill.inactive .status-dot{background:#3a3d52}@keyframes blink{0%,to{opacity:1}50%{opacity:.25}}.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem 1.75rem;border-radius:10px;font-size:.88rem;font-weight:600;cursor:pointer;border:none;font-family:Inter,sans-serif;transition:all .18s ease;letter-spacing:.01em;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 4px 18px var(--primary-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #10b9818c}.btn-secondary{background:#ffffff0d;color:#94a3b8;border:1px solid rgba(255,255,255,.08)}.btn-secondary:hover:not(:disabled){background:#ffffff17;color:#c8ccd8}.btn-secondary.active{background:#fbbf241a;color:#fbbf24;border-color:#fbbf2440}html[data-theme=light] .btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}html[data-theme=light] .btn-secondary:hover:not(:disabled){background:var(--bg-card);color:var(--text-primary);border-color:var(--primary)}html[data-theme=light] .status-pill.working{background:#dcfce7;color:#166534;border-color:#bbf7d0}html[data-theme=light] .status-pill.working .status-dot{background:#22c55e;box-shadow:0 0 6px #22c55e66}html[data-theme=light] .status-pill.break{background:#fef3c7;color:#92400e;border-color:#fde68a}html[data-theme=light] .status-pill.inactive{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}html[data-theme=light] .status-pill.inactive .status-dot{background:#94a3b8}html[data-theme=light] .btn-danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}html[data-theme=light] .btn-danger:hover:not(:disabled){background:#fecaca;color:#7f1d1d}.btn-danger{background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.2)}.btn-danger:hover:not(:disabled){background:#ef44442e;box-shadow:0 4px 14px #ef444433}.btn-shift{background:var(--bg-elevated)!important;border:1px solid var(--border)!important;color:var(--text-dim)!important;min-width:190px;justify-content:center;padding:.8rem 1.5rem!important;font-size:.88rem!important;transition:all .25s cubic-bezier(.4,0,.2,1)!important;opacity:.8}.btn-shift:hover:not(:disabled){background:var(--bg-card)!important;color:var(--text-primary)!important;border-color:var(--border-hover)!important;opacity:1;transform:translateY(-2px)}.btn-shift.suggested{background:#10b98114!important;border:1px solid var(--primary)!important;color:var(--primary)!important;opacity:1;box-shadow:0 0 20px #10b9811a}.btn-shift.suggested:hover{background:var(--primary)!important;color:#fff!important;box-shadow:0 6px 22px var(--primary-glow)}.dashboard-loading{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:#0d0e1a;color:#3a3d52;font-family:Inter,sans-serif;font-size:.85rem;letter-spacing:.05em}.profile-top-grid{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;align-items:start;margin-bottom:1.25rem}.profile-avatar-card{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.profile-avatar-card>div:first-child{flex-shrink:0}.profile-avatar-card>div:nth-child(2){flex:1}.profile-name-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.profile-academic-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}@media(max-width:700px){.profile-top-grid{grid-template-columns:1fr}.profile-avatar-card{flex-direction:row;flex-wrap:wrap;text-align:left;padding:1rem 1.25rem!important;gap:1.25rem}.profile-academic-grid{grid-template-columns:1fr 1fr}}@media(max-width:600px){.profile-name-grid,.profile-academic-grid{grid-template-columns:1fr}.profile-avatar-card{flex-direction:column;align-items:center;text-align:center}}.greeting-banner{background:linear-gradient(135deg,#0d9488,#065f46 60%,#0d0e1a);border-radius:16px;padding:1.5rem 2rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;box-shadow:0 8px 32px #10b98133;flex-wrap:wrap}.greeting-banner-text{flex:1;min-width:0}.greeting-banner-sub{font-size:.82rem;color:#a7f3d0cc;margin-bottom:.25rem;font-weight:500}.greeting-banner-name{font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.01em;margin-bottom:.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.greeting-banner-date{font-size:.78rem;color:#a7f3d0a6}.greeting-banner-actions{display:flex;gap:.75rem;flex-shrink:0;flex-wrap:wrap}.greeting-banner-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;padding:.5rem 1.1rem;font-size:.82rem;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-family:Inter,sans-serif;white-space:nowrap;transition:background .15s}.greeting-banner-btn:hover{background:#ffffff38}@media(max-width:700px){.greeting-banner{flex-direction:column;align-items:flex-start;padding:1.25rem;gap:1rem}.greeting-banner-name{font-size:1.2rem}.greeting-banner-actions{width:100%}.greeting-banner-btn{flex:1;text-align:center;padding:.55rem .75rem}}@media(max-width:400px){.greeting-banner{padding:1rem}.greeting-banner-name{font-size:1.05rem}.greeting-banner-date{display:none}.greeting-banner-actions{flex-direction:column}.greeting-banner-btn{width:100%}}.d-none-mobile{display:flex}.mobile-overlay{display:none;position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:199}.mobile-menu-open .mobile-overlay{display:block}.mobile-menu-toggle,.mobile-close-btn{display:none}@media(max-width:900px){.sidebar{position:fixed;top:0;left:-260px;height:100vh;width:240px!important;z-index:200;transition:left .28s cubic-bezier(.4,0,.2,1),box-shadow .28s;box-shadow:none}.sidebar.mobile-open{left:0!important;box-shadow:12px 0 48px #00000073}.mobile-overlay,.sidebar-toggle-btn{display:none}.mobile-menu-toggle{display:flex;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:8px;align-items:center;justify-content:center;transition:background .15s}.mobile-menu-toggle:hover{background:var(--bg-elevated);color:var(--text-secondary)}.mobile-close-btn{display:flex;background:transparent;border:none;color:var(--text-muted);cursor:pointer;position:absolute;top:50%;right:1.25rem;transform:translateY(-50%);z-index:120}.sidebar-header{height:auto;min-height:70px}.main-content{margin-left:0!important}.topbar{padding:.75rem 1rem}.topbar-date{display:none}.page-content{padding:1rem}.d-none-mobile{display:none!important}.timer-hero{grid-template-columns:1fr}.stats-row{grid-template-columns:1fr 1fr}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:560px}.form-row{grid-template-columns:1fr 1fr}}@media(max-width:640px){.topbar{padding:.65rem .85rem}.topbar-right{gap:.5rem}.topbar-date{display:none}.page-content{padding:.75rem}.timer-main-card{padding:1.25rem;min-height:auto}.timer-clock{font-size:3rem!important}.timer-hero{gap:.75rem}.stats-row{grid-template-columns:1fr 1fr;gap:.6rem}.stat-card{padding:.85rem .75rem}.btn{padding:.6rem 1rem;font-size:.82rem}.view-header{flex-direction:column;align-items:flex-start!important;gap:.75rem}.view-header>div:last-child{width:100%}.form-row{grid-template-columns:1fr!important}.data-table{min-width:480px;font-size:.82rem}.data-table th,.data-table td{padding:.6rem .75rem}.profile-col-wrap{flex-direction:column!important}.sidebar-nav-item{padding:.85rem 1.25rem;min-height:48px}.logout-btn{min-height:48px}}@media(max-width:400px){.timer-clock{font-size:2.4rem!important}.stats-row{grid-template-columns:1fr}.stat-card{flex-direction:row;gap:.75rem;align-items:center;padding:.75rem 1rem}.topbar-title{font-size:.9rem}.page-content{padding:.5rem}}@media(max-width:1024px){.sidebar{position:fixed;left:-240px;transition:left .3s ease}.mobile-menu-open .sidebar{left:0;box-shadow:20px 0 50px #00000080}.mobile-menu-open .mobile-overlay{display:block}.mobile-menu-toggle{display:flex;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;padding:6px;border-radius:8px;transition:all .2s ease}.mobile-menu-toggle:hover{background:var(--bg-card);border-color:var(--primary);transform:translateY(-1px)}.sidebar-header{padding-right:5.5rem;height:auto;min-height:70px}.sidebar-logo-sub{white-space:normal;line-height:1.2}.mobile-close-btn{display:flex;background:transparent;border:none;color:#4b5068;cursor:pointer;position:absolute;top:50%;right:1.25rem;transform:translateY(-50%);z-index:120}.d-none-mobile{display:none!important}.topbar,.page-content{padding:1rem}.timer-hero{grid-template-columns:1fr}.timer-main-card{padding:1.5rem;min-height:auto}.timer-clock{font-size:4rem}.stats-row{grid-template-columns:1fr 1fr}}@media(max-width:640px){.stats-row{grid-template-columns:1fr}.timer-clock{font-size:3rem}.topbar-date{display:none}.topbar-right{gap:.5rem}.btn{padding:.6rem 1rem;font-size:.8rem}}@media(max-width:900px){form .btn-primary,form .btn.btn-primary,form button[type=submit].btn-primary,.settings-card .btn,.settings-card button{width:100%;text-align:center;justify-content:center}.btn-secondary[style*=ef4444],.btn-secondary[style*=sign]{width:100%;text-align:center}}@media(max-width:768px){.search-bar-wrap,.filter-bar,.search-filter-row{flex-direction:column!important;gap:.75rem!important;width:100%}.search-bar-wrap input,.filter-bar input,.search-filter-row input{width:100%}.card-header-row,.section-header-row{flex-direction:column;align-items:flex-start!important;gap:.75rem}}@media(max-width:640px){.modal-content,.modal-box,.dialog-content{border-radius:16px 16px 0 0;max-height:90vh;width:100%!important;margin:0!important;position:fixed;bottom:0;left:0;right:0}.topbar{padding:.6rem .75rem}.topbar-badge{display:none}}.table-container,.data-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:640px){.admin-topbar{padding:0 1rem}.admin-topbar-user-info,.admin-topbar-divider{display:none}.admin-welcome-name{font-size:1.2rem}.admin-welcome-banner{padding:1.25rem}}@media(max-width:640px){.view-title{font-size:1.3rem!important}.view-subtitle{font-size:.82rem!important}.filter-row{flex-direction:column;gap:.75rem}.filter-row select,.filter-row input{width:100%}}@media(max-width:600px){.group-modal-content,.modal-container{width:95vw!important;max-height:90vh;overflow-y:auto}}@media(max-width:640px){.performance-header{flex-direction:column;align-items:flex-start;gap:.75rem}.performance-header h2{font-size:1.2rem}.kpi-card{padding:1rem}.kpi-value{font-size:1.4rem}}@media(max-width:768px){.form-actions{flex-direction:column;align-items:stretch}.form-actions .btn{width:100%!important;padding-left:1rem;padding-right:1rem;justify-content:center}}@media(max-width:768px){.profile-top-grid,.profile-name-grid,.profile-academic-grid{grid-template-columns:1fr}.profile-avatar-card{flex-direction:row;text-align:left;gap:1rem}}@media(max-width:768px){.cd-overview-layout{flex-direction:column;min-height:auto}.cd-overview-side-col{width:100%}.cd-welcome-name{font-size:1.3rem}.cd-welcome-banner{padding:1.25rem 1.5rem}.cd-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:400px){.cd-stats-grid{grid-template-columns:1fr}}@media(max-width:600px){.user-profile-modal,.profile-modal-inner{width:95vw!important;max-height:90vh}}@media(max-width:480px){.celebration-modal{width:90vw;padding:1.5rem 1rem}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.loading-pulse-logo{width:64px;height:64px;background:var(--secondary);border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 30px #10b9814d;border:1px solid rgba(255,255,255,.1);animation:pulse-glow 2s infinite ease-in-out}@keyframes pulse-glow{0%{transform:scale(.95);box-shadow:0 0 #10b98166}70%{transform:scale(1);box-shadow:0 0 0 20px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.btn.loading{position:relative;cursor:wait!important;opacity:.8!important}.btn-loading-text{display:flex;align-items:center;gap:.5rem}.btn-loading-text:before{content:"";width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-pill{display:flex;align-items:center;gap:.5rem;padding:.35rem .8rem;border-radius:50px;font-size:.8rem;font-weight:600;transition:all .2s ease;border:1px solid transparent}.pill-dot{width:8px;height:8px;border-radius:50%}.pill-working{background:#10b9811a;color:#10b981;border-color:#10b98133}.pill-working .pill-dot{background:#10b981;box-shadow:0 0 8px #10b98180;animation:pulse-dot 2s infinite}.pill-break{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b33}.pill-break .pill-dot{background:#f59e0b}.pill-inactive{background:var(--bg-secondary);color:var(--text-muted);border-color:var(--border)}.pill-inactive .pill-dot{background:var(--text-muted)}@keyframes pulse-dot{0%{transform:scale(.95);opacity:.8}50%{transform:scale(1.1);opacity:1}to{transform:scale(.95);opacity:.8}}@media(max-width:768px){.status-pill{padding:.3rem .5rem}.pill-text{display:none}}@media(min-width:769px){.pill-text{display:inline}}.cd-logo-icon{background:var(--secondary)!important;box-shadow:none!important}.cd-avatar{background:linear-gradient(135deg,#10b981,#059669)!important;box-shadow:0 4px 10px #10b98140;font-size:.72rem!important;letter-spacing:.03em}.cd-role-badge{display:inline-flex!important;align-items:center;gap:.3rem;font-size:.62rem!important;font-weight:700!important;color:#10b981!important;letter-spacing:.06em;text-transform:uppercase}.cd-role-badge:before{content:"";display:inline-block;width:5px;height:5px;background:#10b981;border-radius:50%;box-shadow:0 0 5px #10b981;animation:cd-pulse 2s ease-in-out infinite}@keyframes cd-pulse{0%,to{opacity:1}50%{opacity:.4}}.btn-approve{background:#10b981!important;color:#fff!important;border:none!important}.btn-approve:hover{background:#059669!important}.btn-reject{background:#ef44441a!important;color:#ef4444!important;border:1px solid rgba(239,68,68,.2)!important}.btn-reject:hover{background:#ef444433!important}html[data-theme=light] .btn-reject{background:#fee2e2!important;border-color:#fecaca!important}html[data-theme=light] .btn-reject:hover{background:#fecaca!important}.cd-alert-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:99px;color:#f59e0b;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .2s;font-family:Inter,sans-serif}.cd-alert-btn:hover{background:#f59e0b2e}.cd-alert-dot{width:7px;height:7px;background:#f59e0b;border-radius:50%;box-shadow:0 0 6px #f59e0b;animation:cd-pulse 1.2s ease-in-out infinite}.cd-topbar-avatar{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d}.cd-topbar-avatar:hover{transform:scale(1.05)}.notification-badge{position:absolute;top:-6px;right:-8px;background-color:#f43f5e;color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--bg-sidebar);animation:cd-pop .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes cd-pop{0%{transform:scale(0)}80%{transform:scale(1.15)}to{transform:scale(1)}}.cd-spinner{width:36px;height:36px;border:3px solid rgba(16,185,129,.15);border-top-color:#10b981;border-radius:50%;animation:cd-spin .75s linear infinite;margin:0 auto}@keyframes cd-spin{to{transform:rotate(360deg)}}.fade-in{animation:cd-fadeIn .3s ease}@keyframes cd-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cd-welcome-banner{position:relative;background:linear-gradient(135deg,#0d9488,#065f46 60%,#1e1b4b);border-radius:18px;padding:2rem 2.5rem;overflow:hidden;margin-bottom:.5rem}.cd-welcome-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(255,255,255,.08) 0%,transparent 60%),radial-gradient(ellipse at 10% 80%,rgba(16,185,129,.2) 0%,transparent 50%);pointer-events:none}.cd-welcome-content{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.cd-welcome-greeting{font-size:.85rem;color:#ffffffa6;margin-bottom:.25rem;letter-spacing:.03em}.cd-welcome-name{font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:.35rem;line-height:1.2}.cd-welcome-sub{font-size:.85rem;color:#ffffff8c}.cd-welcome-actions{display:flex;gap:.75rem;flex-wrap:wrap}.cd-btn-light{background:#ffffff26!important;border:1px solid rgba(255,255,255,.25)!important;color:#fff!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cd-btn-light:hover{background:#ffffff40!important}.cd-btn-ghost{background:transparent!important;border:1px solid rgba(255,255,255,.2)!important;color:#ffffffbf!important}.cd-btn-ghost:hover{background:#ffffff1a!important;color:#fff!important}.cd-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.cd-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.cd-stat-card:after{content:"";position:absolute;inset:0;background:var(--glow, transparent);opacity:0;transition:opacity .2s;border-radius:inherit}.cd-stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014;border-color:var(--primary)}.cd-stat-card:hover:after{opacity:1}.cd-stat-icon-wrap{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cd-stat-body{flex:1;min-width:0}.cd-stat-value{font-size:2rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}.cd-stat-label{font-size:.78rem;font-weight:600;color:var(--text-secondary);margin-top:.25rem}.cd-stat-sub{font-size:.7rem;color:var(--text-muted);margin-top:.15rem}.cd-stat-arrow{font-size:1.4rem;color:var(--text-muted);transition:transform .15s;margin-left:auto;padding-left:.5rem}.cd-stat-card:hover .cd-stat-arrow{transform:translate(3px);color:var(--text-secondary)}.cd-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:900px){.cd-bottom-grid{grid-template-columns:1fr}}.cd-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 4px 12px #00000008}.cd-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.cd-card-title{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.cd-card-link{font-size:.78rem;color:#10b981;background:none;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:opacity .15s}.cd-card-link:hover{opacity:.75}.cd-card-body{padding:.5rem 0;flex:1}.cd-student-row{display:flex;align-items:center;gap:.75rem;padding:.7rem 1.5rem;transition:background .15s}.cd-student-row:hover{background:var(--bg-elevated)}.cd-student-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#fff;flex-shrink:0}.cd-student-info{flex:1;min-width:0}.cd-student-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cd-student-email{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cd-hours-badge{font-size:.72rem;font-weight:600;color:#10b981;background:#10b9811a;padding:.2rem .5rem;border-radius:6px;border:1px solid rgba(16,185,129,.2);white-space:nowrap}.cd-empty{padding:2rem 1.5rem;text-align:center;color:var(--text-muted);font-size:.85rem}.cd-action-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;width:100%;font-family:Inter,sans-serif;transition:background .15s}.cd-action-row:last-child{border-bottom:none}.cd-action-row:hover{background:var(--bg-elevated)}.cd-action-emoji{font-size:1.3rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:10px;flex-shrink:0}.cd-action-label{font-size:.85rem;font-weight:600;color:var(--text-primary);text-align:left}.cd-action-sub{font-size:.72rem;color:var(--text-muted);text-align:left;margin-top:1px}.cd-quick-actions-grid{display:flex;flex-direction:column}.cd-quick-action-btn{border-bottom:1px solid var(--border)!important;border-right:none!important}.cd-quick-action-btn:last-child{border-bottom:none!important}.cd-quick-action-btn:hover{background:var(--bg-elevated)!important}.view-container{display:flex;flex-direction:column;gap:1.5rem}.view-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.view-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.view-subtitle{font-size:.82rem;color:var(--text-muted);margin:.25rem 0 0}.table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table thead{background:var(--bg-elevated)}.data-table th{padding:.75rem 1.25rem;text-align:left;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:.85rem 1.25rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .12s}.data-table tbody tr:hover{background:var(--bg-elevated)}.form-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:.6rem .9rem;color:var(--text-primary);font-size:.88rem;font-family:Inter,sans-serif;width:100%;outline:none;transition:border-color .18s}.form-input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811f}.form-input::placeholder{color:var(--text-muted)}.loading-state{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:.9rem;gap:.5rem}.loading-state:before{content:"";width:18px;height:18px;border:2px solid rgba(16,185,129,.2);border-top-color:#10b981;border-radius:50%;animation:cd-spin .7s linear infinite;flex-shrink:0}.cd-overview-layout{display:flex;gap:1.5rem;align-items:stretch;min-height:calc(100vh - 120px);height:auto}.cd-overview-main-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:1.5rem}.cd-overview-side-col{width:320px;flex-shrink:0;display:flex;flex-direction:column;gap:1.5rem}.cd-overview-dynamic-card{display:flex;flex-direction:column;flex:1;min-height:250px}.cd-dynamic-body{flex:1;overflow-y:auto}@media(max-width:1200px){.cd-overview-layout{flex-direction:column;height:auto}.cd-overview-side-col{width:100%;height:auto}.cd-overview-main-col{height:auto}.cd-overview-dynamic-card{flex:none}.cd-dynamic-body{max-height:400px}}.cd-scroll-body::-webkit-scrollbar{width:6px}.cd-scroll-body::-webkit-scrollbar-track{background:transparent}.cd-scroll-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.cd-scroll-body::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.hover-row{transition:background .15s}.hover-row:hover{background:var(--bg-elevated)}.notification-badge{background:#ef4444;color:#fff;font-size:.72rem;font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:10px;margin-left:auto;padding:0 5px;box-shadow:0 2px 5px #ef444466;animation:badgePop .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes badgePop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.topbar-notification-dot{position:absolute;top:6px;right:8px;width:8px;height:8px;background:#ef4444;border:2px solid var(--bg-card);border-radius:50%}
