:root{
  /* Pastel palette */
  --bg0:#fbfbff;
  --bg1:#f6f7ff;
  --glass: rgba(255,255,255,.72);
  --border: rgba(20, 20, 40, .10);

  --text:#14162b;
  --muted: rgba(20, 22, 43, .70);
  --muted2: rgba(20, 22, 43, .55);

  --p1:#a78bfa;   /* pastel violet */
  --p2:#67e8f9;   /* pastel cyan */
  --p3:#86efac;   /* pastel green */
  --p4:#fbcfe8;   /* pastel pink */

  --shadow: 0 18px 50px rgba(12, 12, 30, .10);
  --shadow2: 0 10px 24px rgba(12, 12, 30, .10);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--text);
  line-height: 1.75;
  background:
    radial-gradient(900px 520px at 12% 10%, rgba(167,139,250,.35), transparent 55%),
    radial-gradient(820px 520px at 88% 12%, rgba(103,232,249,.35), transparent 52%),
    radial-gradient(860px 520px at 75% 88%, rgba(134,239,172,.25), transparent 55%),
    radial-gradient(760px 520px at 12% 92%, rgba(251,207,232,.25), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}

/* Layout */
main{
  max-width: 980px;
  margin: 44px auto;
  padding: 0 18px;
}

/* Links */
a{
  color: #2b2e66;
  text-decoration: none;
}
a:hover{opacity:.92}

/* Header */
header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(12px);
  background: var(--glass);
  border-bottom: 1px solid var(--border);
}

/* Topbar */
.topbar{
  max-width:980px;
  margin:0 auto;
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.brand{display:flex;align-items:center;gap:10px}
.brandmark{
  width:40px;height:40px;border-radius:14px;
  display:grid;place-items:center;
  font-weight:900;
  color:#1b1d3a;
  background: linear-gradient(135deg, rgba(167,139,250,.45), rgba(103,232,249,.45));
  border: 1px solid rgba(20,20,40,.10);
  box-shadow: 0 10px 22px rgba(12,12,30,.10);
}
.brandtext strong{display:block;line-height:1.05}
.brandtext small{display:block;color:var(--muted2);font-weight:700;margin-top:2px}

.navlinks{display:flex;gap:8px;align-items:center}

/* Menu pills */
.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(20,20,40,.12);
  background: rgba(255,255,255,.55);
  font-weight:800;
  color:rgba(20,22,43,.82);
  box-shadow: 0 6px 16px rgba(12,12,30,.06);
  transition: transform .08s ease, box-shadow .12s ease, background .12s ease;
}
.pill:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.80);
  box-shadow:0 10px 22px rgba(12,12,30,.10)
}

/* Header CTA */
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:14px;
  font-weight:900;
  color:#14162b;
  border:1px solid rgba(20,20,40,.12);
  background: linear-gradient(135deg, rgba(167,139,250,.35), rgba(134,239,172,.35));
  box-shadow: 0 12px 26px rgba(12,12,30,.10);
  transition: transform .08s ease, box-shadow .12s ease;
}
.cta:hover{transform:translateY(-1px);box-shadow:0 16px 34px rgba(12,12,30,.12)}

@media (max-width: 760px){
  .cta{display:none}
  .brandtext small{display:none}
}

/* Headings */
h1{
  font-size: clamp(30px, 4vw, 46px);
  letter-spacing: -0.8px;
  line-height: 1.12;
  margin: 0 0 14px;
}
h2{
  font-size: clamp(20px, 2.4vw, 28px);
  margin: 28px 0 10px;
  letter-spacing: -0.35px;
}
h3{
  font-size: 18px;
  margin: 18px 0 8px;
}

/* Cards */
.card{
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.62));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
  margin: 18px 0 26px;
}

.lead{
  font-size: 18px;
  color: var(--muted);
  margin-top: 10px;
}

/* Badge */
.badge{
  display:inline-flex;
  gap:10px;
  align-items:center;
  font-weight:900;
  font-size: 12px;
  letter-spacing: .45px;
  text-transform: uppercase;
  color: rgba(20, 22, 43, .70);
  margin-bottom: 10px;
}
.badge::before{
  content:"";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--p1), var(--p2));
  box-shadow: 0 0 0 5px rgba(167,139,250,.14);
}

/* Lists */
ul{
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--muted);
}
li{margin: 8px 0}

/* Buttons */
.heroActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

.btnPrimary{
  appearance:none;
  border:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 14px;
  border-radius:14px;
  font-weight:900;
  color:#14162b;
  border:1px solid rgba(20,20,40,.12);
  background: linear-gradient(135deg, rgba(167,139,250,.45), rgba(103,232,249,.45));
  box-shadow: 0 14px 30px rgba(12,12,30,.12);
  transition: transform .08s ease, box-shadow .12s ease;
}
.btnPrimary:hover{transform:translateY(-1px);box-shadow:0 18px 40px rgba(12,12,30,.14)}

.btnGhost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 14px;
  border-radius:14px;
  font-weight:900;
  color:rgba(20,22,43,.85);
  border:1px solid rgba(20,20,40,.12);
  background: rgba(255,255,255,.65);
  transition: transform .08s ease, background .12s ease, box-shadow .12s ease;
}
.btnGhost:hover{
  background:rgba(255,255,255,.90);
  transform:translateY(-1px);
  box-shadow:0 12px 26px rgba(12,12,30,.10)
}

/* Clickable link cards */
.linkgrid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}
@media (min-width: 820px){
  .linkgrid{grid-template-columns: 1fr 1fr;}
}

.btnlink{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(20, 20, 40, .12);
  background: rgba(255,255,255,.70);
  box-shadow: var(--shadow2);
  color: rgba(20, 22, 43, .90);
  font-weight: 850;
  transition: transform .08s ease, box-shadow .12s ease, background .12s ease;
}
.btnlink:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.90);
  box-shadow: 0 14px 30px rgba(12,12,30,.12);
}
.btnlink span{
  font-weight: 900;
  color: rgba(20, 22, 43, .65);
  border: 1px solid rgba(20, 20, 40, .12);
  background: rgba(255,255,255,.70);
  padding: 6px 10px;
  border-radius: 999px;
}

/* Homepage grid */
.grid2{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:860px){.grid2{grid-template-columns:1fr 1fr}}

.mini{display:grid;gap:10px;margin-top:12px}
.miniItem{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(20,20,40,.10);
  background:rgba(255,255,255,.60)
}
.miniItem span{color:var(--muted)}

/* Newsletter section */
.newsletter{
  border-radius: calc(var(--radius) + 6px);
  border: 1px solid rgba(20, 20, 40, .10);
  background:
    radial-gradient(520px 240px at 10% 0%, rgba(167,139,250,.30), transparent 55%),
    radial-gradient(520px 240px at 100% 20%, rgba(103,232,249,.30), transparent 55%),
    radial-gradient(520px 240px at 70% 110%, rgba(134,239,172,.22), transparent 55%),
    rgba(255,255,255,.72);
  box-shadow: var(--shadow);
  padding: 18px;
}
.newsletter strong{display:block;font-size:16px;margin-bottom:6px}
.newsletter p{color:var(--muted);margin:0}

/* Article typography */
main p{color: rgba(20, 22, 43, .86)}

/* Footer */
footer{
  max-width: 980px;
  margin: 44px auto 0;
  padding: 20px 18px 36px;
  border-top: 1px solid rgba(20, 20, 40, .10);
  color: var(--muted2);
  font-size: 14px;
}
footer a{
  display:inline-flex;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(20, 20, 40, .10);
  background: rgba(255,255,255,.55);
}
footer a:hover{background: rgba(255,255,255,.80)}

/* Cookie banner */
.cookieWrap{
  position:fixed;
  left:0;right:0;bottom:16px;
  z-index:9999;
  display:flex;
  justify-content:center;
  padding:0 16px;
}
.cookieCard{
  width:min(980px, 100%);
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:flex-start;
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(20,20,40,.10);
  background: rgba(255,255,255,.85);
  box-shadow: 0 18px 50px rgba(12,12,30,.12);
}
.cookieCard p{margin:6px 0 0;color:var(--muted);font-size:14px}
.cookieBtns{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* Newsletter modal */
.modalOverlay{
  position:fixed;
  inset:0;
  z-index:9998;
  display:grid;
  place-items:center;
  background: rgba(20, 22, 43, .18);
  backdrop-filter: blur(10px);
  padding: 16px;
}
.modalCard{
  width:min(560px, 100%);
  border-radius: 20px;
  border:1px solid rgba(20,20,40,.12);
  background: rgba(255,255,255,.90);
  box-shadow: 0 22px 60px rgba(12,12,30,.16);
  padding: 16px;
}
.modalTop{display:flex;justify-content:space-between;align-items:center}
.modalTop strong{font-size:18px}
.modalClose{
  width:38px;height:38px;
  border-radius:12px;
  border:1px solid rgba(20,20,40,.12);
  background: rgba(255,255,255,.70);
  cursor:pointer;
  font-size:22px;
  line-height:0;
}
.modalClose:hover{background: rgba(255,255,255,.92)}
.modalForm{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.modalForm input{
  flex:1;
  min-width:220px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(20,20,40,.12);
  background: rgba(255,255,255,.75);
  font-weight:700;
}
.modalFine{margin-top:10px;color:var(--muted2);font-size:13px}
