:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{box-sizing:border-box;min-height:100svh}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.z-10{z-index:10}.mx-auto{margin-left:auto;margin-right:auto}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.w-full{width:100%}.min-w-0{min-width:0}.min-w-56{min-width:14rem}.min-w-full{min-width:100%}.max-w-56{max-width:14rem}.max-w-72{max-width:18rem}.max-w-7xl{max-width:80rem}.max-w-\[520px\]{max-width:520px}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-slate-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(226 232 240/var(--tw-divide-opacity,1))}.overflow-x-auto{overflow-x:auto}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-dashed{border-style:dashed}.border-slate-200{--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.bg-amber-100{--tw-bg-opacity:1;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.bg-emerald-100{--tw-bg-opacity:1;background-color:rgb(209 250 229/var(--tw-bg-opacity,1))}.bg-rose-100{--tw-bg-opacity:1;background-color:rgb(255 228 230/var(--tw-bg-opacity,1))}.bg-rose-50{--tw-bg-opacity:1;background-color:rgb(255 241 242/var(--tw-bg-opacity,1))}.bg-slate-100{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-slate-50{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.bg-slate-900{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-left{text-align:left}.text-right{text-align:right}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-extrabold{font-weight:800}.font-semibold{font-weight:600}.tracking-wide{letter-spacing:.025em}.text-amber-800{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-emerald-800{--tw-text-opacity:1;color:rgb(6 95 70/var(--tw-text-opacity,1))}.text-rose-700{--tw-text-opacity:1;color:rgb(190 18 60/var(--tw-text-opacity,1))}.text-rose-800{--tw-text-opacity:1;color:rgb(159 18 57/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.ring-amber-200{--tw-ring-opacity:1;--tw-ring-color:rgb(253 230 138/var(--tw-ring-opacity,1))}.ring-emerald-200{--tw-ring-opacity:1;--tw-ring-color:rgb(167 243 208/var(--tw-ring-opacity,1))}.ring-rose-200{--tw-ring-opacity:1;--tw-ring-color:rgb(254 205 211/var(--tw-ring-opacity,1))}.ring-slate-200{--tw-ring-opacity:1;--tw-ring-color:rgb(226 232 240/var(--tw-ring-opacity,1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}@media (width>=768px){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width>=1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}:root{--primary:#1a1a1a;--primary-light:#333;--accent:#3182ce;--success:#38a169;--danger:#e53e3e;--warning:#d69e2e;--bg:#f7fafc;--card-bg:#fff;--text-main:#2d3748;--text-muted:#718096;--border:#e2e8f0;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);color:var(--text-main);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}.login-container{background:linear-gradient(135deg,#1a1a1a 0%,#333 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border-radius:var(--radius-lg);background:#fff;flex-direction:column;gap:24px;width:100%;max-width:420px;padding:48px;animation:.6s cubic-bezier(.16,1,.3,1) slideUp;display:flex;box-shadow:0 20px 25px -5px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:8px}.login-header h1{color:var(--primary);letter-spacing:-.025em;margin-bottom:8px;font-size:32px;font-weight:800}.login-header p{color:var(--text-muted)}.login-error-box{color:#e53e3e;text-align:center;background:#fff5f5;border:1px solid #feb2b2;border-radius:12px;padding:12px;font-size:14px}.app-container{flex-direction:column;min-height:100vh;display:flex}.header{border-bottom:1px solid var(--border);z-index:1000;background:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.nav-bar{border-bottom:1px solid var(--border);background:#fff;gap:8px;padding:0 24px;display:flex}.nav-item{color:var(--text-muted);cursor:pointer;padding:16px 20px;font-size:15px;font-weight:600;transition:all .2s;position:relative}.nav-item:hover,.nav-item.active{color:var(--primary)}.nav-item.active:after{content:"";background:var(--primary);height:3px;position:absolute;bottom:0;left:0;right:0}.page{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px}.page.page-wide{max-width:100%}.page.page-dashboard{padding:28px 20px}.dashboard-content{flex-direction:column;gap:16px;width:100%;max-width:1400px;margin:0 auto;display:flex}.page-dashboard .form-section{padding:24px}.page-dashboard .form-section h3{margin-bottom:12px}.stat-card{border-radius:var(--radius-md);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;align-items:center;gap:20px;padding:24px;transition:transform .2s;display:flex}.stat-icon{border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;font-size:28px;display:flex}.stat-info h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:13px}.stat-info .value{font-size:32px;font-weight:800;line-height:1}.dashboard-row{grid-template-columns:2fr 1fr;gap:24px;margin-top:24px;display:grid}.dashboard-hero{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(135deg,#fff 0%,#f8fafc 55%,#eef2ff 100%);justify-content:space-between;gap:24px;padding:28px;display:flex}.hero-left{flex-direction:column;flex:1;gap:14px;min-width:260px;display:flex}.hero-title{letter-spacing:-.02em;color:var(--primary);font-size:28px;font-weight:900}.hero-subtitle{color:var(--text-muted);font-size:14px}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}@supports not (gap:12px){.hero-actions{margin-bottom:-12px;margin-right:-12px}.hero-actions>*{margin-bottom:12px;margin-right:12px}.welcome-actions{margin-bottom:-12px;margin-right:-12px}.welcome-actions>*{margin-bottom:12px;margin-right:12px}.list-actions{margin-bottom:-12px;margin-right:-12px}.list-actions>*{margin-bottom:12px;margin-right:12px}}.hero-right{justify-content:flex-end;align-items:center;gap:18px;min-width:320px;display:flex}.donut{border:1px solid var(--border);background:#e2e8f0;border-radius:999px;justify-content:center;align-items:center;width:120px;height:120px;display:flex}@supports (background:conic-gradient(#000 0 25%, #fff 0)){.donut{background:conic-gradient(var(--success) calc(var(--p) * 1%), #e2e8f0 0)}}.donut-inner{border:1px solid var(--border);background:#fff;border-radius:999px;flex-direction:column;justify-content:center;align-items:center;width:86px;height:86px;display:flex}.donut-value{color:var(--primary);font-size:22px;font-weight:900;line-height:1.1}.donut-label{color:var(--text-muted);font-size:12px;font-weight:700}.status-breakdown{flex-direction:column;gap:10px;width:220px;display:flex}.status-row{color:var(--text-main);justify-content:space-between;font-size:14px;display:flex}.status-bar{background:#edf2f7;border-radius:999px;width:100%;height:10px;display:flex;overflow:hidden}.status-bar-open{background:var(--danger);height:100%}.status-bar-closed{background:var(--success);height:100%}.status-bar-progress{background:var(--warning);height:100%}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:18px;display:grid}.kpi-card{border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);background:#fff;flex-direction:column;gap:10px;padding:18px;display:flex}.kpi-top{align-items:center;gap:10px;display:flex}.kpi-icon{border:1px solid var(--border);background:var(--bg);border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.kpi-icon-neutral{color:#3182ce;background:#ebf8ff;border-color:#bee3f8}.kpi-icon-danger{color:#c53030;background:#fff5f5;border-color:#fed7d7}.kpi-icon-success{color:#2f855a;background:#f0fff4;border-color:#c6f6d5}.kpi-icon-warning{color:#b7791f;background:ivory;border-color:#feebc8}.kpi-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:800}.kpi-value{color:var(--primary);font-size:30px;font-weight:900;line-height:1}.kpi-sub{color:var(--text-muted);font-size:13px}.chart-grid{grid-template-columns:1fr;gap:16px;margin-top:16px;display:grid}.chart-card{padding:22px}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.chart-subtitle{color:var(--text-muted);margin-top:6px;font-size:13px}.chart-controls{align-items:center;gap:10px;display:flex}.month-input{border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;padding:10px 12px;font-size:14px}.chart-legend{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}.legend-dot{border-radius:999px;width:10px;height:10px;display:inline-block}.legend-dot-open{background:var(--danger)}.legend-dot-progress{background:#d69e2e}.legend-dot-closed{background:var(--success)}.chart-wrap{border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;width:100%;overflow:hidden}.chart-shell{position:relative}.chart-tooltip{color:#fff;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172aeb;border-radius:12px;min-width:160px;padding:10px 12px;position:absolute;transform:translateY(-100%);box-shadow:0 10px 22px #00000038}.chart-tooltip-title{margin-bottom:8px;font-size:12px;font-weight:800}.chart-tooltip-row{opacity:.95;justify-content:space-between;gap:12px;font-size:12px;line-height:1.3;display:flex}.chart-svg{aspect-ratio:3;width:100%;min-width:0;height:auto;display:block}.chart-bar-group rect{transition:opacity .12s,filter .12s}.chart-bar-group:hover rect{filter:brightness(.98)}.dashboard-row.dashboard-row-2{grid-template-columns:2fr 1fr;align-items:start}.recent-list{flex-direction:column;gap:12px;display:flex}.recent-item{border:1px solid var(--border);border-radius:var(--radius-md);background:#fcfcfc;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:12px;display:grid}.recent-thumb{-o-object-fit:cover;object-fit:cover;border:1px solid var(--border);background:#edf2f7;border-radius:14px;width:56px;height:56px}.recent-info{flex-direction:column;gap:6px;min-width:0;display:flex}.recent-top{justify-content:space-between;align-items:center;gap:10px;display:flex}.recent-area{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:15px;overflow:hidden}.recent-sub{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;display:flex}.recent-dot{color:#cbd5e1}.reminder-grid{grid-template-columns:1fr;gap:12px;display:grid}.reminder-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#fcfcfc;flex-direction:column;gap:10px;padding:14px;display:flex}.reminder-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:800}.reminder-value{color:var(--primary);font-size:28px;font-weight:900;line-height:1}.welcome-box{background:linear-gradient(90deg,#fff,#f8f9fa);position:relative;overflow:hidden}.welcome-content h2{color:var(--primary);margin-bottom:12px;font-size:24px}.welcome-content p{color:var(--text-muted);max-width:500px;margin-bottom:24px}.welcome-actions{gap:12px;display:flex}.progress-container{margin-top:20px}.progress-label{justify-content:space-between;margin-bottom:8px;font-size:14px;font-weight:600;display:flex}.progress-bar{background:#edf2f7;border-radius:99px;height:10px;overflow:hidden}.progress-fill{background:var(--success);height:100%;transition:width .6s}.list-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:32px;display:flex}.list-page{flex-direction:column;gap:14px;display:flex}.list-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.list-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.mini-card{border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);background:#fff;padding:14px 16px}.mini-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:700}.mini-card-value{color:var(--text-main);margin-top:6px;font-size:22px;font-weight:900}.mini-card-open{border-left:4px solid var(--danger)}.mini-card-progress{border-left:4px solid var(--warning)}.mini-card-closed{border-left:4px solid var(--success)}.list-filters{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.list-actions{flex-wrap:wrap;flex:1;justify-content:flex-end;gap:12px;display:flex}.search-box{flex:1}.search-box input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23718096'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'%3E%3C/path%3E%3C/svg%3E");background-position:12px;background-repeat:no-repeat;background-size:20px;width:100%;padding-left:40px}.filter-select{width:160px}.table-wrapper{border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;table-layout:fixed;width:100%;min-width:980px}.list-table th:first-child,.list-table td:first-child{width:48px}.list-table th:nth-child(2),.list-table td:nth-child(2){width:110px}.list-table th:nth-child(3),.list-table td:nth-child(3){width:230px}.list-table th:nth-child(4),.list-table td:nth-child(4),.list-table th:nth-child(5),.list-table td:nth-child(5){width:260px}.list-table th:nth-child(6),.list-table td:nth-child(6){width:190px}.list-table th:nth-child(7),.list-table td:nth-child(7),.list-table th:nth-child(8),.list-table td:nth-child(8){width:110px}.list-table th:nth-child(9),.list-table td:nth-child(9){width:96px}.list-table thead th{padding:12px 10px}.list-table tbody td{padding:10px}.list-table th:first-child,.list-table td:first-child{text-align:center;font-variant-numeric:tabular-nums}.list-table .row-actions{justify-content:flex-start;gap:6px}.list-table .btn-sm{padding:6px 10px;font-size:12px}.icon-action{border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;line-height:1;display:inline-flex}.icon-action:disabled{opacity:.55;cursor:not-allowed}.icon-primary{color:var(--primary);border-color:#3182ce59}.icon-primary:hover:not(:disabled){background:#ebf8ff;border-color:#3182ce8c}.icon-danger{color:var(--danger);border-color:#e53e3e59}.icon-danger:hover:not(:disabled){background:#fff5f5;border-color:#e53e3e8c}.data-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);z-index:1;background:#f8fafc;padding:14px 12px;font-size:12px;position:sticky;top:0}.data-table tbody td{border-bottom:1px solid var(--border);vertical-align:top;color:var(--text-main);background:#fff;padding:12px;font-size:14px}.data-table tbody tr:hover td{background:#fbfdff}.cell-ellipsis{white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.row-clickable{cursor:pointer}.cell-compact{align-items:center;gap:8px;display:flex}.cell-compact .cell-ellipsis{flex:1;min-width:0}.cell-icon{text-align:center;opacity:.9;width:18px;font-size:12px}.table-thumb{-o-object-fit:cover;object-fit:cover;border:1px solid var(--border);background:#edf2f7;border-radius:10px;width:44px;height:44px}.thumb-button{cursor:pointer;background:0 0;border:none;border-radius:10px;padding:0;display:inline-flex}.thumb-button:focus{outline:none}.thumb-button:focus-visible{box-shadow:0 0 0 3px #3182ce40}.image-modal{inset:0;z-index:3000;background:#0f172aa6;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.image-modal-content{border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;flex-direction:column;width:min(980px,100%);max-width:980px;max-height:min(86vh,900px);display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000059}.image-modal-header{border-bottom:1px solid var(--border);background:#f8fafc;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.image-modal-title{color:var(--text-main);font-size:14px;font-weight:700}.image-modal-close{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;width:36px;height:36px;font-size:22px;line-height:1}.image-modal-close:hover{background:#f1f5f9}.image-modal-img{-o-object-fit:contain;object-fit:contain;background:#0b1220;width:100%;height:100%}.detail-modal{z-index:2001;background:#0f172aa6;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.detail-modal-content{border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;flex-direction:column;width:100%;max-width:1080px;max-height:86vh;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000059}.detail-modal-header{border-bottom:1px solid var(--border);background:#f8fafc;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px;display:flex}.detail-title{color:var(--text-main);font-size:16px;font-weight:900}.detail-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.detail-meta{border-bottom:1px solid var(--border);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;padding:14px;display:grid}.detail-meta-item{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;padding:10px 12px}.detail-meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:700}.detail-meta-value{color:var(--text-main);margin-top:6px;font-size:14px;font-weight:700}.detail-grid{grid-template-columns:1fr 1fr;gap:14px;padding:14px;display:grid;overflow:auto}@media (width<=860px){.detail-grid{grid-template-columns:1fr}}.detail-panel{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;flex-direction:column;display:flex;overflow:hidden}.detail-panel-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);background:#f8fafc;padding:12px;font-size:13px;font-weight:900}.detail-img-btn{cursor:pointer;background:0 0;border:none;padding:0}.detail-img{-o-object-fit:contain;object-fit:contain;background:#0b1220;width:100%;height:320px;display:block}.detail-img-empty{height:320px;color:var(--text-muted);background:#f8fafc;justify-content:center;align-items:center;font-weight:700;display:flex}.detail-text{color:var(--text-main);white-space:pre-wrap;padding:12px;font-size:14px;line-height:1.55}.detail-footer{border-top:1px solid var(--border);background:#fff;justify-content:flex-end;padding:14px;display:flex}.temuan-img-container{height:200px;position:relative}.badge-floating{text-transform:uppercase;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:8px;padding:6px 12px;font-size:11px;font-weight:800;position:absolute;top:12px;right:12px;box-shadow:0 2px 4px #0000001a}.badge-floating.badge-open{color:#c53030;background:#fff5f5e6}.badge-floating.badge-closed{color:#2f855a;background:#f0fff4e6}.temuan-id{color:var(--text-muted);background:var(--bg);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:12px}.temuan-meta-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.meta-item{flex-direction:column;display:flex}.meta-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:10px;font-weight:700}.meta-value{color:var(--text-main);font-size:13px;font-weight:600}.card-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:16px}.btn-outline-primary{border:1px solid var(--primary);color:var(--primary);background:0 0}.btn-outline-primary:hover{background:var(--primary);color:#fff}.btn-outline-danger{border:1px solid var(--danger);color:var(--danger);background:0 0}.btn-outline-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-sm{padding:8px 12px;font-size:13px}.user-management-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px;display:flex}.user-actions,.row-actions{flex-wrap:wrap;gap:10px;display:flex}.user-table{min-width:760px}@supports not (gap:10px){.user-actions{margin-bottom:-10px;margin-right:-10px}.user-actions>*{margin-bottom:10px;margin-right:10px}.row-actions{margin-bottom:-10px;margin-right:-10px}.row-actions>*{margin-bottom:10px;margin-right:10px}}.empty-state{text-align:center;border-radius:var(--radius-md);border:2px dashed var(--border);background:#fff;grid-column:1/-1;padding:60px}.empty-icon{margin-bottom:16px;font-size:48px}.user-list{flex-direction:column;gap:12px;display:flex}.user-item{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.user-info{flex-direction:column;display:flex}.user-info strong{color:var(--text-main);font-size:15px}.user-info span{color:var(--text-muted);font-size:13px}.btn-delete{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:18px;transition:background .2s}.btn-delete:hover:not(:disabled){background:#fee2e2}.btn-delete:disabled{opacity:.3;cursor:not-allowed}@media (width<=768px){.dashboard-row{grid-template-columns:1fr}.list-actions{max-width:100%}.dashboard-hero{flex-direction:column}.hero-right{justify-content:flex-start;min-width:0}.kpi-grid{grid-template-columns:repeat(2,1fr)}.chart-grid,.dashboard-row.dashboard-row-2{grid-template-columns:1fr}.recent-item{grid-template-columns:auto 1fr}.recent-item .btn{grid-column:1/-1;justify-content:center;width:100%}}.form-container{flex-direction:column;gap:24px;max-width:800px;margin:0 auto;display:flex}.form-section{border-radius:var(--radius-md);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;padding:32px}.form-section h3{border-bottom:2px solid var(--bg);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:12px;font-size:18px;font-weight:700;display:flex}.grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.field{flex-direction:column;gap:8px;display:flex}.field-full{grid-column:1/-1}label{color:var(--text-main);font-size:14px;font-weight:600}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-main);background:#fcfcfc;padding:12px 16px;font-size:15px;transition:all .2s}input::-moz-placeholder{color:var(--text-muted);opacity:.8}textarea::-moz-placeholder{color:var(--text-muted);opacity:.8}input::placeholder,textarea::placeholder{color:var(--text-muted);opacity:.8}input:-webkit-autofill{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}input:-webkit-autofill:hover{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}input:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}textarea:-webkit-autofill{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}textarea:-webkit-autofill:hover{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}textarea:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}select:-webkit-autofill{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}select:-webkit-autofill:hover{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}select:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-main);caret-color:var(--text-main);box-shadow:inset 0 0 0 1000px #fcfcfc}input:focus,select:focus,textarea:focus{border-color:var(--accent);background:#fff;outline:none;box-shadow:0 0 0 3px #3182ce1a}input[readonly]{cursor:not-allowed;background:#f1f5f9}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light);transform:translateY(-1px)}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover{background:var(--bg);color:var(--primary)}.btn-login{background:var(--primary);color:#fff;width:100%}.actions{justify-content:flex-end;gap:12px;margin-top:12px;display:flex}.temuan-list{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid}.temuan-card{border-radius:var(--radius-md);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;flex-direction:column;transition:transform .2s;display:flex;overflow:hidden}.temuan-card:hover{transform:translateY(-4px)}.temuan-img{-o-object-fit:cover;object-fit:cover;background:#edf2f7;width:100%;height:200px}.temuan-content{flex-direction:column;flex:1;padding:20px;display:flex}.temuan-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.temuan-header h4{font-size:18px;font-weight:700}.badge{text-transform:uppercase;border-radius:99px;padding:4px 10px;font-size:12px;font-weight:700}.badge-open{color:#c53030;background:#fff5f5}.badge-progress{color:#b7791f;background:ivory}.badge-closed{color:#2f855a;background:#f0fff4}.temuan-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:14px;display:-webkit-box;overflow:hidden}.temuan-meta{border-top:1px solid var(--bg);color:var(--text-muted);grid-template-columns:1fr 1fr;gap:8px;margin-top:auto;padding-top:16px;font-size:13px;display:grid}.temuan-meta span{align-items:center;gap:6px;display:flex}.upload-box{border:2px dashed var(--border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;background:#fafafa;padding:20px;transition:all .2s}.upload-box:hover{border-color:var(--accent);background:#f0f7ff}.upload-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:12px;display:flex}@supports not (gap:10px){.upload-actions{margin-bottom:-10px;margin-right:-10px}.upload-actions>*{margin-bottom:10px;margin-right:10px}}.upload-preview{-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-sm);width:100%;max-height:200px;margin-top:12px}@media (width<=640px){.grid{grid-template-columns:1fr}.login-card{padding:32px 24px}.dashboard-grid{grid-template-columns:1fr}}
