:root{--bg: #f3f7fc;--bg-strong: #e8eff8;--surface: rgba(255, 255, 255, .96);--surface-strong: #ffffff;--surface-soft: #fbfdff;--surface-muted: #f3f7fc;--surface-dark: linear-gradient(180deg, #0f172a 0%, #12213d 52%, #18284a 100%);--sidebar-border: rgba(148, 163, 184, .16);--border: rgba(148, 163, 184, .22);--border-strong: rgba(71, 85, 105, .3);--text: #0f172a;--text-muted: #475569;--text-soft: #64748b;--text-inverse: rgba(255, 255, 255, .92);--brand: #2563eb;--brand-strong: #1d4ed8;--brand-soft: rgba(37, 99, 235, .12);--teal: #0f766e;--teal-soft: rgba(15, 118, 110, .12);--amber: #d97706;--amber-soft: rgba(217, 119, 6, .12);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .1);--success: #0f766e;--success-soft: rgba(15, 118, 110, .1);--shadow-lg: 0 24px 56px rgba(15, 23, 42, .12);--shadow-md: 0 14px 30px rgba(15, 23, 42, .09);--shadow-sm: 0 6px 18px rgba(15, 23, 42, .06);--radius-xl: 28px;--radius-lg: 22px;--radius-md: 18px;--radius-sm: 14px;--radius-xs: 12px;--radius-pill: 999px;--font-body: "SUIT Variable", "Apple SD Gothic Neo", sans-serif;--font-display: "Space Grotesk", "SUIT Variable", "Apple SD Gothic Neo", sans-serif;color-scheme:light;font-feature-settings:"liga" 1,"calt" 1}*,*:before,*:after{box-sizing:border-box;font-family:inherit;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}html,body{min-height:100%}body{margin:0;background:radial-gradient(circle at top left,rgba(37,99,235,.1),transparent 26%),radial-gradient(circle at 82% 12%,rgba(14,165,233,.08),transparent 20%),linear-gradient(180deg,#f8fbff,#f1f5fb);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;word-break:keep-all}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(148,163,184,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.08) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.2),transparent 85%);mask-image:linear-gradient(180deg,rgba(0,0,0,.2),transparent 85%);pointer-events:none;opacity:.18}#app{min-height:100vh;position:relative;z-index:1}a{color:inherit;text-decoration:none}button,input,select{font:inherit}img,svg{display:block}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#64748b47;border-radius:999px;border:3px solid transparent;background-clip:content-box}.auth-layout{min-height:100vh;padding:28px;display:grid;place-items:center}.auth-shell{width:min(1180px,100%);display:grid;grid-template-columns:minmax(340px,.86fr) minmax(0,1.14fr);gap:24px;align-items:stretch}.auth-hero,.auth-card,.hero-panel,.page-section,.chart-panel,.stat-card,.table-container,.modal{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-hero,.auth-card,.hero-panel,.page-section,.chart-panel,.stat-card,.product-card{animation:fade-up .42s ease both}.auth-hero{position:relative;overflow:hidden;padding:36px;display:flex;align-items:flex-end;color:var(--text-inverse);background:radial-gradient(circle at top right,rgba(96,165,250,.16),transparent 30%),radial-gradient(circle at bottom left,rgba(37,99,235,.22),transparent 28%),linear-gradient(160deg,#0f172a,#172554 58%,#1d4ed8)}.auth-hero:after{content:"";position:absolute;inset:auto -8% -16% 32%;height:220px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 62%);filter:blur(8px)}.auth-hero-copy,.logo,.hero-copy{display:flex;flex-direction:column;gap:12px}.auth-hero-copy h1,.logo h1,.hero-copy h2,.page-header h2,.section-head h3,.product-card h3,.shell-title-row h2,.sidebar-header h1{margin:0;font-family:var(--font-display);letter-spacing:-.045em}.auth-hero-copy h1{max-width:11ch;font-size:clamp(2.5rem,4vw,4.25rem);line-height:.95}.auth-hero-copy p,.hero-copy p,.section-head p,.page-header p,.hero-hint,.auth-footnote,.product-card-meta,.stat-sub,.profile-caption,.sidebar-status-card p,.logo p,.shell-title-row p{margin:0;color:var(--text-muted);line-height:1.65}.auth-hero p,.auth-hero .mini-label,.auth-hero .eyebrow,.auth-hero .auth-showcase-card p{color:#ffffffc7}.auth-card{order:-1;padding:32px;display:flex;flex-direction:column;justify-content:center;background:#fffffffa}.logo h1{font-size:clamp(2rem,3vw,2.8rem)}.auth-showcase-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:auto}.auth-showcase-card{min-height:164px;padding:18px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.16);background:#ffffff14;display:flex;flex-direction:column;gap:10px}.auth-showcase-card strong,.hero-action-title{font-size:1.05rem;font-weight:600;line-height:1.4}.auth-footnote{margin-top:22px;font-size:.94rem;text-align:center}.auth-footnote a,.text-link{color:var(--brand);font-weight:600}.app-shell{display:flex;min-height:100vh}.sidebar{width:312px;position:sticky;top:0;height:100dvh;padding:20px 16px;display:flex;flex-direction:column;gap:18px;background:var(--surface-dark);border-right:1px solid var(--sidebar-border);box-shadow:inset -1px 0 #ffffff08;color:var(--text-inverse);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.sidebar-brand{align-items:center;gap:14px}.sidebar-header{display:flex}.brand-mark{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;font-family:var(--font-display);font-size:1rem;font-weight:700;letter-spacing:-.04em;background:linear-gradient(135deg,#eff6ff,#bfdbfe);color:#1e3a8a;box-shadow:inset 0 1px #ffffffb3}.sidebar-brand-copy{display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar-header h1{font-size:1.42rem;color:var(--text-inverse);overflow-wrap:anywhere}.sidebar-header p,.sidebar-label,.sidebar-section-label,.shell-kicker,.shell-meta-label,.profile-label,.mini-label,.eyebrow,.stat-label,thead th{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.sidebar-label,.sidebar-section-label,.shell-kicker,.shell-meta-label,.profile-label,.mini-label,.eyebrow,.stat-label,thead th{color:var(--text-soft)}.sidebar .sidebar-label,.sidebar-header p,.sidebar-section-label,.sidebar-status-card p,.profile-caption{color:#ffffffa8}.sidebar-header p,.sidebar-brand-copy h1,.shell-topbar-copy h2,.shell-topbar-copy p{margin:0}.sidebar-panel,.sidebar-footer{display:flex;flex-direction:column;gap:14px}.profile-card,.sidebar-status-card{padding:18px;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.08);background:#ffffff0a;box-shadow:inset 0 1px #ffffff0d}.profile-card{display:flex;justify-content:space-between;gap:14px;min-width:0}.profile-meta{display:flex;flex-direction:column;gap:6px;min-width:0}.profile-meta strong,.sidebar-status-card strong{font-size:1rem;font-weight:600;color:var(--text-inverse);overflow-wrap:anywhere}.hero-meta-grid strong{font-size:1rem;font-weight:600;color:var(--text);overflow-wrap:anywhere}.profile-role,.status-chip,.empty-pill{align-self:flex-start;padding:8px 12px;border-radius:var(--radius-pill);font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.profile-role{background:#bfdbfe24;border:1px solid rgba(191,219,254,.18);color:#dbeafe}.status-chip{background:#0f766e1f;border:1px solid rgba(15,118,110,.2);color:var(--success)}.empty-pill{background:#2563eb14;border:1px solid rgba(37,99,235,.14);color:var(--brand-strong)}.sidebar-nav{display:flex;flex-direction:column;gap:10px}.sidebar-section-label{padding:0 12px}.nav-item{width:100%;padding:14px 15px;display:flex;align-items:center;gap:12px;border:1px solid transparent;border-radius:16px;background:transparent;color:#ffffffd1;cursor:pointer;transition:border-color .16s ease,background-color .16s ease,color .16s ease,box-shadow .16s ease}.nav-item:hover,.nav-item.active{border-color:#bfdbfe29;background:#ffffff12;box-shadow:inset 0 1px #ffffff0a}.nav-item-icon{width:38px;height:38px;flex:0 0 38px;display:grid;place-items:center;border-radius:12px;background:#ffffff14;color:#dbeafe}.nav-item-icon svg,.mobile-menu-toggle svg{width:18px;height:18px}.nav-item-copy{min-width:0;display:flex;flex:1;flex-direction:column;gap:4px;text-align:left}.nav-item-copy>span{font-size:.96rem;font-weight:600;overflow-wrap:anywhere}.nav-item-copy small{color:#ffffff94;font-size:.78rem;overflow-wrap:anywhere}.nav-item-indicator{width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,#93c5fd,#38bdf8);opacity:0;transform:scale(.7);transition:opacity .16s ease,transform .16s ease}.nav-item.active .nav-item-indicator{opacity:1;transform:scale(1)}.sidebar-footer{margin-top:auto;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px))}.sidebar-status-card strong{margin:6px 0}.sidebar-logout{width:100%;min-height:48px;padding:0 18px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:#ffffff0a;color:#fff;cursor:pointer;transition:transform .16s ease,background-color .16s ease,border-color .16s ease}.sidebar-logout:hover{transform:translateY(-1px);background:#ffffff14}.content-shell{flex:1;min-width:0;display:flex;flex-direction:column}.shell-topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:1rem 2rem;background:linear-gradient(180deg,rgba(243,247,252,.96),rgba(243,247,252,.78) 78%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.shell-topbar-copy{min-width:0;display:flex;flex-direction:column;gap:4px}.shell-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.shell-title-row h2{font-size:clamp(1.55rem,2vw,2rem)}.shell-title-row p{color:var(--text-soft);font-size:.95rem;overflow-wrap:anywhere}.shell-divider{width:28px;height:1px;background:#64748b52}.shell-topbar-meta{display:flex;align-items:stretch;gap:12px}.shell-meta-card{min-width:150px;padding:12px 16px;border-radius:18px;border:1px solid rgba(148,163,184,.22);background:#ffffffb8;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:6px}.shell-meta-card strong{font-family:var(--font-display);font-size:.98rem;letter-spacing:-.03em;overflow-wrap:anywhere}.shell-meta-account{min-width:170px}.mobile-sidebar-overlay{display:none}.mobile-menu-toggle{display:none;width:48px;height:48px;padding:0;border-radius:16px;border:1px solid var(--border);background:#ffffffd1;color:var(--text);cursor:pointer;place-items:center;box-shadow:var(--shadow-sm)}.main-content{padding:20px 28px 28px}.content-frame{width:min(100%,1480px);margin:0 auto;display:flex;flex-direction:column;gap:20px}#detail-area,#products-area,#slot-history-area{display:flex;flex-direction:column;gap:20px}.page-header{padding:24px 26px;border:1px solid var(--border);border-radius:var(--radius-xl);background:#fffffff2;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px}.page-header h2{font-size:clamp(1.65rem,2vw,2.3rem)}.detail-toolbar{display:flex;align-items:center;justify-content:flex-start}.hero-panel,.page-section,.chart-panel{position:relative;overflow:hidden;padding:24px;display:flex;flex-direction:column;gap:18px}.hero-panel:before,.page-section:before,.chart-panel:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent,rgba(37,99,235,.16),transparent)}.hero-panel-split{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(340px,.92fr);align-items:stretch;gap:22px}.hero-copy{position:relative;z-index:1}.hero-copy h2{max-width:12ch;font-size:clamp(2rem,3vw,3.2rem);line-height:.96;overflow-wrap:anywhere}.hero-side-stack{display:flex;flex-direction:column;gap:16px}.hero-action-card{padding:18px;border-radius:var(--radius-lg);border:1px solid rgba(37,99,235,.12);background:#f8fbffeb;display:flex;flex-direction:column;gap:14px}.hero-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.hero-meta-grid-compact{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-meta-grid>div,.info-strip>div{padding:16px;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.18);background:#f8fbffd1;display:flex;flex-direction:column;gap:8px;min-width:0}.inline-input-group{display:flex;gap:12px}.inline-input-group>*{min-width:0}.inline-input-group .form-input{flex:1}.toolbar-row{display:flex;flex-wrap:wrap;gap:12px;min-width:0}.toolbar-row>*{min-width:0}.toolbar-row .form-group{flex:1 1 180px;margin-bottom:0}.form-group-align-end{justify-content:flex-end}.stats-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stats-grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stats-grid-4{grid-template-columns:repeat(auto-fit,minmax(205px,1fr))}.stat-card{padding:22px;display:flex;flex-direction:column;gap:12px;background:#fffffffa}.stat-value{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.45rem);line-height:.95;letter-spacing:-.04em}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.section-head h3{font-size:clamp(1.15rem,1.6vw,1.4rem);overflow-wrap:anywhere}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.chart-wrap{height:340px}.product-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}.product-card{padding:22px;border-radius:var(--radius-lg);border:1px solid rgba(148,163,184,.24);background:#fffffffa;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px;min-height:290px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.product-card:hover{transform:translateY(-1px);border-color:#2563eb38;box-shadow:0 12px 24px #0f172a14}.product-card-head{display:flex;justify-content:space-between;gap:14px}.product-card h3{font-size:1.24rem;line-height:1.15;margin-top:4px;overflow-wrap:anywhere}.product-card-meta{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:.88rem}.metric-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metric-tile{padding:14px;border-radius:16px;border:1px solid rgba(148,163,184,.18);background:#f8fbffd6;display:flex;flex-direction:column;gap:6px}.metric-tile span{color:var(--text-soft);font-size:.82rem}.metric-tile strong{font-size:1.06rem;font-weight:700}.product-card-actions{margin-top:auto;display:flex;flex-wrap:wrap;gap:10px}.info-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.table-container{overflow:auto;max-width:100%;background:#fffffffa}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(148,163,184,.2)}.table-toolbar h3{margin:0;font-size:.98rem;overflow-wrap:anywhere}table{width:100%;min-width:680px;border-collapse:collapse}thead th{padding:15px 18px;text-align:left;border-bottom:1px solid rgba(148,163,184,.18);background:#f9fbfffa;position:sticky;top:0;z-index:1}tbody td{padding:15px 18px;border-bottom:1px solid rgba(148,163,184,.12);color:var(--text-muted);font-size:.94rem;overflow-wrap:anywhere}tbody tr:hover{background:#2563eb06}tbody tr:last-child td{border-bottom:none}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{color:var(--text-muted);font-size:.92rem}.form-input{width:100%;min-width:0;min-height:52px;padding:0 16px;border-radius:16px;border:1px solid rgba(148,163,184,.26);background:#ffffffe6;color:var(--text);font-size:.92rem;outline:none;transition:border-color .16s ease,background-color .16s ease,box-shadow .16s ease}.form-input:focus{border-color:#2563eb73;background:#fff;box-shadow:0 0 0 4px #2563eb14}.form-input::placeholder{color:var(--text-soft)}.custom-select{position:relative;width:100%}.custom-select-trigger{width:100%;min-width:0;min-height:52px;padding:0 16px;border-radius:16px;border:1px solid rgba(148,163,184,.26);background:#ffffffe6;color:var(--text);display:inline-flex;align-items:center;justify-content:space-between;gap:12px;font-size:.9rem;text-align:left;cursor:pointer;transition:border-color .16s ease,background-color .16s ease,box-shadow .16s ease,transform .16s ease}.custom-select-trigger:hover{background:#fff}.custom-select-trigger:focus-visible{border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb14;outline:none}.custom-select.is-open .custom-select-trigger{border-color:#2563eb73;background:#fff}.custom-select-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-label.is-placeholder{color:var(--text-soft)}.custom-select-icon{flex:0 0 auto;color:var(--text-soft);font-size:.95rem;font-weight:700;line-height:1;transform:rotate(45deg);transition:transform .16s ease}.custom-select.is-open .custom-select-icon{transform:rotate(0)}.custom-select-menu{position:fixed;top:0;left:0;z-index:1200;display:flex;flex-direction:column;gap:4px;min-width:0;max-height:256px;padding:8px;overflow-y:auto;border:1px solid var(--border);border-radius:20px;background:#fffffff5;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.custom-select-menu[hidden]{display:none}.custom-select-option,.custom-select-empty{min-height:44px;padding:12px 14px;border-radius:14px;font-size:.9rem}.custom-select-option{width:100%;border:0;background:transparent;color:var(--text);text-align:left;cursor:pointer;transition:background-color .16s ease,color .16s ease}.custom-select-option:hover,.custom-select-option:focus-visible{background:#2563eb14;outline:none}.custom-select-option.is-selected{background:var(--brand);color:var(--surface-strong)}.custom-select-option:disabled{color:var(--text-soft);cursor:not-allowed}.custom-select-empty{color:var(--text-soft)}.toolbar-select{width:auto;min-width:min(100%,220px);max-width:100%}.toolbar-select-sm{min-width:min(100%,180px)}.btn{min-height:48px;padding:0 18px;border-radius:16px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:.92rem;font-weight:600;cursor:pointer;transition:transform .16s ease,opacity .16s ease,background-color .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-strong) 100%);color:var(--surface-strong);border-color:transparent;box-shadow:0 10px 20px #2563eb2e}.btn-secondary{background:#ffffffe0;color:var(--text);border-color:#94a3b83d}.btn-ghost{background:#f8fbffe0;color:var(--text);border-color:#94a3b833}.btn-danger{background:#ffffffe6;color:var(--danger);border-color:#dc26263d}.btn-sm{min-height:38px;padding:0 14px;border-radius:13px;font-size:.84rem}.btn-block{width:100%}.badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:var(--radius-pill);font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.badge-green{background:var(--success-soft);color:var(--success)}.badge-red{background:var(--danger-soft);color:var(--danger)}.badge-neutral{background:#94a3b829;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;padding:24px;background:#0f172a3d;display:grid;place-items:center;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal{width:min(100%,520px);overflow:hidden;background:#fffffffa}.modal-header,.modal-body,.modal-footer{padding:22px}.modal-header,.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-header{border-bottom:1px solid rgba(148,163,184,.18)}.modal-header h3{margin:0;font-family:var(--font-display);letter-spacing:-.04em}.modal-footer{border-top:1px solid rgba(148,163,184,.18);justify-content:flex-end}.modal-close{width:40px;height:40px;border-radius:14px;border:1px solid rgba(148,163,184,.2);background:#f8fbffeb;color:var(--text-muted);cursor:pointer}.toast-container{position:fixed;top:18px;right:18px;display:flex;flex-direction:column;gap:10px;z-index:1100}.toast{min-width:240px;max-width:320px;padding:14px 16px;border-radius:18px;border:1px solid var(--border);background:#fffffff5;color:var(--text);box-shadow:var(--shadow-md)}.toast.error{border-color:#dc262638}.toast.success{border-color:#0f766e3d}.empty-state{min-height:240px;display:grid;place-items:center;gap:10px;padding:28px;text-align:center}.exchange-empty{border:1px dashed rgba(37,99,235,.24);border-radius:var(--radius-lg);background:linear-gradient(180deg,#2563eb0a,#f8fbffe0)}.empty-state h3{margin:0;font-family:var(--font-display);font-size:1.2rem;letter-spacing:-.04em}.empty-state p{margin:0;color:var(--text-muted);max-width:44ch}.empty-icon{font-size:2rem;opacity:.45}.spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(148,163,184,.18);border-top-color:var(--brand);animation:spin .9s linear infinite}.page-loading{min-height:220px;display:grid;place-items:center}.error-msg{padding:14px 16px;border-radius:16px;border:1px solid rgba(220,38,38,.18);background:#dc26260f;color:#991b1b}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--text-soft)}.text-sm{font-size:.9rem}.truncate{display:inline-block;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1200px){.auth-shell{grid-template-columns:1fr}.auth-hero{min-height:380px}.hero-panel-split,.detail-grid{grid-template-columns:1fr}.hero-copy h2{max-width:none}}@media(max-width:980px){body.sidebar-open{overflow:hidden}.sidebar{position:fixed;inset:0 auto 0 0;z-index:220;width:min(320px,calc(100vw - 32px));max-width:320px;transform:translate(calc(-100% - 18px));transition:transform .18s ease;box-shadow:var(--shadow-lg)}body.sidebar-open .sidebar{transform:translate(0)}.mobile-sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:210;border:0;padding:0;background:#0f172a4d;opacity:0;pointer-events:none;transition:opacity .18s ease}body.sidebar-open .mobile-sidebar-overlay{opacity:1;pointer-events:auto}.mobile-menu-toggle{display:grid}.shell-topbar{padding:1rem;align-items:flex-start}.shell-topbar-meta{display:none}.main-content{padding:16px 18px 22px}}@media(max-width:760px){.auth-layout,.modal-overlay{padding:16px}.auth-hero,.auth-card,.hero-panel,.page-section,.chart-panel,.stat-card{padding:20px;border-radius:22px}.auth-showcase-grid,.hero-meta-grid,.metric-strip,.info-strip{grid-template-columns:1fr}.inline-input-group,.product-card-actions{flex-direction:column}.form-group-align-end{justify-content:stretch}.chart-wrap{height:300px}.table-container{border-radius:20px}.table-toolbar{padding:14px 16px}thead th,tbody td{padding:13px 14px}}@media(max-width:560px){.auth-layout{padding:12px}.auth-hero-copy h1,.hero-copy h2{font-size:2rem}.shell-title-row{flex-direction:column;align-items:flex-start;gap:8px}.shell-divider{display:none}.section-head{flex-direction:column;align-items:flex-start}.product-grid{grid-template-columns:1fr}.toast-container{inset:auto 12px 12px}.toast{max-width:none}}
