@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,600;0,9..144,800;1,9..144,400&family=Sora:wght@300;400;500;600&display=swap');
:root{--cream:#faf6ee;--warm:#f0e6d3;--sage:#7fa87a;--sage-light:#a8cc9e;--sage-dark:#4e7548;--terracotta:#c97059;--terracotta-light:#e8967a;--butter:#f5c842;--lavender:#a98ed6;--rose:#e87a8a;--ink:#2a1f14;--ink-soft:#7a6a56;--card-bg:#fffcf6;--border:rgba(42,31,20,0.1);--shadow:0 8px 40px rgba(42,31,20,0.08);--radius:24px;--radius-sm:14px;--sidebar-w:260px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Sora',sans-serif;background:var(--cream);color:var(--ink);overflow-x:hidden}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:9000}
h1,h2,h3,h4{font-family:'Fraunces',serif;letter-spacing:-.5px}
h1{font-size:clamp(2.4rem,5vw,4.8rem);font-weight:800;line-height:1.06}
h2{font-size:clamp(1.8rem,3vw,3rem);font-weight:700;line-height:1.15}
h3{font-size:1.15rem;font-weight:600}em{font-style:italic;color:var(--terracotta)}a{text-decoration:none;color:inherit}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border:none;border-radius:100px;font-family:'Sora',sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s}
.btn:hover{transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-primary{background:var(--terracotta);color:white;box-shadow:0 4px 20px rgba(201,112,89,.3)}.btn-primary:hover{background:var(--terracotta-light);box-shadow:0 8px 28px rgba(201,112,89,.45)}
.btn-secondary{background:var(--warm);color:var(--ink);border:1px solid var(--border)}.btn-dark{background:var(--ink);color:white}.btn-dark:hover{background:#3d2e1c}
.btn-success{background:var(--sage);color:white}.btn-danger{background:#e05252;color:white}.btn-sm{padding:8px 18px;font-size:.8rem}.btn-xs{padding:5px 12px;font-size:.72rem}.btn-block{width:100%;justify-content:center}

/* FORM */
.form-group{margin-bottom:20px}.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}
.form-input{width:100%;padding:13px 18px;background:var(--warm);border:2px solid transparent;border-radius:var(--radius-sm);font-family:'Sora',sans-serif;font-size:.92rem;color:var(--ink);transition:border-color .2s,background .2s;outline:none}
.form-input:focus{border-color:var(--terracotta);background:white}.form-input::placeholder{color:var(--ink-soft);opacity:.6}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a6a56' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-color:var(--warm);padding-right:40px}
.form-error{color:#e05252;font-size:.78rem;margin-top:6px;display:block}

/* CARDS */
.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:transform .25s,box-shadow .25s}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-flat{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:24px}

/* BADGE */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:100px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.badge-green{background:#d4edda;color:#2d6a35}.badge-orange{background:#fde8d8;color:#c97059}.badge-blue{background:#dce8fb;color:#2d5fa3}.badge-gray{background:var(--warm);color:var(--ink-soft)}.badge-purple{background:#ede4f8;color:#6b3fa0}.badge-red{background:#fde8e8;color:#c0392b}

/* PROGRESS */
.progress-label{display:flex;justify-content:space-between;font-size:.78rem;color:var(--ink-soft);margin-bottom:7px}
.progress-bar{height:8px;background:var(--warm);border-radius:100px;overflow:hidden}
.progress-fill{height:100%;border-radius:100px;transition:width 1.2s cubic-bezier(.22,1,.36,1)}
.pf-tc{background:linear-gradient(90deg,var(--terracotta),var(--terracotta-light))}.pf-sage{background:linear-gradient(90deg,var(--sage-dark),var(--sage))}.pf-lav{background:linear-gradient(90deg,var(--lavender),#c8b4e8)}.pf-but{background:linear-gradient(90deg,#d4a017,var(--butter))}

/* SECTION LABEL */
.section-label{display:inline-block;padding:5px 16px;background:var(--warm);border-radius:100px;font-size:.76rem;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:14px}

/* TOAST */
#toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);padding:13px 28px;border-radius:100px;font-size:.85rem;font-weight:500;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;z-index:9999;white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.2)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}#toast.success{background:var(--sage-dark);color:white}#toast.error{background:#c0392b;color:white}#toast.info{background:var(--ink);color:white}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(42,31,20,.5);backdrop-filter:blur(6px);z-index:800;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}.modal{background:var(--card-bg);border-radius:var(--radius);padding:36px;width:100%;max-width:520px;position:relative;animation:modalIn .3s cubic-bezier(.34,1.56,.64,1);max-height:90vh;overflow-y:auto}
@keyframes modalIn{from{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-close{position:absolute;top:18px;right:18px;background:var(--warm);border:none;width:34px;height:34px;border-radius:50%;font-size:1rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--border)}

/* APP LAYOUT */
.app-layout{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--ink);color:white;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:200;overflow-y:auto;transition:transform .3s}
.sidebar-logo{padding:24px 22px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo a{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:700;color:white}.sidebar-logo span{color:var(--terracotta-light)}
.sidebar-user{padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:12px}
.su-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.su-name{font-weight:600;font-size:.86rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.su-level{font-size:.68rem;color:rgba(255,255,255,.45);margin-top:2px}
.sidebar-nav{flex:1;padding:12px 0}.nav-section-title{padding:10px 22px 5px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.28)}
.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:10px 22px;color:rgba(255,255,255,.62);font-size:.855rem;font-weight:500;transition:background .2s,color .2s;border-left:3px solid transparent;cursor:pointer}
.sidebar-nav a:hover{background:rgba(255,255,255,.07);color:white}.sidebar-nav a.active{background:rgba(201,112,89,.15);color:var(--terracotta-light);border-left-color:var(--terracotta-light)}
.nav-icon{font-size:1.05rem;width:22px;text-align:center}
.sidebar-bottom{padding:14px 22px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-bottom a{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.45);font-size:.8rem;padding:7px 0;cursor:pointer;transition:color .2s}.sidebar-bottom a:hover{color:white}
.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh}
.topbar{background:rgba(250,246,238,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:15px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.topbar-title{font-family:'Fraunces',serif;font-size:1.25rem;font-weight:700}.topbar-right{display:flex;align-items:center;gap:14px}
.topbar-xp{display:flex;align-items:center;gap:7px;background:var(--warm);padding:6px 14px;border-radius:100px;font-size:.8rem;font-weight:600}
.menu-toggle{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;padding:4px}
.page-content{padding:32px}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:28px}
.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px}
.sc-icon{font-size:1.7rem;margin-bottom:8px}.sc-val{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:700}.sc-label{font-size:.72rem;color:var(--ink-soft);margin-top:3px}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* TABLE */
.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:var(--warm)}
th{padding:12px 18px;text-align:left;font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
td{padding:13px 18px;border-top:1px solid var(--border);vertical-align:middle}tr:hover td{background:rgba(127,168,122,.04)}

/* SPINNER */
.spinner{width:40px;height:40px;border:3px solid var(--warm);border-top-color:var(--terracotta);border-radius:50%;animation:spin .8s linear infinite;margin:60px auto}
.spinner-sm{width:18px;height:18px;border-width:2px;margin:0;display:inline-block}

/* EMPTY */
.empty-state{text-align:center;padding:60px 20px}.empty-state .es-icon{font-size:3.5rem;margin-bottom:16px}.empty-state p{font-size:.88rem;color:var(--ink-soft);margin-top:8px}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes viz{from{height:4px}to{height:28px}}
/* LOADER BAR */
.loader-bar{display:none}

/* RESPONSIVE SIDEBAR */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);position:fixed}
  .sidebar.open{transform:translateX(0);box-shadow:8px 0 32px rgba(42,31,20,.2)}
  .main-content{margin-left:0}
  .menu-toggle{display:flex}
  .page-content{padding:20px 16px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
}

.fade-up{animation:fadeUp .5s ease both}
.stagger>*{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}.stagger.loaded>*:nth-child(1){opacity:1;transform:none;transition-delay:.05s}.stagger.loaded>*:nth-child(2){opacity:1;transform:none;transition-delay:.1s}.stagger.loaded>*:nth-child(3){opacity:1;transform:none;transition-delay:.15s}.stagger.loaded>*:nth-child(4){opacity:1;transform:none;transition-delay:.2s}.stagger.loaded>*:nth-child(n+5){opacity:1;transform:none;transition-delay:.25s}