@font-face{font-family:Mitr;src:url(/assets/Mitr-Regular-BfhZPCB2.ttf) format("truetype");font-weight:400;font-style:normal}body{font-family:Mitr,sans-serif}.nav{background:#ffffffbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#2b2b2b;padding:12px 24px;border-bottom:1px solid rgba(0,0,0,.06);position:sticky;top:0;z-index:1000}.nav-inner{display:flex;align-items:center}.brand{font-weight:700;font-size:20px;padding-right:24px;color:#208ba9}.tabs{display:flex;gap:10px}.tab{padding:8px 14px;border-radius:6px;font-weight:500;color:#444;transition:.2s;text-decoration:none}.tab:hover{background:#0000000f}.tab.active{background:#208ba9;color:#fff}.actions{display:flex;gap:16px;align-items:center}.logout-btn{background:transparent;border:none;color:#d9534f;cursor:pointer;font-weight:600}.iconbtn{background:transparent;border:none;font-size:20px;cursor:pointer;color:#333;transition:.2s}.iconbtn:hover{color:#208ba9}.avatar{font-weight:600;color:#333}.hamburger{display:inline-flex}.drawer{display:none;background:#fff;padding:12px;border-top:1px solid rgba(0,0,0,.05)}.drawer.open{display:flex;flex-direction:column;gap:10px}@media (min-width: 768px){.hamburger,.drawer{display:none}}.dashboard{padding:20px;min-height:100vh;background:#efefef;display:flex;flex-direction:column}.breadcrumb{font-size:14px;color:#666;margin:16px 0 32px;font-weight:400}.dashboard-cards{display:grid;grid-template-columns:repeat(3,260px);justify-content:center;gap:32px 80px}.dashboard-cards .dashboard-card:nth-child(4){grid-column:2;grid-row:2}.dashboard-cards .dashboard-card:nth-child(5){grid-column:2;grid-row:3}.dashboard-card{background:#fff;border-radius:8px;min-height:120px;box-shadow:0 10px 18px #0000001f;border:1px solid rgba(0,0,0,.03);position:relative;padding:16px 20px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial}.dashboard-card-icon{position:absolute;top:12px;left:12px;font-size:18px;line-height:1;opacity:.9}.dashboard-card-title{font-size:14px;font-weight:500;color:#444;margin-top:8px;margin-bottom:12px}.dashboard-card-value{font-size:40px;font-weight:600;line-height:1.2}.dashboard-cards .dashboard-card:nth-child(1) .dashboard-card-value,.dashboard-cards .dashboard-card:nth-child(1) .dashboard-card-icon{color:#1a6e18}.dashboard-cards .dashboard-card:nth-child(2) .dashboard-card-value,.dashboard-cards .dashboard-card:nth-child(2) .dashboard-card-icon{color:#c9a12a}.dashboard-cards .dashboard-card:nth-child(3) .dashboard-card-value,.dashboard-cards .dashboard-card:nth-child(3) .dashboard-card-icon{color:#6b6b6b}.dashboard-cards .dashboard-card:nth-child(4) .dashboard-card-value,.dashboard-cards .dashboard-card:nth-child(4) .dashboard-card-icon{color:#c91111}.dashboard-cards .dashboard-card:nth-child(5) .dashboard-card-value,.dashboard-cards .dashboard-card:nth-child(5) .dashboard-card-icon{color:#bfbfbf}.ticket-wrap{max-width:100%;margin:0 auto;padding:16px}.crumb{margin-bottom:12px;color:#666;font-size:.95rem}.grid{display:grid;grid-template-columns:2fr 1fr;gap:40px}.left-col,.right-col{min-width:0}@media (max-width: 1024px){.grid{grid-template-columns:1fr}}.card{background:#c5e3ffee;border:1px solid #ececec;border-radius:14px;padding:16px;margin-bottom:12px}.card-right{background:#fffe;border:1px solid #ececec;border-radius:14px;padding:16px;margin-bottom:12px}.card-title{display:flex;font-weight:700;font-size:larger;margin:0 0 10px;color:#000}.attribute-btn{border:1px solid rgb(203,203,203);border-radius:5px;cursor:pointer;display:inline-block;padding:6px 10px}.update-btn{margin-top:8px;display:inline-block;padding:10px 14px;border-radius:10px;border:1px solid #dfe6f2;background:#f7fbff;cursor:pointer}.update-btn:hover{background:#eef6ff}.left-col .desc{line-height:1.5;white-space:pre-wrap}.left-col .progress-list{display:grid;gap:12px}.left-col .progress-item{border:1px solid #eee;border-radius:12px;padding:10px 12px;background:#c5e3ffee}.left-col .progress-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.left-col .progress-meta{font-size:.92rem;color:#333}.left-col .progress-note{margin:8px 0 0;line-height:1.45;white-space:pre-wrap}.left-col .icon-btn{border:1px solid #e9e9e9;background:#fff;padding:6px 8px;border-radius:8px;cursor:pointer}.left-col .icon-btn:hover{background:#f7f7f7}.left-col .attach{margin-top:10px}.left-col .attach-sm{margin-top:6px}.left-col .attach-head{font-size:.85rem;color:#555;margin-bottom:6px}.left-col .attach-row{display:flex;align-items:center;justify-content:space-between;border:1px solid #eee;border-radius:10px;padding:8px 10px;margin-bottom:6px;background-color:#fff}.left-col .attach-file{display:flex;align-items:center;gap:8px}.left-col .file-icon{font-size:1.1rem}.left-col .file-name{font-size:.95rem}.left-col .attach-actions{display:flex;align-items:center;gap:6px}.left-col .icon-btn.danger{border-color:#ffdada}.left-col .icon-btn.danger:hover{background:#fff4f4}@media (max-width: 800px){.left-col .progress-head{flex-direction:column;align-items:flex-start;gap:4px}}.right-col{padding:20px;background-color:#e6e6e6f5;border-radius:10px}.right-col .sla-row{display:flex;align-items:center;gap:10px;margin:6px 0}.right-col .sla-row .label{color:#444;font-size:.95rem}.right-col .sla-badge{font-weight:800;font-size:1.1rem;padding:6px 12px;border:1px solid #dfe6f2;border-radius:10px;background:#fff;line-height:1.1}.right-col .sla-badge.in-progress{background:#f6fbff;border-color:#d7e7ff}.right-col .sla-badge.open{background:#fafafa}.right-col .sla-badge.resolved{background:#f4fff6;border-color:#cfeeda}.right-col .sla-badge.closed{background:#f9f9f9;color:#333}.right-col .sla-date{font-weight:600;padding:6px 12px;border:1px solid #ececec;border-radius:10px;background:#fff}.right-col .info{padding-top:14px}.right-col .info-row{display:grid;gap:12px;margin-bottom:12px}.right-col .info-row.one{grid-template-columns:1fr}.right-col .info-row.two{grid-template-columns:1fr 1fr}.right-col .info-row.three{grid-template-columns:1fr 1fr 1fr}.right-col .info-item.full{grid-column:1 / -1}.right-col .info-label{font-size:.78rem;color:#333;margin-bottom:6px;display:inline-block}.right-col .info-label.empty{visibility:hidden;height:0;margin:0}.right-col .form-input,.right-col .form-select{width:100%;padding:10px 12px;min-height:40px;border:2px solid #e6e6e6;border-radius:12px;background:#fff;outline:none;line-height:1.2;box-sizing:border-box}.right-col .form-input:focus,.right-col .form-select:focus{border-color:#c9d8ff;box-shadow:0 0 0 3px #6e96ff26}.right-col .readonly-field{background:#f4f6fb;color:#374151;cursor:default}.right-col .readonly-field:focus{border-color:#e6e6e6;box-shadow:none}.right-col .chip-select{text-transform:uppercase;font-weight:800;letter-spacing:.02em;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#777 50%),linear-gradient(135deg,#777 50%,transparent 50%),linear-gradient(to right,transparent,transparent);background-position:calc(100% - 18px) 1.1em,calc(100% - 13px) 1.1em,calc(100% - 2.2em) .4em;background-size:5px 5px,5px 5px,1px 1.6em;background-repeat:no-repeat;padding-right:2.6em}.right-col input[type=number]::-webkit-outer-spin-button,.right-col input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.right-col .update-btn{margin-top:8px;color:#fff;display:flex;justify-self:flex-end;width:30%;background-color:#4086ff}.card-title-row{display:flex;justify-content:space-between;align-items:center}.edit-link{border:none;background:none;color:#2563eb;cursor:pointer;font-size:.9rem}.edit-link:hover{text-decoration:underline}.desc-edit-box{margin-top:8px}.form-textarea{width:100%;min-height:120px;resize:vertical}.desc-edit-actions{margin-top:8px;display:flex;gap:8px}.btn-save{background:#22c55e;color:#fff;border:none;padding:4px 10px;border-radius:4px}.btn-cancel{background:#e5e7eb;border:none;padding:4px 10px;border-radius:4px}.login-root{--bg: radial-gradient(circle at top left, #1d4ed8 0, #0f172a 40%, #020617 100%);--card-bg: rgba(15, 23, 42, .94);--card-border: rgba(148, 163, 184, .35);--text-main: #e5e7eb;--text-muted: #9ca3af;--primary: #60a5fa;--primary-strong: #3b82f6;--primary-soft: rgba(59, 130, 246, .2);--danger: #fecaca;--ring: 0 0 0 2px rgba(96, 165, 250, .55);min-height:100dvh;margin:0;padding:0;box-sizing:border-box;position:relative;background:#020617;color:var(--text-main);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif}.login-layer{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);opacity:.98;pointer-events:none}.login-center{position:relative;min-height:100dvh;display:grid;place-items:center;padding:24px 16px;box-sizing:border-box}.login-card{width:min(100%,380px);border-radius:20px;padding:24px 22px 20px;box-sizing:border-box;background:var(--card-bg);border:1px solid var(--card-border);box-shadow:0 24px 60px #0f172ae6,0 0 0 1px #0f172ab3;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:grid;gap:18px}.login-card-header{display:grid;gap:8px}.login-logo-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.9);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.login-logo-dot{width:6px;height:6px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 6px #22c55e59}.login-title{margin:4px 0 0;font-size:22px;line-height:1.3;font-weight:700;color:#f9fafb}.login-subtitle{margin:0;font-size:13px;color:var(--text-muted)}.login-form{display:grid;gap:14px}.login-label{display:grid;gap:6px;font-size:13px}.login-input{width:100%;height:44px;padding:10px 12px;border-radius:12px;border:1px solid rgba(51,65,85,.9);background:#0f172af2;color:#e5e7eb;font-size:14px;outline:none;box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease,transform .04s ease}.login-input::placeholder{color:#64748b}.login-input:hover:not(:disabled){background:#020617}.login-input:focus-visible{border-color:var(--primary-strong);box-shadow:var(--ring)}.login-password-wrap{position:relative;display:grid}.login-input--password{padding-right:44px}.login-reveal{position:absolute;right:8px;top:50%;transform:translateY(-50%);height:28px;min-width:28px;padding:0 6px;border-radius:999px;border:1px solid transparent;background:transparent;cursor:pointer;font-size:16px;line-height:1;color:#9ca3af;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease}.login-reveal:hover:not(:disabled){background:#1e40af66;color:#e5e7eb}.login-reveal:focus-visible{outline:none;border-color:var(--primary-strong);box-shadow:var(--ring)}.login-error{border-radius:12px;border:1px solid var(--danger);background:#7f1d1d40;color:#fecaca;padding:10px 11px;font-size:13px}.login-submit{height:44px;border-radius:999px;border:none;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#f9fafb;font-weight:600;font-size:14px;cursor:pointer;margin-top:4px;box-shadow:0 10px 24px #2563eb59,0 0 0 1px #0f172a99;transition:background .15s ease,box-shadow .15s ease,transform .05s ease}.login-brand{margin-bottom:26px;text-align:center;-webkit-user-select:none;user-select:none}.login-brand-main{font-size:28px;font-weight:800;letter-spacing:.18em;color:#fff}.login-brand-sub{margin-top:4px;font-size:12px;letter-spacing:.35em;font-weight:600;color:#60a5fa}.login-submit:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 14px 28px #2563eb73,0 0 0 1px #0f172ab3}.login-submit:active:not(:disabled){transform:translateY(1px);box-shadow:0 8px 16px #2563eb59}.login-meta{margin-top:6px;font-size:11px;color:var(--text-muted)}.login-footer{margin-top:16px;text-align:center;font-size:11px;color:#94a3b8cc}@media (max-width: 480px){.login-card{width:100%;padding:20px 18px 18px;border-radius:18px}.login-title{font-size:20px}.login-input,.login-submit{height:42px}}.login-links{margin-top:12px;text-align:center;font-size:13px;color:var(--text-muted)}.login-link{color:var(--primary);text-decoration:none;font-weight:500;transition:color .15s ease}.login-link:hover{color:#dbeafe;text-decoration:underline}.login-divider{margin:0 8px;color:var(--text-muted)}@media (prefers-reduced-motion: reduce){.login-input,.login-submit,.login-reveal{transition:none}}.ctk__actions{display:flex;justify-content:flex-end;padding-top:8px;border-top:1px dashed var(--border);margin-top:12px}.ctk-back{display:inline-flex;align-items:center;gap:6px;font-size:.95rem;color:#454545;text-decoration:none;background:#f3f6ff;padding:6px 14px;border-radius:8px;transition:.25s ease;border:1px solid #dfe6ff}.ctk-back:hover{background:#e4ebff;color:#4a4a4a;transform:translate(-2px)}.ctk-back .arrow{font-size:1rem;font-weight:700}.ctk__head{display:flex;align-items:center;gap:16px;margin-bottom:16px}:root{--bg:#f6f7f9;--card:#fff;--text:#1f2937;--muted:#6b7280;--border:#e5e7eb;--ring:#2563eb;--primary:#4f7cac;--danger:#dc2626}.au{max-width:900px;margin:24px auto;padding:16px}.au__head{margin-bottom:12px}.au__title{margin:0 0 4px 8px;font-size:24px;font-weight:700}.au__subtitle{margin:0;color:var(--muted);font-size:13px}.au-card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 2px 10px #0000000a;padding:16px}.au-grid{display:grid;gap:20px;grid-template-columns:1fr 360px}@media (max-width: 960px){.au-grid{grid-template-columns:1fr}}.au__section{margin:8px 0 10px;font-size:13px;font-weight:700;color:#374151}@media (max-width: 640px){.grid-2{grid-template-columns:1fr}}.field.inline{margin:6px 0}.req{color:var(--danger)}.input.is-error{border-color:var(--danger)}.error{display:block;color:var(--danger);font-size:12px;margin-top:4px}.row{display:flex;gap:8px;align-items:center}.check{display:flex;gap:8px;align-items:center;font-size:14px}.au__actions{display:flex;justify-content:flex-end;padding-top:10px;border-top:1px dashed var(--border);margin-top:14px}:root{--bg:#f6f7f9;--card:#fff;--text:#1f2937;--muted:#6b7280;--border:#e5e7eb;--ring:#2563eb;--primary:#4f7cac}*{box-sizing:border-box}body{background:var(--bg);color:var(--text)}.ctk{max-width:1100px;margin:24px auto;padding:16px}.ctk__head{margin-bottom:12px}.ctk__title{margin:0 0 4px;font-size:24px;font-weight:700}.ctk__subtitle{margin:0;color:var(--muted);font-size:13px}.ctk-card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 2px 10px #0000000a;padding:16px}.ctk-grid{display:grid;gap:20px;grid-template-columns:1fr 380px}@media (max-width: 960px){.ctk-grid{grid-template-columns:1fr}}.ctk__section{margin:10px 0 8px;font-size:13px;font-weight:700;color:#374151}.hint{font-size:12px;color:var(--muted);margin:0 0 8px}.grid-2{display:grid;gap:12px;grid-template-columns:1fr 1fr}.grid-3{display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}@media (max-width: 600px){.grid-2,.grid-3{grid-template-columns:1fr}}.field{margin-bottom:10px}.label{display:block;font-size:13px;font-weight:600;margin:0 0 6px}.req{color:#dc2626}.input,.textarea,select.input{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:14px;background:#fff;outline:none}.input:focus,.textarea:focus,select.input:focus{border-color:var(--ring);box-shadow:0 0 0 3px #2563eb26}.textarea{min-height:120px;resize:vertical}.row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.ctk__actions{display:flex;justify-content:flex-end;padding-top:8px;border-top:1px dashed var(--border);margin-top:12px;gap:8px}.btn{cursor:pointer;padding:9px 14px;border-radius:10px;font-weight:600;border:1px solid var(--border);background:#fff}.btn--primary{border:none;background:var(--primary);color:#fff}.btn--light{background:#fff}.btn--ghost{background:#f9fafb}.tickets-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#eff6ff,#eef2ff);padding:1rem}@media (min-width: 768px){.tickets-page{padding:2rem}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-slide-in{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.glass-card{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5)}.page-header{max-width:1280px;margin:0 auto 2rem;animation:slideIn .3s ease-out}.header-top{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}@media (min-width: 768px){.header-top{flex-direction:row;align-items:center;justify-content:space-between}}.page-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.page-subtitle{color:#6b7280}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#4f46e5,#2563eb);color:#fff;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:600;border:none;cursor:pointer;box-shadow:0 10px 25px -5px #4f46e54d;transition:all .2s ease;text-decoration:none}.btn-primary:hover{transform:scale(1.05);box-shadow:0 15px 30px -5px #4f46e566}.search-filter-bar{max-width:1280px;margin:0 auto 1.5rem}.search-filter-container{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a;padding:1rem}.search-row{display:flex;flex-direction:column;gap:.75rem}@media (min-width: 768px){.search-row{flex-direction:row}}.search-input-wrapper{position:relative;flex:1}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.search-input{width:100%;padding:.75rem 1rem .75rem 3rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;outline:none;transition:all .2s}.search-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.filter-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:500;border:none;cursor:pointer;transition:all .2s}.filter-toggle-btn.active{background:#4f46e5;color:#fff;box-shadow:0 10px 25px -5px #4f46e54d}.filter-toggle-btn.inactive{background:#fff;color:#374151;border:1px solid #e5e7eb}.filter-toggle-btn.inactive:hover{border-color:#c7d2fe}.filter-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;animation:slideIn .3s ease-out}.filter-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}@media (min-width: 768px){.filter-grid{grid-template-columns:repeat(4,1fr)}}.filter-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.filter-select,.filter-date{width:100%;padding:.5rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;outline:none;transition:all .2s}.filter-select:focus,.filter-date:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.clear-filters-btn{display:flex;align-items:center;gap:.25rem;margin-top:1rem;font-size:.875rem;color:#4f46e5;font-weight:500;background:none;border:none;cursor:pointer;padding:0}.clear-filters-btn:hover{color:#4338ca}.table-container{max-width:1280px;margin:0 auto}.table-wrapper{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;overflow:hidden}.table-scroll{overflow-x:auto}.tickets-table{width:100%;border-collapse:collapse;table-layout:auto;table-layout:fixed}.tickets-table thead tr{background:linear-gradient(135deg,#eef2ff,#dbeafe);border-bottom:1px solid #e5e7eb}.tickets-table thead th{padding:1rem;text-align:left;font-size:.75rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.tickets-table thead th.text-center{text-align:center}.tickets-table tbody{background:#fff}.tickets-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .15s ease}.tickets-table tbody tr:hover{background:#eef2ff80}.tickets-table tbody td{padding:1rem;font-size:.875rem;color:#1f2937;vertical-align:middle}.tickets-table th:nth-child(1),.tickets-table td:nth-child(1){width:150px}.tickets-table th:nth-child(2),.tickets-table td:nth-child(2){width:44%}.tickets-table th:nth-child(3),.tickets-table td:nth-child(3){width:14%}.tickets-table th:nth-child(4),.tickets-table td:nth-child(4){width:14%}.tickets-table th:nth-child(5),.tickets-table td:nth-child(5){width:120px}.tickets-table th:nth-child(6),.tickets-table td:nth-child(6){width:140px}.tickets-table th:nth-child(7),.tickets-table td:nth-child(7){width:120px}.tickets-table th:nth-child(8),.tickets-table td:nth-child(8){width:160px}.tickets-table th:nth-child(9),.tickets-table td:nth-child(9){width:120px}.cell-id{font-family:ui-monospace,monospace;font-weight:600;color:#4f46e5;white-space:nowrap}.cell-subject{display:inline-block;font-weight:500;color:#111827;white-space:normal;word-break:break-word;overflow:visible;text-overflow:unset;line-height:1.35}.cell-text{color:#6b7280;white-space:nowrap}.tickets-table td:nth-child(3) .cell-text,.tickets-table td:nth-child(4) .cell-text{display:block;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tickets-table td:nth-child(8) .cell-project{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-date{color:#9ca3af;white-space:nowrap}.pill{display:inline-flex;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px;border:1px solid;white-space:nowrap}.pill-open{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.pill-in-progress{background:#fef3c7;color:#92400e;border-color:#fde68a}.pill-on-hold{background:#f3f4f6;color:#374151;border-color:#d1d5db}.pill-closed,.pill-low{background:#d1fae5;color:#065f46;border-color:#a7f3d0}.pill-medium{background:#fed7aa;color:#9a3412;border-color:#fdba74}.pill-high{background:#fee2e2;color:#991b1b;border-color:#fecaca}.action-buttons{display:flex;align-items:center;justify-content:center;gap:.5rem}.action-btn{padding:.5rem;border-radius:.5rem;border:none;cursor:pointer;transition:all .15s;background:transparent}.action-btn-edit{color:#4f46e5}.action-btn-edit:hover{background:#eef2ff}.action-btn-delete{color:#dc2626}.action-btn-delete:hover{background:#fee2e2}.empty-state{padding:3rem 1rem;text-align:center;color:#6b7280}.empty-icon{margin:0 auto .5rem;color:#d1d5db}.empty-title{font-size:1.125rem;font-weight:500;margin-bottom:.5rem}.empty-text{font-size:.875rem}.skeleton-row{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-box{height:1rem;background:#e5e7eb;border-radius:.25rem;width:75%}.pagination-bar{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;background:#fafafa;border-top:1px solid #e5e7eb}@media (min-width: 768px){.pagination-bar{flex-direction:row}}.pagination-info{font-size:.875rem;color:#6b7280}.pagination-info strong{font-weight:600}.pagination-controls{display:flex;align-items:center;gap:.75rem}.page-size-select{padding:.5rem .75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;outline:none;transition:all .2s}.page-size-select:hover,.page-size-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.pagination-buttons{display:flex;align-items:center;gap:.5rem}.page-btn{padding:.5rem;border:1px solid #e5e7eb;background:#fff;border-radius:.5rem;cursor:pointer;transition:all .15s}.page-btn:hover:not(:disabled){background:#f9fafb}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{padding:.5rem 1rem;font-size:.875rem;font-weight:500}@media (max-width: 767px){.hide-mobile{display:none}}@media (min-width: 768px){.show-mobile{display:none}}.report-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:#f5f7fb;font-family:Arial,Helvetica,sans-serif;color:#444}.report-sidebar{background:#fff;border-right:1px solid #eee;padding:16px 14px;display:flex;flex-direction:column}.sidebar-head{padding:10px 10px 14px;border-bottom:1px solid #f1f1f1;margin-bottom:12px}.sidebar-title{font-size:18px;font-weight:800;color:#2f6fa6}.sidebar-sub{margin-top:4px;font-size:12px;color:#7a9bb6}.sidebar-list{display:flex;flex-direction:column;gap:10px;padding:8px 6px;flex:1;overflow:auto}.sidebar-btn{text-align:left;border:1px solid #e9eef5;background:#fbfdff;border-radius:10px;padding:10px 12px;cursor:pointer;transition:.12s ease}.sidebar-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px #0000000f}.sidebar-btn.active{border-color:#2f6fa659;box-shadow:0 8px 18px #2f6fa61f;background:#f3f9ff}.sidebar-btn-title{font-weight:800;color:#2c3e50;font-size:13px}.sidebar-btn-desc{margin-top:4px;font-size:12px;color:#7a9bb6}.sidebar-footer{margin-top:10px;padding:10px;color:#9aa7b3;font-size:12px}.report-main{padding:24px 18px}.report-page{max-width:860px;margin:0 auto;color:#444}.report-title{font-size:34px;color:#2f6fa6;margin-bottom:6px}.report-sub{color:#7a9bb6;margin-bottom:18px}.report-form{background:#fff;padding:22px 28px;border-radius:12px;box-shadow:0 10px 24px #0000000f;border:1px solid #eef2f7}.filter-row{display:flex;gap:16px;align-items:center;margin-bottom:14px}.filter-row label{display:inline-flex;gap:8px;align-items:center;font-weight:800;color:#2c3e50}.param-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.param-field label{display:block;font-size:12px;font-weight:800;color:#2c3e50;margin-bottom:6px}.param-field input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e9eef5;background:#fbfdff;outline:none}.param-field input:focus{border-color:#2f6fa659;box-shadow:0 0 0 3px #2f6fa61a}.param-actions{display:flex;align-items:flex-end;justify-content:flex-start}.btn-ghost{border:1px solid #e9eef5;background:#fff;border-radius:10px;padding:10px 12px;cursor:pointer;font-weight:800;color:#2c3e50}.btn-ghost:hover{opacity:.9}.format-row{margin:10px 0 18px;display:flex;gap:18px;align-items:center}.format-row label{display:inline-flex;gap:8px;align-items:center;font-weight:700;color:#333}.format-row label.disabled{opacity:.45}.actions{margin-top:6px}.btn-submit{background:#6ea23a;color:#fff;border:none;padding:10px 18px;border-radius:10px;cursor:pointer;box-shadow:0 2px #0000000d;font-weight:800}.btn-submit:hover{opacity:.95}.report-actions{display:flex;gap:10px;flex-wrap:wrap}.btn-submit.btn-excel{background:#1f8f5f}.hint-row{margin-top:14px}.hint{font-size:12px;color:#7a9bb6;margin-top:6px}.hint-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;color:#2c3e50}@media (max-width: 900px){.report-layout{grid-template-columns:1fr}.report-sidebar{position:sticky;top:0;z-index:10;border-right:none;border-bottom:1px solid #eee}.sidebar-list{flex-direction:row;overflow-x:auto;overflow-y:hidden;gap:10px}.sidebar-btn{min-width:220px}.param-grid{grid-template-columns:1fr}}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.35;background:radial-gradient(700px 500px at 15% 20%,rgba(59,130,246,.55),transparent 60%),radial-gradient(600px 450px at 80% 30%,rgba(96,165,250,.35),transparent 55%),radial-gradient(900px 700px at 50% 110%,rgba(2,6,23,.85),transparent 60%);filter:blur(0px)}.auth-brand{font-weight:800;letter-spacing:.8px;color:#e5e7eb;font-size:18px;margin-bottom:6px}.auth-subtitle{margin:8px 0 0;font-size:13px;color:#9ca3af;line-height:1.4}.auth-label{font-size:13px;color:#cbd5e1}.auth-input{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(148,163,184,.35);background:#0206178c;color:#e5e7eb;outline:none}.auth-btn{border:0;cursor:pointer;border-radius:12px;padding:12px 14px;font-weight:700;letter-spacing:.2px;color:#eaf2ff;background:linear-gradient(180deg,#60a5faf2,#2563ebf2);box-shadow:0 10px 28px #2563eb40}.auth-linkbtn{background:transparent;border:0;cursor:pointer;padding:8px 10px;border-radius:10px;color:#93c5fd;font-size:13px}html,body{margin:0;padding:0;height:100%}#root{min-height:100vh}.auth-root{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden;background:radial-gradient(circle at top left,#1d4ed8 0,#0f172a 40%,#020617);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.35;background:radial-gradient(700px 500px at 15% 20%,rgba(59,130,246,.55),transparent 60%),radial-gradient(600px 450px at 80% 30%,rgba(96,165,250,.35),transparent 55%),radial-gradient(900px 700px at 50% 110%,rgba(2,6,23,.85),transparent 60%)}.auth-card{width:min(520px,100%);position:relative;z-index:1;border-radius:18px;padding:22px 22px 18px;background:#0f172af0;border:1px solid rgba(148,163,184,.35);box-shadow:0 18px 60px #00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-header{text-align:center;margin-bottom:14px}.auth-brand{font-weight:900;letter-spacing:1px;color:#e5e7eb;font-size:18px;margin-bottom:6px}.auth-title{margin:0;font-size:22px;color:#e5e7eb;letter-spacing:.2px}.auth-subtitle{margin:8px 0 0;font-size:13px;color:#9ca3af;line-height:1.45}.auth-form{display:grid;gap:10px;margin-top:14px}.auth-label{font-size:13px;color:#cbd5e1;margin-top:2px}.auth-input{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(148,163,184,.35);background:#0206178c;color:#e5e7eb;outline:none;transition:box-shadow .12s ease,border-color .12s ease,transform .12s ease}.auth-input::placeholder{color:#94a3b8b3}.auth-input:focus{border-color:#60a5fae6;box-shadow:0 0 0 4px #3b82f62e}.auth-input:disabled{opacity:.65;cursor:not-allowed}.auth-btn{margin-top:6px;border:0;cursor:pointer;border-radius:12px;padding:12px 14px;font-weight:800;letter-spacing:.2px;color:#eaf2ff;background:linear-gradient(180deg,#60a5faf2,#2563ebf2);box-shadow:0 10px 28px #2563eb40;transition:filter .12s ease,transform .12s ease,opacity .12s ease}.auth-btn:hover{filter:brightness(1.05)}.auth-btn:active{transform:translateY(1px)}.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-alert{margin-top:12px;border-radius:12px;padding:10px 12px;font-size:13px;line-height:1.35}.auth-alert.success{background:#10b9811f;border:1px solid rgba(16,185,129,.25);color:#d1fae5}.auth-alert.error{background:#ef44441f;border:1px solid rgba(239,68,68,.25);color:#fee2e2}.auth-footer{display:flex;justify-content:center;margin-top:14px}.auth-linkbtn{background:transparent;border:0;cursor:pointer;padding:8px 10px;border-radius:10px;color:#93c5fd;font-size:13px;transition:background .12s ease,transform .12s ease}.auth-linkbtn:hover{text-decoration:underline;background:#3b82f61a}.auth-linkbtn:active{transform:translateY(1px)}@media (max-width: 420px){.auth-card{padding:18px 16px 14px;border-radius:16px}.auth-title{font-size:20px}}.approve-container{padding:24px;background:#f9fafb;min-height:100%}.page-header{margin-bottom:16px}.page-header h2{margin:0;font-size:30px;font-weight:800;color:#111827}.page-desc{margin-top:4px;color:#6b7280;font-size:14px}.card{background:#fff;border-radius:12px;box-shadow:0 6px 18px #0000000f;padding:16px}.info{margin:12px 0;color:#374151}.error{margin:12px 0;color:#dc2626;font-weight:600}.empty{padding:24px;text-align:center;color:#6b7280;font-size:15px}.muted{color:#9ca3af;font-size:12px}.table-wrap{overflow-x:auto}.approve-table{width:100%;border-collapse:collapse;min-width:860px}.approve-table th,.approve-table td{padding:14px 16px;border-bottom:1px solid #e5e7eb;text-align:left}.approve-table th{background:#f3f4f6;font-size:13px;font-weight:700;color:#374151}.approve-table tr:hover{background:#f9fafb}.actions-header{text-align:right}.actions-cell{text-align:right;white-space:nowrap}.actions{display:inline-flex;gap:10px}.btn{height:34px;padding:0 14px;border-radius:8px;border:none;font-size:14px;font-weight:700;cursor:pointer;background:#e5e7eb;color:#111827}.btn:hover{filter:brightness(.97)}.btn.approve{background:#16a34a;color:#fff}.btn.danger{background:#dc2626;color:#fff}.card-footer{margin-top:12px;display:flex;justify-content:flex-end}@media (max-width: 600px){.approve-container{padding:16px}.page-header h2{font-size:24px}}
