@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.login-bg{min-height:100vh;display:grid;place-items:center;background:radial-gradient(ellipse 80% 60% at 15% 10%,rgba(232,128,64,.07),transparent),radial-gradient(ellipse 60% 60% at 85% 90%,rgba(200,104,40,.05),transparent),#09090c;position:relative;overflow:hidden;padding:24px}.login-orb{position:absolute;border-radius:50%;pointer-events:none}.login-orb-1{width:560px;height:560px;background:radial-gradient(circle,rgba(232,128,64,.12) 0%,transparent 65%);top:-180px;left:-160px;animation:orb-drift 18s ease-in-out infinite alternate}.login-orb-2{width:440px;height:440px;background:radial-gradient(circle,rgba(200,104,40,.08) 0%,transparent 65%);bottom:-120px;right:-100px;animation:orb-drift 22s ease-in-out infinite alternate-reverse}@keyframes orb-drift{0%{transform:translate(0)}to{transform:translate(30px,20px)}}.login-card{position:relative;z-index:1;width:min(420px,100%);background:linear-gradient(158deg,#141519f7,#0c0d10fa);border:1px solid rgba(232,128,64,.14);border-radius:28px;padding:44px 38px 34px;display:grid;gap:28px;box-shadow:0 0 0 1px #ffffff08 inset,0 40px 80px #0009,0 8px 32px #e8804012;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.login-brand{display:flex;justify-content:center;align-items:center}.login-logo-pill{background:#fff;border-radius:18px;padding:16px 32px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 1px #e880401a,0 12px 36px #0006,0 0 60px #e880401f}.login-logo{width:140px;height:auto;object-fit:contain;display:block}.login-header{text-align:center;display:grid;gap:6px}.login-title{margin:0;font-family:Playfair Display,serif;font-size:26px;font-weight:600;color:#f2f0ee;letter-spacing:.4px}.login-subtitle{margin:0;font-size:11.5px;color:#5a5868;letter-spacing:1.4px;text-transform:uppercase}.login-form{display:grid;gap:18px}.login-field{position:relative}.login-input{width:100%;background:#ffffff09;border:1px solid rgba(255,255,255,.09);border-radius:14px;color:#f2f0ee;padding:22px 16px 8px;font-size:15px;font-family:Sora,system-ui,sans-serif;line-height:1;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;box-sizing:border-box}.login-input::placeholder{color:transparent}.login-input:focus{border-color:#e880408c;box-shadow:0 0 0 3px #e880401c;background:#e880400a}.login-label{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:14px;color:#545264;pointer-events:none;transition:top .18s ease,transform .18s ease,font-size .18s ease,color .18s ease;font-family:Sora,system-ui,sans-serif;white-space:nowrap}.login-input:focus+.login-label,.login-input:not(:placeholder-shown)+.login-label{top:10px;transform:none;font-size:10.5px;letter-spacing:.4px;color:#e88040cc}.login-error{background:#ff464612;border:1px solid rgba(255,100,100,.22);border-radius:12px;padding:10px 14px;font-size:13px;color:#ffb4b4;display:flex;align-items:center;gap:8px;animation:shake .35s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.login-btn{width:100%;min-height:50px;padding:14px;background:linear-gradient(118deg,#e88040,#f09858 55%,#e88040);background-size:200% 100%;background-position:0% 50%;color:#1a0a00;border:none;border-radius:14px;font-size:15px;font-weight:700;font-family:Sora,system-ui,sans-serif;letter-spacing:.35px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-position .4s ease,transform .15s ease,box-shadow .2s ease,filter .2s ease}.login-btn:hover:not(:disabled){background-position:100% 50%;transform:translateY(-2px);box-shadow:0 18px 40px #e8804052;filter:brightness(1.05)}.login-btn:active:not(:disabled){transform:translateY(0);box-shadow:none}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.login-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(26,10,0,.25);border-top-color:#1a0a00;border-radius:50%;animation:login-spin .65s linear infinite;flex-shrink:0}@keyframes login-spin{to{transform:rotate(360deg)}}.login-footer{margin:0;text-align:center;font-size:11.5px;color:#7a78884d;letter-spacing:.4px}.login-divider{display:flex;align-items:center;gap:14px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(232,128,64,.22),transparent)}.login-divider-text{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#e8804066}@media (max-width: 480px){.login-card{padding:36px 26px 28px;border-radius:24px;gap:22px}.login-logo-pill{padding:14px 26px;border-radius:16px}.login-logo{width:116px}.login-title{font-size:22px}}:root{--bg-base: #F8F7F4;--bg-surface: #FFFFFF;--bg-elevated: #F3F2EF;--bg-hover: #EDECEA;--border: rgba(0,0,0,.07);--border-strong: rgba(0,0,0,.13);--accent: #E07A3A;--accent-dim: rgba(224,122,58,.1);--accent-hover: #C96A2A;--text-primary: #1A1916;--text-secondary: #6B6860;--text-muted: #A8A49E;--success: #16A34A;--success-bg: #F0FDF4;--success-border: rgba(22,163,74,.22);--warning: #D97706;--warning-bg: #FFFBEB;--warning-border: rgba(217,119,6,.22);--danger: #DC2626;--danger-bg: #FEF2F2;--danger-border: rgba(220,38,38,.22);--info: #2563EB;--info-bg: #EFF6FF;--info-border: rgba(37,99,235,.22);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-card: 0 1px 3px rgba(0,0,0,.08), 0 0 0 1px var(--border);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--shadow-accent: 0 4px 14px rgba(224,122,58,.3);--focus-ring: 0 0 0 3px rgba(224,122,58,.22);--transition: .18s ease;--brand-orange: #E07A3A;--brand-orange-light: #F09858;--brand-orange-dark: #C86828;--brand-orange-glow: rgba(224,122,58,.18);--brand-orange-border: rgba(224,122,58,.2);--bg: #F8F7F4;--bg-deep: #F8F7F4;--panel: #FFFFFF;--panel-soft: #F3F2EF;--panel-border: rgba(0,0,0,.07);--text: #1A1916;--accent-2: #2563EB;--accent-3: #16A34A;--green: #16A34A;--green-bg: #F0FDF4;--green-border: rgba(22,163,74,.22);--red: #DC2626;--red-bg: #FEF2F2;--red-border: rgba(220,38,38,.22);--yellow: #D97706;--yellow-bg: #FFFBEB;--yellow-border:rgba(217,119,6,.22);--shadow-orange:0 4px 14px rgba(224,122,58,.3);--border-light: rgba(0,0,0,.1);--brand-gray: #A8A49E}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;z-index:100;transition:transform .28s cubic-bezier(.4,0,.2,1)}.sidebar-brand{padding:18px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo-wrap{background:var(--accent-dim);border-radius:var(--radius-md);padding:4px 8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-sm);border:1px solid rgba(224,122,58,.2)}.sidebar-logo{width:60px;height:auto;display:block}.sidebar-brand-text{display:flex;flex-direction:column;gap:1px}.sidebar-brand-name{font-size:13px;font-weight:700;letter-spacing:2px;color:var(--text-primary);text-transform:uppercase}.sidebar-brand-sub{font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted)}.sidebar-nav{padding:12px 8px;display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}.sidebar-nav-section{font-size:9px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--text-muted);padding:8px 10px 4px;margin-top:4px}.nav-link,.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:500;transition:all var(--transition);border:1px solid transparent;cursor:pointer;text-decoration:none;position:relative}.nav-link:hover,.nav-item:hover{color:var(--text-primary);background:var(--bg-elevated)}.nav-link.active,.nav-item.active{color:var(--accent);background:var(--accent-dim);border-left:2px solid var(--accent);font-weight:600;padding-left:8px}.nav-icon{width:16px;height:16px;flex-shrink:0;color:var(--text-muted);transition:color var(--transition)}.nav-link:hover .nav-icon,.nav-item:hover .nav-icon{color:var(--text-secondary)}.nav-link.active .nav-icon,.nav-item.active .nav-icon{color:var(--accent)}.sidebar-footer{padding:10px 8px;border-top:1px solid var(--border);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:6px}.sidebar-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(224,122,58,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;font-weight:700;color:var(--accent)}.sidebar-user-name{font-size:12px;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{display:flex;align-items:center;gap:8px;width:100%;padding:9px 10px;border-radius:var(--radius-md);background:transparent;border:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition)}.sidebar-logout:hover{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger)}.main{flex:1;min-width:0;background:var(--bg-base);min-height:100vh;display:flex;flex-direction:column}.shell-content{flex:1}.topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0 32px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;gap:12px;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.topbar--scrolled{box-shadow:var(--shadow-md)}.topbar-left{display:flex;align-items:center;gap:8px;min-width:0}.topbar-hamburger{display:none;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all var(--transition)}.topbar-hamburger:hover{background:var(--bg-elevated);color:var(--text-primary)}.topbar-breadcrumb{font-size:13px;color:var(--text-muted)}.topbar-sep{color:var(--text-muted);font-size:11px}.topbar-current{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.user-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);font-size:12px;font-weight:500}.user-dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:299;opacity:0;pointer-events:none;transition:opacity .28s;display:none}.content{padding:32px 40px 64px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-card)}.card-sm{padding:16px}.card.full{grid-column:1 / -1}.card.soft{background:var(--bg-elevated)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.card-title{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:-.1px}.card-subtitle{font-size:12px;color:var(--text-muted);margin:2px 0 0}.card-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:12px;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-icon.accent{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(224,122,58,.2)}.stat-card-icon.success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.stat-card-icon.warning{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.stat-card-icon.muted{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.stat-card-value{font-size:32px;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-1px;font-variant-numeric:tabular-nums}.stat-card-label{font-size:12px;color:var(--text-secondary);font-weight:500}.stat-card-delta{font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:999px}.stat-card-delta.up{background:var(--success-bg);color:var(--success)}.stat-card-delta.down{background:var(--danger-bg);color:var(--danger)}.stat-card-delta.flat{background:var(--bg-elevated);color:var(--text-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-card);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.kpi-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-icon-wrap{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon-wrap.orange{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(224,122,58,.2)}.kpi-icon-wrap.blue{background:var(--info-bg);color:var(--info);border:1px solid var(--info-border)}.kpi-icon-wrap.green{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.kpi-icon-wrap.yellow{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.kpi-body{display:flex;flex-direction:column;gap:2px;min-width:0}.kpi-num{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.5px}.kpi-lbl{font-size:11px;font-weight:500;color:var(--text-secondary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;border:1px solid transparent;white-space:nowrap}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.badge--success,.badge-success,.badge--green{background:var(--success-bg);border-color:var(--success-border);color:var(--success)}.badge--warning,.badge-warning,.badge--yellow{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning)}.badge--danger,.badge-danger,.badge--red{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger)}.badge--neutral,.badge-neutral,.badge--gray{background:var(--bg-elevated);border-color:var(--border-strong);color:var(--text-secondary)}.badge--accent,.badge-accent{background:var(--accent-dim);border-color:#e07a3a40;color:var(--accent)}button{font-family:Inter,sans-serif}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;border:1px solid transparent;text-decoration:none;white-space:nowrap;transition:all var(--transition);line-height:1}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn-primary,a.btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:1px solid transparent;padding:9px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--transition)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-accent)}.btn-primary:active:not(:disabled){transform:none}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary,a.btn-secondary{display:inline-flex;align-items:center;gap:6px;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-strong);padding:9px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--transition)}.btn-secondary:hover:not(:disabled){background:var(--bg-elevated);border-color:#0000002e}.btn-ghost,.ghost,a.btn-ghost{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--accent);border:1px solid rgba(224,122,58,.3);padding:8px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--transition)}.btn-ghost:hover:not(:disabled),.ghost:hover:not(:disabled){background:var(--accent-dim);border-color:#e07a3a73}.btn-ghost:disabled,.ghost:disabled{opacity:.45;cursor:not-allowed}.btn-danger,a.btn-danger{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--danger);border:1px solid var(--danger-border);padding:8px 12px;border-radius:var(--radius-md);font-size:12px;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--transition)}.btn-danger:hover:not(:disabled){background:var(--danger-bg);border-color:#dc262659}.btn-excel,a.btn-excel{display:inline-flex;align-items:center;gap:6px;background:#16a34a;color:#fff;border:1px solid transparent;padding:8px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--transition)}.btn-excel:hover:not(:disabled){background:#15803d}.btn-excel:disabled{opacity:.45;cursor:not-allowed}.btn-link,.link,a.btn-link{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:0;font-size:13px;font-family:Inter,sans-serif;text-decoration:none;transition:color var(--transition)}.btn-link:hover,.link:hover{color:var(--text-primary)}.btn-sm{padding:6px 10px!important;font-size:12px!important;border-radius:var(--radius-sm)!important}.primary{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;padding:10px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:13px;font-family:Inter,sans-serif;white-space:nowrap;transition:all var(--transition)}.primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-accent)}.primary:disabled{opacity:.45;cursor:not-allowed}button:disabled{opacity:.45;cursor:not-allowed}.toolbar,.dt-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:180px}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;width:14px;height:14px}.search-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:8px 12px 8px 34px;font-size:13px;font-family:Inter,sans-serif;transition:border-color var(--transition),box-shadow var(--transition)}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}.search-input::placeholder{color:var(--text-muted)}.input,.select,.textarea,input:not([type=checkbox]):not([type=radio]):not([type=range]),textarea,select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:9px 12px;font-size:13px;font-family:Inter,sans-serif;width:100%;transition:border-color var(--transition),box-shadow var(--transition)}input:not([type=checkbox]):not([type=radio]):not([type=range])::placeholder,textarea::placeholder{color:var(--text-muted)}input:not([type=checkbox]):not([type=radio]):not([type=range]):focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}textarea{resize:vertical}select{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='%236B6860' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}label{display:grid;gap:6px;font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-secondary)}.checkbox{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--text-secondary);cursor:pointer}.checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md);border:1px solid var(--border)}.table-wrapper .data-table,.table-wrapper .dt{border:none;border-radius:0;min-width:500px}.data-table,.dt{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.dt-head{display:grid;align-items:center;padding:10px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border);font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-secondary);gap:12px}.dt-row{display:grid;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);gap:12px;transition:background var(--transition);font-size:13px;background:var(--bg-surface)}.dt-row:nth-child(2n){background:#fafafa}.dt-row:last-child{border-bottom:none}.dt-row:hover{background:var(--bg-hover)}.dt-cell-title{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dt-cell-muted{color:var(--text-secondary);font-size:12px}.dt-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.dt-empty{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:14px}.modal-overlay,.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:grid;place-items:center;padding:20px;z-index:200;animation:fadeIn .15s ease}.modal{width:min(560px,94vw);background:var(--bg-surface);border:1px solid var(--border-strong);border-top:2px solid var(--accent);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);animation:fadeInUp .2s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.modal-grid{display:grid;gap:14px;padding:20px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;background:var(--bg-elevated);border-top:1px solid var(--border)}.pg{display:grid;gap:24px}.pg-head,.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.pg-title{margin:0;font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.pg-sub{margin:4px 0 0;font-size:13px;color:var(--text-muted)}.pg-actions,.page-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-top:2px;flex-wrap:wrap}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;gap:12px;text-align:center}.empty-state-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:4px}.empty-state-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.empty-state-sub{font-size:13px;color:var(--text-muted);margin:0;max-width:320px}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{background:var(--bg-elevated);border-radius:var(--radius-sm);animation:skeleton-pulse 1.6s ease infinite}.progress-bar{width:100%;height:5px;background:var(--bg-elevated);border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .4s ease}.progress-bar-fill.success{background:var(--success)}.progress-bar-fill.warning{background:var(--warning)}.chart-container{width:100%;overflow:hidden}.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.chart-body{height:clamp(200px,26vw,300px)}.chart-body canvas{width:100%!important;height:100%!important}.dashboard-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dashboard-row-3{display:grid;grid-template-columns:2fr 1fr;gap:16px}.dash-row{display:grid;grid-template-columns:3fr 2fr;gap:16px}.stats{display:grid;gap:10px}.stat-block{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;display:grid;gap:8px}.stat-block strong{font-size:13px;font-weight:600;color:var(--text-primary)}.responses{display:grid;gap:10px}.response{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface)}.response>.row{padding:10px 14px;background:var(--bg-elevated);border-bottom:1px solid var(--border);font-size:12px;display:flex;justify-content:space-between;align-items:center}.response>.row strong{font-size:13px;color:var(--text-primary)}.response>.row span:last-child{color:var(--text-muted);font-size:11px}.response ul{list-style:none;margin:0;padding:12px 14px;display:grid;gap:8px}.response ul li{font-size:13px;color:var(--text-primary)}.response ul li strong{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:2px}.row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pill-row{display:flex;flex-wrap:wrap;gap:6px}.pill{background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px;padding:3px 9px;font-size:11px;color:var(--text-secondary)}.stat{font-size:32px;font-weight:700;color:var(--text-primary);margin:0;font-variant-numeric:tabular-nums;letter-spacing:-1px}.muted{color:var(--text-muted);font-size:13px}.error{color:var(--danger);font-size:13px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.list{list-style:none;padding:0;margin:0;display:grid;gap:0}.list li{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.list li:last-child{border-bottom:none}.list li strong{color:var(--text-primary);font-weight:500}.thead{display:grid;grid-template-columns:2fr 1fr 2fr;gap:12px;align-items:center;padding:10px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border);font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-secondary)}.trow{display:grid;grid-template-columns:2fr 1fr 2fr;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;transition:background var(--transition)}.trow:last-child{border-bottom:none}.trow:hover{background:var(--bg-hover)}.hide-mobile{display:initial}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}.builder{display:grid;gap:20px}.section{border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;display:grid;gap:14px;background:var(--bg-elevated);transition:border-color var(--transition)}.section:hover{border-color:#e07a3a4d}.section-title input{margin-top:4px}.section-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.question-list{display:grid;gap:8px}.question-item{border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;background:var(--bg-surface);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.question-item:hover{border-color:#e07a3a59;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.question-handle{cursor:grab;color:var(--text-muted);font-size:9px;border:1px dashed var(--border);border-radius:var(--radius-sm);padding:6px 8px;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;transition:all var(--transition)}.question-handle:hover{border-color:#e07a3a59;color:var(--accent)}.question-meta h4{margin:0;font-size:13px;font-weight:500;color:var(--text-primary)}.question-meta p{margin:3px 0 0;color:var(--text-muted);font-size:11px}.question-actions{display:flex;gap:6px}.options{display:grid;gap:8px}.qr-card{background:radial-gradient(circle at top left,rgba(96,165,250,.1),transparent 32%),radial-gradient(circle at bottom right,rgba(232,128,64,.08),transparent 28%),linear-gradient(140deg,#0c1320,#0f1a2d 52%,#12233c);border:1px solid rgba(148,163,184,.16);border-radius:24px;padding:28px;box-shadow:0 24px 54px #0f172a3d}.qr-wrap{display:grid;grid-template-columns:minmax(280px,380px) 1fr;gap:32px;align-items:center}.qr-preview-shell{display:grid;gap:14px}.qr-preview{position:relative;width:100%;min-height:420px;padding:18px;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border-radius:22px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.07);box-shadow:inset 0 1px #ffffff0d,0 18px 40px #02061738}.qr-preview img{width:100%;max-width:360px;height:auto;object-fit:contain;border-radius:18px}.qr-fallback{font-size:14px;color:#94a3b8}.qr-chip-row{display:flex;gap:10px;flex-wrap:wrap}.qr-chip{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:#ffffff12;border:1px solid rgba(255,255,255,.07);color:#94a3b8;font-size:11px;font-weight:600}.qr-kicker{display:inline-flex;align-items:center;min-height:30px;margin-bottom:10px;padding:0 12px;border-radius:999px;background:#60a5fa1a;border:1px solid rgba(147,197,253,.22);color:#bfdbfe;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.qr-meta h4{margin:0 0 10px;font-size:24px;color:#f1f0ee}.qr-meta p{margin:0 0 16px;color:#94a3b8;line-height:1.6;font-size:14px}.qr-highlights{margin:0 0 18px;padding-left:18px;color:#dbeafe;display:grid;gap:8px;font-size:13px}.qr-highlights li::marker{color:#60a5fa}.qr-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.login-root{min-height:100vh;display:grid;grid-template-columns:420px 1fr}.login-brand{background:linear-gradient(160deg,#0e0f12,#111318);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;border-right:1px solid rgba(232,128,64,.1)}.login-brand:before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(232,128,64,.13) 0%,transparent 68%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.login-brand:after{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(232,128,64,.35),transparent)}.login-brand-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:28px;padding:48px 32px;text-align:center}.login-logo-wrap{background:#fff;border-radius:20px;padding:20px 36px;box-shadow:0 0 60px #e880402e,0 20px 48px #00000073}.login-logo{width:180px;height:auto;display:block}.login-tagline{color:#f2f0ee66;font-size:13px;line-height:1.75;margin:0}.login-dot-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;opacity:.15;margin-top:12px}.login-dot-grid span{width:4px;height:4px;border-radius:50%;background:#e07a3a;display:block}.login-form-panel{background:#0c0d10;display:flex;align-items:center;justify-content:center;padding:48px 32px}.login-form-inner{width:min(380px,100%);display:grid;gap:36px}.login-form-header h1{margin:0;font-size:32px;font-weight:700;color:#f1f0ee;letter-spacing:-.5px}.login-form-header p{margin:10px 0 0;color:#4b5060;font-size:14px}.login-form{display:grid;gap:20px}.login-field{display:grid;gap:8px}.login-field-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#4b5060}.login-input{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);color:#f1f0ee;padding:13px 16px;font-size:14px;font-family:Inter,sans-serif;box-sizing:border-box;transition:border-color .2s,box-shadow .2s,background .2s}.login-input::placeholder{color:#7a788880}.login-input:focus{outline:none;border-color:#e07a3a;background:#e07a3a0a;box-shadow:0 0 0 3px #e07a3a24}.login-btn{width:100%;background:#e07a3a;color:#fff;border:none;padding:15px 20px;border-radius:var(--radius-md);cursor:pointer;font-weight:700;font-size:14px;font-family:Inter,sans-serif;letter-spacing:.2px;margin-top:4px;transition:all .15s ease}.login-btn:hover:not(:disabled){background:#c96a2a;transform:translateY(-2px);box-shadow:0 18px 36px #e07a3a47}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.55;cursor:not-allowed}.login-error{background:#dc262612;border:1px solid rgba(220,38,38,.2);border-radius:var(--radius-md);padding:12px 14px;color:#fca5a5;font-size:13px;line-height:1.5}.auth-bg{min-height:100vh;display:grid;place-items:center;background:#0a0b0e}.auth-card{background:#111318;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:32px;width:min(420px,90vw);display:grid;gap:16px}.public-shell{min-height:100vh;display:grid;place-items:center;padding:40px 16px;background:radial-gradient(circle at top,#e7f7f3,#f2f9ff 60%)}.public-card{background:#faffff;color:#1b2b2a;border-radius:24px;padding:28px;width:min(720px,92vw);display:grid;gap:18px;box-shadow:0 30px 60px #2e7a8e2e;font-family:Inter,sans-serif;border:1px solid #d6eef0}.public-card h1{font-weight:700;margin:0;font-size:22px}.public-card .primary{background:linear-gradient(120deg,#35b6a6,#5bc0ff);color:#0b1f1f}.public-card input:not([type=checkbox]):not([type=radio]),.public-card textarea,.public-card select{background:#f6fffe;border:1px solid #cfe9ee;color:#1b2b2a;font-size:14px}.public-brand{font-weight:700;letter-spacing:4px;font-size:14px;color:#2b8f8a;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;margin-bottom:10px;width:100%}.public-logo{width:100%;height:min(52vw,360px);object-fit:contain}.notice{background:#e8f6f6;padding:12px;border-radius:14px;font-size:13px;border:1px solid #cfe9ee}.public-card .muted{color:#5a5249}.req{color:#b42318}.public-card .section{background:#eef9f8;border-color:#cfe9ee}.section-heading{margin:0;font-size:20px;font-weight:700;color:#1f1b16}.public-card .question{border:1px dashed #cfe9ee;border-radius:16px;padding:16px;display:grid;gap:12px}.public-card .card.soft{background:#eef9f8;border:1px solid #cfe9ee;box-shadow:none}.public-card .pill{background:#f5fffd;border-color:#cfe9ee;color:#3d6b72}.public-card .error{color:#b42318}.range{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px}.range-value{font-weight:600;color:#1f1b16;min-width:20px;text-align:center}.rating-block{display:grid;gap:10px}.rating-labels{display:flex;justify-content:space-between;font-size:13px;color:#3d6b72;gap:18px}.rating-end{display:grid;justify-items:start;gap:2px}.rating-end:last-child{justify-items:end;text-align:right}.rating-num{font-weight:700;font-size:14px;color:#1f4f52}.rating-text{font-size:12px;color:#4a7c82}.rating-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(44px,1fr));gap:10px}.rating-btn{border:1px solid #a9dbe0;background:#f5fffd;color:#1f4f52;border-radius:12px;padding:7px 10px;min-width:40px;cursor:pointer;font-weight:600;font-size:12px;font-family:Inter,sans-serif;transition:all .15s ease}.rating-btn.active{background:linear-gradient(140deg,#35b6a6,#5bc0ff);color:#0b1f1f;border-color:#35b6a6;box-shadow:0 8px 16px #35b6a647}.not-found-shell{min-height:100vh;display:grid;place-items:center;padding:40px 20px;background:var(--bg-base)}.not-found-card{text-align:center;display:grid;gap:18px;max-width:400px}.not-found-code{font-size:88px;font-weight:700;color:var(--accent);line-height:1;margin:0}.not-found-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.not-found-sub{color:var(--text-secondary);font-size:14px;margin:0}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.sidebar{width:200px}.dashboard-row-3,.dash-row{grid-template-columns:1fr}}@media (max-width: 900px){.dashboard-row{grid-template-columns:1fr}}@media (max-width: 768px){.app-shell{display:block}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;transform:translate(-100%);z-index:300;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-overlay.open{opacity:1;pointer-events:auto}.topbar{padding:0 16px}.topbar-hamburger{display:flex}.content{padding:20px 16px 48px}.kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.dashboard-row,.dashboard-row-3{grid-template-columns:1fr}.dt-row{font-size:12px}.dt-head{font-size:9px}.hide-mobile{display:none}.qr-wrap{grid-template-columns:1fr;justify-items:center;text-align:center}.qr-chip-row,.qr-actions{justify-content:center}.login-root{grid-template-columns:1fr}.login-brand{padding:40px 24px;border-right:none;border-bottom:1px solid rgba(232,128,64,.1)}.login-brand-inner{padding:0;gap:20px}.login-logo-wrap{padding:16px 28px}.login-logo{width:140px}.login-form-panel{padding:40px 24px}.login-form-header h1{font-size:26px}}@media (max-width: 600px){.pg-head,.page-header{flex-direction:column;align-items:flex-start;gap:12px}.pg-actions,.page-header-actions{width:100%;display:flex;flex-wrap:wrap;gap:8px;margin-top:0}.pg-actions .btn,.pg-actions .btn-primary,.pg-actions .btn-secondary,.pg-actions .btn-ghost,.pg-actions .btn-excel,.page-header-actions .btn,.page-header-actions .btn-primary,.page-header-actions .btn-secondary,.page-header-actions .btn-ghost,.page-header-actions .btn-excel{flex:1;min-width:120px;justify-content:center}.toolbar{flex-direction:column;align-items:stretch}.toolbar .search-wrap,.toolbar .search-input{width:100%}.toolbar select{width:100%!important;min-width:unset!important}.modal-overlay,.modal-backdrop{padding:0}.modal{position:fixed;top:0;right:0;bottom:0;left:0;border-radius:0;width:100vw;max-height:100vh;overflow-y:auto;animation:none}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}.kpi-num{font-size:22px}.pg-title{font-size:20px}.rating-options{grid-template-columns:repeat(5,minmax(0,1fr));gap:4px}.rating-btn{min-width:0;padding:3px 0;font-size:11px;border-radius:10px}.qr-card{padding:18px;border-radius:18px}.qr-preview{min-height:260px}}
