.confirm-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:#fff;border-radius:16px;padding:32px;max-width:420px;width:90%;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease-out;text-align:center}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal__icon{font-size:56px;margin-bottom:16px;height:80px;display:flex;align-items:center;justify-content:center}.confirm-modal__icon--danger{color:#f44336}.confirm-modal__icon--warning{color:#ff9800}.confirm-modal__icon--info{color:#2196f3}.confirm-modal__title{font-size:24px;font-weight:800;color:#212121;margin:0 0 12px}.confirm-modal__message{font-size:16px;color:#616161;line-height:1.6;margin:0 0 28px}.confirm-modal__actions{display:flex;gap:12px;justify-content:center}.confirm-modal__button{padding:12px 28px;border-radius:8px;font-size:15px;font-weight:700;border:none;cursor:pointer;transition:all .2s;min-width:120px}.confirm-modal__button--cancel{background:#e0e0e0;color:#424242}.confirm-modal__button--cancel:hover{background:#d0d0d0;transform:translateY(-1px)}.confirm-modal__button--confirm{background:#f44336;color:#fff}.confirm-modal__button--confirm:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 4px 12px #f443364d}@media(max-width:480px){.confirm-modal{padding:24px;width:85%}.confirm-modal__title{font-size:20px}.confirm-modal__message{font-size:14px}.confirm-modal__actions{flex-direction:column}.confirm-modal__button{width:100%}}.notif-bell{position:relative}.notif-bell__btn{position:relative;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:none;background:#ffffff14;color:#ffffffbf;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}.notif-bell__btn:hover,.notif-bell__btn.active{background:#ffffff2e;color:#fff}.notif-bell__count{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;border:2px solid #1a0a2e}.notif-panel{width:320px;background:#fff;border-radius:14px;box-shadow:0 8px 32px #00000038;z-index:2000;overflow:hidden;display:flex;flex-direction:column;max-height:480px}.notif-panel__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;font-size:.875rem;font-weight:700;color:#1a0a2e;border-bottom:1px solid #f0f0f0;flex-shrink:0}.notif-panel__close{background:none;border:none;cursor:pointer;color:#9ca3af;display:flex;align-items:center;padding:2px;border-radius:4px}.notif-panel__close:hover{color:#374151;background:#f3f4f6}.notif-panel__body{overflow-y:auto;flex:1;padding:8px 0}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:36px 20px;color:#d1d5db}.notif-empty p{font-size:.85rem;color:#9ca3af;margin:0}.notif-section{border-bottom:1px solid #f3f4f6;padding-bottom:4px;margin-bottom:2px}.notif-section:last-child{border-bottom:none}.notif-section__header{display:flex;align-items:center;gap:6px;padding:8px 14px 6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;-webkit-user-select:none;user-select:none}.notif-section__header:hover{opacity:.8}.notif-section__icon{display:flex;align-items:center}.notif-section__title{flex:1}.notif-section__badge{color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notif-section__items{display:flex;flex-direction:column}.notif-item{display:flex;flex-direction:column;gap:1px;padding:6px 14px 6px 32px;cursor:pointer;transition:background .1s}.notif-item:hover{background:#f9fafb}.notif-item__main{font-size:.8rem;color:#1a0a2e;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item__meta{font-size:.72rem;color:#9ca3af}.notif-more{font-size:.75rem;color:#6d28d9;padding:4px 14px 8px 32px;margin:0;cursor:pointer;font-weight:600}.notif-more:hover{text-decoration:underline}.admin-sidebar{width:260px;min-height:100vh;background:var(--primary);color:var(--text-white);padding:20px 14px;position:fixed;left:0;top:0;overflow-y:auto;box-shadow:2px 0 16px #0000001f;transition:transform var(--transition-slow);z-index:1000;display:flex;flex-direction:column}.admin-sidebar::-webkit-scrollbar{width:4px}.admin-sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:10px}.admin-sidebar-overlay{display:none;position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999}@media(max-width:768px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-overlay{display:block}}.admin-sidebar__header{padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:20px}.admin-sidebar__logo-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:8px 0}.admin-sidebar__logo{display:flex;justify-content:center;align-items:center;flex:1}.admin-sidebar__logo img{width:84px;max-height:84px;height:auto;object-fit:contain}.admin-sidebar__user{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);background:#ffffff0f}.admin-sidebar__avatar{width:38px;height:38px;min-width:38px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;letter-spacing:.02em}.admin-sidebar__username{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.admin-sidebar__role{font-size:11px;opacity:.6;text-transform:uppercase;letter-spacing:.04em;font-weight:500}.admin-sidebar__nav{display:flex;flex-direction:column;gap:2px;flex:1}.admin-sidebar__link{display:flex;align-items:center;gap:12px;padding:10px 14px;color:#ffffffb3;text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);font-size:13.5px;font-weight:500;background:transparent;border:none;width:100%;text-align:left;cursor:pointer;line-height:1.4}.admin-sidebar__link:hover{background:#ffffff14;color:#fffffff2}.admin-sidebar__link.active{background:#ffffff1f;color:#fff;font-weight:600}.admin-sidebar__link svg{flex-shrink:0;opacity:.75}.admin-sidebar__link.active svg,.admin-sidebar__link:hover svg{opacity:1}.admin-sidebar__logout{border-top:1px solid rgba(255,255,255,.08);padding-top:8px;margin-top:16px}.admin-sidebar__logout:hover{background:#ef444426;color:#fca5a5}.admin-sidebar__group{display:flex;flex-direction:column}.admin-sidebar__group-toggle{justify-content:flex-start;position:relative}.admin-sidebar__chevron{margin-left:auto;opacity:.5;transition:transform .25s ease;flex-shrink:0}.admin-sidebar__chevron.open{transform:rotate(90deg)}.admin-sidebar__submenu{display:flex;flex-direction:column;gap:1px;padding-left:16px;margin-top:2px;margin-left:22px;border-left:1.5px solid rgba(255,255,255,.1);animation:submenuSlide .2s ease}@keyframes submenuSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.admin-sidebar__sublink{display:flex;align-items:center;padding:8px 12px;color:#ffffff8c;text-decoration:none;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:13px;font-weight:400}.admin-sidebar__sublink:hover{background:#ffffff0f;color:#ffffffe6}.admin-sidebar__sublink.active{background:#ffffff1a;color:#fff;font-weight:600}.admin-layout{display:flex;min-height:100vh;background:var(--bg-body);width:100%;color:var(--text-primary)}.admin-layout__content{flex:1;margin-left:260px;padding:0;min-height:100vh;background:var(--bg-body);width:calc(100% - 260px)}.admin-layout__hamburger{display:none;position:fixed;top:14px;left:14px;z-index:1001;background:var(--primary);border:none;border-radius:var(--radius-md);width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer;box-shadow:var(--shadow-md);transition:background var(--transition-fast)}.admin-layout__hamburger span{display:block;width:22px;height:2.5px;background:#fff;border-radius:2px;transition:all var(--transition-base)}.admin-layout__hamburger:hover{background:var(--primary-light)}@media(max-width:768px){.admin-layout__hamburger{display:flex}.admin-layout__content{margin-left:0;padding:60px 0 0;width:100%}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);padding:20px}.error-boundary__content{background:#fff;border-radius:16px;padding:48px;max-width:500px;width:100%;text-align:center;box-shadow:0 10px 40px #0000001a}.error-boundary__icon{font-size:64px;margin-bottom:24px}.error-boundary__title{color:#300444;font-size:28px;font-weight:700;margin:0 0 16px}.error-boundary__message{color:#666;font-size:16px;line-height:1.6;margin:0 0 24px}.error-boundary__details{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:8px;padding:16px;font-size:13px;color:#c00;text-align:left;overflow-x:auto;margin-bottom:24px;white-space:pre-wrap;word-break:break-word}.error-boundary__actions{display:flex;gap:12px;justify-content:center}.error-boundary__btn{padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.error-boundary__btn--primary{background:#300444;color:#fff}.error-boundary__btn--primary:hover{background:#4a0660;transform:translateY(-2px)}.error-boundary__btn--secondary{background:transparent;color:#666;border:2px solid #e0e0e0}.error-boundary__btn--secondary:hover{background:#f5f5f5;border-color:#ccc}@media(max-width:480px){.error-boundary__content{padding:32px 24px}.error-boundary__icon{font-size:48px}.error-boundary__title{font-size:24px}.error-boundary__actions{flex-direction:column}.error-boundary__btn{width:100%}}:root{font-family:Inter,system-ui,-apple-system,sans-serif;--primary: #300444;--primary-light: #4a0660;--primary-lighter: #6a1b9a;--primary-subtle: #f3e8ff;--primary-ring: rgba(48, 4, 68, .12);--bg-body: #f8f9fb;--bg-card: #ffffff;--bg-hover: #f4f5f7;--bg-subtle: #f1f3f5;--border: #e5e7eb;--border-light: #f0f0f0;--text-primary: #111827;--text-secondary: #4b5563;--text-muted: #9ca3af;--text-white: #ffffff;--success: #10b981;--success-bg: #ecfdf5;--success-border: #a7f3d0;--warning: #f59e0b;--warning-bg: #fffbeb;--warning-border: #fde68a;--danger: #ef4444;--danger-bg: #fef2f2;--danger-border: #fecaca;--info: #3b82f6;--info-bg: #eff6ff;--info-border: #bfdbfe;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-pill: 100px;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg: 0 10px 25px -3px rgba(0,0,0,.08), 0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl: 0 20px 40px -4px rgba(0,0,0,.1);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{margin:0;background:var(--bg-body);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}.admin-page{padding:28px 32px}.admin-page__header{margin-bottom:28px}.admin-page__title{font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.admin-page__subtitle{font-size:14px;color:var(--text-muted);margin-top:4px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card__header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.card__body{padding:24px}.btn{border:none;background:var(--bg-subtle);color:var(--text-primary);padding:9px 16px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:500;font-size:13.5px;display:inline-flex;align-items:center;gap:6px;line-height:1.4}.btn:hover{background:var(--border)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary{background:var(--primary);color:var(--text-white)}.btn--primary:hover{background:var(--primary-light);box-shadow:0 2px 8px var(--primary-ring)}.btn--danger{background:var(--danger);color:var(--text-white)}.btn--danger:hover{background:#dc2626}.btn--ghost{background:transparent;border:1.5px solid var(--border)}.btn--ghost:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-subtle)}.btn--sm{padding:6px 12px;font-size:12.5px;border-radius:var(--radius-sm)}.btn--icon{padding:8px;border-radius:var(--radius-md)}.input{width:100%;padding:9px 14px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-primary);outline:none;font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:inherit}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:100px}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form__row{display:grid;gap:6px;margin-bottom:18px}.form__row label{font-weight:600;font-size:13px;color:var(--text-secondary);letter-spacing:.01em}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:collapse;font-size:13.5px}.table thead th{background:var(--bg-subtle);color:var(--text-secondary);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.table tbody td{padding:14px 16px;border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-hover)}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;line-height:1.4}.badge--success{background:var(--success-bg);color:#065f46}.badge--warning{background:var(--warning-bg);color:#92400e}.badge--danger{background:var(--danger-bg);color:#991b1b}.badge--info{background:var(--info-bg);color:#1e40af}.badge--purple{background:var(--primary-subtle);color:var(--primary)}.badge--neutral{background:var(--bg-subtle);color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.tabs{display:flex;gap:4px;border-bottom:2px solid var(--border-light);margin-bottom:24px}.tab{padding:10px 18px;font-size:13.5px;font-weight:500;color:var(--text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast)}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.filter-bar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:20px}.filter-bar .input,.filter-bar .select{max-width:280px}.search-box{position:relative;flex:1;min-width:200px;max-width:400px}.search-box__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-box .input{padding-left:38px}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modal-in .2s ease-out}.modal__header{padding:24px 24px 0;display:flex;align-items:center;justify-content:space-between}.modal__title{font-size:18px;font-weight:700;color:var(--text-primary)}.modal__close{width:32px;height:32px;border-radius:var(--radius-md);border:none;background:var(--bg-subtle);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.modal__close:hover{background:var(--border);color:var(--text-primary)}.modal__body{padding:20px 24px 24px}.modal__actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 24px}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:13.5px;display:flex;align-items:center;gap:10px;margin-bottom:16px}.alert--error{background:var(--danger-bg);color:#991b1b;border:1px solid var(--danger-border)}.alert--success{background:var(--success-bg);color:#065f46;border:1px solid var(--success-border)}.alert--warning{background:var(--warning-bg);color:#92400e;border:1px solid var(--warning-border)}.alert--info{background:var(--info-bg);color:#1e40af;border:1px solid var(--info-border)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state__icon{font-size:48px;margin-bottom:12px;opacity:.4}.empty-state__text{font-size:15px;font-weight:500}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px}.pagination__btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;transition:all var(--transition-fast)}.pagination__btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-subtle)}.pagination__btn.active{background:var(--primary);border-color:var(--primary);color:var(--text-white)}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;color:var(--text-muted);font-size:14px}.error-message{background:var(--danger-bg);color:#991b1b;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--danger-border);margin:16px 0;font-size:14px}.success-message{background:var(--success-bg);color:#065f46;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--success-border);margin:16px 0;font-size:14px}.muted{color:var(--text-muted)}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:SF Mono,Cascadia Code,monospace}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.gap-2{gap:16px}.gap-3{gap:24px}@media(max-width:768px){.admin-page{padding:16px}.admin-page__title{font-size:22px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .input,.filter-bar .select,.search-box{max-width:100%}.modal{max-width:100%;margin:12px}}
