
:root {
  --sky: #4aa1d9;
  --sky-deep: #2d7fb7;
  --lavender: #a78bd4;
  --lavender-deep: #8c72bb;
  --red: #ef4339;
  --green: #53b84e;
  --yellow: #fff2b5;
  --navy: #36476a;
  --ink: #1d2330;
  --paper: #fffaf1;
  --paper-2: #f6efde;
  --white: #ffffff;
  --line: #202020;
  --soft-shadow: 0 16px 34px rgba(27, 31, 41, 0.12);
  --card-shadow: 0 12px 26px rgba(27, 31, 41, 0.10);
  --radius-xxl: 34px;
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --radius-sm: 12px;
  --container: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.6), transparent 28%),
    linear-gradient(180deg, #dff2fb 0%, #f9fbfe 20%, #f9fbfe 100%);
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
main { overflow-x: clip; }
.container { width: min(var(--container), calc(100% - 34px)); margin: 0 auto; }

h1, h2, h3, h4, .brand-title, .hand {
  font-family: "Comic Sans MS", "Trebuchet MS", "Marker Felt", cursive;
  letter-spacing: .01em;
}
h1, h2, h3 { line-height: 1.08; color: #1b2431; margin: 0 0 14px; }
h1 { font-size: clamp(2.4rem, 4.8vw, 4.8rem); }
h2 { font-size: clamp(1.95rem, 3.2vw, 3.2rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.65rem); }
p { margin: 0 0 16px; line-height: 1.72; }
ul { margin: 0; padding-left: 20px; }
li { margin-bottom: 8px; }
.lead { font-size: 1.08rem; color: #314053; }
.muted { color: #58667a; }
.center { text-align: center; }

.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 250, 241, 0.92);
  backdrop-filter: blur(14px);
  border-bottom: 3px solid rgba(32, 32, 32, 0.07);
}
.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 84px;
}
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, var(--sky), var(--lavender));
  border: 3px solid var(--line);
  box-shadow: var(--card-shadow);
  transform: rotate(-4deg);
  color: white;
  font-size: 1.5rem;
  font-weight: 900;
}
.brand-title { display: block; font-size: 1.7rem; line-height: 1; }
.brand small {
  display: block;
  margin-top: 6px;
  font-size: .88rem;
  color: #556376;
  font-family: Inter, system-ui, sans-serif;
}
.nav-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.nav-links a, .mobile-nav a {
  padding: 11px 14px;
  border-radius: 999px;
  font-size: .95rem;
  font-weight: 800;
  transition: transform .15s ease, background-color .15s ease;
}
.nav-links a:hover, .mobile-nav a:hover, .nav-links a.active, .mobile-nav a.active {
  background: rgba(167, 139, 212, 0.18);
  transform: translateY(-1px);
}
.menu-btn {
  display: none;
  padding: 12px 16px;
  border-radius: 999px;
  border: 3px solid var(--line);
  background: white;
  font-weight: 900;
  cursor: pointer;
  box-shadow: var(--card-shadow);
}
.mobile-nav { display: none; padding: 0 0 18px; }
.mobile-nav.open { display: grid; gap: 8px; }

.page-hero {
  position: relative;
  padding: 34px 0 60px;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 18px 0 0;
  border-bottom-left-radius: 52px;
  border-bottom-right-radius: 52px;
  background: linear-gradient(120deg, rgba(74,161,217,.92), rgba(167,139,212,.96));
  box-shadow: inset 0 -8px 0 rgba(255,255,255,.22);
}
.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.06fr .94fr;
  gap: 34px;
  align-items: center;
  padding-top: 28px;
}
.hero-copy { color: white; text-shadow: 0 2px 8px rgba(0,0,0,.14); }
.hero-copy h1, .hero-copy p, .hero-copy .eyebrow { color: white; }
.hero-copy .lead { max-width: 660px; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.42);
  background: rgba(255,255,255,.15);
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.eyebrow.dark {
  background: rgba(239, 67, 57, .10);
  border-color: rgba(32,32,32,.08);
  color: var(--red);
}
.hero-ribbon, .trust-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-radius: 999px;
  border: 3px solid var(--line);
  box-shadow: var(--card-shadow);
  font-size: .84rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.hero-ribbon { margin-top: 14px; background: var(--yellow); color: #7b5900; }
.hero-cta, .btn-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 999px;
  border: 3px solid var(--line);
  box-shadow: var(--card-shadow);
  font-weight: 900;
  transition: transform .15s ease, box-shadow .15s ease;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(32,32,32,.14); }
.btn-primary { background: var(--red); color: white; }
.btn-secondary { background: white; color: var(--ink); }
.btn-blue { background: var(--sky); color: white; }
.btn-green { background: var(--green); color: white; }
.btn-outline { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.72); color: white; }
.link-chip {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 900; color: white; padding: 12px 2px 0;
}

.hero-art { position: relative; min-height: 520px; }
.cover-card {
  position: absolute;
  right: 12px;
  top: 18px;
  width: min(100%, 400px);
  padding: 14px;
  background: var(--paper);
  border: 4px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--soft-shadow);
  transform: rotate(2deg);
  z-index: 3;
}
.cover-card img { border-radius: 18px; }
.mini-panel {
  position: absolute;
  left: 28px;
  bottom: 28px;
  width: min(66%, 330px);
  overflow: hidden;
  border: 4px solid var(--line);
  border-radius: 24px;
  background: rgba(255,250,241,.96);
  box-shadow: var(--soft-shadow);
  transform: rotate(-4deg);
  z-index: 1;
}
.mini-panel img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.mini-panel .caption {
  padding: 12px 14px 14px;
  font-size: .94rem;
  font-weight: 700;
  background: white;
}
.sticker {
  position: absolute;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 18px;
  border-radius: 999px;
  border: 3px solid var(--line);
  box-shadow: var(--card-shadow);
  font-weight: 900;
}
.sticker.red { background: #fff0ef; color: var(--red); }
.sticker.green { background: #effae9; color: #2d6b2a; }
.sticker.yellow { background: var(--yellow); color: #7b5900; }
.sticker.one { left: -10px; top: -8px; transform: rotate(-8deg); }
.sticker.two { left: 18px; bottom: 120px; transform: rotate(8deg); }

.section { position: relative; padding: 78px 0; }
.section.paper { background: linear-gradient(180deg, #fffef9, #fdf8ef); }
.section.tint-blue { background: linear-gradient(180deg, rgba(74,161,217,.08), rgba(74,161,217,.02)); }
.section.tint-lavender { background: linear-gradient(180deg, rgba(167,139,212,.12), rgba(167,139,212,.03)); }
.section-header { max-width: 740px; margin: 0 auto 36px; text-align: center; }
.display-note {
  position: relative;
  display: inline-block;
  padding-bottom: 10px;
}
.display-note::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 10px;
  border-radius: 999px;
  background: rgba(239,67,57,.24);
  z-index: -1;
}

.grid-2, .grid-3, .grid-4, .gallery-grid, .media-grid, .contact-grid, .trust-strip, .footer-grid, .resource-grid, .info-grid, .steps-grid {
  display: grid; gap: 22px;
}
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4, .trust-strip { grid-template-columns: repeat(4, 1fr); }
.gallery-grid { grid-template-columns: repeat(2, 1fr); }
.media-grid { grid-template-columns: repeat(3, 1fr); }
.contact-grid { grid-template-columns: 1.08fr .92fr; align-items: start; }
.resource-grid { grid-template-columns: repeat(4, 1fr); }
.info-grid { grid-template-columns: repeat(3, 1fr); }
.steps-grid { grid-template-columns: repeat(3, 1fr); }

.card, .resource-card, .media-card, .paper-card, .quote-card, .contact-card, .bubble-card, .book-feature-card, .trust-item, .step-card, .footer-card {
  background: rgba(255,255,255,.96);
  border: 4px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
}
.card, .resource-card, .media-card, .paper-card, .quote-card, .contact-card, .bubble-card, .book-feature-card, .trust-item, .step-card, .footer-card { padding: 24px; }
.card, .resource-card, .media-card, .book-feature-card, .trust-item, .step-card { transition: transform .15s ease; }
.card:hover, .resource-card:hover, .media-card:hover, .book-feature-card:hover, .trust-item:hover, .step-card:hover { transform: translateY(-2px); }

.icon-chip {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  margin-bottom: 16px;
  border: 3px solid var(--line);
  border-radius: 18px;
  font-size: 1.4rem;
  font-weight: 900;
}
.icon-blue { background: #e7f5fd; }
.icon-red { background: #fff0ee; }
.icon-green { background: #effae9; }
.icon-yellow { background: #fff7cf; }

.trust-wrap { margin-top: -8px; }
.trust-item {
  padding: 20px;
  background: rgba(255,255,255,.95);
}
.trust-item h3 { font-size: 1.12rem; margin-bottom: 8px; }
.trust-item p { margin: 0; font-size: .96rem; color: #445264; }

.feature-band {
  padding: 30px;
  background: linear-gradient(180deg, #fffefb, #fdf5e7);
  border: 4px solid var(--line);
  border-radius: 34px;
  box-shadow: var(--soft-shadow);
}
.feature-grid { display: grid; grid-template-columns: 1.02fr .98fr; gap: 24px; align-items: center; }
.tag-row, .note-strip, .meta-strip { display: flex; flex-wrap: wrap; gap: 10px; }
.tag, .note-pill, .meta-pill, .resource-chip {
  display: inline-flex;
  align-items: center;
  padding: 9px 14px;
  border-radius: 999px;
  border: 3px solid var(--line);
  background: var(--paper);
  box-shadow: var(--card-shadow);
  font-weight: 900;
  font-size: .9rem;
}
.note-pill.red, .meta-pill.red { color: var(--red); }
.note-pill.green, .meta-pill.green { color: #2d6b2a; }
.note-pill.blue, .meta-pill.blue { color: var(--sky-deep); }
.resource-chip {
  margin: 4px 6px 0 0;
  box-shadow: none;
  border-width: 2px;
  background: #f0f7ff;
  font-size: .82rem;
}
.book-showcase {
  position: relative;
  padding: 20px;
  border: 4px solid var(--line);
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(74,161,217,.15), rgba(167,139,212,.14));
}
.book-showcase .main-cover {
  background: white;
  padding: 12px;
  border-radius: 22px;
  border: 4px solid var(--line);
  box-shadow: var(--card-shadow);
}
.book-showcase .small-spread {
  position: absolute;
  right: -18px;
  bottom: -18px;
  width: 52%;
  padding: 10px;
  background: var(--paper);
  border: 4px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--card-shadow);
  transform: rotate(4deg);
}
.book-showcase img { border-radius: 14px; }

.book-hero-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 24px;
  align-items: start;
}
.book-side {
  display: grid;
  gap: 20px;
}
.book-cover-panel, .quote-highlight, .action-panel {
  background: rgba(255,255,255,.96);
  border: 4px solid var(--line);
  border-radius: 30px;
  box-shadow: var(--card-shadow);
}
.book-cover-panel { padding: 14px; }
.book-cover-panel img { border-radius: 18px; }
.quote-highlight, .action-panel { padding: 24px; }
.quote-highlight blockquote {
  margin: 0 0 16px;
  font-size: 1.14rem;
  line-height: 1.68;
  font-weight: 800;
}
.quote-highlight cite { font-style: normal; color: #5a6678; font-weight: 800; }
.action-panel h3 { margin-bottom: 12px; }
.check-list { list-style: none; padding: 0; margin: 0; }
.check-list li {
  position: relative;
  padding-left: 28px;
}
.check-list li::before {
  content: "•";
  position: absolute;
  left: 10px;
  top: -1px;
  color: var(--red);
  font-size: 1.2rem;
  font-weight: 900;
}
.gallery-item {
  padding: 10px;
  border-radius: 24px;
  border: 4px solid var(--line);
  background: white;
  box-shadow: var(--card-shadow);
}
.gallery-item img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: 14px;
}
.gallery-item .caption {
  padding: 10px 4px 4px;
  font-weight: 700;
  color: #314053;
}

.split-panel {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 28px;
  align-items: center;
}
.story-frame {
  background: white;
  border: 4px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--soft-shadow);
  padding: 12px;
}
.story-frame img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  border-radius: 18px;
}
.speech {
  position: relative;
  padding: 24px;
  background: white;
  border: 4px solid var(--line);
  border-radius: 30px;
  box-shadow: var(--card-shadow);
}
.speech::after {
  content: "";
  position: absolute;
  left: 36px;
  bottom: -18px;
  width: 28px;
  height: 28px;
  background: white;
  border-right: 4px solid var(--line);
  border-bottom: 4px solid var(--line);
  transform: rotate(45deg);
}

.quote-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #fffef9, #fff5e8);
}
.quote-mark {
  position: absolute;
  top: -18px;
  right: 18px;
  font-size: 7rem;
  color: rgba(239,67,57,.14);
  font-family: Georgia, serif;
}
.quote-card blockquote {
  margin: 0 0 14px;
  font-size: 1.14rem;
  line-height: 1.72;
  font-weight: 800;
}
.quote-card cite { font-style: normal; color: #58667a; font-weight: 800; }

.kicker { color: var(--red); text-transform: uppercase; font-weight: 900; font-size: .82rem; letter-spacing: .08em; margin-bottom: 10px; }
.media-card h3 { margin-bottom: 10px; }
.media-thumb {
  position: relative;
  margin-bottom: 16px;
  overflow: hidden;
  border: 4px solid var(--line);
  border-radius: 20px;
}
.media-thumb img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.play-badge {
  position: absolute;
  left: 14px;
  bottom: 14px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 3px solid var(--line);
  background: rgba(255,255,255,.94);
  font-weight: 900;
}

.bubble-card h3, .resource-card h3, .paper-card h3, .contact-card h3 { margin-bottom: 10px; }
.resource-card { position: relative; overflow: hidden; }
.resource-card::after {
  content: "";
  position: absolute;
  right: -24px;
  top: -24px;
  width: 94px;
  height: 94px;
  border-radius: 50%;
  background: rgba(74,161,217,.12);
}
.step-card .step-number {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  margin-bottom: 14px;
  border-radius: 14px;
  border: 3px solid var(--line);
  background: var(--yellow);
  font-weight: 900;
}

.contact-form label { display: block; margin-bottom: 8px; font-weight: 900; }
.input, textarea, select {
  width: 100%;
  margin-bottom: 16px;
  padding: 14px 16px;
  border: 3px solid var(--line);
  border-radius: 18px;
  font: inherit;
  background: white;
}
textarea { min-height: 150px; resize: vertical; }
.form-note { font-size: .94rem; color: #5b6879; }
.success-message {
  display: none;
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 3px solid var(--line);
  background: #effae9;
  font-weight: 800;
}
.success-message.show { display: block; }

.section-cta {
  padding: 78px 0 24px;
}
.section-cta-inner {
  padding: 28px;
  border: 4px solid var(--line);
  border-radius: 32px;
  background: linear-gradient(180deg, #fffefb, #fdf5e7);
  box-shadow: var(--soft-shadow);
}
.section-cta-inner h2 { margin-bottom: 10px; }

.footer {
  margin-top: 34px;
  padding: 46px 0 34px;
  color: white;
  background: linear-gradient(180deg, #2d4b67, #27374d);
  border-top-left-radius: 36px;
  border-top-right-radius: 36px;
}
.footer-grid {
  grid-template-columns: 1.15fr .85fr .95fr;
  align-items: start;
}
.footer .brand-title { color: white; }
.footer small, .footer .muted, .footer p { color: rgba(255,255,255,.84); }
.footer-links-col h3 {
  margin-bottom: 12px;
  font-size: 1.15rem;
  color: white;
}
.footer-links-col a {
  display: block;
  margin-bottom: 10px;
  color: rgba(255,255,255,.9);
}
.footer-links-col a:hover { color: white; }
.footer-card {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.15);
  box-shadow: none;
}
.footer-meta {
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.84);
}

.spacer-sm { height: 10px; }
.spacer-md { height: 18px; }
.spacer-lg { height: 30px; }

@media (max-width: 1024px) {
  .hero-inner, .feature-grid, .split-panel, .contact-grid, .book-hero-grid, .footer-grid { grid-template-columns: 1fr; }
  .grid-4, .trust-strip, .resource-grid, .media-grid, .info-grid, .grid-3, .steps-grid, .grid-2, .gallery-grid { grid-template-columns: 1fr 1fr; }
  .hero-art { min-height: 500px; }
  .cover-card { position: relative; right: 0; top: 0; margin: 0 auto; }
  .mini-panel { left: 10px; }
  .book-showcase .small-spread { position: relative; width: 58%; right: auto; bottom: auto; margin: 16px 0 0 auto; }
}
@media (max-width: 780px) {
  .nav-links { display: none; }
  .menu-btn { display: inline-flex; }
  .grid-4, .trust-strip, .resource-grid, .media-grid, .info-grid, .grid-3, .steps-grid, .grid-2, .gallery-grid { grid-template-columns: 1fr; }
  .brand-title { font-size: 1.45rem; }
  .hero-art { min-height: 430px; }
  .footer-links-col a { margin-bottom: 8px; }
}
@media (max-width: 560px) {
  .container { width: min(100% - 22px, var(--container)); }
  .nav-wrap { min-height: 76px; }
  .page-hero { padding: 26px 0 46px; }
  .page-hero::before { inset: 12px 0 0; border-bottom-left-radius: 28px; border-bottom-right-radius: 28px; }
  h1 { font-size: 2.15rem; }
  h2 { font-size: 1.72rem; }
  .section { padding: 60px 0; }
  .section-cta { padding-top: 56px; }
  .hero-art { min-height: 350px; }
  .cover-card { width: 88%; padding: 10px; }
  .mini-panel { width: 72%; left: 0; bottom: 8px; }
  .card, .resource-card, .media-card, .paper-card, .quote-card, .contact-card, .bubble-card, .book-feature-card, .trust-item, .step-card, .footer-card, .quote-highlight, .action-panel { padding: 18px; }
  .hero-ribbon, .trust-badge, .eyebrow, .tag, .note-pill, .meta-pill { font-size: .76rem; }
}
