:root{--primary: #feee00;--primary-dark: #eab308;--ink: #111827;--muted: #6b7280;--line: #e5e7eb;--surface: #ffffff;--soft: #f8fafc;--danger: #ef4444;--radius: 18px;--shadow: 0 18px 55px rgba(15, 23, 42, .08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;background:#f6f7fb;color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{transition:transform .18s ease,box-shadow .18s ease,background .18s ease,opacity .18s ease}button:not(:disabled):hover{transform:translateY(-1px)}button:not(:disabled):active{transform:translateY(0)}.btn{border:0;border-radius:13px;padding:11px 15px;cursor:pointer;font-weight:850;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary),#fbbf24);color:#111;box-shadow:0 12px 24px #eab30838}.btn-primary:before{content:"\2726";font-size:13px}.btn-dark{background:linear-gradient(135deg,#111827,#020617);color:#fff;box-shadow:0 12px 24px #1118272e}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 12px 24px #ef44442e}.btn-danger:before{content:"\1f5d1\fe0f";font-size:13px}.btn-soft{background:#eef2ff;color:#3730a3;border:1px solid #e0e7ff}.btn-soft:before{content:"\2022";font-size:18px;line-height:0}.card{background:#ffffffeb;border:1px solid rgba(226,232,240,.9);border-radius:var(--radius);box-shadow:var(--shadow)}.input{width:100%;border:1px solid #d7dce5;border-radius:13px;padding:12px 13px;outline:none;background:#fff;color:var(--ink);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.input:focus{border-color:#111827;box-shadow:0 0 0 4px #11182714}.input::placeholder{color:#9ca3af}.table-wrap{overflow-x:auto;border-radius:20px}table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}th,td{text-align:left;padding:14px 16px;border-bottom:1px solid #eef2f7;vertical-align:top}th{background:#f8fafc;font-size:12px;color:#475569;text-transform:uppercase;letter-spacing:.045em;font-weight:900;position:sticky;top:0;z-index:1}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#f3f4f6;color:#334155;font-size:12px;font-weight:850;border:1px solid #e5e7eb}.status-badge{background:#ecfeff;color:#155e75;border-color:#cffafe;text-align:center}.status-pending,.bg-yellow{background:#fffbeb;color:#92400e;border-color:#fde68a}.status-approved,.bg-green{background:#ecfdf5;color:#047857;border-color:#a7f3d0}.status-rejected,.bg-red{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.page-head{display:flex;gap:14px;align-items:flex-end;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;padding:18px;border-radius:22px;background:linear-gradient(135deg,#fffffff0,#fffbebc7);border:1px solid rgba(226,232,240,.85);box-shadow:0 14px 40px #0f172a0f}.grid{display:grid;gap:16px}.form-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}@media (max-width: 800px){table{min-width:640px}}.actions-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.tab-actions{margin-bottom:12px}.tab-bar{display:flex;gap:8px;margin:0 0 14px;flex-wrap:wrap}.tab-button{border:1px solid #e5e7eb;background:#fff;color:#475569;border-radius:13px;padding:10px 14px;cursor:pointer;font-weight:900}.tab-button.active{background:#111827;color:#fff;border-color:#111827;box-shadow:0 12px 24px #11182729}.inline-check{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 10px;color:#475569;font-size:13px;font-weight:850}.inline-check input{width:16px;height:16px}.search-input{width:240px}.filter-input{width:190px}.message-badge{margin-bottom:12px}.toast-stack{position:fixed;top:18px;right:18px;z-index:90;width:min(360px,calc(100vw - 32px));pointer-events:none}.app-toast{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:13px 14px;border-radius:14px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 20px 50px #0f172a2e;pointer-events:auto}.app-toast strong,.app-toast span{display:block}.app-toast strong{margin-bottom:3px;font-size:13px;color:#111827}.app-toast span{color:#475569;font-size:13px;font-weight:750;line-height:1.35}.toast-success{border-left:5px solid #10b981}.toast-error{border-left:5px solid #ef4444}.toast-close{border:0;background:#f3f4f6;color:#111827;border-radius:10px;width:30px;height:30px;cursor:pointer;font-weight:900;line-height:1;flex:0 0 auto}.nowrap{white-space:nowrap;display:flex;gap:8px}.table-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;min-width:220px}.purchase-actions{flex-wrap:nowrap;min-width:300px}.purchase-actions .btn{white-space:nowrap}.pagination-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;color:#475569;font-size:13px;font-weight:800}.quantity-input{width:112px}.confirm-copy{margin:0 0 14px;color:#334155;line-height:1.55;font-weight:700}.danger-text{color:#b91c1c!important}.wide-cell{min-width:280px;max-width:460px}.thumb{width:48px;height:48px;object-fit:cover;border-radius:14px;background:#f3f4f6;border:1px solid #e5e7eb;box-shadow:0 8px 18px #0f172a14}.thumb.wide{width:76px}.preview-img{width:128px;height:96px;object-fit:cover;border-radius:14px;margin-top:10px;border:1px solid #e5e7eb;background:#f9fafb;display:block}.preview-img.small{width:78px;height:78px}.preview-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.modal-backdrop{position:fixed;inset:0;background:#0f172a85;z-index:40}.modal-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(760px,calc(100vw - 28px));max-height:calc(100vh - 34px);overflow:auto;background:#fff;border-radius:24px;box-shadow:0 28px 90px #00000040;z-index:50;border:1px solid #e5e7eb}.modal-wide{width:min(1080px,calc(100vw - 28px))}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #eef2f7;position:sticky;top:0;background:#fffffff0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:1}.modal-head h2{margin:0;font-size:20px}.modal-body{padding:18px 20px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 20px;border-top:1px solid #eef2f7;position:sticky;bottom:0;background:#fff}.icon-btn{border:0;background:#f3f4f6;color:#111827;border-radius:12px;width:38px;height:38px;font-size:24px;cursor:pointer;line-height:1;display:inline-grid;place-items:center}.span-2{grid-column:span 2}.check-row{display:flex;gap:10px;align-items:center;font-weight:800;padding-top:28px}.assigned-store-list{display:grid;gap:10px;max-height:230px;overflow:auto;padding:10px;border:1px solid #e5e7eb;border-radius:14px;background:#fff}.assigned-store-row{display:flex;align-items:center;gap:10px;margin:0;padding:10px 12px;border:1px solid #eef2f7;border-radius:12px;background:#fbfcff;cursor:pointer}.assigned-store-row:hover{border-color:#c7d2fe;background:#f8fafc}.assigned-store-row input{width:16px;height:16px;flex:0 0 auto}.assigned-store-row span{display:flex;flex-direction:column;gap:2px;min-width:0}.assigned-store-row strong{color:#111827;font-size:14px;line-height:1.25;word-break:break-word}.assigned-store-row small{color:#6b7280;font-size:11px;font-weight:800}.assigned-store-empty{padding:14px;border:1px dashed #d1d5db;border-radius:14px;color:#6b7280;font-size:13px;font-weight:800;background:#fbfcff}label{display:block;font-weight:800;font-size:13px;margin-bottom:6px;color:#374151}.field-error{display:block;margin-top:6px;color:#dc2626;font-size:12px;font-weight:700}.store-modal-body{display:flex;flex-direction:column;gap:18px;background:#fbfcff}.store-section{background:#fff;border:1px solid #edf0f5;border-radius:16px;padding:16px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #eef2f7}.section-title h3{margin:0;font-size:15px;color:#111827}.section-title-row{flex-wrap:wrap}.section-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.image-upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.upload-tile{border:1px dashed #d7dce5;border-radius:14px;padding:12px;background:#fcfdff}.upload-preview{display:flex;align-items:center;justify-content:center;min-height:112px;margin-top:10px;background:#f8fafc;border-radius:12px;border:1px solid #eef2f7;overflow:hidden}.upload-preview .preview-img{width:100%;height:118px;margin:0;border:0;border-radius:0}.clear-file-btn{margin-top:10px;width:100%}.switch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.switch-row{padding:12px;margin:0;border:1px solid #edf0f5;border-radius:12px;background:#fcfdff}.switch-row input{width:16px;height:16px}.server-list{display:flex;flex-direction:column;gap:14px}.server-row{border:1px solid #edf0f5;border-radius:14px;padding:14px;background:#fcfdff}.server-row-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.server-row-head label{margin:0}.server-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.server-preview{width:92px;height:68px;border-radius:10px}.text-cell{min-width:260px;max-width:360px;white-space:normal;line-height:1.45}.id-cell{min-width:180px;max-width:240px;word-break:break-word;font-size:12px;color:#4b5563}.server-cell{min-width:280px;max-width:380px}.server-table-item{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #eef2f7}.server-table-item:last-child{border-bottom:0}.server-table-item strong{display:block;font-size:12px;color:#111827}.server-table-item span{display:block;margin-top:2px;font-size:12px;color:#4b5563;line-height:1.35}.detail-modal-body{gap:16px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.detail-item{border:1px solid #edf0f5;border-radius:12px;background:#fcfdff;padding:12px;min-width:0}.detail-item span{display:block;margin-bottom:5px;color:#6b7280;font-size:12px;font-weight:800}.detail-item strong{display:block;color:#111827;font-size:14px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.detail-full{grid-column:1 / -1}.detail-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px}.detail-image-card{border:1px solid #edf0f5;border-radius:14px;background:#fcfdff;padding:12px;min-height:170px}.detail-image-card span{display:block;margin-bottom:8px;color:#6b7280;font-size:12px;font-weight:800}.detail-image-card img{width:100%;height:120px;object-fit:cover;border-radius:12px;border:1px solid #eef2f7;background:#f8fafc}.detail-image-card strong{display:flex;align-items:center;justify-content:center;height:120px;color:#9ca3af;border:1px dashed #d7dce5;border-radius:12px;background:#f8fafc}.detail-empty{color:#6b7280;font-size:13px;font-weight:700}.server-detail-row{display:flex;gap:12px;align-items:flex-start}.server-detail-row img{width:58px;height:58px;object-fit:cover;border-radius:12px;border:1px solid #e5e7eb;background:#f9fafb;flex:0 0 auto}.server-detail-row strong{display:block;color:#111827;font-size:14px}.server-detail-row span{display:block;margin-top:4px;color:#4b5563;font-size:13px;line-height:1.4}.server-detail-row small{display:block;margin-top:6px;color:#6b7280;font-size:12px;word-break:break-word}.config-preview-item{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.option-preview-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;padding:10px;border:1px solid #eef2f7;border-radius:12px;background:#f8fafc}.option-preview-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid #edf0f5;border-radius:12px;background:#fff;font-size:12px;font-weight:700}.category-picker{border:1px solid #edf0f5;border-radius:16px;background:#fcfdff;padding:14px}.category-picker-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.category-picker-head label{margin:0 0 4px}.category-picker-head span{color:#6b7280;font-size:12px;font-weight:800}.category-check-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;max-height:320px;overflow:auto;padding:12px;margin-top:10px;border:1px solid #eef2f7;border-radius:14px;background:#fff}.category-check-row{display:flex;align-items:center;gap:10px;margin:0;padding:10px;min-width:0;border:1px solid #edf0f5;border-radius:12px;background:#fcfdff;cursor:pointer;transition:border-color .15s ease,background .15s ease}.category-check-row:hover{border-color:#c7d2fe;background:#f8fafc}.category-check-row input{width:16px;height:16px;flex:0 0 auto}.category-check-row .thumb{width:40px;height:40px;border-radius:10px;flex:0 0 auto}.category-check-row span{display:flex;flex-direction:column;gap:3px;min-width:0}.category-check-row strong{color:#111827;font-size:13px;line-height:1.3;word-break:break-word}.category-check-row small{color:#6b7280;font-size:11px;font-weight:800;line-height:1.35;word-break:break-word}.selected-category-list{background:#fff}.selected-category-chip{padding-right:6px}.chip-remove{border:0;background:#f3f4f6;color:#111827;width:24px;height:24px;border-radius:8px;cursor:pointer;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.config-section-head{justify-content:space-between;margin-bottom:10px}.config-section-head label{margin:0}.config-detail-body .detail-item strong{max-height:160px;overflow:auto}.config-detail-list{display:flex;flex-direction:column;gap:14px}.config-detail-card{border:1px solid #edf0f5;border-radius:14px;padding:14px;background:#fcfdff}.config-detail-img{width:100%;max-width:260px;height:130px;object-fit:cover;border-radius:12px;border:1px solid #eef2f7;background:#f8fafc;display:block}.config-page-head p{max-width:520px}.config-table{min-width:980px}.config-table td{vertical-align:middle}.config-type-cell,.config-name-cell{display:flex;flex-direction:column;gap:6px;min-width:0}.config-type-cell small,.config-name-cell small,.config-date{color:#6b7280;font-size:12px;font-weight:700}.config-type-badge{width:max-content;background:#ecfeff;color:#155e75;text-transform:capitalize}.config-name-cell strong{color:#111827;font-size:14px;line-height:1.35;word-break:break-word}.config-content-cell{min-width:340px}.config-row-preview{display:flex;align-items:center;gap:12px;min-width:0}.config-row-preview strong{display:block;color:#111827;font-size:13px;margin-bottom:3px}.config-row-preview span{display:block;color:#4b5563;font-size:13px;line-height:1.35;word-break:break-word}.config-preview-thumbs{display:flex;align-items:center;gap:6px;flex:0 0 auto}.config-preview-thumbs .thumb{width:42px;height:42px;border-radius:10px}.config-detail-table-wrap{overflow-x:auto;border:1px solid #edf0f5;border-radius:14px;background:#fff}.config-detail-table{min-width:720px}.config-detail-table th{background:#f8fafc}.config-detail-table td{vertical-align:top}.config-detail-item-title{width:210px}.config-detail-item-title strong{display:block;color:#111827;font-size:14px;margin-bottom:5px}.config-detail-item-title span{color:#6b7280;font-size:12px;font-weight:800}.config-field-list{display:flex;flex-direction:column;gap:8px}.config-field-row{display:grid;grid-template-columns:150px minmax(0,1fr);gap:12px;align-items:start;padding:10px;border:1px solid #edf0f5;border-radius:12px;background:#fcfdff}.config-field-row span{color:#6b7280;font-size:12px;font-weight:800;word-break:break-word}.config-field-row strong{color:#111827;font-size:13px;line-height:1.45;white-space:pre-wrap;word-break:break-word;max-height:180px;overflow:auto}.config-field-row .config-detail-img{width:180px;max-width:100%;height:110px;margin:0}.product-modal-body .store-section{padding:18px}.product-row-list{display:flex;flex-direction:column;gap:12px}.gallery-upload-tile{grid-column:span 2}.gallery-upload-tile .preview-list{padding:10px;border:1px solid #eef2f7;border-radius:12px;background:#f8fafc}.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px}.value-row{border:1px solid #edf0f5;border-radius:12px;background:#fff;padding:10px}.value-actions{align-items:flex-start}.value-actions .input{min-width:0}.full-width-btn{width:100%}button:disabled{opacity:.65;cursor:not-allowed}@media (max-width: 760px){.span-2,.gallery-upload-tile{grid-column:span 1}.search-input,.filter-input,.actions-row{width:100%}.section-grid,.server-grid{grid-template-columns:1fr}.store-section{padding:14px}.config-row-preview{align-items:flex-start}.config-field-row{grid-template-columns:1fr}}td{align-content:center}h1{margin:0;font-size:clamp(24px,3vw,34px);letter-spacing:-.045em;color:#0f172a}.page-head p{margin:7px 0 0;color:#64748b;font-weight:600}tbody tr{transition:background .16s ease,transform .16s ease}tbody tr:hover{background:#fffdf0}tbody tr:last-child td{border-bottom:0}.actions-row .input{background:#fff}.search-input,.filter-input{min-height:42px}.message-badge{box-shadow:0 10px 24px #0f172a0f}.card[style*="padding:20px"]{position:relative;overflow:hidden;padding:22px!important}.card[style*="padding:20px"]:after{content:"";position:absolute;right:-34px;top:-34px;width:110px;height:110px;border-radius:50%;background:#feee003d}.card[style*="padding:20px"] .badge:before{content:"\25c6";color:#eab308;font-size:10px}.card[style*="padding:20px"] h2{letter-spacing:-.04em;color:#0f172a}.modal-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-body{background:linear-gradient(180deg,#fff,#fbfcff)}label{letter-spacing:-.01em}select.input{cursor:pointer}input[type=checkbox]{accent-color:#111827}.nowrap .btn{padding-inline:12px;min-height:38px}.nowrap .btn-soft:before{content:"\270e";font-size:13px}.nowrap .btn-danger:before{content:"\1f5d1\fe0f";font-size:13px}button[disabled]:before{opacity:.55}@media (max-width: 760px){.page-head{padding:14px;align-items:stretch}.btn{width:auto}.actions-row .btn,.actions-row .input,.actions-row select{flex:1 1 100%}th,td{padding:12px 13px}}.stats-grid-pro{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}.stat-card{position:relative;overflow:hidden;padding:22px;min-height:150px}.stat-card:after{content:"";position:absolute;right:-34px;top:-34px;width:112px;height:112px;border-radius:50%;background:#feee0038}.stat-card .stat-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:#111827;color:#fff;font-size:22px;margin-bottom:14px;box-shadow:0 14px 28px #11182724}.stat-card h2{font-size:36px;margin:14px 0 0;letter-spacing:-.055em}html,body{width:100%;max-width:100%;overflow-x:hidden}body{min-height:100vh;min-height:100dvh}app-root{display:block;min-width:0}.admin-shell,.main,.content,.card,.page-head,.table-wrap{min-width:0;max-width:100%}.table-wrap{width:100%;overflow-x:auto;overflow-y:visible;border-radius:22px;border:1px solid rgba(226,232,240,.95);box-shadow:0 16px 45px #0f172a12;background:#fff;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f8fafc}.table-wrap::-webkit-scrollbar{height:10px}.table-wrap::-webkit-scrollbar-track{background:#f8fafc;border-radius:999px}.table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px;border:2px solid #f8fafc}table{width:100%;min-width:920px;border-collapse:separate;border-spacing:0;table-layout:auto;background:#fff}thead th{position:sticky;top:0;z-index:2;height:50px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}th,td{padding:14px 16px;text-align:left;vertical-align:middle!important;line-height:1.45}td{color:#334155;font-size:14px;align-content:initial!important}tbody tr{min-height:64px}tbody tr:hover{background:#fffbeb}tbody td:first-child,thead th:first-child{padding-left:20px}tbody td:last-child,thead th:last-child{padding-right:20px}.nowrap{white-space:nowrap}td.nowrap{display:table-cell!important;min-width:176px;vertical-align:middle!important}td.nowrap .btn,td.nowrap button{margin-right:8px;margin-bottom:6px}td.nowrap .btn:last-child,td.nowrap button:last-child{margin-right:0}.actions-row{min-width:0}.actions-row .btn,.actions-row .input,.actions-row select{flex-shrink:0}.wide-cell,.text-cell,.server-cell,.id-cell,.config-content-cell{white-space:normal;overflow-wrap:anywhere;word-break:normal}.id-cell{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.thumb{display:block;margin:0;flex:0 0 auto}.badge,.status-badge{vertical-align:middle;max-width:100%}td[colspan]{height:86px;text-align:center;color:#64748b;font-weight:800;background:#fcfdff}@media (max-width: 900px){table{min-width:860px}.table-wrap{border-radius:18px}}@media (max-width: 760px){html,body{overflow-x:hidden}table{min-width:820px}th,td{padding:12px 14px}td.nowrap{min-width:160px}.page-head{margin-bottom:14px}}th,td{text-align:center}.auto-refresh-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 12px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;box-shadow:0 4px 12px #0f172a0f}.auto-refresh-switch input{display:none}.switch-slider{position:relative;width:44px;height:24px;border-radius:999px;background:#cbd5e1;transition:.25s ease}.switch-slider:before{content:"";position:absolute;width:18px;height:18px;top:3px;left:3px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0f172a40;transition:.25s ease}.auto-refresh-switch input:checked+.switch-slider{background:#2563eb}.auto-refresh-switch input:checked+.switch-slider:before{transform:translate(20px)}.switch-text{display:flex;flex-direction:column;line-height:1.1;font-size:13px;font-weight:600;color:#0f172a}.switch-text small{margin-top:2px;font-size:11px;font-weight:500;color:#64748b}
