@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Fraunces:ital,wght@0,300;0,700;0,900;1,300;1,600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f0ede8;
  --blob1:#f4d0b8;--blob2:#b8d4e8;--blob3:#d4c8f0;--blob4:#c8e8d0;
  --glass:rgba(255,255,255,.52);--glass-b:rgba(255,255,255,.78);
  --glass-shadow:0 8px 32px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.9);
  --ink:#18161f;--ink2:#45435a;--muted:rgba(24,22,31,.42);
  --accent:#5b4fcf;--accent2:#8b7ff0;--accent-glow:rgba(91,79,207,.22);
  --green:#16a34a;--green-bg:rgba(22,163,74,.1);--green-border:rgba(22,163,74,.2);
  --red:#dc2626;--red-bg:rgba(220,38,38,.08);--red-border:rgba(220,38,38,.18);
  --amber:#b45309;--amber-bg:rgba(180,83,9,.1);--amber-border:rgba(180,83,9,.2);
  --blue:#2563eb;--blue-bg:rgba(37,99,235,.1);--blue-border:rgba(37,99,235,.2);
  --nav-h:68px;--r:14px;--r2:22px;--r3:30px;
}
html{scroll-behavior:smooth}
body{background:#f7f6fb;color:var(--ink);font-family:'Inter',sans-serif;font-weight:400;overflow-x:hidden;min-height:100vh}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(91,79,207,.25);border-radius:3px}

/* ── BG — clean app-style, no moving blobs ── */
.bg-wrap{
  position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;
}
.bg-wrap::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 10% 5%, rgba(91,79,207,.07) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 90% 90%, rgba(139,127,240,.06) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 50% 50%, rgba(244,208,184,.05) 0%, transparent 60%);
}
/* keep stub classes for legacy html that still has blob divs */
.blob{display:none}
.b1,.b2,.b3,.b4{display:none}

/* ── ICON SYSTEM ── */
/* Color utilities */
.ic-purple{color:var(--accent)!important}
.ic-green{color:var(--green)!important}
.ic-red{color:var(--red)!important}
.ic-amber{color:var(--amber)!important}
.ic-blue{color:var(--blue)!important}
.ic-muted{color:var(--muted)!important}
.ic-white{color:#fff!important}
/* Chip = colored background circle/square with icon */
.chip{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}
.chip-sm{width:32px;height:32px;font-size:16px;border-radius:9px}
.chip-md{width:40px;height:40px;font-size:20px;border-radius:12px}
.chip-lg{width:52px;height:52px;font-size:26px;border-radius:16px}
.chip-purple{background:rgba(91,79,207,.12);color:var(--accent)}
.chip-green{background:var(--green-bg);color:var(--green)}
.chip-red{background:var(--red-bg);color:var(--red)}
.chip-amber{background:var(--amber-bg);color:var(--amber)}
.chip-blue{background:var(--blue-bg);color:var(--blue)}
.chip-ink{background:rgba(24,22,31,.08);color:var(--ink2)}

/* ── NAVBAR ── */
.navbar{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:400;width:calc(100% - 36px);max-width:1120px;border-radius:100px;padding:9px 10px 9px 22px;display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,255,255,.62);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border:1px solid rgba(255,255,255,.82);box-shadow:0 4px 20px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.95);transition:all .3s}
.nav-logo{font-family:'Fraunces',serif;font-size:19px;font-weight:700;color:var(--ink);text-decoration:none;letter-spacing:-.03em;flex-shrink:0}
.nav-logo span{color:var(--accent)}
.nav-center{display:flex;gap:2px;list-style:none}
.nav-center a{font-size:13px;color:var(--ink2);text-decoration:none;padding:7px 15px;border-radius:100px;transition:all .2s;font-weight:500;display:flex;align-items:center;gap:6px}
.nav-center a:hover{background:rgba(255,255,255,.7);color:var(--ink)}
.nav-center a.active{background:rgba(91,79,207,.1);color:var(--accent)}
.nav-center a i{font-size:15px}
.nav-right{display:flex;align-items:center;gap:8px}
.nav-avatar-wrap{position:relative}
.nav-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:#fff;cursor:pointer;transition:all .2s;flex-shrink:0;user-select:none}
.nav-avatar:hover{transform:scale(1.08);box-shadow:0 4px 12px var(--accent-glow)}
.nav-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:rgba(255,255,255,.92);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.9);border-radius:var(--r2);box-shadow:0 12px 40px rgba(0,0,0,.12);min-width:210px;padding:8px;opacity:0;pointer-events:none;transform:translateY(-8px) scale(.97);transition:all .2s cubic-bezier(.34,1.56,.64,1);z-index:500}
.nav-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}
.nav-dd-header{padding:10px 12px 8px;border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:6px}
.nav-dd-name{font-size:13px;font-weight:700;color:var(--ink)}
.nav-dd-email{font-size:11px;color:var(--muted);margin-top:2px}
.nav-dd-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);font-size:13px;color:var(--ink2);text-decoration:none;cursor:pointer;transition:all .15s;border:none;background:none;width:100%;text-align:left;font-family:'Inter',sans-serif}
.nav-dd-item i{font-size:17px;width:20px;text-align:center}
.nav-dd-item:hover{background:rgba(91,79,207,.08);color:var(--accent)}
.nav-dd-sep{height:1px;background:rgba(0,0,0,.06);margin:6px 0}
.nav-dd-item.danger:hover{background:var(--red-bg);color:var(--red)}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none}
.nav-burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}
.nav-mobile{display:none;position:fixed;inset:0;top:0;z-index:350;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);padding:80px 24px 24px;flex-direction:column;gap:8px}
.nav-mobile.open{display:flex}
.nav-mobile a{font-size:18px;font-weight:600;color:var(--ink);text-decoration:none;padding:14px 20px;border-radius:var(--r2);transition:all .2s;display:flex;align-items:center;gap:12px}
.nav-mobile a:hover{background:rgba(91,79,207,.08);color:var(--accent)}
.nav-mobile a i{font-size:22px}
.nav-mobile-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.06);border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink2)}

/* ── GLASS UTILS ── */
.glass{background:var(--glass);backdrop-filter:blur(22px) saturate(170%);-webkit-backdrop-filter:blur(22px) saturate(170%);border:1px solid var(--glass-b);box-shadow:var(--glass-shadow)}
.glass-card{background:rgba(255,255,255,.52);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.78);box-shadow:0 4px 20px rgba(0,0,0,.06),inset 0 1px 0 rgba(255,255,255,.9);border-radius:var(--r2)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 20px;border-radius:100px;font-size:13px;font-weight:600;font-family:'Inter',sans-serif;border:none;cursor:pointer;text-decoration:none;transition:all .25s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;line-height:1}
.btn i{font-size:16px}
.btn-primary{background:var(--ink);color:#fff;box-shadow:0 3px 10px rgba(24,22,31,.2)}
.btn-primary:hover{background:var(--accent);transform:scale(1.04);box-shadow:0 6px 18px var(--accent-glow)}
.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 14px var(--accent-glow)}
.btn-accent:hover{transform:scale(1.04) translateY(-1px);box-shadow:0 8px 22px var(--accent-glow)}
.btn-glass{background:rgba(255,255,255,.55);color:var(--ink);border:1px solid rgba(255,255,255,.82);backdrop-filter:blur(12px)}
.btn-glass:hover{background:rgba(255,255,255,.85);transform:scale(1.03)}
.btn-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.btn-green:hover{background:var(--green);color:#fff}
.btn-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}
.btn-blue:hover{background:var(--blue);color:#fff}
.btn-amber{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.btn-amber:hover{background:var(--amber);color:#fff}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-sm{padding:7px 16px;font-size:12px}
.btn-sm i{font-size:14px}
.btn-lg{padding:14px 36px;font-size:14px}
.btn-xs{padding:5px 12px;font-size:11px;border-radius:8px}

/* ── INPUTS ── */
.input-wrap{display:flex;flex-direction:column;gap:5px}
.input-label{font-size:11px;font-weight:700;color:var(--ink2);letter-spacing:.04em;text-transform:uppercase}
.input{width:100%;padding:11px 14px;background:rgba(255,255,255,.62);border:1px solid rgba(255,255,255,.82);border-radius:var(--r);font-size:14px;color:var(--ink);font-family:'Inter',sans-serif;backdrop-filter:blur(10px);transition:all .2s;outline:none}
.input:focus{background:rgba(255,255,255,.88);border-color:rgba(91,79,207,.4);box-shadow:0 0 0 3px rgba(91,79,207,.1)}
.input::placeholder{color:var(--muted)}
textarea.input{resize:vertical;min-height:90px}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;z-index:600;background:rgba(18,16,26,.45);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:rgba(255,255,255,.88);backdrop-filter:blur(36px);border:1px solid rgba(255,255,255,.92);border-radius:var(--r3);padding:36px;width:100%;max-width:480px;box-shadow:0 24px 72px rgba(0,0,0,.14);transform:scale(.95) translateY(12px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:relative}
.modal-overlay.open .modal{transform:scale(1) translateY(0)}
.modal-title{font-family:'Fraunces',serif;font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
.modal-close{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.06);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--ink2);transition:all .2s}
.modal-close:hover{background:rgba(0,0,0,.12)}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:700}
.badge i{font-size:12px}
.badge-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.badge-accent{background:rgba(91,79,207,.1);color:var(--accent);border:1px solid rgba(91,79,207,.2)}
.badge-amber{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.badge-red{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.badge-pulse::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:20px;right:20px;z-index:999;display:flex;flex-direction:column;gap:7px}
.toast{display:flex;align-items:center;gap:10px;padding:11px 16px;border-radius:14px;background:rgba(18,16,26,.92);color:#fff;backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.1);font-size:13px;font-weight:500;animation:tIn .4s cubic-bezier(.34,1.56,.64,1);min-width:220px;box-shadow:0 6px 20px rgba(0,0,0,.18)}
.toast .ti{font-size:18px;flex-shrink:0}
.toast.success .ti{color:#4ade80}
.toast.error .ti{color:#f87171}
.toast.info .ti{color:var(--accent2)}
@keyframes tIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* ── PAGE ── */
.page-wrap{position:relative;z-index:1;padding-top:calc(var(--nav-h) + 36px);min-height:100vh}
.container{max-width:1120px;margin:0 auto;padding:0 20px}

/* ── SPINNER ── */
.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:spin .7s linear infinite;flex-shrink:0}
.spinner-dark{border-color:rgba(91,79,207,.2);border-top-color:var(--accent)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:64px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}
.empty-icon{font-size:52px;color:var(--muted);opacity:.5}
.empty-icon i{font-size:52px}
.empty-title{font-family:'Fraunces',serif;font-size:20px;font-weight:700;letter-spacing:-.02em}
.empty-sub{font-size:13px;color:var(--muted);max-width:280px;line-height:1.6}

/* ── PROGRESS BAR ── */
.progress-bar{height:4px;background:rgba(0,0,0,.06);border-radius:10px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:10px;transition:width .4s ease}

/* ── TABS ── */
.tabs{display:flex;gap:2px;background:rgba(0,0,0,.05);border-radius:12px;padding:3px;width:fit-content}
.tab-btn{padding:8px 18px;border-radius:10px;border:none;background:transparent;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;display:flex;align-items:center;gap:7px}
.tab-btn i{font-size:16px}
.tab-btn.active{background:#fff;color:var(--ink);box-shadow:0 2px 6px rgba(0,0,0,.07)}

/* ── SECTION TITLE ── */
.section-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(91,79,207,.08);color:var(--accent);padding:5px 13px;border-radius:100px;font-size:11px;font-weight:700;border:1px solid rgba(91,79,207,.14);letter-spacing:.04em;text-transform:uppercase}
.page-title{font-family:'Fraunces',serif;font-size:clamp(24px,4vw,38px);font-weight:700;letter-spacing:-.03em;line-height:1.1}
.page-title em{font-style:italic;font-weight:300;color:var(--accent)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes popIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .navbar{width:calc(100% - 20px);padding:8px 10px 8px 18px}
  .nav-center{display:none}
  .nav-burger{display:flex}
  .container{padding:0 14px}
  .page-wrap{padding-top:calc(var(--nav-h) + 16px)}
}
