/* ─────────────────────────────────────────────────────────────────
   Din Mamma AI — kitchen-warm, fridge-paper, typewriter + handwritten
   ───────────────────────────────────────────────────────────────── */

:root {
  /* Palette: "cream kitchen" — warm, dry, nothing screens blue */
  --cream:       #F4EAD2;   /* main paper */
  --cream-2:     #EAD9B4;   /* darker paper, taped sign */
  --cream-soft:  #FAF3E0;   /* lighter surface */
  --ink:         #2A1D12;   /* near-black brown, body copy */
  --ink-soft:    #5A4733;
  --ink-mute:    #8A7558;
  --line:        #E0CFA6;   /* hairline on cream */

  --tomato:      #C8442A;   /* warm red — strikethrough, CTAs */
  --tomato-deep: #9A2F1C;
  --mustard:     #D4A23C;   /* accents */
  --mustard-deep:#A87613;
  --kitchen:     #2F4A33;   /* dark green */
  --kitchen-2:   #3E5F42;
  --ceramic:     #E9DFC6;   /* tile-ish */

  /* Post-it colors */
  --postit-yellow: #F3D86F;
  --postit-pink:   #F4B8A8;
  --postit-blue:   #B9D3C8;
  --postit-green:  #C9D6A8;

  --radius:     14px;
  --radius-sm:  8px;

  --max: 1200px;
  --gutter: 28px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Paper grain — the whole page sits on slightly textured warm paper. */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(rgba(90,71,51,.08) 1px, transparent 1px),
    radial-gradient(rgba(90,71,51,.05) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
  opacity: .55;
  mix-blend-mode: multiply;
}

/* Subtle warm vignette */
body::after {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse at 50% -10%, rgba(255,240,205,.5), transparent 60%),
    radial-gradient(ellipse at 50% 120%, rgba(154,47,28,.10), transparent 60%);
}

main, header, footer, section { position: relative; z-index: 1; }

/* Type ------------------------------------------------------------ */

.serif   { font-family: "Newsreader", Georgia, serif; font-weight: 500; }
.hand    { font-family: "Caveat", "Comic Sans MS", cursive; font-weight: 600; }
.hand-tight { font-family: "Kalam", "Caveat", cursive; font-weight: 400; }
.type    { font-family: "Special Elite", "Courier New", ui-monospace, monospace; font-weight: 400; }
.mono    { font-family: "JetBrains Mono", ui-monospace, monospace; }

h1, h2, h3 { font-family: "Newsreader", Georgia, serif; font-weight: 500; letter-spacing: -0.01em; }
h1 { font-size: clamp(38px, 5.2vw, 72px); line-height: 1.02; margin: 0 0 .3em; }
h2 { font-size: clamp(30px, 3.6vw, 46px); line-height: 1.08; margin: 0 0 .4em; }
h3 { font-size: clamp(20px, 1.8vw, 26px); line-height: 1.2; margin: 0 0 .4em; }

p  { margin: 0 0 1em; max-width: 62ch; text-wrap: pretty; }
small, .sm { font-size: 13px; color: var(--ink-soft); }

em.hand, .eye {
  font-family: "Caveat", cursive;
  font-style: normal;
  color: var(--tomato-deep);
  font-weight: 700;
}

a { color: inherit; text-underline-offset: 3px; }
a:hover { color: var(--tomato-deep); }

/* Layout ---------------------------------------------------------- */

.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--gutter); }
.wrap-wide { max-width: 1320px; margin: 0 auto; padding: 0 var(--gutter); }

.section { padding: 96px 0; }
.section-tight { padding: 64px 0; }

.kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: "Special Elite", monospace;
  font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-soft);
  padding: 4px 10px;
  background: var(--cream-soft);
  border: 1px dashed var(--ink-mute);
  border-radius: 999px;
}
.kicker .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--tomato); }

/* Nav ------------------------------------------------------------- */

.nav {
  position: sticky; top: 0; z-index: 40;
  background: color-mix(in oklab, var(--cream) 88%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px dashed var(--line);
}
.nav-row {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.nav a { text-decoration: none; }
.nav-links { display: flex; gap: 28px; align-items: center; }
.nav-links a { color: var(--ink-soft); font-size: 14.5px; }
.nav-links a:hover { color: var(--ink); }

.logo {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: "Newsreader", serif; font-weight: 500; font-size: 22px;
  letter-spacing: -0.02em;
}
.logo-mark {
  width: 34px; height: 34px;
  display: grid; place-items: center;
  background: var(--tomato);
  color: #fff;
  border-radius: 8px;
  font-family: "Caveat", cursive; font-size: 22px; font-weight: 700;
  transform: rotate(-4deg);
  box-shadow: 0 2px 0 rgba(0,0,0,.15), 0 6px 16px rgba(200,68,42,.25);
}

/* Buttons --------------------------------------------------------- */

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: "Manrope", sans-serif;
  font-weight: 600; font-size: 15px;
  padding: 14px 22px;
  border-radius: 999px;
  border: 0; cursor: pointer;
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-primary {
  background: var(--ink);
  color: var(--cream-soft);
  box-shadow: 0 2px 0 var(--tomato-deep), 0 10px 24px rgba(42,29,18,.18);
}
.btn-primary:hover { transform: translateY(-1px); background: #1e140b; }
.btn-secondary {
  background: transparent;
  color: var(--ink);
  border: 1.5px solid var(--ink);
}
.btn-secondary:hover { background: var(--ink); color: var(--cream-soft); }

.btn-tomato {
  background: var(--tomato);
  color: #FFF6E7;
  box-shadow: 0 3px 0 var(--tomato-deep), 0 10px 24px rgba(200,68,42,.3);
}
.btn-tomato:hover { transform: translateY(-1px); background: #b03b22; }

/* Tape, post-its, cards ------------------------------------------- */

.tape {
  position: absolute;
  width: 90px; height: 22px;
  background: rgba(255, 230, 140, .55);
  border: 1px solid rgba(160, 130, 40, .25);
  box-shadow: 0 1px 2px rgba(0,0,0,.08);
  mix-blend-mode: multiply;
}
.tape::before, .tape::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 4px;
  background: repeating-linear-gradient(
    90deg, transparent 0 2px, rgba(0,0,0,.05) 2px 3px
  );
}
.tape::before { left: 0; } .tape::after { right: 0; }

.postit {
  position: relative;
  background: var(--postit-yellow);
  padding: 22px 22px 26px;
  font-family: "Kalam", "Caveat", cursive;
  color: #3C2A10;
  box-shadow:
    0 1px 0 rgba(0,0,0,.05),
    0 10px 18px -8px rgba(0,0,0,.25),
    inset 0 -20px 24px -16px rgba(160,120,20,.22);
  border-radius: 2px 2px 2px 14px;
}
.postit.pink  { background: var(--postit-pink); color: #561E11; }
.postit.blue  { background: var(--postit-blue); color: #1E3A2E; }
.postit.green { background: var(--postit-green); color: #334119; }

.card {
  background: var(--cream-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  position: relative;
  box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 1px 2px rgba(42,29,18,.05);
}
.card.dark {
  background: var(--kitchen);
  color: #EADFC2;
  border-color: #1E3223;
}
.card.dark h3, .card.dark .serif { color: #F4EAD2; }

/* Strikethrough that looks hand-drawn */
.strike-hand {
  position: relative;
  display: inline-block;
}
.strike-hand::after {
  content: "";
  position: absolute;
  left: -2%; right: -2%;
  top: 52%;
  height: 8px;
  background:
    linear-gradient(90deg,
      transparent 0, var(--tomato) 5%, var(--tomato) 95%, transparent 100%);
  transform: rotate(-1.5deg);
  opacity: .85;
  border-radius: 4px;
  filter: url(#rough);
}

/* Utility --------------------------------------------------------- */

.grid { display: grid; gap: 24px; }
.g-2 { grid-template-columns: repeat(2, 1fr); }
.g-3 { grid-template-columns: repeat(3, 1fr); }
.g-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
  .g-2, .g-3, .g-4 { grid-template-columns: 1fr; }
  .section { padding: 64px 0; }
}

.divider {
  height: 1px;
  background: repeating-linear-gradient(
    90deg, var(--ink-mute) 0 6px, transparent 6px 12px
  );
  opacity: .4;
  margin: 0;
}

.eyebrow {
  font-family: "Special Elite", monospace;
  font-size: 12px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 14px;
}

/* The HERO sign — a real printed A4 page taped to the wall */

.hero {
  min-height: calc(100vh - 64px);
  display: grid;
  place-items: center;
  padding: 80px 0 100px;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(255,244,210,.7), transparent 60%),
    linear-gradient(180deg, var(--cream), var(--cream-2));
}

.a4 {
  position: relative;
  width: min(620px, 86vw);
  aspect-ratio: 1 / 1.29;
  background: #FCFAF2;
  color: #1C1308;
  padding: 72px 56px 64px;
  box-shadow:
    0 2px 0 rgba(0,0,0,.04),
    0 18px 40px -10px rgba(42,29,18,.25),
    0 50px 80px -30px rgba(42,29,18,.35);
  border-radius: 2px;
  transform: rotate(-1.2deg);
  background-image:
    radial-gradient(rgba(42,29,18,.07) 1px, transparent 1px),
    radial-gradient(rgba(42,29,18,.04) 1px, transparent 1px);
  background-size: 4px 4px, 9px 9px;
  background-blend-mode: multiply;
}
.a4::before, .a4::after {
  content: ""; position: absolute;
  width: 120px; height: 28px;
  background: rgba(255, 220, 120, .55);
  border: 1px solid rgba(140, 100, 20, .25);
  mix-blend-mode: multiply;
  box-shadow: 0 1px 2px rgba(0,0,0,.1);
}
.a4::before { top: -14px; left: 40px; transform: rotate(-4deg); }
.a4::after  { top: -14px; right: 40px; transform: rotate(3deg); }

.a4-text {
  font-family: "Special Elite", monospace;
  font-size: clamp(26px, 3.2vw, 42px);
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: #1C1308;
}
.a4-text > div { line-height: 1.5; padding: 2px 0; }
.a4-text .strikeline { display: inline-block; vertical-align: top; padding: 2px 0; }
.a4-text .strikeline {
  position: relative;
  display: inline-block;
}
.a4-text .strikeline::after {
  content: "";
  position: absolute;
  left: -4%; right: -4%;
  top: 55%;
  height: 5px;
  background: var(--tomato);
  transform: rotate(-1deg) skewX(-2deg);
  border-radius: 3px;
  box-shadow: 0 1px 0 rgba(0,0,0,.08);
}

.correction {
  font-family: "Caveat", cursive;
  color: var(--tomato-deep);
  font-size: 1.05em;
  font-weight: 700;
  line-height: 1;
}

/* Marquee */

.marquee {
  overflow: hidden;
  border-top: 1px dashed var(--line);
  border-bottom: 1px dashed var(--line);
  padding: 18px 0;
  background: var(--cream-soft);
}
.marquee-track {
  display: flex; gap: 56px;
  animation: scroll 40s linear infinite;
  white-space: nowrap;
}
.marquee span {
  font-family: "Newsreader", serif; font-style: italic;
  font-size: 22px;
  color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 24px;
}
.marquee span::after { content: "✶"; color: var(--tomato); font-style: normal; }
@keyframes scroll { to { transform: translateX(-50%); } }

/* Feature grid */

.feature {
  padding: 28px;
  background: var(--cream-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  position: relative;
  min-height: 240px;
  display: flex; flex-direction: column;
}
.feature .f-icon {
  width: 46px; height: 46px; display: grid; place-items: center;
  background: var(--tomato); color: #fff;
  border-radius: 12px; margin-bottom: 16px;
  font-family: "Caveat", cursive; font-size: 22px;
  transform: rotate(-3deg);
}
.feature h3 { font-size: 22px; margin-bottom: 8px; }
.feature p { color: var(--ink-soft); font-size: 15.5px; margin: 0; }
.feature .mom-says {
  margin-top: 18px;
  font-family: "Kalam", cursive;
  color: var(--tomato-deep);
  font-size: 17px;
  line-height: 1.3;
  border-left: 3px solid var(--tomato);
  padding-left: 12px;
}

/* Steps */

.step {
  padding: 40px 28px 28px;
  background: var(--cream-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  position: relative;
}
.step-num {
  position: absolute;
  top: -22px; left: 22px;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--ink); color: var(--cream-soft);
  border-radius: 50%;
  font-family: "Newsreader", serif; font-size: 22px;
  transform: rotate(-4deg);
}
.step h3 { margin-top: 8px; }
.step p { color: var(--ink-soft); margin: 0; }

/* Scenarios / For vem */

.scenario {
  background: var(--cream-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  position: relative;
}
.scenario .who {
  font-family: "Special Elite", monospace;
  font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 10px;
}
.scenario .quote {
  font-family: "Newsreader", serif;
  font-size: 22px;
  line-height: 1.3;
  margin: 0 0 20px;
  color: var(--ink);
}
.scenario .mom {
  font-family: "Kalam", cursive;
  color: var(--tomato-deep);
  font-size: 18px;
  line-height: 1.35;
  border-top: 1px dashed var(--line);
  padding-top: 14px;
}
.scenario .mom::before { content: "— Mamma: "; font-family: "Special Elite", monospace; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-mute); display: block; margin-bottom: 4px; }

/* Price */

.price-card {
  background: var(--cream-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px 28px;
  position: relative;
  display: flex; flex-direction: column;
}
.price-card.featured {
  background: var(--ink);
  color: var(--cream-soft);
  border-color: var(--ink);
}
.price-card.featured h3 { color: var(--cream-soft); }
.price-card.featured .price-num { color: var(--postit-yellow); }
.price-card .plan-name {
  font-family: "Caveat", cursive;
  color: var(--tomato-deep);
  font-size: 28px;
  line-height: 1;
  margin-bottom: 6px;
}
.price-card.featured .plan-name { color: var(--postit-yellow); }
.price-card .plan-desc {
  font-size: 14.5px;
  color: var(--ink-soft);
  margin-bottom: 22px;
}
.price-card.featured .plan-desc { color: #D6C9A4; }
.price-card .price-num {
  font-family: "Newsreader", serif;
  font-size: 54px; line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.price-card .price-unit {
  font-size: 13px; color: var(--ink-mute);
  margin-bottom: 24px;
}
.price-card.featured .price-unit { color: #B8A97F; }
.price-card ul {
  list-style: none; padding: 0; margin: 0 0 24px;
  font-size: 15px;
  flex: 1;
}
.price-card li {
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  display: flex; align-items: flex-start; gap: 10px;
}
.price-card.featured li { border-color: rgba(255,255,255,.12); }
.price-card li::before {
  content: "✓";
  color: var(--tomato);
  font-family: "Caveat", cursive;
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
  transform: translateY(-2px);
}
.price-card.featured li::before { color: var(--postit-yellow); }

.price-card .ribbon {
  position: absolute; top: -14px; right: 20px;
  background: var(--tomato); color: #fff;
  padding: 6px 14px;
  font-family: "Caveat", cursive; font-size: 20px;
  transform: rotate(3deg);
  border-radius: 4px;
  box-shadow: 0 2px 0 rgba(0,0,0,.15);
}

/* FAQ */

.faq-item {
  border-top: 1px dashed var(--line);
  padding: 22px 0;
}
.faq-item:last-child { border-bottom: 1px dashed var(--line); }
.faq-q {
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer;
  font-family: "Newsreader", serif;
  font-size: 22px;
  color: var(--ink);
}
.faq-q:hover { color: var(--tomato-deep); }
.faq-q .chev {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1px solid var(--ink-mute);
  font-size: 14px;
  transition: transform .2s ease, background .2s ease;
  flex-shrink: 0;
}
.faq-item.open .faq-q .chev { transform: rotate(45deg); background: var(--ink); color: var(--cream-soft); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .3s ease, padding .3s ease;
  color: var(--ink-soft);
  padding-top: 0;
}
.faq-item.open .faq-a {
  max-height: 600px;
  padding-top: 14px;
}
.faq-a .mom {
  margin-top: 14px;
  font-family: "Kalam", cursive;
  color: var(--tomato-deep);
  font-size: 17px;
}

/* Footer */

footer {
  background: var(--kitchen);
  color: #EADFC2;
  padding: 64px 0 40px;
  margin-top: 60px;
}
footer h4 {
  font-family: "Newsreader", serif; font-weight: 500;
  font-size: 18px;
  color: var(--postit-yellow);
  margin: 0 0 14px;
}
footer a { color: #D8CDAC; text-decoration: none; display: block; padding: 4px 0; }
footer a:hover { color: #FFF; }
footer .foot-bottom {
  border-top: 1px dashed rgba(255,255,255,.15);
  margin-top: 40px; padding-top: 24px;
  display: flex; justify-content: space-between; flex-wrap: wrap;
  gap: 16px;
  font-size: 13px; color: #B8A97F;
}

/* iPhone mockup */

.iphone {
  width: 320px;
  aspect-ratio: 9 / 19.5;
  background: #111;
  border-radius: 44px;
  padding: 12px;
  box-shadow:
    0 2px 0 #000 inset,
    0 40px 80px -20px rgba(0,0,0,.4),
    0 0 0 1.5px #333;
  margin: 0 auto;
  position: relative;
}
.iphone-screen {
  width: 100%; height: 100%;
  background: #F6EFDA;
  border-radius: 32px;
  overflow: hidden;
  position: relative;
  display: flex; flex-direction: column;
}
.iphone-notch {
  position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  width: 96px; height: 28px; background: #000; border-radius: 999px;
  z-index: 2;
}
.iphone-status {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 26px 6px;
  font-size: 14px; font-weight: 600; color: #2A1D12;
  font-family: -apple-system, sans-serif;
}
.chat-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px 12px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  background: var(--cream-soft);
}
.chat-avatar {
  width: 38px; height: 38px;
  background: var(--tomato);
  color: #fff;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: "Caveat", cursive; font-size: 20px;
  transform: rotate(-4deg);
}
.chat-name { font-weight: 600; font-size: 15px; color: var(--ink); }
.chat-status { font-size: 12px; color: #2F7A3A; }
.chat-messages {
  flex: 1; overflow-y: auto;
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 10px;
  font-size: 14.5px;
}
.bubble {
  max-width: 78%;
  padding: 10px 14px;
  border-radius: 18px;
  line-height: 1.35;
}
.bubble.mom {
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  color: var(--ink);
  align-self: flex-start;
  border-bottom-left-radius: 6px;
}
.bubble.me {
  background: var(--tomato);
  color: #FFF6E7;
  align-self: flex-end;
  border-bottom-right-radius: 6px;
}
.bubble.mom strong { color: var(--tomato-deep); }

.typing {
  display: inline-flex; gap: 4px; padding: 14px 16px !important;
}
.typing i {
  width: 7px; height: 7px; border-radius: 50%; background: var(--ink-mute);
  animation: blink 1.2s infinite ease-in-out;
}
.typing i:nth-child(2){ animation-delay: .2s; }
.typing i:nth-child(3){ animation-delay: .4s; }
@keyframes blink { 0%,100% { opacity: .3; transform: translateY(0); } 50% { opacity: 1; transform: translateY(-2px); } }

/* Desktop mockup */

.desktop {
  background: var(--cream-soft);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 30px 60px -20px rgba(42,29,18,.25);
}
.desk-top {
  display: flex; gap: 8px; padding: 12px 16px;
  background: #EFE5C9;
  border-bottom: 1px solid var(--line);
}
.desk-top i {
  width: 12px; height: 12px; border-radius: 50%;
  background: #D4A23C;
}
.desk-top i:nth-child(1){ background: #C8442A; }
.desk-top i:nth-child(3){ background: #6A9E56; }

.desk-body { display: grid; grid-template-columns: 200px 1fr; min-height: 440px; }
.desk-side {
  background: #F0E6C9;
  border-right: 1px solid var(--line);
  padding: 18px 16px;
  font-size: 14px;
}
.desk-side .side-logo { font-family: "Newsreader", serif; font-size: 18px; margin-bottom: 18px; font-weight: 500; }
.desk-side .side-item {
  padding: 8px 10px; margin-bottom: 2px; border-radius: 8px;
  color: var(--ink-soft); display: flex; gap: 10px; align-items: center;
}
.desk-side .side-item.active { background: var(--ink); color: var(--cream-soft); }
.desk-side .side-item .dot-num {
  margin-left: auto;
  background: var(--tomato); color: #fff;
  font-size: 11px; padding: 2px 7px; border-radius: 999px;
  font-weight: 600;
}
.desk-side .side-item.active .dot-num { background: var(--postit-yellow); color: var(--ink); }

.desk-main { padding: 24px 26px; }
.desk-greet { font-family: "Caveat", cursive; color: var(--tomato-deep); font-size: 26px; line-height: 1.1; margin-bottom: 4px; }
.desk-greet-sub { color: var(--ink-soft); font-size: 14px; margin-bottom: 22px; }

.desk-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 22px; }
.desk-card {
  background: #FFFBEC;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
}
.desk-card .k { font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; font-family: "Special Elite", monospace; }
.desk-card .v { font-family: "Newsreader", serif; font-size: 26px; line-height: 1; }
.desk-card .v small { font-size: 13px; color: var(--ink-mute); margin-left: 4px; }
.desk-card.warn { background: #FBE9D9; }
.desk-card.warn .v { color: var(--tomato-deep); }

.desk-today h4 {
  font-family: "Newsreader", serif; font-weight: 500; font-size: 16px;
  margin: 0 0 10px; color: var(--ink);
}
.desk-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #FFFBEC;
  margin-bottom: 8px;
  font-size: 14px;
}
.desk-row .tag {
  font-family: "Special Elite", monospace; font-size: 11px;
  padding: 2px 8px; border-radius: 999px;
  background: var(--postit-yellow); color: #3C2A10;
  letter-spacing: .06em; text-transform: uppercase;
}
.desk-row .tag.alert { background: var(--tomato); color: #fff; }
.desk-row .tag.ok { background: #C9D6A8; color: #334119; }
.desk-row .label { flex: 1; }
.desk-row .when { color: var(--ink-mute); font-size: 13px; }

/* Stickers & doodles (fridge-note feeling) */

.sticker {
  position: absolute;
  font-family: "Caveat", cursive;
  color: var(--tomato-deep);
  font-size: 26px;
  line-height: 1;
  transform: rotate(-6deg);
  text-align: center;
}

/* Hero floating sticky notes around the A4 */

.hero-wrap { position: relative; }
.hero-note {
  position: absolute;
  width: 170px;
  padding: 16px 16px 18px;
  font-family: "Kalam", cursive;
  font-size: 15.5px;
  line-height: 1.3;
  box-shadow: 0 1px 0 rgba(0,0,0,.05), 0 12px 20px -10px rgba(0,0,0,.28);
  transform: rotate(-5deg);
  z-index: 2;
}
.hero-note .magnet {
  position: absolute;
  top: -9px; left: 50%;
  transform: translateX(-50%);
  width: 22px; height: 22px;
  background: radial-gradient(circle at 35% 30%, #E8856E, #9A2F1C);
  border-radius: 50%;
  box-shadow: 0 2px 3px rgba(0,0,0,.2);
}

/* Hide some decoration on small screens */
@media (max-width: 900px) {
  .hero-note { display: none; }
  .a4 { transform: rotate(-0.5deg); padding: 56px 32px 48px; }
  .a4::before, .a4::after { width: 80px; }
}

/* Big type helpers */
.display {
  font-family: "Newsreader", serif;
  font-weight: 500;
  font-size: clamp(44px, 6.2vw, 96px);
  line-height: 1.02;
  letter-spacing: -0.025em;
}

.lede {
  font-size: clamp(19px, 1.4vw, 22px);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 52ch;
}

/* Section header w/ kicker */
.sec-head {
  max-width: 720px;
  margin: 0 auto 56px;
  text-align: center;
}
.sec-head .kicker { margin-bottom: 18px; }
.sec-head p { margin: 12px auto 0; color: var(--ink-soft); }

.center { text-align: center; }

/* Final CTA block */

.kaffe {
  background: var(--tomato);
  color: #FFF6E7;
  border-radius: 24px;
  padding: 64px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.kaffe::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 4px 4px;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.kaffe h2 { color: #FFF6E7; font-size: clamp(36px, 4.8vw, 64px); }
.kaffe .btn-primary { background: #1C1308; color: var(--postit-yellow); }

/* Lappen (flyer) section */

.flyer-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: center;
}
@media (max-width: 900px) { .flyer-row { grid-template-columns: 1fr; } }

.flyer {
  position: relative;
  background: #FCFAF2;
  padding: 52px 40px 40px;
  aspect-ratio: 3 / 4;
  max-width: 380px;
  font-family: "Special Elite", monospace;
  color: #1C1308;
  box-shadow: 0 18px 40px -10px rgba(42,29,18,.25);
  transform: rotate(2deg);
  background-image:
    radial-gradient(rgba(42,29,18,.06) 1px, transparent 1px);
  background-size: 3px 3px;
  background-blend-mode: multiply;
}
.flyer::before {
  content: ""; position: absolute;
  top: -10px; left: 50%; transform: translateX(-50%) rotate(-2deg);
  width: 100px; height: 22px;
  background: rgba(255, 220, 120, .6);
  border: 1px solid rgba(140, 100, 20, .25);
}
.flyer .small-strike {
  font-size: 20px; line-height: 1.2;
  position: relative; display: inline-block;
}
.flyer .small-strike::after {
  content: ""; position: absolute; left: -2%; right: -2%; top: 55%;
  height: 3px; background: var(--tomato);
  transform: rotate(-2deg);
}
.flyer .correction-sm {
  font-family: "Caveat", cursive;
  color: var(--tomato-deep);
  font-size: 26px; line-height: 1.05;
  font-weight: 700;
}
.flyer .qr {
  width: 80px; height: 80px;
  background: #111;
  background-image:
    linear-gradient(0deg, #fff 0%, #fff 20%, transparent 20%, transparent 40%, #fff 40%, #fff 50%, transparent 50%, transparent 65%, #fff 65%, #fff 78%, transparent 78%),
    linear-gradient(90deg, transparent 0%, transparent 12%, #fff 12%, #fff 18%, transparent 18%, transparent 32%, #fff 32%, #fff 42%, transparent 42%, transparent 58%, #fff 58%, #fff 68%, transparent 68%, transparent 82%, #fff 82%, #fff 92%, transparent 92%);
  background-size: 100% 100%;
  padding: 6px;
  background-repeat: no-repeat;
  margin-top: auto;
}
