:root{--color-bg-primary: #f4f5f7;--color-bg-secondary: #ffffff;--color-bg-tertiary: #edf0f3;--color-bg-white: #ffffff;--color-glass-bg: #ffffff;--color-glass-bg-hover: #f8fafc;--color-glass-bg-active: #ffffff;--color-glass-border: #e3e6ea;--color-glass-shadow: rgba(0, 0, 0, .08);--color-border: #e1e5ea;--color-primary-dark: #102a43;--color-primary-medium: #1f3f68;--color-primary-light: #486581;--color-brand-dark: #0b223d;--color-text-primary: #111827;--color-text-secondary: #374151;--color-text-tertiary: #6b7280;--color-text-inverse: #ffffff;--color-text-disabled: #9ca3af;--color-accent: #1d4d8f;--color-accent-hover: #153c72;--color-accent-light: rgba(29, 77, 143, .16);--color-accent-lighter: rgba(29, 77, 143, .08);--color-success: #1f9d75;--color-success-light: rgba(31, 157, 117, .14);--color-warning: #c9872d;--color-warning-light: rgba(201, 135, 45, .16);--color-danger: #d3475f;--color-danger-light: rgba(211, 71, 95, .14);--color-info: #358ec9;--color-info-light: rgba(53, 142, 201, .14);--font-family: "Manrope", sans-serif;--font-family-body: "Manrope", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.375rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2.25rem;--font-size-4xl: 2.9rem;--font-weight-regular: 500;--font-weight-medium: 600;--font-weight-semibold: 700;--font-weight-bold: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 14px;--radius-pill: 999px;--glass-blur: 10px;--glass-blur-heavy: 18px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 8px 20px rgba(15, 23, 42, .06);--shadow-md: 0 14px 32px rgba(15, 23, 42, .1);--shadow-lg: 0 20px 44px rgba(15, 23, 42, .14);--shadow-xl: 0 26px 56px rgba(15, 23, 42, .18);--transition-fast: .16s cubic-bezier(.4, 0, .2, 1);--transition-base: .26s cubic-bezier(.2, .8, .2, 1);--transition-normal: .32s cubic-bezier(.2, .8, .2, 1);--transition-slow: .42s cubic-bezier(.2, .8, .2, 1);--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--sidebar-width-expanded: 290px;--sidebar-width-collapsed: 86px;--header-height: 78px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh;overflow-x:hidden}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{overflow-wrap:break-word;font-weight:var(--font-weight-semibold)}p{overflow-wrap:break-word}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:#eef1f5;border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#bcc6d3,#9eacbc);border-radius:var(--radius-pill);border:2px solid #eef1f5}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#a7b4c4,#8e9db0)}.heading-1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:-.02em;color:var(--color-primary-dark)}.heading-2{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:-.01em;color:var(--color-primary-dark)}.heading-3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-primary-dark)}.heading-4{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-primary-dark)}.heading-5{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);line-height:var(--line-height-normal);color:var(--color-primary-dark)}.heading-6{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:var(--line-height-normal);color:var(--color-primary-dark)}.text-body{font-size:var(--font-size-md);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary)}.text-body-sm{font-size:var(--font-size-sm);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-secondary)}.text-caption{font-size:var(--font-size-xs);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-tertiary)}.text-overline{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:var(--line-height-normal);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary)}.text-primary{color:var(--color-text-primary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger,.text-red-500{color:var(--color-danger)}.text-gray-400{color:var(--color-text-disabled)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-text-primary{color:var(--color-text-primary)}.text-text-tertiary{color:var(--color-text-tertiary)}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.08em}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:fade-in var(--transition-base) ease-out both}.animate-fade-in-up{animation:fade-in-up var(--transition-slow) ease-out both}.animate-fade-in-down{animation:fade-in-down var(--transition-slow) ease-out both}.animate-slide-in-left{animation:slide-in-left var(--transition-slow) ease-out both}.animate-slide-in-right{animation:slide-in-right var(--transition-slow) ease-out both}.animate-scale-in{animation:scale-in var(--transition-base) ease-out both}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-delay-1{animation-delay:50ms}.animate-delay-2{animation-delay:.1s}.animate-delay-3{animation-delay:.15s}.animate-delay-4{animation-delay:.2s}.animate-delay-5{animation-delay:.25s}.animate-delay-6{animation-delay:.3s}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.03)}.hover-glow{transition:box-shadow var(--transition-base)}.hover-glow:hover{box-shadow:0 0 24px var(--color-accent-light)}.skeleton{background:linear-gradient(90deg,var(--color-bg-secondary) 25%,var(--color-bg-tertiary) 50%,var(--color-bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:14px;width:100%;margin-bottom:var(--space-2)}.skeleton-heading{height:24px;width:60%;margin-bottom:var(--space-3)}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.overlay{position:fixed;inset:0;background-color:#0f172a2e;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:var(--z-overlay);animation:fade-in var(--transition-fast) ease-out}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.68rem 1.15rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);line-height:1.2;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:all var(--transition-fast);letter-spacing:.01em;box-shadow:none}.btn:active{transform:scale(.98)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn .btn-icon{width:18px;height:18px;flex-shrink:0;stroke-width:2px}.btn-sm{padding:.5rem .95rem;font-size:var(--font-size-xs)}.btn-lg{padding:.8rem 1.5rem;font-size:var(--font-size-lg)}.btn-block{width:100%}.btn-primary{background:linear-gradient(135deg,var(--color-primary-dark),var(--color-primary-medium));color:var(--color-text-inverse);border-color:transparent;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:linear-gradient(135deg,#0a2443,#15365e);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0) scale(.98)}.btn-accent{background:var(--color-accent);color:var(--color-text-inverse);border-color:transparent;box-shadow:none}.btn-accent:hover{background:var(--color-accent-hover);transform:translateY(-1px)}.btn-secondary{background-color:#fff;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:#f8fafc;color:var(--color-text-primary);border-color:#cfd7e2}.btn-ghost{background-color:#fff;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover{background-color:#f2f5f9;color:var(--color-primary-dark)}.btn-danger{background:linear-gradient(135deg,#d3475f,#c63f55);color:var(--color-text-inverse);border-color:transparent;box-shadow:0 10px 24px #c63f554d}.btn-danger:hover{box-shadow:0 14px 28px #c63f5557;transform:translateY(-1px)}.btn-danger-ghost{background-color:transparent;color:var(--color-danger);border:1px solid transparent}.btn-danger-ghost:hover{background-color:#ef44441a}.btn-danger-outline{background-color:#d3475f0d;color:var(--color-danger);border:1px solid var(--color-danger)}.btn-danger-outline:hover{background-color:#ef44441a}.btn-outline{background-color:transparent;color:var(--color-primary-dark);border:1px solid var(--color-primary-light)}.btn-outline:hover{background-color:#637ca91a;color:var(--color-primary-dark)}.btn-icon-only{padding:var(--space-2);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center}.btn-icon-only .btn-icon{width:20px;height:20px}.btn-action{background-color:#fff;border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast)}.btn-action:hover{background-color:#f2f5f9;color:var(--color-primary-dark);transform:translateY(-1px)}.btn-action--primary:hover{background-color:#0d1b2a1a;color:var(--color-primary-dark)}.btn-action--success:hover{background-color:var(--color-success-light);color:var(--color-success)}.btn-action--danger:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:18px;height:18px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite}.btn-primary.btn-loading:after{border-color:#fff6;border-right-color:transparent}@keyframes btn-spin{to{transform:rotate(360deg)}}@media(max-width:1280px){.btn{padding:.6rem 1rem;font-size:var(--font-size-sm);height:38px}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-md);height:auto}.btn-sm{padding:.45rem .85rem;font-size:.72rem;height:32px}}@media(max-width:640px){.btn{padding:.6rem .95rem;font-size:.85rem;width:100%;justify-content:center}.btn-icon-only{width:44px;height:44px}.btn-icon-only .btn-icon{width:24px;height:24px}}.card{background-color:#fff;border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-xs);border:1px solid var(--color-glass-border);transition:box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.card-glass{background:#fff;border:1px solid var(--color-glass-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-xs);transition:background-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}.card-glass:hover{box-shadow:var(--shadow-sm);border-color:#d8dde3}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px)}.card-interactive:active{transform:translateY(0)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:var(--space-1)}.card-body{font-size:var(--font-size-md);color:var(--color-text-secondary)}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.stat-card{display:flex;flex-direction:column;gap:var(--space-3)}.stat-card-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl)}.stat-card-icon--accent{background-color:var(--color-accent-light);color:var(--color-accent)}.stat-card-icon--success{background-color:var(--color-success-light);color:var(--color-success)}.stat-card-icon--warning{background-color:var(--color-warning-light);color:var(--color-warning)}.stat-card-icon--danger{background-color:var(--color-danger-light);color:var(--color-danger)}.stat-card-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.stat-card-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary)}.card-compact{padding:var(--space-4)}.card-spacious{padding:var(--space-8)}.form-group{display:flex;flex-direction:column;gap:var(--space-2);width:100%}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);padding-left:var(--space-1)}.form-label--required:after{content:" *";color:var(--color-danger)}.form-input{width:100%;padding:.78rem 1rem;min-height:44px;font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:#f8fafc;border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input::placeholder{color:var(--color-text-disabled)}.form-input:hover{background-color:#fff;border-color:#ccd5e1}.form-input:focus{background-color:#fff;border-color:var(--color-primary-dark);box-shadow:0 0 0 3px #102a4324}.form-textarea{width:100%;padding:.78rem 1rem;font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:#f8fafc;border:1px solid var(--color-border);border-radius:var(--radius-lg);outline:none;resize:vertical;min-height:100px;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-textarea:focus{background-color:#fff;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.form-select{width:100%;padding:.78rem 1rem;padding-right:calc(var(--space-10) + 4px);min-height:44px;font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:#f8fafc;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23444444' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:13px 13px;border:1px solid var(--color-border);border-radius:var(--radius-lg);outline:none;appearance:none;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-select:focus{background-color:#fff;border-color:var(--color-primary-dark);box-shadow:0 0 0 3px #102a4324}.form-select option{color:var(--color-text-primary);background-color:#fff}.form-select option:checked,.form-select option:hover{color:#fff;background-color:var(--color-primary-dark)}.form-input--error,.form-textarea--error,.form-select--error{border-color:var(--color-danger);background-color:#d3475f0f}.form-input--error:focus,.form-textarea--error:focus,.form-select--error:focus{border-color:var(--color-danger);box-shadow:0 0 0 4px #d3475f29}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);padding-left:var(--space-1);animation:form-error-in .2s ease-out}@keyframes form-error-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);padding-left:var(--space-1)}.form-check{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.form-check-input{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer}.form-check-label{font-size:var(--font-size-md);color:var(--color-text-primary);cursor:pointer}.form-input-wrapper{position:relative;display:flex;align-items:center}.form-input-wrapper .form-input,.form-input-wrapper .form-select{padding-left:var(--space-10)}.form-input-icon{position:absolute;left:var(--space-4);width:18px;height:18px;color:var(--color-text-tertiary);pointer-events:none;transition:color var(--transition-fast)}.form-input-wrapper:focus-within .form-input-icon{color:var(--color-accent)}.form-input-action{position:absolute;right:var(--space-2);padding:var(--space-2);color:var(--color-text-tertiary);cursor:pointer;border-radius:50%;transition:color var(--transition-fast),background-color var(--transition-fast)}.form-input-action:hover{color:var(--color-text-primary);background-color:var(--color-accent-lighter)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{opacity:.5;cursor:not-allowed}.form-error-message{padding:var(--space-3) var(--space-4);background-color:#ef44441a;border:1px solid rgba(211,71,95,.25);color:var(--color-danger);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md);margin-bottom:var(--space-4)}.form-success-message{padding:var(--space-3) var(--space-4);background-color:#10b9811a;border:1px solid rgba(31,157,117,.24);color:var(--color-success);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md);margin-bottom:var(--space-4)}.phone-input-group{display:flex;align-items:stretch;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background-color:#f8fafc;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.phone-input-group:focus-within{background-color:#fff;border-color:var(--color-primary-dark);box-shadow:0 0 0 3px #102a4324}.phone-prefix{display:flex;align-items:center;padding:0 .75rem;background-color:#eef2f7;border-right:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary);white-space:nowrap;-webkit-user-select:none;user-select:none}.phone-input-group .form-input{border:none;border-radius:0;background:transparent;box-shadow:none;flex:1;min-width:0}.phone-input-group .form-input:focus{border:none;box-shadow:none;background:transparent}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:1.4;border-radius:var(--radius-pill);white-space:nowrap}.badge-default{background-color:#6f7f9a24;color:var(--color-text-secondary)}.badge-accent{background-color:var(--color-accent-lighter);color:var(--color-accent)}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger)}.badge-info{background-color:var(--color-info-light);color:var(--color-info)}.badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.badge-dot--success{background-color:var(--color-success)}.badge-dot--warning{background-color:var(--color-warning)}.badge-dot--danger{background-color:var(--color-danger)}.badge-dot--accent{background-color:var(--color-accent)}.badge-lg{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.status-plate{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;border:1px solid;white-space:nowrap;letter-spacing:.01em}.status-plate-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.darkgreen-plate{background-color:#10b9811a;color:#10b981;border-color:#10b98140}.darkgreen-plate .status-plate-dot{background-color:#10b981}.darkred-plate{background-color:#ef44441a;color:#ef4444;border-color:#ef444440}.darkred-plate .status-plate-dot{background-color:#ef4444}.darkyellow-plate{background-color:#f59e0b1a;color:#f59e0b;border-color:#f59e0b40}.darkyellow-plate .status-plate-dot{background-color:#f59e0b}.darkblue-plate{background-color:#3b82f61a;color:#3b82f6;border-color:#3b82f640}.darkblue-plate .status-plate-dot{background-color:#3b82f6}.darkgray-plate{background-color:#6b72801a;color:#6b7280;border-color:#6b728040}.darkgray-plate .status-plate-dot{background-color:#6b7280}.table-wrapper{width:100%;overflow-x:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;background:#fff;border:1px solid var(--color-border);box-shadow:var(--shadow-xs);margin-bottom:0;border-bottom:1px solid var(--color-border)}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--font-size-sm);color:var(--color-text-primary)}.data-table thead th{padding:1rem;text-align:left;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f8fafc;border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table thead th:first-child{padding-left:var(--space-6)}.data-table thead th:last-child{padding-right:var(--space-6)}.data-table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.data-table thead th.sortable:hover{color:var(--color-primary-dark);background:#f1f5f9}.data-table thead th.text-right{text-align:right}.data-table tbody tr{transition:background-color var(--transition-fast),transform var(--transition-fast)}.data-table tbody tr:hover{background-color:#f5f8fc}.data-table tbody td{padding:.9rem 1rem;border-bottom:1px solid #edf0f3;color:var(--color-text-primary);vertical-align:middle;font-weight:600;height:52px}.data-table tbody td:first-child{padding-left:var(--space-6)}.data-table tbody td:last-child{padding-right:var(--space-6)}.data-table tbody td.text-right{text-align:right}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:nth-child(2n){background-color:#fbfcfd}.text-primary{color:var(--color-text-primary);font-weight:700}.text-secondary{color:var(--color-text-secondary)}.font-medium{font-weight:600}.data-table .btn-action{color:var(--color-text-secondary);opacity:1}.data-table .btn-action:hover{color:var(--color-primary-dark);opacity:1;background:var(--color-bg-tertiary)}.table-empty{text-align:center;padding:var(--space-12) var(--space-6);display:flex;flex-direction:column;align-items:center;justify-content:center}.table-empty-icon{margin-bottom:var(--space-4);color:var(--color-text-tertiary);background-color:var(--color-bg-secondary);width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border)}.table-empty-icon svg{width:32px;height:32px;opacity:.8}.table-empty-title{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2)}.table-empty-text{font-size:.875rem;color:var(--color-text-secondary);max-width:300px;line-height:1.5}@media(max-width:768px){.data-table thead th,.data-table tbody td{padding:var(--space-2) var(--space-3)}.data-table tbody td:first-child{padding-left:var(--space-3)}.data-table tbody td:last-child{padding-right:var(--space-3)}.data-table{min-width:600px}}svg{stroke-width:2.1px}.container{width:100%;max-width:1320px;margin:0 auto;padding:0 var(--space-6)}.container-fluid{width:100%;padding:0 var(--space-6)}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.m-0{margin:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.w-full{width:100%}.h-full{height:100%}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.border{border:1px solid var(--color-border)}.rounded-lg{border-radius:var(--radius-lg)}.bg-danger\/10{background-color:var(--color-danger-light)}.bg-success\/10{background-color:var(--color-success-light)}.bg-warning\/10{background-color:var(--color-warning-light)}.bg-info\/10{background-color:var(--color-info-light)}.border-danger\/30{border-color:#d3475f4d}.text-\[10px\]{font-size:10px}.mobile-visible{display:none}.desktop-hidden{display:none!important}@media(max-width:1024px){.container{padding:0 var(--space-4)}.grid-cols-4,.grid-cols-3{grid-template-columns:repeat(2,1fr)}.grid-cols-2{grid-template-columns:1fr}.tablet-hidden{display:none!important}.tablet-block{display:block!important}.tablet-flex{display:flex!important}.tablet-col{flex-direction:column!important}.tablet-gap-4{gap:var(--space-4)!important}.tablet-cols-1{grid-template-columns:repeat(1,1fr)!important}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.container{padding:0 var(--space-3)}.grid-cols-4,.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}.mobile-hidden{display:none!important}.mobile-block{display:block!important}.mobile-flex{display:flex!important}.mobile-col{flex-direction:column!important}.mobile-p-3{padding:var(--space-3)!important}.mobile-p-4{padding:var(--space-4)!important}.mobile-visible{display:inline}.md\:grid-cols-2{grid-template-columns:1fr}}.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width-expanded);background:#f7f8fa;display:flex;flex-direction:column;z-index:var(--z-sticky);transition:width var(--transition-slow),transform .32s cubic-bezier(.22,1,.36,1),opacity .24s ease;overflow:hidden;box-shadow:none;border-right:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--space-3) 0}.sidebar--collapsed{width:var(--sidebar-width-collapsed)}.sidebar-brand{display:flex;align-items:center;justify-content:center;padding:var(--space-3);height:var(--header-height);margin:0 var(--space-3) var(--space-4);background:transparent;border:none;border-radius:var(--radius-lg);box-shadow:none}.sidebar-brand-image{max-width:100%;max-height:100px;object-fit:contain;transition:all var(--transition-base);filter:drop-shadow(0 1px 1px rgba(15,23,42,.18)) brightness(1.04)}.sidebar--collapsed .sidebar-brand-image{max-width:40px;object-fit:cover;object-position:left}.sidebar-nav{flex:1;padding:0 var(--space-3);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:var(--space-4)}.sidebar-nav-section{margin-bottom:0;background:transparent;border:none;border-radius:0;padding:0;border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2)}.sidebar-nav-section:last-child{border-bottom:none}.sidebar-nav-section-title{font-size:.7rem;font-weight:700;color:#9aa4b2;text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-4);white-space:nowrap;overflow:hidden;opacity:1;transition:opacity var(--transition-base)}.sidebar--collapsed .sidebar-nav-section-title{opacity:0;height:0;padding:0;margin:0}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:.86rem .95rem;margin-bottom:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);border:1px solid transparent;background:transparent;position:relative}.sidebar--collapsed .sidebar-nav-item{justify-content:center;padding:var(--space-4) 0;gap:0}.sidebar-nav-item:hover{background-color:#f0f3f7;color:var(--color-primary-dark)}.sidebar-nav-item--active{background:#e3ebf7;color:#0e294a;border-color:#c8d6ea;box-shadow:inset 0 0 0 1px #ffffff73;font-weight:700}.sidebar-nav-item--active .sidebar-nav-icon{color:#0e294a}.sidebar-nav-item--active:hover{background:#dae5f4;color:#0e294a}.sidebar-nav-item--active:before{content:"";position:absolute;left:8px;top:50%;transform:translateY(-50%);width:4px;height:18px;border-radius:999px;background:#0e294a}.sidebar-nav-item--disabled{opacity:.5;cursor:not-allowed}.sidebar-nav-icon{width:24px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-nav-icon svg{width:20px;height:20px;stroke-width:2}.sidebar-nav-label{overflow:hidden;opacity:1;transition:opacity var(--transition-base),width var(--transition-base)}.sidebar--collapsed .sidebar-nav-label{opacity:0;width:0}.sidebar-toggle{display:flex;align-items:center;justify-content:center;padding:0;margin:0 var(--space-3) var(--space-3);margin-top:auto;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-md);background:#fff;border:1px solid var(--color-border);width:40px;height:40px}.sidebar-toggle:hover{color:#0e294a;background:#f0f4fa;border-color:#cfd8e6}.sidebar-toggle-icon{width:20px;height:20px;stroke-width:2.4;transition:transform var(--transition-base)}.sidebar--collapsed .sidebar-toggle-icon{transform:rotate(180deg)}.sidebar-footer{display:none}.sidebar-version{font-size:.75rem;font-weight:700;color:var(--color-primary-dark)}.sidebar-copyright{font-size:.65rem;color:var(--color-text-tertiary);margin-top:var(--space-1)}@media(max-width:768px){.sidebar{transform:translate(calc(-100% - 24px));opacity:0;box-shadow:0 18px 42px #0a192d42;width:min(84vw,320px);background:#f7f8fafa;border:1px solid #dddddd;border-left:none;border-radius:0 16px 16px 0;margin:0;height:100vh;top:0;left:0;transition:transform .34s cubic-bezier(.22,1,.36,1),opacity .26s ease;z-index:1000}.sidebar--mobile-open{transform:translate(0);opacity:1}.sidebar-brand{margin-bottom:var(--space-3)}}.app-shell{display:flex;min-height:100vh;background:var(--color-bg-primary);width:100%;overflow-x:hidden}.app-content-area{flex:1;margin-left:var(--sidebar-width-expanded);transition:margin-left var(--transition-slow);display:flex;flex-direction:column;min-height:100vh;min-width:0;max-width:100%;border-left:1px solid var(--color-border)}.app-content-area--collapsed{margin-left:var(--sidebar-width-collapsed)}.app-main{flex:1;padding:var(--space-6);padding-top:calc(var(--header-height) + var(--space-6))}.app-header{position:fixed;top:0;right:0;left:var(--sidebar-width-expanded);height:var(--header-height);background:#f4f5f7c7;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);z-index:var(--z-sticky);transition:left var(--transition-slow)}.header-group{background:transparent;border:none;border-radius:0;min-height:48px;padding:0}.header-group--left{padding-left:0}.header-group--right{padding-right:0}.header-profile-trigger{padding:var(--space-1) var(--space-2);border-radius:var(--radius-md)}.header-profile-trigger:hover{background:#f2f4f7}.app-header .btn-ghost,.app-header .heading-5,.app-header .font-medium{color:var(--color-text-primary)}.app-header .system-date{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);opacity:1;display:block}.sidebar-profile-avatar{width:40px;height:40px;border-radius:50%;background:#f3f4f6;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;border:1px solid var(--color-border);box-shadow:none}.app-header--collapsed{left:var(--sidebar-width-collapsed)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);padding:var(--space-6)}.login-card{width:100%;max-width:440px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);box-shadow:var(--shadow-sm);animation:fade-in-up var(--transition-slow) ease-out}.page-header{margin-bottom:var(--space-8);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-4)}.page-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary-dark);letter-spacing:-.03em}.page-subtitle{font-size:var(--font-size-md);color:var(--color-text-tertiary);margin-top:var(--space-2)}.modal-overlay{position:fixed;inset:0;background:#0f172a73;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4);animation:fade-in .2s ease-out}.modal-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:fade-in-up .3s ease-out;border:1px solid var(--color-border)}.modal-card--lg{max-width:680px}.modal-card>form{display:flex;flex-direction:column;overflow:hidden;height:100%;margin:0}.modal-header{background:#f8fafc;display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);flex-shrink:0}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);letter-spacing:.01em}.modal-close{background:#fff;border:1px solid var(--color-border);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;width:32px;height:32px}.modal-close:hover{background:#f8fafc;border-color:#d7dce2;color:var(--color-text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto;flex-grow:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background-color:#fafbfc;flex-shrink:0}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:calc(var(--z-modal) + 10);display:flex;flex-direction:column;gap:var(--space-2)}.toast{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-3);min-width:280px;max-width:400px;animation:fade-in-up .3s ease-out;font-size:var(--font-size-sm)}.toast--success{border-left:3px solid var(--color-success)}.toast--error{border-left:3px solid var(--color-danger)}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast--success .toast-icon{color:var(--color-success)}.toast--error .toast-icon{color:var(--color-danger)}.page-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.page-actions>.search-input-wrapper,.page-actions>.voucher-filters,.action-group-pill{background:transparent;border:none;border-radius:0;min-height:48px}.page-actions>.search-input-wrapper{background:transparent;border:none;border-radius:0;min-height:auto;padding:0}.page-actions>.voucher-filters,.action-group-pill{padding:0}.modal-header .btn-icon{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center}.modal-header .btn-icon:hover{background:#f5f8fc;border-color:#d7dce2;color:var(--color-text-primary)}.page-actions .btn-primary,.page-actions .btn-success{min-height:44px}.search-input-wrapper{position:relative;flex:1;max-width:360px}.search-input-wrapper .form-input{padding-left:var(--space-10)}.search-input-wrapper .search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-tertiary);pointer-events:none}.clickable{cursor:pointer}.avatar-sm{width:36px;height:36px;font-size:.8rem}.avatar-md{width:40px;height:40px;font-size:.85rem}.avatar-img-cover{width:100%;height:100%;object-fit:cover;border-radius:50%}.hidden-input{display:none}.btn-full{width:100%}.form-error-inline{display:block}.reason-wrap{max-width:300px;white-space:normal}.balance-display{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-align:center;padding:var(--space-4);background:#e9e9e9;border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.balance-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.balance-mode-toggle{display:flex;gap:var(--space-2);margin-top:var(--space-1)}.balance-mode-btn{display:inline-flex;align-items:center;gap:var(--space-2);flex:1;justify-content:center;padding:.55rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.balance-mode-btn:hover{border-color:var(--color-primary-medium);color:var(--color-primary-medium);background:var(--color-accent-lighter)}.balance-mode-btn--active{border-color:var(--color-primary-medium);background:var(--color-accent-lighter);color:var(--color-primary-medium);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-xs)}.balance-preview{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-success-light);border:1px solid rgba(31,157,117,.25);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-success)}.balance-preview strong{font-weight:var(--font-weight-semibold)}@media(max-width:768px){.app-content-area,.app-content-area--collapsed{margin-left:0}.app-header,.app-header--collapsed{left:0}.app-main{padding:var(--space-4);padding-top:var(--space-4);width:100%;overflow-x:hidden}.app-shell{overflow-x:hidden;position:relative;flex-direction:column}.app-header{left:0;width:100%;position:sticky;top:0}.table-wrapper{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.login-card{padding:var(--space-6)}.mobile-hidden{display:none!important}.mobile-flex{display:flex!important}.page-actions{flex-direction:column;align-items:stretch}.search-input-wrapper{max-width:100%}.modal-overlay{padding:var(--space-4);align-items:center}.modal-card{max-width:100%;width:100%;margin:0;max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column}.modal-body{overflow-y:auto;padding:var(--space-4)}.modal-footer{flex-direction:column;gap:var(--space-3)}.modal-footer .btn{width:100%;margin:0}}@media(max-width:1024px){.modal-card{max-width:90vw}}.app-shell{position:relative}.pp-upload-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-bg-tertiary);margin-bottom:var(--space-2)}.pp-upload-area{position:relative;display:inline-flex;align-items:center;justify-content:center}.pp-avatar-circle{width:110px;height:110px;border-radius:50%;border:3px solid var(--color-primary-dark);overflow:hidden;cursor:pointer;position:relative;transition:all .3s ease;background:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center}.pp-avatar-circle:hover{border-color:var(--color-accent);box-shadow:0 0 0 4px #e67e2226;transform:scale(1.03)}.pp-avatar-circle.pp-avatar-loading{pointer-events:none;opacity:.7}.pp-avatar-img{width:100%;height:100%;object-fit:cover;display:block}.pp-avatar-edit-overlay{position:absolute;inset:0;background:#0000008c;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;transition:opacity .25s ease;color:#fff;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.pp-avatar-circle:hover .pp-avatar-edit-overlay{opacity:1}.pp-avatar-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--color-text-tertiary);transition:color .2s ease}.pp-avatar-circle:hover .pp-avatar-placeholder{color:var(--color-accent)}.pp-upload-text{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.pp-avatar-spinner{display:flex;align-items:center;justify-content:center}.pp-remove-btn{position:absolute;top:-4px;right:-4px;width:28px;height:28px;border-radius:50%;border:2px solid var(--color-bg-white);background:var(--color-danger, #ef4444);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:2;box-shadow:0 2px 6px #ef44444d}.pp-remove-btn:hover{background:#dc2626;transform:scale(1.1)}.pp-upload-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:600;letter-spacing:.01em}
