:root{--brand: #EFB738;--brand-dark: #5C2626;--brand-light: #FBF1D9;--brand-blush: #E8A5A0;--bg: #FFFFFF;--bg-muted: #F9FAFB;--fg: #111111;--fg-muted: #6B7280;--fg-subtle: #9CA3AF;--fg-inverse: #FFFFFF;--border: #E5E7EB;--border-strong: #D1D5DB;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-400: #9CA3AF;--gray-500: #6B7280;--danger: #DC2626;--danger-bg: #FEE2E2;--warning: #F59E0B;--info: #2563EB;--info-bg: #DBEAFE;--s-xs: 4px;--s-sm: 8px;--s-md: 16px;--s-lg: 24px;--s-xl: 32px;--s-2xl: 48px;--s-3xl: 64px;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-full: 9999px;--font-xs: 12px;--font-sm: 14px;--font-base: 16px;--font-lg: 18px;--font-xl: 20px;--font-2xl: 24px;--font-3xl: 30px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -4px rgba(0,0,0,.1);--sidebar-w: 220px;--topbar-h: 64px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--fg);background:var(--bg-muted);-webkit-font-smoothing:antialiased}.admin-shell{display:flex;min-height:100vh}.admin-sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.admin-sidebar-logo{padding:20px var(--s-lg) 16px;font-size:var(--font-xl);font-weight:800;color:var(--brand-dark);letter-spacing:-.02em;border-bottom:1px solid var(--border);line-height:1.1}.admin-sidebar-logo-sub{font-size:9px;font-weight:700;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.15em;margin-top:4px}.admin-sidebar-nav{flex:1;padding:var(--s-sm) 0;overflow-y:auto}.admin-sidebar-section{padding:var(--s-sm) var(--s-lg) var(--s-xs);font-size:var(--font-xs);font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.05em}.admin-sidebar-item{display:flex;align-items:center;gap:var(--s-sm);padding:10px var(--s-lg);font-size:var(--font-sm);color:var(--fg-muted);text-decoration:none;border-right:3px solid transparent;transition:background .12s,color .12s;position:relative}.admin-sidebar-item:hover{background:var(--gray-50);color:var(--fg)}.admin-sidebar-item.active{background:var(--brand-light);color:var(--brand-dark);font-weight:600;border-right-color:var(--brand-dark)}.admin-sidebar-item-icon{font-size:16px;width:20px;text-align:center;color:var(--fg-muted)}.admin-sidebar-item.active .admin-sidebar-item-icon{color:var(--brand-dark)}.admin-sidebar-footer{border-top:1px solid var(--border);padding:var(--s-md);display:flex;align-items:center;gap:var(--s-sm)}.admin-sidebar-user{flex:1;min-width:0}.admin-sidebar-user-name{font-size:var(--font-sm);font-weight:500;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-sidebar-signout{background:none;border:none;padding:0;color:var(--fg-muted);font-size:var(--font-xs);cursor:pointer;text-decoration:underline}.admin-sidebar-signout:hover{color:var(--brand-dark)}.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}.admin-topbar{height:var(--topbar-h);background:var(--brand-light);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--s-xl);gap:var(--s-lg);position:sticky;top:0;z-index:10}.admin-topbar-hamburger{display:none;background:none;border:none;padding:var(--s-sm);cursor:pointer;font-size:20px;color:var(--brand-dark)}.admin-topbar-tabs{display:flex;gap:var(--s-lg);flex:1}.admin-topbar-tab{color:var(--brand-dark);opacity:.7;text-decoration:none;font-size:var(--font-sm);font-weight:500;padding:var(--s-sm) 0;border-bottom:2px solid transparent}.admin-topbar-tab:hover{opacity:1}.admin-topbar-tab.active{opacity:1;font-weight:600;border-bottom-color:var(--brand-dark)}.admin-topbar-search{display:flex;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:6px var(--s-sm) 6px 28px;width:240px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.35-4.35'/></svg>");background-repeat:no-repeat;background-position:10px center;background-size:14px 14px}.admin-topbar-search input{border:none;outline:none;background:transparent;font-size:var(--font-sm);flex:1;min-width:0}.admin-topbar-icon-btn{background:none;border:none;cursor:pointer;color:var(--brand-dark);padding:var(--s-xs);border-radius:var(--r-full);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.admin-topbar-icon-btn:hover{background:#5c26261a}.admin-content{padding:var(--s-xl);max-width:1400px;width:100%}.admin-breadcrumb{font-size:var(--font-sm);color:var(--fg-muted);margin-bottom:var(--s-sm)}.admin-breadcrumb a{color:var(--fg-muted);text-decoration:none}.admin-breadcrumb a:hover{color:var(--brand-dark)}.admin-breadcrumb-sep{margin:0 var(--s-xs);color:var(--gray-400)}.admin-breadcrumb-current{color:var(--fg);font-weight:500}.admin-title{font-size:28px;font-weight:800;color:var(--brand-dark);margin:0 0 6px;letter-spacing:-.01em;line-height:1.2}.admin-subtitle{font-size:var(--font-sm);color:var(--fg-muted);margin:0 0 var(--s-lg) 0;line-height:1.5}.admin-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s-md);margin-bottom:var(--s-lg);flex-wrap:wrap}.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-md);margin-bottom:var(--s-lg)}.admin-stat{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:0 1px 3px #0000000a;display:flex;flex-direction:column;gap:10px;transition:box-shadow .15s,transform .15s}.admin-stat:hover{box-shadow:0 4px 12px #5c262614;transform:translateY(-1px)}.admin-stat.accent{background:var(--brand-light);border-color:#f5dfa8}.admin-stat-label{font-size:11px;font-weight:700;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em}.admin-stat-row{display:flex;align-items:baseline;justify-content:space-between}.admin-stat-value{font-size:var(--font-3xl);font-weight:700;color:var(--brand-dark);line-height:1}.admin-stat-icon{width:36px;height:36px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;background:var(--brand-light);color:var(--brand-dark);font-size:18px}.admin-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 1px 3px #0000000a,0 1px 2px #00000008}.admin-card+.admin-card{margin-top:var(--s-md)}.admin-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--s-md) var(--s-lg);border-bottom:1px solid var(--border)}.admin-card-title{font-size:var(--font-lg);font-weight:700;color:var(--brand-dark);margin:0}.admin-card-body{padding:var(--s-lg)}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.admin-table thead th{text-align:left;padding:12px var(--s-md);font-size:11px;font-weight:700;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);background:var(--bg-muted);white-space:nowrap}.admin-table tbody tr{border-bottom:1px solid var(--border);transition:background .12s}.admin-table tbody tr:last-child{border-bottom:none}.admin-table tbody tr.clickable{cursor:pointer}.admin-table tbody tr.clickable:hover{background:var(--gray-50)}.admin-table td{padding:14px var(--s-md);color:var(--fg);vertical-align:middle}.admin-role-dot{display:inline-block;width:8px;height:8px;border-radius:var(--r-full);background:var(--brand-dark);margin-right:var(--s-sm);vertical-align:middle;box-shadow:0 0 0 3px var(--brand-light)}.admin-role-name{font-weight:600;color:var(--fg)}.admin-actions-cell{text-align:right;white-space:nowrap}.admin-icon-btn{background:none;border:none;cursor:pointer;color:var(--fg-muted);padding:var(--s-xs);border-radius:var(--r-sm)}.admin-icon-btn:hover{color:var(--brand-dark);background:var(--gray-100)}.admin-icon-btn.danger:hover{color:var(--danger);background:var(--danger-bg)}.admin-link-btn{background:none;border:none;cursor:pointer;font-size:var(--font-sm);padding:0;text-decoration:underline}.admin-link-btn.danger{color:var(--danger)}.admin-badge{display:inline-block;padding:2px var(--s-sm);font-size:var(--font-xs);font-weight:500;border-radius:var(--r-sm);background:var(--brand-light);color:var(--brand-dark);white-space:nowrap}.admin-badge.muted{background:var(--gray-100);color:var(--fg-muted)}.admin-badges{display:flex;flex-wrap:wrap;gap:var(--s-xs)}.admin-avatar{border-radius:var(--r-full);display:inline-flex;align-items:center;justify-content:center;background:var(--brand);color:var(--brand-dark);font-weight:600;flex-shrink:0}.admin-avatar.sm{width:32px;height:32px;font-size:var(--font-sm)}.admin-avatar.md{width:48px;height:48px;font-size:var(--font-lg)}.admin-avatar.lg{width:64px;height:64px;font-size:var(--font-2xl)}.admin-avatar.blush{background:var(--brand-blush);color:var(--brand-dark)}.admin-avatar.gray{background:var(--gray-100);color:var(--fg-muted)}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-xs);padding:10px 20px;font-size:var(--font-sm);font-weight:700;border-radius:var(--r-md);cursor:pointer;border:1px solid transparent;transition:opacity .12s,background .12s,transform 80ms,box-shadow .12s;white-space:nowrap;font-family:inherit}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn:active:not(:disabled){transform:translateY(1px)}.admin-btn.primary{background:var(--brand-dark);color:var(--fg-inverse);box-shadow:0 2px 4px #5c262640,0 1px 2px #5c262626}.admin-btn.primary:hover:not(:disabled){background:#6d2d2d;box-shadow:0 4px 8px #5c26264d,0 2px 4px #5c262633}.admin-btn.secondary{background:transparent;color:var(--brand-dark);border-color:transparent;font-weight:700}.admin-btn.secondary:hover:not(:disabled){background:var(--brand-light)}.admin-btn.danger{background:var(--danger);color:var(--fg-inverse);box-shadow:0 2px 4px #dc262640}.admin-btn.danger:hover:not(:disabled){background:#b91c1c}.admin-btn.accent{background:var(--brand);color:var(--brand-dark);box-shadow:0 2px 4px #efb7384d}.admin-btn.accent:hover:not(:disabled){background:#e0a828}.admin-field{margin-bottom:var(--s-md)}.admin-label{display:block;font-size:var(--font-sm);font-weight:600;color:var(--fg);margin-bottom:var(--s-xs)}.admin-label .req{color:var(--danger)}.admin-input,.admin-textarea,.admin-select{width:100%;padding:10px 12px;font-size:var(--font-sm);border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--fg);outline:none;font-family:inherit;transition:border-color .12s,box-shadow .12s}.admin-input:focus,.admin-textarea:focus,.admin-select:focus{border-color:var(--brand-dark);box-shadow:0 0 0 3px #5c26261a}.admin-input.error{border-color:var(--danger)}.admin-input.error:focus{box-shadow:0 0 0 3px #dc26261a}.admin-textarea{resize:vertical;min-height:80px}.admin-error-text{color:var(--danger);font-size:var(--font-xs);margin-top:var(--s-xs)}.admin-filter-bar{display:flex;gap:var(--s-md);margin-bottom:var(--s-md);flex-wrap:wrap;align-items:center}.admin-filter-bar .admin-input,.admin-filter-bar .admin-select{width:auto;min-width:200px;flex:0 1 auto}.admin-form-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:var(--s-md);align-items:start}@media (max-width: 900px){.admin-form-grid{grid-template-columns:1fr}}.admin-label-upper{font-size:11px;font-weight:700;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;display:block}.admin-card-helper{font-size:var(--font-xs);color:var(--fg-muted);font-style:italic;line-height:1.5;padding-top:var(--s-md);margin-top:var(--s-md);border-top:1px dashed var(--border)}.admin-section-actions{display:flex;align-items:center;gap:var(--s-sm);font-size:11px;font-weight:700;letter-spacing:.08em}.admin-section-actions a,.admin-section-actions button{color:var(--brand-dark);background:none;border:none;padding:0;cursor:pointer;text-decoration:none;font:inherit;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.admin-section-actions a:hover,.admin-section-actions button:hover{text-decoration:underline}.admin-section-actions-sep{color:var(--gray-300)}.admin-perm-group-toggle{font-size:10px!important;font-weight:700!important;letter-spacing:.08em;text-transform:uppercase}.admin-error-inline{display:flex;align-items:center;gap:6px;color:var(--danger);font-size:var(--font-xs);margin-top:var(--s-xs)}.admin-error-inline:before{content:"ⓘ";font-size:14px}.admin-perm-groups{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--s-md)}.admin-perm-group{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-md);transition:border-color .15s,box-shadow .15s}.admin-perm-group:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.admin-perm-group-header{display:flex;align-items:center;justify-content:space-between;gap:var(--s-sm);margin-bottom:var(--s-sm)}.admin-perm-group-title{display:flex;align-items:center;gap:8px;font-size:var(--font-sm);font-weight:700;color:var(--brand-dark)}.admin-perm-group-icon{font-size:16px;filter:none}.admin-perm-group-toggle{font-size:11px;font-weight:600;color:var(--brand-dark);background:none;border:none;padding:0;cursor:pointer;text-transform:uppercase;letter-spacing:.04em}.admin-perm-group-toggle:hover{text-decoration:underline}.admin-checkbox-list{display:flex;flex-direction:column}.admin-checkbox-row{display:flex;align-items:center;justify-content:space-between;gap:var(--s-sm);padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;font-size:var(--font-sm);color:var(--fg);transition:background .12s;-webkit-user-select:none;user-select:none}.admin-checkbox-row:hover{background:var(--gray-50)}.admin-checkbox-row.checked{background:var(--brand-light)}.admin-checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--brand-dark);cursor:pointer;margin:0;flex-shrink:0}.admin-checkbox-row-label{flex:1;min-width:0}.admin-banner{padding:12px var(--s-md);border-radius:var(--r-md);font-size:var(--font-sm);margin-bottom:var(--s-md);border-left:4px solid}.admin-banner.info{background:var(--info-bg);border-color:var(--info);color:var(--fg)}.admin-banner.danger{background:var(--danger-bg);border-color:var(--danger);color:var(--danger);font-size:var(--font-xs)}.admin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1300;padding:var(--s-md)}.admin-modal{background:var(--bg);border-radius:var(--r-xl);padding:var(--s-xl);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;width:100%;max-width:480px}.admin-modal.sm{max-width:420px}.admin-modal-title{font-size:var(--font-lg);font-weight:700;margin:0 0 var(--s-md) 0}.admin-modal-actions{display:flex;justify-content:flex-end;gap:var(--s-sm);margin-top:var(--s-xl)}.admin-meta-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-md);margin-top:var(--s-lg)}.admin-meta-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 20px;box-shadow:0 1px 3px #0000000a}.admin-meta-label{font-size:11px;font-weight:700;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.admin-meta-value{font-size:var(--font-base);font-weight:600;color:var(--fg)}.admin-meta-sub{font-size:var(--font-xs);color:var(--fg-muted);margin-top:2px}@media (max-width: 768px){.admin-meta-row{grid-template-columns:1fr}}.admin-user-header{display:flex;align-items:center;gap:var(--s-md)}.admin-user-header-info{flex:1;min-width:0}.admin-user-header-name{font-size:var(--font-xl);font-weight:700;color:var(--fg);margin:0}.admin-user-header-meta{font-size:var(--font-sm);color:var(--fg-muted)}.login-page{display:flex;min-height:100vh;flex-wrap:wrap}.login-hero{flex:1;min-width:0;background:var(--brand-light);position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--s-2xl);border-top:4px solid var(--brand)}.login-hero-logo{width:96px;height:96px;border-radius:var(--r-lg);background:var(--brand-dark);display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:48px;font-weight:800;margin-bottom:var(--s-lg);box-shadow:var(--shadow-md)}.login-hero-title{font-size:42px;font-weight:800;color:var(--brand-dark);letter-spacing:-.02em;margin:0 0 var(--s-sm) 0}.login-hero-sub{font-size:var(--font-base);color:var(--brand-dark);opacity:.8;text-align:center;max-width:420px;margin:0}.login-panel{flex:0 0 480px;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:var(--s-2xl)}.login-card{width:100%;max-width:380px}.login-card-logo{width:48px;height:48px;border-radius:var(--r-md);background:var(--brand-dark);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:var(--font-xl);font-weight:800;margin-bottom:var(--s-md)}.login-card-title{font-size:var(--font-2xl);font-weight:700;color:var(--fg);margin:0 0 var(--s-xs) 0}.login-card-sub{font-size:var(--font-sm);color:var(--fg-muted);margin:0 0 var(--s-lg) 0}.login-google-btn{width:100%;padding:12px var(--s-md);background:var(--brand-dark);color:var(--fg-inverse);border:none;border-radius:var(--r-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--s-sm);font-family:inherit}.login-google-btn:hover:not(:disabled){background:#6d2d2d}.login-google-btn:disabled{opacity:.7;cursor:not-allowed}.login-help{margin-top:var(--s-md);font-size:var(--font-xs);color:var(--fg-muted);text-align:center}.login-help a{color:var(--brand-dark);text-decoration:none}.login-help a:hover{text-decoration:underline}.login-alert{padding:var(--s-md);border-radius:var(--r-md);font-size:var(--font-sm);margin-bottom:var(--s-md);border-left:4px solid}.login-alert.danger{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}@media (max-width: 900px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-perm-groups{grid-template-columns:1fr}.admin-topbar-search{width:180px}}@media (max-width: 768px){:root{--sidebar-w: 0px}.admin-sidebar{position:fixed;left:0;top:0;width:260px;height:100vh;z-index:1200;transform:translate(-100%);transition:transform .2s ease;box-shadow:var(--shadow-lg)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1100}.admin-sidebar-backdrop.open{display:block}.admin-topbar-hamburger{display:flex}.admin-topbar{padding:0 var(--s-md);gap:var(--s-sm)}.admin-topbar-tabs{display:none}.admin-topbar-search{width:100%;max-width:240px}.admin-content{padding:var(--s-md)}.admin-stats{grid-template-columns:1fr 1fr;gap:var(--s-sm)}.admin-stat{padding:var(--s-sm) var(--s-md)}.admin-stat-value{font-size:var(--font-2xl)}.admin-title{font-size:var(--font-xl)}.admin-card-body{padding:var(--s-md)}.admin-modal{padding:var(--s-lg)}.login-page{flex-direction:column;min-height:auto}.login-hero{flex:0 0 auto;min-height:0;padding:var(--s-xl) var(--s-lg);border-top-width:3px}.login-hero-title{font-size:var(--font-2xl);margin-top:var(--s-sm)}.login-hero-sub{font-size:var(--font-sm)}.login-hero-logo{width:56px;height:56px;font-size:28px;margin-bottom:var(--s-sm)}.login-panel{flex:1 1 auto;padding:var(--s-lg);align-items:flex-start;padding-top:var(--s-xl)}.login-card{max-width:100%}.login-card-logo{display:none}.login-card-title{font-size:var(--font-xl)}.admin-filter-bar{flex-direction:column;align-items:stretch}.admin-filter-bar .admin-input,.admin-filter-bar .admin-select{width:100%}}@media (max-width: 480px){.admin-stats{grid-template-columns:1fr}.admin-title-row{flex-direction:column;align-items:stretch}.admin-title-row .admin-btn{width:100%}}
