:root{--bg:#0a0a10;--bg-elevated:#111118;--surface:#16161f;--surface-hover:#1c1c28;--surface-2:#202030;--stroke:#ffffff0d;--stroke-hover:#ffffff1a;--text:#eaeaf2;--text-secondary:#8e8ea8;--muted:#5c5c78;--accent:#8b5cf6;--accent-hover:#a78bfa;--accent-subtle:#8b5cf614;--accent-glow:#8b5cf61f;--danger:#f87171;--danger-bg:#f871710f;--success:#34d399;--success-bg:#34d3990f;--amber:#fbbf24;--amber-bg:#fbbf240f;--blue:#60a5fa;--blue-bg:#60a5fa0f;--shadow-sm:0 1px 3px #00000080;--shadow:0 8px 32px #0006;--shadow-lg:0 24px 64px #0009;--radius:10px;--radius-sm:7px;--radius-pill:999px;--font:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", ui-monospace, monospace;--transition:.18s cubic-bezier(.4, 0, .2, 1);font:13.5px/1.6 var(--font);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,:before,:after{box-sizing:border-box}body{background:var(--bg);min-height:100vh;margin:0}#root{min-height:100vh}button,input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}.shell{grid-template-columns:256px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--stroke);scrollbar-width:none;flex-direction:column;gap:24px;height:100vh;padding:24px 16px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar::-webkit-scrollbar{display:none}.brand{align-items:center;gap:12px;padding:4px 8px;display:flex}.brand-mark{border-radius:var(--radius-sm);background:0 0;flex-shrink:0;place-items:center;width:38px;height:38px;display:grid}.brand-mark svg{width:34px;height:34px}.brand-text h2{letter-spacing:-.02em;color:var(--text);margin:0;font-size:17px;font-weight:700}.brand-text span{color:var(--muted);letter-spacing:.02em;font-size:11px}.nav{flex-direction:column;gap:4px;display:flex}.nav-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 8px;padding:0 12px;font-size:10px}.nav-item{border-radius:var(--radius-sm);text-align:left;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:1px solid #0000;align-items:center;gap:12px;padding:10px 14px;font-size:13.5px;font-weight:500;display:flex}.nav-item svg{opacity:.6;transition:opacity var(--transition);flex-shrink:0}.nav-item:hover{color:var(--text);border-color:var(--stroke);background:#ffffff08}.nav-item:hover svg{opacity:.9}.nav-item--active{background:var(--accent-subtle);color:var(--accent-hover);border-color:#8b5cf62e;font-weight:600}.nav-item--active svg{opacity:1;color:var(--accent)}.sidebar-foot{border-top:1px solid var(--stroke);flex-direction:column;gap:14px;margin-top:auto;padding-top:20px;display:flex}.sidebar-foot__user{align-items:center;gap:12px;padding:0 4px;display:flex}.sidebar-avatar{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--stroke);width:34px;height:34px;color:var(--text-secondary);place-items:center;font-size:12px;font-weight:600;display:grid}.sidebar-foot__name{color:var(--text);margin:0;font-size:13px;font-weight:600}.sidebar-foot__role{color:var(--muted);margin:0;font-size:11px}.sidebar-logout{border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;align-items:center;gap:8px;padding:8px 14px;font-size:12.5px;display:flex}.sidebar-logout:hover{color:var(--danger);background:var(--danger-bg);border-color:#f871714d}.main{min-width:0;padding:32px 40px 56px;position:relative}.main:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle,#ffffff05 1px,#0000 1px);background-size:24px 24px;position:fixed;inset:0 0 0 256px}.main>*{z-index:1;position:relative}.topbar{border-bottom:1px solid var(--stroke);justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:28px;padding-bottom:24px;display:flex}.eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin:0 0 6px;font-size:10.5px}.topbar h1{letter-spacing:-.03em;color:var(--text);margin:0 0 4px;font-size:28px;font-weight:700}.topbar__sub{color:var(--text-secondary);margin:0;font-size:13.5px}.topbar__right{flex-shrink:0;align-items:center;gap:12px;display:flex}.status-chip{border-radius:var(--radius-pill);background:var(--success-bg);color:var(--success);border:1px solid #34d39926;align-items:center;gap:8px;padding:7px 14px;font-size:11.5px;font-weight:500;display:flex}.status-chip__dot{background:var(--success);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn--primary{background:var(--accent);color:#fff;box-shadow:0 0 16px var(--accent-glow);border:none;font-weight:600}.btn--primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 0 24px #8b5cf64d}.btn--primary:active{transform:translateY(0)}.btn--ghost{background:var(--surface);border-color:var(--stroke);color:var(--text-secondary)}.btn--ghost:hover{border-color:var(--stroke-hover);color:var(--text);background:var(--surface-hover)}.btn--sm{padding:5px 10px;font-size:11.5px}.btn--full{justify-content:center;width:100%}.banner{border-radius:var(--radius);margin-bottom:20px;padding:12px 18px;font-size:13px}.banner--error{background:var(--danger-bg);color:var(--danger);border:1px solid #f8717126}.card{background:var(--surface);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color var(--transition), box-shadow var(--transition);padding:22px}.card:hover{border-color:var(--stroke-hover)}.card__header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.card__header h3{letter-spacing:-.01em;margin:0 0 4px;font-size:16px;font-weight:600}.card__header p{color:var(--text-secondary);margin:0;font-size:13px}.card--full{grid-column:1/-1}.view-card{padding:28px}.stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.stat-card--violet:before{background:linear-gradient(180deg, var(--accent), #8b5cf633)}.stat-card--blue:before{background:linear-gradient(180deg, var(--blue), #60a5fa33)}.stat-card--emerald:before{background:linear-gradient(180deg, var(--success), #34d39933)}.stat-card--amber:before{background:linear-gradient(180deg, var(--amber), #fbbf2433)}.stat-card--violet .sparkline{color:var(--accent)}.stat-card--blue .sparkline{color:var(--blue)}.stat-card--emerald .sparkline{color:var(--success)}.stat-card--amber .sparkline{color:var(--amber)}.stat-card__head{justify-content:space-between;align-items:flex-start;display:flex}.stat-card__icon{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-secondary);background:#ffffff0a;place-items:center;display:grid}.stat-card__icon svg{width:18px;height:18px}.stat-card h3{letter-spacing:-.03em;margin:6px 0 0;font-size:28px;font-weight:700}.stat-row{justify-content:space-between;align-items:flex-end;gap:12px;display:flex}.sparkline{opacity:.8;width:100px;height:36px}.card-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:11px}.card-hint{color:var(--muted);margin:4px 0 0;font-size:12.5px}.dashboard__tables{grid-template-columns:1fr;gap:20px;display:grid}.table{flex-direction:column;gap:6px;display:flex}.row{border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--stroke);transition:all var(--transition);grid-template-columns:2fr repeat(3,minmax(0,1fr));align-items:center;gap:12px;padding:12px 16px;display:grid}.row:not(.row--header):hover{border-color:var(--stroke-hover);background:var(--surface-hover)}.row--header{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);background:0 0;border:1px solid #0000;padding:0 16px 8px;font-size:10.5px;font-weight:600}.row__cell{align-items:center;gap:10px;min-width:0;display:flex}.row__cell--main{flex-direction:column;gap:2px;display:flex}.row__cell--main strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.row__cell--main span{color:var(--muted);font-size:12px}.row__meta{color:var(--text-secondary);font-size:12.5px}.row__role-tag{border-radius:var(--radius-pill);background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--stroke);justify-self:start;padding:3px 10px;font-size:11px;display:inline-flex}.user-avatar{background:var(--accent-subtle);width:32px;height:32px;color:var(--accent);border:1px solid #8b5cf633;border-radius:50%;flex-shrink:0;place-items:center;font-size:11px;font-weight:700;display:grid}.row__cell--main:has(.user-avatar){flex-direction:row;align-items:center;gap:12px}.row__cell--main:has(.user-avatar)>div{flex-direction:column;gap:2px;display:flex}.toolbar{flex-wrap:wrap;gap:10px;margin:0 0 18px;display:flex}.toolbar__search{flex:1;min-width:200px;position:relative}.toolbar__search svg{color:var(--muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.toolbar__search input{background:var(--bg-elevated);border:1px solid var(--stroke);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:border-color var(--transition);padding:9px 12px 9px 36px;font-size:13px}.toolbar__search input::placeholder{color:var(--muted)}.toolbar__search input:focus{border-color:#8b5cf666;outline:none;box-shadow:0 0 0 3px #8b5cf614}.toolbar select{appearance:none;background:var(--bg-elevated);border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition);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='%236e6e8a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:9px 32px 9px 14px;font-size:13px}.toolbar select:focus{border-color:#8b5cf666;outline:none}.filter-chips{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.chip{border-radius:var(--radius-pill);background:var(--accent-subtle);color:var(--accent-hover);border:1px solid #8b5cf62e;padding:4px 10px;font-size:11px;font-weight:500}.table-meta{color:var(--muted);justify-content:space-between;margin-bottom:10px;padding:0 4px;font-size:11.5px;display:flex}.pagination{border-top:1px solid var(--stroke);justify-content:center;align-items:center;gap:12px;margin-top:18px;padding-top:16px;display:flex}.pagination__btn{background:var(--surface);border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;padding:7px 14px;font-size:12.5px;font-weight:500;display:inline-flex}.pagination__btn:hover:not(:disabled){border-color:var(--stroke-hover);color:var(--text)}.pagination__btn:disabled{opacity:.35;cursor:not-allowed}.pagination__info{color:var(--muted);font-size:12px}.pagination__info strong{color:var(--text-secondary)}.badge{border-radius:var(--radius-pill);text-transform:capitalize;letter-spacing:.02em;justify-self:start;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge--green{background:var(--success-bg);color:var(--success);border:1px solid #34d39926}.badge--gray{color:#94a3b8;background:#94a3b814;border:1px solid #94a3b81f}.badge--red{background:var(--danger-bg);color:var(--danger);border:1px solid #f8717126}.badge--amber{background:var(--amber-bg);color:var(--amber);border:1px solid #fbbf2426}.badge--blue{background:var(--blue-bg);color:var(--blue);border:1px solid #60a5fa26}.empty-state{text-align:center;padding:40px 24px}.empty-state__inner{background:#8b5cf605;border:1px dashed #8b5cf626;border-radius:16px;max-width:320px;margin:0 auto;padding:28px}.empty-state h4{color:var(--text);margin:0 0 8px;font-size:16px;font-weight:600}.empty-state p{color:var(--text-secondary);margin:0 0 16px;font-size:13px}.skeleton{position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000,#8b5cf60f,#0000);animation:1.8s infinite shimmer;position:absolute;inset:0;transform:translate(-100%)}.skeleton-line{border-radius:var(--radius-pill);background:#ffffff0f;height:10px;margin-bottom:8px;display:block}.skeleton-line.short{width:60%}.skeleton-pill{border-radius:var(--radius-pill);background:#ffffff0f;width:80px;height:18px}.stat-card .skeleton-line{margin-bottom:10px}.login-shell{grid-template-columns:1.1fr .9fr;min-height:100vh;display:grid}.login-panel{justify-content:center;align-items:center;padding:48px;display:flex}.login-panel--hero{background:var(--bg);position:relative;overflow:hidden}.login-hero__bg{z-index:0;position:absolute;inset:0}.login-orb{filter:blur(100px);border-radius:50%;animation:12s ease-in-out infinite float;position:absolute}.login-orb--1{background:#8b5cf633;width:500px;height:500px;top:-15%;left:-10%}.login-orb--2{background:#60a5fa26;width:350px;height:350px;animation-delay:-4s;bottom:-10%;right:-5%}.login-orb--3{background:#34d3991a;width:250px;height:250px;animation-delay:-8s;top:50%;left:40%}@keyframes float{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-20px)scale(1.05)}66%{transform:translate(-20px,15px)scale(.95)}}.login-hero__content{z-index:1;max-width:480px;position:relative}.login-hero__badge{border-radius:var(--radius-pill);background:var(--accent-subtle);color:var(--accent);border:1px solid #8b5cf633;align-items:center;gap:8px;margin-bottom:24px;padding:6px 14px;font-size:12px;font-weight:600;display:inline-flex}.login-hero__badge svg{width:16px;height:16px}.login-hero__content h1{letter-spacing:-.04em;background:linear-gradient(135deg, var(--text) 0%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 16px;font-size:40px;font-weight:800;line-height:1.1}.login-hero__sub{color:var(--text-secondary);margin:0 0 36px;font-size:15px;line-height:1.6}.login-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.login-grid__item{border:1px solid var(--stroke);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:border-color var(--transition);background:#ffffff08;flex-direction:column;gap:8px;padding:16px;display:flex}.login-grid__item:hover{border-color:#8b5cf633}.login-grid__item span{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.login-grid__item strong{color:var(--text);letter-spacing:-.03em;font-size:24px;font-weight:700}.login-activity{border:1px solid var(--stroke);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff05;padding:18px}.login-activity__head{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:8px;margin:0 0 12px;font-size:11px;display:flex}.login-activity ul{color:var(--text-secondary);gap:8px;margin:0;padding-left:18px;font-size:13px;display:grid}.login-panel--form{background:var(--bg-elevated);border-left:1px solid var(--stroke)}.login-form__wrap{width:100%;max-width:380px}.login-form__header{margin-bottom:32px}.login-form__header svg{color:var(--accent);margin-bottom:16px}.login-form__header h2{letter-spacing:-.02em;margin:0 0 8px;font-size:22px;font-weight:700}.login-form__header p{color:var(--text-secondary);margin:0;font-size:13.5px}.login-form{flex-direction:column;gap:20px;display:flex}.login-form label{flex-direction:column;gap:7px;display:flex}.login-form label>span{color:var(--text-secondary);font-size:12px;font-weight:500}.login-form input{background:var(--surface);border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text);transition:all var(--transition);padding:11px 14px;font-size:13.5px}.login-form input::placeholder{color:var(--muted)}.login-form input:focus{border-color:#8b5cf680;outline:none;box-shadow:0 0 0 3px #8b5cf614}.login-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);box-shadow:0 0 20px var(--accent-glow);border:none;margin-top:4px;padding:12px;font-size:14px;font-weight:600}.login-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 0 32px #8b5cf64d}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-error{color:var(--danger);background:var(--danger-bg);border-radius:var(--radius-sm);border:1px solid #f8717126;padding:10px 14px;font-size:13px}.login-foot{color:var(--muted);margin-top:24px;font-size:12px}.login-foot strong{color:var(--text-secondary)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#0009;place-items:center;padding:20px;animation:.2s fade-in;display:grid;position:fixed;inset:0}.modal-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--stroke);width:min(520px,100%);box-shadow:var(--shadow-lg);padding:24px;animation:.25s modal-in}@keyframes modal-in{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-head{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-head h3{margin:0;font-size:17px;font-weight:600}.modal-close{background:var(--surface-2);border:1px solid var(--stroke);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);place-items:center;display:grid}.modal-close:hover{border-color:var(--stroke-hover);color:var(--text)}.modal-body{flex-direction:column;gap:16px;display:flex}.modal-form{flex-direction:column;gap:18px;display:flex}.modal-form label{flex-direction:column;gap:7px;display:flex}.modal-form label>span{color:var(--text-secondary);font-size:12px;font-weight:500}.modal-form input,.modal-form select,.modal-form textarea{background:var(--bg-elevated);border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition);padding:10px 14px;font-size:13px}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{border-color:#8b5cf666;outline:none;box-shadow:0 0 0 3px #8b5cf614}.modal-form textarea{resize:vertical;min-height:80px}.modal-form input::placeholder,.modal-form textarea::placeholder{color:var(--muted)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.stat-grid .stat-card{animation:.5s both card-in}.stat-grid .stat-card:first-child{animation-delay:0s}.stat-grid .stat-card:nth-child(2){animation-delay:70ms}.stat-grid .stat-card:nth-child(3){animation-delay:.14s}.stat-grid .stat-card:nth-child(4){animation-delay:.21s}@keyframes card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.table .row:not(.row--header){animation:.35s both row-in}.table .row:nth-child(2){animation-delay:30ms}.table .row:nth-child(3){animation-delay:60ms}.table .row:nth-child(4){animation-delay:90ms}.table .row:nth-child(5){animation-delay:.12s}.table .row:nth-child(6){animation-delay:.15s}.table .row:nth-child(7){animation-delay:.18s}.table .row:nth-child(8){animation-delay:.21s}.table .row:nth-child(9){animation-delay:.24s}@keyframes row-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}@media (width<=1280px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.shell{grid-template-columns:1fr}.sidebar{z-index:50;flex-direction:row;justify-content:space-between;align-items:center;gap:16px;height:auto;padding:14px 20px;position:sticky;top:0}.nav{flex-flow:wrap;gap:4px}.nav-label,.nav-item span{display:none}.nav-item{padding:8px 10px}.sidebar-foot,.brand-text span{display:none}.main{padding:24px 20px 40px}.topbar{flex-direction:column;align-items:flex-start;gap:16px}.topbar__right{width:100%}.stat-grid{grid-template-columns:1fr}.row{grid-template-columns:1fr;align-items:flex-start;gap:8px}.row--header{display:none}.toolbar{flex-direction:column}.login-shell{grid-template-columns:1fr}.login-panel--hero{display:none}}@media (width<=640px){.topbar h1{font-size:22px}.view-card{padding:18px}.login-form__wrap{padding:0 8px}}@media (prefers-reduced-motion:reduce){.skeleton:after,.login-orb,.stat-grid .stat-card,.table .row,.modal-card,.status-chip__dot{animation:none}*{transition-duration:.01ms!important}}
