@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@400;500;600;700&family=Permanent+Marker&display=swap');

:root{
  --color-accent:#9B59B6;
  --color-lemon:#F5A623;
  --color-lavender:#E8D5F5;
  --color-cream:#FAF7FF;
  --color-dark:#1F1030;
  --color-mid:#C39BD3;
  --color-muted:#7D6B8A;
  --color-border:#DDD0EA;
  --white:#FFFFFF;

  --font-serif:'Source Serif 4',Georgia,serif;
  --font-sans:'DM Sans',system-ui,sans-serif;
  --font-hand:'Permanent Marker',cursive;

  --max-content:1080px;
  --max-prose:680px;
  --page-pad:24px;
  --gutter:24px;
  --section-gap:96px;

  --radius-sm:4px;
  --radius-button:6px;
  --radius-card:8px;
  --radius-pill:100px;
}
@media (min-width:768px){ :root{ --page-pad:48px; } }

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:68px;}
body{
  margin:0;
  background:var(--color-cream);
  color:var(--color-muted);
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:var(--color-accent);text-decoration:none;}

h1,h2,h3,h4{
  font-family:var(--font-serif);
  color:var(--color-dark);
  margin:0;
  line-height:1.12;
  letter-spacing:-0.01em;
  font-weight:700;
}
p{margin:0;}

/* ---------- layout ---------- */
.wrap{max-width:var(--max-content);margin:0 auto;padding-left:var(--page-pad);padding-right:var(--page-pad);}
.section{padding:var(--section-gap) 0;}

/* ---------- shared type helpers ---------- */
.eyebrow{
  font-family:var(--font-hand);
  color:var(--color-accent);
  font-size:18px;
  letter-spacing:0.01em;
  margin:0 0 14px;
}
.eyebrow.on-dark{color:var(--color-mid);}
.eyebrow.lemon{color:var(--color-lemon);}
.lead{font-size:18px;line-height:1.65;}
.display{font-size:clamp(40px,6.4vw,68px);line-height:1.04;letter-spacing:-0.02em;}
.tagline-i{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--color-accent);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-sans);font-size:13px;font-weight:700;
  letter-spacing:0.02em;
  border-radius:var(--radius-button);
  padding:13px 22px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap;
  text-transform:uppercase;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent);}
.btn-primary:hover{box-shadow:0 6px 20px rgba(155,89,182,.35);}
.btn-secondary{background:transparent;color:var(--color-accent);border-color:var(--color-accent);}
.btn-secondary:hover{background:var(--color-accent);color:#fff;}
.btn-lemon{background:var(--color-lemon);color:var(--color-dark);border-color:var(--color-lemon);}
.btn-lemon:hover{box-shadow:0 6px 20px rgba(245,166,35,.4);}
.btn-ghost{background:transparent;color:var(--color-dark);border-color:var(--color-border);}
.btn-ghost:hover{border-color:var(--color-dark);}
.btn-ghost.on-dark{color:var(--color-lavender);border-color:rgba(232,213,245,.32);}
.btn-ghost.on-dark:hover{border-color:var(--color-lavender);background:rgba(232,213,245,.08);}
.btn-dark{background:var(--color-dark);color:var(--color-lavender);border-color:var(--color-dark);}
.btn-dark:hover{box-shadow:0 6px 20px rgba(31,16,48,.3);}
.btn-sm{padding:9px 16px;font-size:12px;}

/* ---------- tags / labels ---------- */
.label{
  font-family:var(--font-sans);font-weight:700;font-size:11px;
  text-transform:uppercase;letter-spacing:0.12em;
}
.tag{
  display:inline-flex;align-items:center;
  font-family:var(--font-sans);font-weight:700;font-size:11px;
  text-transform:uppercase;letter-spacing:0.12em;
  padding:5px 12px;border-radius:var(--radius-pill);
}
.tag-cat{background:var(--color-lavender);color:var(--color-accent);border:1px solid var(--color-accent);}
.tag-lemon{background:var(--color-lemon);color:var(--color-dark);}
.tag-dark{background:var(--color-dark);color:var(--color-lavender);}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:var(--color-dark);
  border-bottom:1px solid rgba(232,213,245,.12);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
.logo{display:flex;align-items:center;gap:9px;font-family:var(--font-serif);font-weight:700;font-size:19px;color:#fff;white-space:nowrap;}
.logo .mark{color:var(--color-accent);font-size:20px;line-height:1;}
.logo:hover .mark{color:var(--color-lemon);}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0;}
.nav-links a{font-family:var(--font-sans);font-weight:600;font-size:14px;color:var(--color-mid);transition:color .15s ease;}
.nav-links a:hover{color:#fff;}
.nav-right{display:flex;align-items:center;gap:18px;}
.ig-link{display:inline-flex;align-items:center;gap:7px;color:var(--color-mid);font-family:var(--font-sans);font-weight:600;font-size:14px;transition:color .15s;}
.ig-link:hover{color:var(--color-lemon);}
.ig-link svg{width:17px;height:17px;}
.nav-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:6px;}
.nav-toggle svg{width:24px;height:24px;}

@media (max-width:880px){
  .nav-links,.nav-right .ig-link span,.nav-right .desktop-only{display:none;}
  .nav-toggle{display:inline-flex;}
  .nav-links.open{
    display:flex;flex-direction:column;align-items:flex-start;gap:18px;
    position:absolute;top:68px;left:0;right:0;
    background:var(--color-dark);padding:24px var(--page-pad) 32px;
    border-bottom:1px solid rgba(232,213,245,.12);
  }
  .nav-links.open a{font-size:18px;color:#fff;}
}

/* ---------- cards ---------- */
.card{
  background:var(--white);
  border:1.5px solid var(--color-border);
  border-radius:var(--radius-card);
  padding:24px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:scale(1.02);box-shadow:0 4px 16px rgba(0,0,0,.10);}

.post-card{display:flex;flex-direction:column;gap:14px;height:100%;}
.post-card .cat{font-family:var(--font-hand);color:var(--color-accent);font-size:15px;}
.post-card h3{font-size:21px;font-weight:700;}
.post-card .excerpt{color:var(--color-muted);font-size:15px;}
.post-card .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:8px;gap:12px;}
.post-card .byline{font-family:var(--font-hand);color:var(--color-mid);font-size:14px;}
.read-link{font-family:var(--font-sans);font-weight:700;font-size:13px;color:var(--color-accent);display:inline-flex;align-items:center;gap:5px;}
.read-link .arr{transition:transform .18s ease;}
.card:hover .read-link .arr{transform:translateX(3px);}

/* featured card */
.featured-card{
  position:relative;overflow:hidden;
  background:var(--color-dark);
  border:1.5px solid var(--color-dark);
  border-radius:var(--radius-card);
  padding:40px;
  color:var(--color-mid);
}
.featured-card .circle{
  position:absolute;border-radius:50%;
  border:1.5px solid var(--color-accent);opacity:.15;
  width:300px;height:300px;top:-120px;right:-90px;pointer-events:none;
}
.featured-card .circle.lemon{border-color:var(--color-lemon);width:180px;height:180px;top:60px;right:40px;opacity:.18;}
.featured-card h3{color:#fff;font-size:28px;font-weight:700;margin-bottom:8px;}
.featured-card .excerpt{color:var(--color-mid);font-size:16px;max-width:46ch;margin-bottom:24px;}
.featured-card .cat{font-family:var(--font-hand);color:var(--color-lemon);font-size:16px;margin-bottom:14px;display:block;}

/* ---------- pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);}
.pillar{background:var(--white);border:1.5px solid var(--color-border);border-radius:var(--radius-card);padding:28px;transition:transform .2s ease, box-shadow .2s ease;}
.pillar:hover{transform:scale(1.02);box-shadow:0 4px 16px rgba(0,0,0,.10);}
.pillar .pnum{font-family:var(--font-hand);color:var(--color-accent);font-size:22px;}
.pillar h3{font-size:22px;margin:10px 0 8px;}
.pillar p{font-size:15px;color:var(--color-muted);}
@media (max-width:740px){.pillars{grid-template-columns:1fr;}}

/* ---------- footer ---------- */
.footer{background:var(--color-dark);color:var(--color-mid);padding:64px 0 40px;}
.footer-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.footer .logo{margin-bottom:16px;}
.footer-tag{font-family:var(--font-serif);font-style:italic;color:var(--color-mid);font-size:17px;max-width:30ch;}
.footer-cols{display:flex;gap:64px;flex-wrap:wrap;}
.footer-col h4{font-family:var(--font-sans);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--color-mid);margin-bottom:14px;}
.footer-col a{display:block;color:var(--color-lavender);font-size:14px;font-weight:500;margin-bottom:10px;transition:color .15s;}
.footer-col a:hover{color:var(--color-lemon);}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(232,213,245,.14);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--color-muted);}
.footer-bottom .hand{font-family:var(--font-hand);color:var(--color-mid);}

/* ---------- reveal animation ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease, transform .6s ease;}
  .reveal.in{opacity:1;transform:none;}
}
