@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Fraunces:ital,wght@0,700;0,900;1,700&display=swap');

:root {
  --bg:        #f8f7ff;
  --bg-2:      #ffffff;
  --bg-3:      #f0eeff;
  --border:    #e2dff5;
  --border-2:  #cdc8f0;
  --text:      #1a1730;
  --text-2:    #4a4568;
  --text-3:    #8b85a8;

  --pink:      #f72585;
  --purple:    #7209b7;
  --blue:      #3a86ff;
  --cyan:      #4cc9f0;
  --orange:    #fb5607;

  --grad-1:    linear-gradient(135deg, #f72585, #7209b7, #3a86ff);
  --grad-2:    linear-gradient(135deg, #f72585, #fb5607);
  --grad-3:    linear-gradient(135deg, #3a86ff, #4cc9f0);

  --shadow-sm: 0 2px 8px rgba(114,9,183,0.08);
  --shadow-md: 0 8px 24px rgba(114,9,183,0.12);
  --shadow-lg: 0 20px 60px rgba(114,9,183,0.18);

  --radius:    16px;
  --radius-sm: 10px;
  --radius-xs: 6px;

  --font-head: 'Fraunces', serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  min-height: 100vh;
}

.bg-dots {
  position: fixed; inset: 0;
  background-image: radial-gradient(circle, #7209b712 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none; z-index: 0;
}

.bg-blob {
  position: fixed; border-radius: 50%;
  filter: blur(70px); pointer-events: none; z-index: 0; opacity: 0.1;
}
.bg-blob-1 { width:550px; height:550px; background:var(--pink); top:-200px; right:-100px; animation: bf 10s ease-in-out infinite; }
.bg-blob-2 { width:450px; height:450px; background:var(--blue); bottom:-150px; left:-100px; animation: bf 12s ease-in-out infinite reverse; }
.bg-blob-3 { width:300px; height:300px; background:var(--purple); top:45%; left:25%; animation: bf 8s ease-in-out infinite 2s; }

@keyframes bf {
  0%,100% { transform: translate(0,0) scale(1); }
  50% { transform: translate(20px,-25px) scale(1.05); }
}

.container { max-width:1080px; margin:0 auto; padding:0 28px; position:relative; z-index:1; }

/* ── Nav ── */
nav {
  position:sticky; top:0; z-index:100;
  background:rgba(248,247,255,0.88);
  backdrop-filter:blur(20px);
  border-bottom:1.5px solid var(--border);
}
.nav-inner {
  max-width:1080px; margin:0 auto; padding:0 28px;
  height:64px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.nav-logo {
  font-family:var(--font-head); font-size:1.55rem; font-weight:900;
  text-decoration:none; letter-spacing:-0.02em;
  background:var(--grad-1); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link {
  color:var(--text-2); text-decoration:none;
  font-size:0.9rem; font-weight:600;
  padding:8px 14px; border-radius:var(--radius-xs); transition:all 0.2s;
}
.nav-link:hover { color:var(--text); background:var(--bg-3); }
.nav-link.active { color:var(--purple); }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 22px; border-radius:var(--radius-sm);
  font-family:var(--font-body); font-size:0.9rem; font-weight:700;
  cursor:pointer; border:none; text-decoration:none; transition:all 0.2s; white-space:nowrap;
}
.btn-primary {
  background:var(--grad-1); color:white;
  box-shadow:0 4px 16px rgba(247,37,133,0.35);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(247,37,133,0.45); }
.btn-secondary {
  background:var(--bg-2); color:var(--text);
  border:1.5px solid var(--border-2);
}
.btn-secondary:hover { border-color:var(--purple); color:var(--purple); background:var(--bg-3); }
.btn-ghost { background:transparent; color:var(--text-2); border:1.5px solid var(--border); }
.btn-ghost:hover { border-color:var(--text-3); color:var(--text); }
.btn-danger { background:#fff0f3; color:#e5183a; border:1.5px solid #ffc2cc; }
.btn-danger:hover { background:#ffe0e6; }
.btn-sm  { padding:7px 14px; font-size:0.82rem; border-radius:var(--radius-xs); }
.btn-lg  { padding:15px 36px; font-size:1rem; border-radius:var(--radius); }
.btn-xl  { padding:18px 44px; font-size:1.05rem; border-radius:var(--radius); }
.btn-full { width:100%; }

/* ── Cards ── */
.card {
  background:var(--bg-2); border:1.5px solid var(--border);
  border-radius:var(--radius); padding:28px;
  box-shadow:var(--shadow-sm); transition:all 0.25s;
}
.card:hover { box-shadow:var(--shadow-md); border-color:var(--border-2); }

/* ── Inputs ── */
.field { display:flex; flex-direction:column; gap:7px; }
.field-label { font-size:0.85rem; font-weight:700; color:var(--text-2); }
.input {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--radius-sm); color:var(--text);
  font-family:var(--font-body); font-size:0.95rem; font-weight:500;
  padding:12px 16px; width:100%; outline:none; transition:all 0.2s;
}
.input:focus { border-color:var(--purple); background:var(--bg-2); box-shadow:0 0 0 4px rgba(114,9,183,0.08); }
.input::placeholder { color:var(--text-3); font-weight:400; }

/* ── Gradient text ── */
.grad  { background:var(--grad-1); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.grad2 { background:var(--grad-2); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.grad3 { background:var(--grad-3); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── Badges ── */
.badge { display:inline-flex; align-items:center; gap:5px; padding:5px 12px; border-radius:100px; font-size:0.78rem; font-weight:700; }
.badge-purple { background:#f3eeff; color:var(--purple); border:1.5px solid #d8c4f7; }
.badge-pink   { background:#fff0f7; color:var(--pink);   border:1.5px solid #fbc4df; }
.badge-blue   { background:#eef4ff; color:var(--blue);   border:1.5px solid #c4d8ff; }
.badge-green  { background:#efffef; color:#16a34a;       border:1.5px solid #bbf7bb; }

/* ── Toast ── */
#toast-container { position:fixed; top:76px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:8px; }
.toast {
  background:var(--bg-2); border:1.5px solid var(--border);
  border-radius:var(--radius-sm); padding:13px 20px;
  font-size:0.9rem; font-weight:600; max-width:300px;
  box-shadow:var(--shadow-md); color:var(--text);
  animation:toastIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both;
}
.toast.success { border-color:#22c55e; background:#f0fdf4; color:#15803d; }
.toast.error   { border-color:#ef4444; background:#fef2f2; color:#dc2626; }
@keyframes toastIn { from { transform:translateX(110%) scale(0.9); opacity:0; } to { transform:translateX(0) scale(1); opacity:1; } }

/* ── Spinner ── */
.spinner { width:17px; height:17px; border:2.5px solid rgba(255,255,255,0.35); border-top-color:white; border-radius:50%; animation:spin 0.65s linear infinite; display:inline-block; flex-shrink:0; }
.spinner-dark { border-color:rgba(114,9,183,0.2); border-top-color:var(--purple); }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Empty ── */
.empty { text-align:center; padding:64px 24px; color:var(--text-3); }
.empty-icon { font-size:3.5rem; margin-bottom:16px; display:block; opacity:0.5; }
.empty h3 { font-family:var(--font-head); font-size:1.3rem; color:var(--text-2); margin-bottom:8px; }
.empty p  { font-size:0.9rem; max-width:280px; margin:0 auto; }

/* ── Animations ── */
@keyframes fadeUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
.fade-up { animation:fadeUp 0.5s ease both; }

/* ── Overlay ── */
.overlay {
  display:none; position:fixed; inset:0;
  background:rgba(26,23,48,0.5); backdrop-filter:blur(4px);
  z-index:200; align-items:center; justify-content:center;
}
.overlay.show { display:flex; }

@media (max-width:640px) { .container { padding:0 16px; } .nav-inner { padding:0 16px; } .hide-mobile { display:none !important; } }