:root {
  --paper: #fdfaf4;
  --paper-dark: #f5efe1;
  --ink: #1a1209;
  --ink-soft: #3d3020;
  --ink-muted: #8a7a60;
  --pop: #e84f3d;
  --pop-light: #ffd6d0;
  --pop-pale: #fff0ee;
  --butter: #f5c842;
  --butter-pale: #fef9e1;
  --mint: #3bb89a;
  --mint-pale: #d6f5ef;
  --lilac: #b39ddb;
  --lilac-pale: #ede7f6;
  --border: rgba(26,18,9,0.1);
}
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--paper);
  color:var(--ink);
  font-family:'Karla', sans-serif;
  font-weight:300;
  line-height:1.65;
  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='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9999;
}
@keyframes fadeUp   { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }
@keyframes bounce   { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes spin     { to{transform:rotate(360deg)} }
@keyframes stamp    { 0%{transform:scale(1.4) rotate(-8deg);opacity:0} 60%{transform:scale(0.95) rotate(2deg);opacity:1} 100%{transform:scale(1) rotate(-3deg);opacity:1} }
@keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes drift    { 0%,100%{transform:translateY(0) rotate(0deg)} 33%{transform:translateY(-6px) rotate(2deg)} 66%{transform:translateY(4px) rotate(-1deg)} }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .65s ease, transform .65s ease; }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-d1 { transition-delay:.1s; }
.reveal-d2 { transition-delay:.2s; }
.reveal-d3 { transition-delay:.3s; }

/* NAV */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 40px;
  background:rgba(253,250,244,0.92);
  backdrop-filter:blur(10px);
  border-bottom:2px dashed var(--border);
}
.nav-logo {
  font-family:'Caveat', cursive;
  font-size:1.5rem; font-weight:700;
  color:var(--ink); text-decoration:none;
  transition:color .2s;
}
.nav-logo:hover { color:var(--pop); }
.nav-logo span { color:var(--pop); }
.nav-links { display:flex; gap:8px; list-style:none; }
.nav-links a {
  font-family:'Caveat', cursive;
  font-size:1.05rem; font-weight:600;
  color:var(--ink-soft); text-decoration:none;
  padding:6px 16px; border-radius:100px;
  border:1.5px solid transparent;
  transition:all .2s;
}
.nav-links a:hover { color:var(--pop); border-color:var(--pop); background:var(--pop-pale); }

/* HERO */
.hero {
  min-height:100vh;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:140px 40px 80px;
  text-align:center;
  position:relative; overflow:hidden;
}
.doodle {
  position:absolute; pointer-events:none; user-select:none;
  animation:drift 5s ease-in-out infinite;
  font-size:2rem;
}
.d1{top:12%;left:6%;font-size:2.5rem;animation-delay:0s}
.d2{top:18%;right:8%;font-size:1.8rem;animation-delay:1.2s}
.d3{top:55%;left:3%;font-size:3rem;animation-delay:2s}
.d4{top:65%;right:5%;font-size:2.2rem;animation-delay:.7s}
.d5{top:80%;left:14%;font-size:1.6rem;animation-delay:3s}
.d6{top:30%;right:14%;font-size:2rem;animation-delay:1.8s}
.d7{bottom:10%;right:12%;font-size:2.8rem;animation-delay:.4s}
.d8{top:8%;left:30%;font-size:1.4rem;animation-delay:2.5s}

.hero-stamp {
  display:inline-block;
  background:var(--butter);
  border:3px solid var(--ink);
  border-radius:4px;
  padding:6px 18px;
  font-family:'Caveat', cursive;
  font-size:1rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  margin-bottom:28px;
  transform:rotate(-2deg);
  box-shadow:3px 3px 0 var(--ink);
  animation:stamp .5s ease .4s both;
}
.hero-title {
  font-family:'Fraunces', serif;
  font-weight:700;
  font-size:clamp(3.2rem, 7vw, 7.5rem);
  line-height:1.0;
  color:var(--ink);
  margin-bottom:24px;
  animation:fadeUp .8s ease .2s both;
  max-width:900px;
}
.hero-title .squig { color:var(--pop); font-style:italic; }
.hero-title .underline-hand { position:relative; display:inline-block; }
.hero-title .underline-hand::after {
  content:'';
  position:absolute; left:0; bottom:-6px;
  width:100%; height:8px;
  background:var(--butter);
  z-index:-1; border-radius:2px;
  transform:rotate(-1deg);
}
.hero-sub {
  font-family:'Fraunces', serif;
  font-style:italic; font-weight:300;
  font-size:1.25rem; color:var(--ink-soft);
  max-width:560px; margin:0 auto 48px;
  line-height:1.7;
  animation:fadeUp .8s ease .4s both;
}
.hero-ctas {
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
  animation:fadeUp .8s ease .6s both;
}
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 28px; border-radius:6px;
  font-family:'Caveat', cursive; font-size:1.15rem; font-weight:700;
  text-decoration:none;
  border:2.5px solid var(--ink);
  transition:transform .15s, box-shadow .15s;
  box-shadow:4px 4px 0 var(--ink);
  cursor:pointer;
}
.btn:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.btn:active{ transform:translate(2px,2px);  box-shadow:2px 2px 0 var(--ink); }
.btn-pop   { background:var(--pop); color:#fff; }
.btn-ghost { background:transparent; color:var(--ink); }

/* TICKER */
.ticker {
  background:var(--ink); color:var(--paper);
  padding:12px 0; overflow:hidden;
  border-top:2px solid var(--ink); border-bottom:2px solid var(--ink);
}
.ticker-track {
  display:flex; width:max-content;
  animation:marquee 24s linear infinite;
}
.ticker-item {
  font-family:'Caveat', cursive; font-size:1.1rem; font-weight:600;
  white-space:nowrap; padding:0 36px;
  display:flex; align-items:center; gap:20px;
}
.ticker-item span { color:var(--butter); }

/* SECTIONS */
.section { padding:90px 40px; max-width:1160px; margin:0 auto; }
.section-kicker {
  font-family:'Caveat', cursive; font-size:1.1rem; font-weight:700;
  color:var(--pop); display:flex; align-items:center; gap:10px;
  margin-bottom:12px;
}
.kicker-star { font-size:1rem; animation:spin 4s linear infinite; display:inline-block; }
.section-heading {
  font-family:'Fraunces', serif; font-weight:700;
  font-size:clamp(2rem,4vw,3.2rem); line-height:1.15;
  color:var(--ink); margin-bottom:12px;
}
.section-heading em { font-style:italic; color:var(--pop); }
.section-dek {
  font-family:'Fraunces', serif; font-style:italic; font-weight:300;
  color:var(--ink-muted); font-size:1.05rem;
  margin-bottom:52px; max-width:520px; line-height:1.8;
}

/* POSTS GRID */
.posts-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; }
.post-card {
  background:#fff;
  border:2.5px solid var(--ink); border-radius:12px; overflow:hidden;
  text-decoration:none; color:inherit; display:block;
  transition:transform .2s, box-shadow .2s;
  box-shadow:5px 5px 0 var(--ink);
}
.post-card:hover { transform:translate(-3px,-3px); box-shadow:8px 8px 0 var(--ink); }
.post-card:active{ transform:translate(2px,2px);  box-shadow:3px 3px 0 var(--ink); }
.post-card.big { grid-column:span 2; }
.card-thumb {
  width:100%; aspect-ratio:16/9;
  display:flex; align-items:center; justify-content:center;
  font-size:4rem;
}
.post-card.big .card-thumb { aspect-ratio:2/1; font-size:5.5rem; }
.bg-stripe-red    { background:repeating-linear-gradient(45deg,#fff0ee,#fff0ee 10px,#ffe3df 10px,#ffe3df 20px); }
.bg-stripe-yellow { background:repeating-linear-gradient(-45deg,#fef9e1,#fef9e1 10px,#fdf0b5 10px,#fdf0b5 20px); }
.bg-dot-mint      { background:radial-gradient(circle,var(--mint) 1.5px,transparent 1.5px) 0 0/20px 20px,var(--mint-pale); }
.bg-dot-lilac     { background:radial-gradient(circle,var(--lilac) 1.5px,transparent 1.5px) 0 0/20px 20px,var(--lilac-pale); }
.bg-check-butter  { background:repeating-conic-gradient(#fdf0b5 0% 25%,#fef9e1 0% 50%) 0 0/24px 24px; }
.card-img { width:100%; height:100%; object-fit:cover; display:block; }
.card-emoji { filter:drop-shadow(2px 4px 8px rgba(0,0,0,.15)); animation:bounce 3s ease-in-out infinite; }
.card-body { padding:20px 22px; }
.card-cat {
  font-family:'Caveat', cursive; font-size:.9rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; color:var(--pop); margin-bottom:8px;
}
.card-title {
  font-family:'Fraunces', serif; font-weight:700;
  font-size:1.05rem; line-height:1.3; color:var(--ink); margin-bottom:8px;
}
.post-card.big .card-title { font-size:1.4rem; }
.card-blurb {
  font-family:'Fraunces', serif; font-style:italic; font-weight:300;
  font-size:.88rem; color:var(--ink-muted); line-height:1.7; margin-bottom:14px;
}
.card-footer {
  display:flex; align-items:center; justify-content:space-between;
  font-size:.75rem; color:var(--ink-muted);
}
.card-read-more { font-family:'Caveat', cursive; font-size:.9rem; font-weight:700; color:var(--pop); }

/* ABOUT */
.about-section {
  background:var(--ink); padding:90px 0;
  position:relative; overflow:hidden;
}
.about-pattern {
  position:absolute; inset:0;
  background:radial-gradient(circle at 1px 1px,rgba(245,200,66,.12) 1px,transparent 0) 0 0/40px 40px;
  pointer-events:none;
}
.about-inner {
  max-width:1160px; margin:0 auto; padding:0 40px;
  display:grid; grid-template-columns:1fr 1.2fr; gap:80px; align-items:start;
}
.about-left .section-kicker { color:var(--butter); }
.about-left .section-heading { color:var(--paper); }
.about-left .section-heading em { color:var(--butter); }
.about-body {
  font-family:'Fraunces', serif; font-style:italic; font-weight:300;
  font-size:1.05rem; color:rgba(253,250,244,.7); line-height:1.9; margin-bottom:32px;
}
.timeline { display:flex; flex-direction:column; }
.tl-item { display:flex; gap:20px; position:relative; }
.tl-item:not(:last-child)::before {
  content:''; position:absolute;
  left:19px; top:44px; bottom:-4px; width:2px;
  background:repeating-linear-gradient(to bottom,rgba(245,200,66,.4) 0,rgba(245,200,66,.4) 6px,transparent 6px,transparent 12px);
}
.tl-dot {
  width:40px; height:40px; border-radius:50%;
  background:var(--butter); border:2.5px solid var(--ink);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; flex-shrink:0;
  box-shadow:3px 3px 0 rgba(245,200,66,.3); margin-top:4px;
}
.tl-text { padding:4px 0 28px; }
.tl-role { font-family:'Caveat', cursive; font-size:1.05rem; font-weight:700; color:var(--paper); margin-bottom:2px; }
.tl-note { font-size:.82rem; color:rgba(253,250,244,.45); line-height:1.5; }
.fun-facts { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fact-card {
  background:rgba(253,250,244,.05);
  border:1.5px solid rgba(253,250,244,.1); border-radius:12px;
  padding:22px 18px; transition:background .2s, border-color .2s; cursor:default;
}
.fact-card:hover { background:rgba(253,250,244,.09); border-color:rgba(245,200,66,.3); }
.fact-emoji { font-size:1.8rem; margin-bottom:10px; display:block; }
.fact-value {
  font-family:'Fraunces', serif; font-weight:700;
  font-size:2rem; color:var(--butter); line-height:1; margin-bottom:4px;
}
.fact-label {
  font-size:.75rem; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(253,250,244,.4); line-height:1.4;
}
.fact-card.wide {
  grid-column:span 2;
  background:rgba(232,79,61,.1); border-color:rgba(232,79,61,.25);
  display:flex; align-items:center; gap:20px;
}
.fact-card.wide .fact-value { font-size:1.2rem; color:var(--pop); line-height:1.5; }
.about-quote {
  color:var(--butter);
  font-size:1.15rem;
  border-left:3px solid var(--butter);
  padding-left:20px;
  margin-top:12px;
}
.about-photo {
  width:100%; border-radius:12px;
  border:2.5px solid rgba(253,250,244,.15);
  box-shadow:8px 8px 0 rgba(245,200,66,.2);
}

/* RECIPES */
.recipes-section {
  background:var(--butter-pale);
  border-top:2.5px solid var(--ink); border-bottom:2.5px solid var(--ink);
  padding:90px 0;
}
.recipes-inner { max-width:1160px; margin:0 auto; padding:0 40px; }
.recipe-row {
  display:flex; gap:16px;
  overflow-x:auto; padding-bottom:12px;
  scrollbar-width:thin; scrollbar-color:var(--ink) var(--butter-pale);
  cursor:grab;
}
.recipe-row:active { cursor:grabbing; }
.recipe-card {
  flex-shrink:0; width:240px;
  background:#fff; border:2.5px solid var(--ink); border-radius:12px; overflow:hidden;
  box-shadow:4px 4px 0 var(--ink);
  transition:transform .2s, box-shadow .2s;
  text-decoration:none; color:inherit; display:block;
}
.recipe-card:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.recipe-thumb {
  width:100%; height:160px;
  display:flex; align-items:center; justify-content:center;
  font-size:3.2rem; border-bottom:2px solid var(--ink);
}
.recipe-body { padding:16px; }
.recipe-cat {
  font-family:'Caveat', cursive; font-size:.85rem; font-weight:700;
  color:var(--mint); text-transform:uppercase; letter-spacing:.06em; margin-bottom:6px;
}
.recipe-name {
  font-family:'Fraunces', serif; font-weight:700;
  font-size:.95rem; line-height:1.3; color:var(--ink); margin-bottom:10px;
}
.recipe-meta { display:flex; gap:12px; font-size:.72rem; color:var(--ink-muted); }

/* SNIPPETS */
.snippets-section { padding:90px 0; overflow:hidden; }
.snippets-inner { max-width:1160px; margin:0 auto; padding:0 40px; }
.snippets-masonry { columns:3; column-gap:20px; }
.snippet-card {
  break-inside:avoid; margin-bottom:20px;
  border:2.5px solid var(--ink); border-radius:12px;
  padding:28px 24px; box-shadow:4px 4px 0 var(--ink);
  position:relative; overflow:hidden;
  transition:transform .2s, box-shadow .2s; cursor:default;
}
.snippet-card:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.snippet-card.c-red    { background:var(--pop-pale); }
.snippet-card.c-yellow { background:var(--butter-pale); }
.snippet-card.c-mint   { background:var(--mint-pale); }
.snippet-card.c-lilac  { background:var(--lilac-pale); }
.snippet-card.c-white  { background:#fff; }
.snippet-emoji { font-size:2.2rem; margin-bottom:12px; display:block; }
.snippet-text {
  font-family:'Fraunces', serif; font-style:italic; font-weight:300;
  font-size:1.05rem; color:var(--ink); line-height:1.7; margin-bottom:14px;
}
.snippet-from { font-family:'Caveat', cursive; font-size:.88rem; font-weight:700; color:var(--ink-muted); }
.snippet-tape {
  position:absolute; top:-2px; left:50%; transform:translateX(-50%) rotate(1deg);
  width:60px; height:22px; background:rgba(245,200,66,.55); border-radius:2px;
}

/* NEWSLETTER */
.newsletter {
  background:var(--pop);
  border-top:2.5px solid var(--ink); border-bottom:2.5px solid var(--ink);
  padding:80px 40px; text-align:center; position:relative; overflow:hidden;
}
.nl-deco { position:absolute; font-size:8rem; opacity:.08; top:50%; transform:translateY(-50%); pointer-events:none; }
.nl-deco-l { left:40px; }
.nl-deco-r { right:40px; }
.nl-title { font-family:'Fraunces', serif; font-weight:700; font-size:clamp(2rem,4vw,3rem); color:#fff; margin-bottom:10px; position:relative; }
.nl-title em { font-style:italic; }
.nl-sub { font-family:'Fraunces', serif; font-style:italic; font-weight:300; color:rgba(255,255,255,.75); font-size:1.05rem; margin-bottom:36px; position:relative; }
.nl-form { display:flex; justify-content:center; gap:10px; max-width:460px; margin:0 auto; position:relative; }
.nl-input {
  flex:1; padding:13px 20px;
  border:2.5px solid var(--ink); border-radius:8px;
  font-family:'Karla', sans-serif; font-size:.95rem;
  background:#fff; color:var(--ink); outline:none;
  box-shadow:3px 3px 0 var(--ink);
}
.nl-input::placeholder { color:var(--ink-muted); }
.nl-btn {
  padding:13px 24px;
  background:var(--butter); color:var(--ink);
  border:2.5px solid var(--ink); border-radius:8px;
  font-family:'Caveat', cursive; font-size:1.1rem; font-weight:700;
  cursor:pointer; box-shadow:3px 3px 0 var(--ink);
  transition:transform .15s, box-shadow .15s; white-space:nowrap;
}
.nl-btn:hover { transform:translate(-2px,-2px); box-shadow:5px 5px 0 var(--ink); }
.nl-btn:active { transform:translate(1px,1px); box-shadow:2px 2px 0 var(--ink); }

/* FOOTER */
footer {
  background:var(--paper-dark);
  border-top:2.5px solid var(--ink);
  padding:56px 40px 40px; text-align:center;
}
.footer-logo { font-family:'Caveat', cursive; font-size:2.2rem; font-weight:700; color:var(--ink); display:block; margin-bottom:8px; }
.footer-logo span { color:var(--pop); }
.footer-words { font-family:'Fraunces', serif; font-style:italic; font-size:.95rem; color:var(--ink-muted); margin-bottom:32px; }
.footer-nav { display:flex; justify-content:center; gap:8px; list-style:none; flex-wrap:wrap; margin-bottom:32px; }
.footer-nav a {
  font-family:'Caveat', cursive; font-size:1rem; font-weight:600;
  color:var(--ink-soft); text-decoration:none;
  padding:5px 14px; border:1.5px solid var(--border); border-radius:100px;
  transition:all .2s;
}
.footer-nav a:hover { color:var(--pop); border-color:var(--pop); background:var(--pop-pale); }
.footer-copy { font-size:.75rem; color:var(--ink-muted); }

/* POST ARTICLE */
.post {
  max-width:720px; margin:0 auto;
  padding:140px 40px 80px;
}
.post-header { margin-bottom:48px; }
.post-back {
  font-family:'Caveat', cursive; font-size:1rem; font-weight:700;
  color:var(--pop); text-decoration:none;
  display:inline-block; margin-bottom:24px;
  transition:color .2s;
}
.post-back:hover { color:var(--ink); }
.post-cat {
  font-family:'Caveat', cursive; font-size:1rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; color:var(--pop);
  margin-bottom:12px;
}
.post-title {
  font-family:'Fraunces', serif; font-weight:700;
  font-size:clamp(2rem, 4.5vw, 3rem); line-height:1.15;
  color:var(--ink); margin-bottom:14px;
}
.post-meta {
  font-size:.85rem; color:var(--ink-muted);
}
.post-content p {
  font-family:'Fraunces', serif; font-weight:300;
  font-size:1.1rem; line-height:1.9; color:var(--ink-soft);
  margin-bottom:28px;
}
.post-content h2 {
  font-family:'Fraunces', serif; font-weight:700;
  font-size:1.5rem; color:var(--ink); margin:48px 0 20px;
  line-height:1.3;
}
.post-content ul, .post-content ol {
  font-family:'Fraunces', serif; font-weight:300;
  font-size:1.1rem; line-height:1.9; color:var(--ink-soft);
  margin:0 0 28px 24px;
}
.post-content li { margin-bottom:6px; }
.post-content blockquote {
  border-left:3px solid var(--butter);
  padding:4px 0 4px 24px;
  margin:36px 0;
}
.post-content blockquote p {
  font-style:italic; color:var(--ink); font-size:1.15rem;
  margin-bottom:0;
}
.post-content em { font-style:italic; }
.post-content strong { font-weight:700; color:var(--ink); }

/* RESPONSIVE */
@media(max-width:900px){
  nav { padding:12px 20px; }
  .nav-links { display:none; }
  .hero { padding:110px 20px 60px; }
  .section { padding:60px 20px; }
  .posts-grid { grid-template-columns:1fr; }
  .post-card.big { grid-column:span 1; }
  .about-inner { grid-template-columns:1fr; gap:48px; padding:0 20px; }
  .fun-facts { grid-template-columns:1fr 1fr; }
  .fact-card.wide { grid-column:span 2; }
  .recipes-inner { padding:0 20px; }
  .snippets-masonry { columns:1; }
  .snippets-inner { padding:0 20px; }
  .footer-nav { flex-direction:column; align-items:center; }
  footer { padding:40px 20px; }
  .about-section { padding:60px 0; }
  .recipes-section { padding:60px 0; }
  .post { padding:110px 20px 60px; }
}
