:root{--color-bg-primary: #F8F5F0;--color-bg-card: #FFFFFF;--color-bg-elevated: #F5F0E8;--color-bg-input: #F0EDE8;--color-bg-hover: #EDE8E0;--color-bg-overlay: rgba(44, 40, 37, .4);--color-bg-skeleton: #E8E4DD;--color-brand-primary: #C4917B;--color-brand-secondary: #B07D68;--color-brand-gradient: linear-gradient(135deg, #C4917B 0%, #D4A48F 100%);--color-brand-light: rgba(196, 145, 123, .12);--color-brand-glow: rgba(196, 145, 123, .2);--color-success: #6B9B7D;--color-success-bg: rgba(107, 155, 125, .1);--color-warning: #D4A04C;--color-warning-bg: rgba(212, 160, 76, .1);--color-danger: #C46B6B;--color-danger-bg: rgba(196, 107, 107, .08);--color-info: #7B9BC4;--color-info-bg: rgba(123, 155, 196, .1);--color-text-primary: #2C2825;--color-text-secondary: #8A8279;--color-text-muted: #B5ADA3;--color-text-inverse: #FFFFFF;--color-text-brand: #B07D68;--color-text-on-brand: #FFFFFF;--color-border: rgba(44, 40, 37, .08);--color-border-strong: rgba(44, 40, 37, .15);--color-border-active: rgba(196, 145, 123, .4);--font-heading: "Source Serif 4", "Noto Serif", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--leading-xs: 1rem;--leading-sm: 1.25rem;--leading-base: 1.5rem;--leading-md: 1.5rem;--leading-lg: 1.75rem;--leading-xl: 1.75rem;--leading-2xl: 2.25rem;--leading-3xl: 2.75rem;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(44, 40, 37, .04);--shadow-sm: 0 1px 3px rgba(44, 40, 37, .06), 0 1px 2px rgba(44, 40, 37, .04);--shadow-md: 0 4px 12px rgba(44, 40, 37, .08);--shadow-lg: 0 8px 28px rgba(44, 40, 37, .1);--shadow-xl: 0 16px 48px rgba(44, 40, 37, .12);--shadow-glow: 0 0 16px var(--color-brand-glow);--shadow-inner: inset 0 2px 4px rgba(44, 40, 37, .06);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .35s;--z-base: 0;--z-sticky: 50;--z-dropdown: 100;--z-overlay: 150;--z-modal: 200;--z-toast: 300;--sidebar-width: 260px;--header-height: 56px}[data-theme=dark]{--color-bg-primary: #1E1B18;--color-bg-card: #2A2622;--color-bg-elevated: #332E29;--color-bg-input: #3A3530;--color-bg-hover: #433D37;--color-bg-overlay: rgba(0, 0, 0, .5);--color-bg-skeleton: #3A3530;--color-brand-primary: #D4A48F;--color-brand-secondary: #E0B8A5;--color-brand-gradient: linear-gradient(135deg, #D4A48F 0%, #E0B8A5 100%);--color-brand-light: rgba(212, 164, 143, .15);--color-brand-glow: rgba(212, 164, 143, .25);--color-success: #82B896;--color-success-bg: rgba(130, 184, 150, .12);--color-warning: #E0B36A;--color-warning-bg: rgba(224, 179, 106, .12);--color-danger: #D88888;--color-danger-bg: rgba(216, 136, 136, .1);--color-info: #94B3D4;--color-info-bg: rgba(148, 179, 212, .12);--color-text-primary: #F0EDE8;--color-text-secondary: #A89E94;--color-text-muted: #7A7068;--color-text-inverse: #1E1B18;--color-text-brand: #D4A48F;--color-text-on-brand: #1E1B18;--color-border: rgba(240, 237, 232, .08);--color-border-strong: rgba(240, 237, 232, .15);--color-border-active: rgba(212, 164, 143, .4);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2), 0 1px 2px rgba(0, 0, 0, .15);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .3);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .35);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--weight-normal);line-height:var(--leading-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100dvh;overflow-x:hidden;transition:background-color var(--duration-slow) var(--ease-out),color var(--duration-slow) var(--ease-out)}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:var(--color-text-brand);text-decoration:none;transition:color var(--duration-fast)}a:hover{color:var(--color-brand-primary)}img{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--weight-semibold);color:var(--color-text-primary);letter-spacing:-.01em}h1{font-size:var(--text-3xl);line-height:var(--leading-3xl)}h2{font-size:var(--text-2xl);line-height:var(--leading-2xl)}h3{font-size:var(--text-xl);line-height:var(--leading-xl)}h4{font-size:var(--text-lg);line-height:var(--leading-lg)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-brand{color:var(--color-text-brand)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}p{color:var(--color-text-secondary);line-height:var(--leading-base)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-body);font-weight:var(--weight-semibold);line-height:1;border:1.5px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);-webkit-user-select:none;user-select:none;white-space:nowrap;text-decoration:none}.btn--sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);min-height:32px;border-radius:var(--radius-sm)}.btn--md{padding:var(--space-3) var(--space-5);font-size:var(--text-base);min-height:40px}.btn--lg{padding:var(--space-4) var(--space-6);font-size:var(--text-md);min-height:48px;border-radius:var(--radius-lg)}.btn--full{width:100%}.btn--primary{background:var(--color-brand-primary);color:var(--color-text-on-brand)}.btn--primary:hover:not(:disabled){background:var(--color-brand-secondary);box-shadow:var(--shadow-md)}.btn--secondary{background:transparent;color:var(--color-text-primary);border-color:var(--color-border-strong)}.btn--secondary:hover:not(:disabled){background:var(--color-brand-light);border-color:var(--color-border-active)}.btn--ghost{background:transparent;color:var(--color-text-brand)}.btn--ghost:hover:not(:disabled){background:var(--color-brand-light)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){opacity:.9;box-shadow:var(--shadow-md)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-md);color:var(--color-text-primary);background:var(--color-bg-input);border:1.5px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);min-height:40px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus{border-color:var(--color-brand-primary);box-shadow:0 0 0 3px var(--color-brand-glow)}.input::placeholder{color:var(--color-text-muted)}.input:disabled{opacity:.5;cursor:not-allowed}.input--error{border-color:var(--color-danger)}.form-group{margin-bottom:var(--space-5)}.label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary)}.input-error{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-danger)}.select{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text-primary);background:var(--color-bg-input);border:1.5px solid var(--color-border);border-radius:var(--radius-md);outline:none;cursor:pointer;min-height:36px;-webkit-appearance:none;-moz-appearance:none;appearance:none;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='%238A8279' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.select:focus{border-color:var(--color-brand-primary);box-shadow:0 0 0 3px var(--color-brand-glow)}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.card--elevated{box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;padding:2px var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--radius-full);letter-spacing:.02em;white-space:nowrap;line-height:var(--leading-xs)}.badge--primary{background:var(--color-brand-light);color:var(--color-brand-secondary)}.badge--success{background:var(--color-success-bg);color:var(--color-success)}.badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge--info{background:var(--color-info-bg);color:var(--color-info)}.badge--muted{background:#b5ada31f;color:var(--color-text-muted)}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:var(--leading-sm)}.alert--error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(196,107,107,.15)}.alert--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid rgba(107,155,125,.15)}.auth-page{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-5);min-height:100dvh}.auth-card{width:100%;max-width:420px;background:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-lg);animation:fadeInUp .5s var(--ease-out)}.auth-card h1{text-align:center;margin-bottom:var(--space-2)}.auth-card>p{text-align:center;margin-bottom:var(--space-6)}.admin-layout{display:flex;min-height:100dvh}.admin-sidebar{width:var(--sidebar-width);background:var(--color-bg-card);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:var(--z-sticky);transition:transform var(--duration-normal) var(--ease-out)}.admin-sidebar__header{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--color-border)}.admin-sidebar__logo{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:-.02em}.admin-sidebar__logo span{color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--weight-normal);font-family:var(--font-body);margin-left:var(--space-2)}.admin-sidebar__nav{flex:1;padding:var(--space-3);overflow-y:auto}.admin-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-base);font-weight:var(--weight-medium);text-decoration:none;transition:all var(--duration-fast) var(--ease-out);cursor:pointer;border:none;background:none;width:100%;text-align:left}.admin-nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.admin-nav-item.active{background:var(--color-brand-light);color:var(--color-brand-primary);font-weight:var(--weight-semibold)}.admin-nav-item__icon{width:20px;height:20px;flex-shrink:0;opacity:.7}.admin-nav-item.active .admin-nav-item__icon{opacity:1}.admin-sidebar__footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border)}.admin-sidebar__user{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.admin-sidebar__user-info{flex:1;min-width:0}.admin-sidebar__user-name{font-weight:var(--weight-medium);font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-sidebar__user-role{font-size:var(--text-xs);color:var(--color-text-muted)}.admin-content{flex:1;margin-left:var(--sidebar-width);min-height:100dvh}.admin-page{padding:var(--space-8);max-width:1200px;animation:fadeIn .3s var(--ease-out)}.admin-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4)}.admin-page__header h1{font-size:var(--text-2xl);margin:0}.admin-page__toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}.admin-page__search{flex:1;min-width:200px;max-width:360px;position:relative}.admin-page__search .input{padding-left:var(--space-10);min-height:38px;font-size:var(--text-sm)}.admin-page__search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.data-table-wrapper{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:var(--weight-semibold);font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border-strong);white-space:nowrap;background:var(--color-bg-elevated)}.data-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-bg-hover)}.data-table__cell--name{font-weight:var(--weight-medium)}.data-table__cell--mono{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary)}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card__label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-card__value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);line-height:1}.stat-card--brand .stat-card__value{color:var(--color-brand-primary)}.stat-card--success .stat-card__value{color:var(--color-success)}.stat-card--info .stat-card__value{color:var(--color-info)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-top:1px solid var(--color-border)}.pagination__info{font-size:var(--text-sm);color:var(--color-text-muted)}.pagination__controls{display:flex;align-items:center;gap:var(--space-2)}.pagination__btn{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast);min-height:32px}.pagination__btn:hover:not(:disabled){background:var(--color-brand-light);border-color:var(--color-border-active);color:var(--color-brand-primary)}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .15s var(--ease-out)}.dialog{width:100%;max-width:480px;background:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-xl);animation:fadeInUp .25s var(--ease-out)}.dialog__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.dialog__header h2{font-size:var(--text-xl);margin:0}.dialog__close{width:32px;height:32px;border-radius:var(--radius-full);background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);font-size:var(--text-lg);display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast)}.dialog__close:hover{background:var(--color-bg-hover)}.dialog__actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:var(--weight-bold);color:var(--color-text-inverse);background:var(--color-brand-primary);flex-shrink:0;overflow:hidden}.avatar--sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar--md{width:40px;height:40px;font-size:var(--text-sm)}.spinner{width:36px;height:36px;border:3px solid var(--color-border-strong);border-top-color:var(--color-brand-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.loading-center{display:flex;align-items:center;justify-content:center;padding:var(--space-16)}.empty-state{text-align:center;padding:var(--space-12) var(--space-8);color:var(--color-text-muted)}.empty-state__icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.4}.empty-state__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-2)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}
