:root{--navy:#16235c;--navy-light:#203090;--gold:#2b4cdb;--gold-dark:#1e3bb8;--bg:#f4f6fb;--surface:#fff;--border:#e3e6eb;--text:#1f2733;--text-muted:#6b7480;--danger:#e1483a;--danger-dark:#c23a2d;--success:#1f9d61;--radius:10px;--shadow:0 1px 3px #10182814, 0 1px 2px #1018280a;--sidebar-w:248px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0}.admin-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--navy);color:#cdd5e0;z-index:50;flex-direction:column;transition:transform .25s;display:flex;position:fixed;inset:0 auto 0 0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{z-index:40;background:#10182873;position:fixed;inset:0}@media (width>=861px){.sidebar-backdrop{display:none}}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:1.5rem 1.25rem}.sidebar-brand .brand-name{color:var(--gold);font-size:1.25rem;font-weight:700}.sidebar-logo{background:#fff;border-radius:8px;width:156px;max-width:100%;margin-bottom:8px;padding:8px 10px;display:block}.login-logo{width:210px;max-width:80%;height:auto;margin:0 auto .75rem;display:block}.sidebar-brand .brand-sub{letter-spacing:.06em;text-transform:uppercase;color:#8893a3;margin-top:2px;font-size:.7rem}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:1rem .75rem;display:flex;overflow-y:auto}.nav-item{color:#cdd5e0;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;width:100%;padding:.65rem .85rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.active{background:var(--gold);color:#fff}.nav-item.logout{color:#e7c3bf}.nav-item.logout:hover{color:#ff9d92;background:#e1483a2e}.sidebar-footer{border-top:1px solid #ffffff14;padding:1rem .75rem}.main-area{flex-direction:column;flex:1;min-width:0;margin-left:0;transition:margin-left .25s;display:flex}@media (width>=861px){.main-area{margin-left:var(--sidebar-w)}.main-area.expanded{margin-left:0}}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:20;justify-content:space-between;align-items:center;height:60px;padding:0 1.5rem;display:flex;position:sticky;top:0}.topbar .page-title{font-size:1.1rem;font-weight:600}.topbar .user-chip{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.content{flex:1;padding:1.5rem}.hamburger{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:4px;display:inline-flex}.hamburger:hover{color:var(--gold-dark);background:#eef2ff}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:1.25rem}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.page-head h1{font-size:1.4rem}.table-wrap{overflow-x:auto}table.data{border-collapse:collapse;width:100%}table.data th,table.data td{text-align:left;border-bottom:1px solid var(--border);vertical-align:middle;padding:.8rem 1rem}table.data th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#fafbfc;font-size:.72rem}table.data tr:last-child td{border-bottom:none}table.data tr:hover td{background:#fafbfc}.row-actions{justify-content:flex-end;gap:.4rem;display:flex}.thumb{object-fit:cover;border:1px solid var(--border);background:#eef0f3;border-radius:6px;width:44px;height:44px}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem .95rem;font-size:.85rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover{background:#f6f7f9;border-color:#c7ccd4}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--gold);border-color:var(--gold);color:#fff}.btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark);color:#fff}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-dark);border-color:var(--danger-dark);color:#fff}.btn-sm{padding:.4rem .6rem;font-size:.8rem}.btn-icon{padding:.45rem}.form-group{margin-bottom:1rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}label.field-label{color:var(--text);margin-bottom:.35rem;font-size:.82rem;font-weight:600;display:block}input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],select,textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:8px;padding:.6rem .75rem;font-family:inherit;font-size:.9rem}input:focus,select:focus,textarea:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px #c9a84c26}textarea{resize:vertical;min-height:90px}.checkbox-row{align-items:center;gap:.5rem;display:flex}.checkbox-row input{width:16px;height:16px;accent-color:var(--gold)}.field-hint{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.badge{border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-block}.badge-green{color:var(--success);background:#e3f6ec}.badge-gray{color:var(--text-muted);background:#eceef1}.badge-gold{color:var(--gold-dark);background:#e0e7ff}.badge-blue{color:#2563eb;background:#e3eefb}.modal-overlay{z-index:100;background:#1018288c;justify-content:center;align-items:flex-start;padding:3rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--surface);border-radius:12px;width:100%;max-width:560px;box-shadow:0 20px 50px #0000004d}.modal.wide{max-width:920px}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.1rem 1.25rem;display:flex}.modal-head h3{font-size:1.05rem}.modal-body{padding:1.25rem}.modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:.6rem;padding:1rem 1.25rem;display:flex}.icon-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:.25rem;display:inline-flex}.icon-btn:hover{color:var(--text)}.alert{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.alert-error{color:var(--danger-dark);background:#fdecea;border:1px solid #f5c6c2}.alert-success{color:#157a47;background:#e3f6ec;border:1px solid #b6e6c9}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:1.25rem;display:flex}.stat-icon{width:46px;height:46px;color:var(--gold-dark);background:#e0e7ff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-value{font-size:1.6rem;font-weight:700;line-height:1.1}.stat-label{color:var(--text-muted);font-size:.8rem}.login-split{align-items:stretch;min-height:100vh;display:flex}.login-visual{background-color:var(--navy);background-position:50%;background-repeat:no-repeat;background-size:cover;flex:80%;position:relative;overflow:hidden}.login-visual-overlay{color:#fff;background:linear-gradient(#0b113026 0%,#0b11300d 45%,#0b1130b8 100%);flex-direction:column;justify-content:space-between;padding:3rem 3.5rem;display:flex;position:absolute;inset:0}.login-visual-badge{letter-spacing:.08em;text-transform:uppercase;color:#dbe3ff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1f;border:1px solid #ffffff38;border-radius:999px;padding:.4rem .9rem;font-size:.72rem;font-weight:600;display:inline-block}.login-visual-copy{max-width:560px}.login-visual-copy h1{letter-spacing:-.01em;font-size:clamp(2rem,3.4vw,3.2rem);font-weight:800;line-height:1.05}.login-visual-tagline{letter-spacing:.22em;text-transform:uppercase;color:#ffcf5c;margin:.35rem 0 0;font-size:.8rem;font-weight:600}.login-visual-lead{color:#ccd5ee;max-width:460px;margin:1.1rem 0 0;font-size:1.02rem;line-height:1.6}.login-visual-foot{color:#fff9;font-size:.78rem}.login-panel{background:var(--surface);flex:0 0 20%;justify-content:center;align-items:center;min-width:360px;max-width:480px;padding:2rem 2.25rem;display:flex}.login-form-wrap{width:100%;max-width:320px}.login-form-wrap .brand{text-align:center;margin-bottom:2rem}.login-form-wrap .login-logo{width:220px;max-width:100%;height:auto;margin:0 auto .9rem;display:block}.login-form-wrap .brand-sub{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);font-size:.72rem}.login-help{text-align:center;margin-top:1.5rem;font-size:.75rem;line-height:1.5}@media (width<=860px){.login-split{flex-direction:column}.login-visual{display:none}.login-panel{flex:auto;min-width:0;max-width:none;min-height:100vh}}.muted{color:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.loading{text-align:center;color:var(--text-muted);padding:3rem}.skel{background:linear-gradient(90deg,#eef2f8 25%,#e3e9f3 37%,#eef2f8 63%) 0 0/400% 100%;border-radius:8px;animation:1.4s infinite skel}@keyframes skel{0%{background-position:100% 0}to{background-position:0 0}}.skel-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.25rem}.toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.toolbar input,.toolbar select{max-width:280px}.image-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.85rem;display:grid}.image-tile{border:1px solid var(--border);background:#fafbfc;border-radius:8px;overflow:hidden}.image-tile.is-primary{border-color:var(--gold);box-shadow:0 0 0 2px #2b4cdb2e}.image-tile-preview{position:relative}.image-tile img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.primary-flag{background:var(--gold);color:#fff;border-radius:999px;align-items:center;gap:3px;padding:2px 7px;font-size:.62rem;font-weight:700;display:inline-flex;position:absolute;top:6px;left:6px}.image-tile-body{flex-direction:column;gap:.4rem;padding:.5rem;display:flex}.image-tile-actions{justify-content:space-between;align-items:center;gap:.3rem;display:flex}.swatch-dot{border:1px solid var(--border);vertical-align:middle;border-radius:50%;width:14px;height:14px;display:inline-block}.pagination{justify-content:center;align-items:center;gap:.75rem;margin-top:1.25rem;display:flex}.dropzone{text-align:center;color:var(--text-muted);cursor:pointer;background:#f7f9fe;border:2px dashed #c7d0e0;border-radius:12px;padding:1.75rem 1rem;transition:border-color .15s,background .15s}.dropzone:hover{border-color:var(--gold);background:#eef2ff}.dropzone.drag{border-color:var(--gold);color:var(--gold-dark);background:#e0e7ff}.dropzone svg{color:var(--gold)}.dz-title{color:var(--text);margin-top:.5rem;font-weight:600}.dz-sub{margin-top:.25rem;font-size:.78rem}.upload-list{flex-direction:column;gap:.4rem;margin-top:.85rem;display:flex}.upload-item{align-items:center;gap:.6rem;font-size:.8rem;display:flex}.upload-status{flex-shrink:0;display:inline-flex}.upload-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text);flex:0 0 200px;overflow:hidden}.progress{background:#e7ebf3;border-radius:999px;flex:1;height:6px;overflow:hidden}.progress>i{background:var(--gold);border-radius:999px;height:100%;transition:width .2s;display:block}.upload-pct{text-align:right;min-width:44px;color:var(--text-muted);flex-shrink:0}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=860px){.form-row{grid-template-columns:1fr}}
