:root{font-family:Inter,system-ui,sans-serif;line-height:1.5;color:#0f172a;background-color:#f3f4f6}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#f3f4f6}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid #0ea5e9;outline-offset:2px}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#f8fafc;padding:24px 16px;display:flex;flex-direction:column;gap:16px}.sidebar__brand{font-size:28px;font-weight:700}.sidebar__link{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;color:#cbd5f5;margin-bottom:4px}.sidebar__link--active{background:#22d3ee;color:#0e101a;font-weight:600}.layout__main{display:flex;flex-direction:column}.layout__header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 32px 8px}.layout__title{margin:0;font-size:24px;font-weight:600}.layout__subtitle{font-size:14px;color:#475569}.token-box{display:flex;flex-direction:column;gap:4px;width:320px}.token-box__label{display:inline-flex;align-items:center;gap:6px}.token-box__input{display:flex;gap:8px}.token-box input{flex:1;padding:8px 10px;border-radius:6px;border:1px solid #cbd5f5}.token-box button{border:none;background:#e11d48;color:#fff;padding:8px 12px;border-radius:6px;cursor:pointer}.layout__content{flex:1;padding:0 32px 48px}.button,button{border:none;background:#2563eb;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:500}button:disabled{opacity:.6;cursor:not-allowed}button.danger{background:#dc2626}.table-wrapper{width:100%;overflow-x:auto;margin-top:16px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px;border-bottom:1px solid #e2e8f0;text-align:left}.table__actions{display:flex;gap:8px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.dashboard-skeleton{display:grid;gap:16px}.kpi-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 10px 20px #0f172a14}.kpi-card__title{margin:0;color:#475569}.kpi-card__value{margin:8px 0 0;font-size:32px;font-weight:700}.card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 10px 20px #0f172a14;margin-bottom:24px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}.section-header input[type=search]{padding:10px 12px;border-radius:10px;border:1px solid #cbd5f5;min-width:240px}.events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.event-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 10px 20px #0f172a14;display:flex;flex-direction:column;gap:12px}.event-card__actions{display:flex;gap:8px;flex-wrap:wrap}.pagination{display:flex;gap:12px;align-items:center;justify-content:flex-end;margin-top:16px}.badge{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge--success{background:#10b98133;color:#047857}.badge--danger{background:#f8717133;color:#b91c1c}.badge--warning{background:#fbbf2433;color:#92400e}.badge--info{background:#3b82f633;color:#1d4ed8}.badge--neutral{background:#94a3b833;color:#475569}.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000}.modal__backdrop{position:absolute;inset:0;background:#0f172a99}.modal__panel{position:relative;background:#fff;border-radius:16px;width:90%;max-width:960px;max-height:90vh;overflow-y:auto;padding:16px 24px}.modal__panel--sm{max-width:420px}.modal__panel--md{max-width:720px}.modal__panel--lg{max-width:960px}.modal__header{display:flex;justify-content:space-between;align-items:center}.modal__content{margin-top:12px}.category-manager__header{display:flex;justify-content:space-between;align-items:center;gap:12px}.category-manager__header input{max-width:240px;padding:8px 10px;border-radius:6px;border:1px solid #cbd5f5}.category-form{margin-top:16px;background:#f8fafc;border-radius:12px;padding:16px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.form-grid label{display:flex;flex-direction:column;font-size:14px;color:#475569}.form-grid input,.form-grid select,.form-grid textarea{margin-top:6px;padding:8px 10px;border-radius:8px;border:1px solid #cbd5f5}.form-grid--full{grid-column:1 / -1}.form-actions{margin-top:12px;display:flex;gap:8px}.error-text{color:#dc2626;font-size:14px}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.result-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 8px 16px #0f172a14}.result-card select,.result-card input{width:100%;margin-top:6px}.result-card__row{margin-top:12px;border-top:1px solid #e2e8f0;padding-top:12px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.chart-wrapper{width:100%;height:300px}.chart-header{display:flex;justify-content:space-between;align-items:center}.chart-header select{padding:6px 8px;border-radius:8px;border:1px solid #cbd5f5}.message-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.message-list li{display:flex;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.error-state{background:#fff;border-radius:16px;padding:32px;text-align:center;box-shadow:0 8px 24px #0f172a14;margin-top:24px}.page-loading{background:#fff;border-radius:16px;padding:24px;box-shadow:inset 0 0 0 1px #0f172a0d}.skeleton{background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:200% 100%;animation:pulse 1.2s infinite}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:999}.loading-overlay__backdrop{position:absolute;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-overlay__content{position:relative;background:#0f172a;color:#e2e8f0;padding:24px 32px;border-radius:16px;display:flex;align-items:center;gap:16px;box-shadow:0 16px 48px #00000040}.loading-overlay__spinner{width:28px;height:28px;border-radius:50%;border:3px solid rgba(255,255,255,.2);border-top-color:#38bdf8;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;right:24px;bottom:24px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{min-width:240px;background:#0f172a;color:#f8fafc;padding:12px 16px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;gap:12px;box-shadow:0 16px 32px #0f172a59}.toast button{background:transparent;color:inherit;border:none;font-size:18px;padding:0}.toast--success{background:#0f172a;border-left:4px solid #22c55e}.toast--error{background:#450a0a;border-left:4px solid #f87171}.toast--info{border-left:4px solid #38bdf8}.fade-in{animation:fadeIn .6s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.switch{position:relative;display:inline-block;width:46px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.2s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%}input:checked+.slider{background-color:#22c55e}input:checked+.slider:before{transform:translate(22px)}.sidebar{transition:transform .3s ease}.sidebar__toggle{display:none}.sidebar__link{transition:background .2s ease,transform .2s ease}.sidebar__link:hover{background:#ffffff1f;transform:translate(4px)}.sidebar__link--active{background:linear-gradient(90deg,#0ea5e9,#38bdf8);color:#0f172a;box-shadow:0 4px 12px #0ea5e959}@media(max-width:900px){.layout{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;max-width:260px;transform:translate(-100%);z-index:998}.sidebar--visible{transform:translate(0)}.sidebar__toggle{display:flex;align-items:center;gap:8px;background:#0f172a;color:#f8fafc;border:none;padding:10px 12px;border-radius:999px;align-self:flex-end}.layout__header{flex-direction:column;gap:12px;position:sticky;top:0;background:#f5f7fb;z-index:2;padding-top:16px}.token-box{width:100%}.layout__content{padding:0 16px 32px}.chart-grid{grid-template-columns:1fr}.table{font-size:13px}}
