html { scroll-behavior: smooth; }
* { box-sizing: border-box; }
body { margin: 0; font-family: Arial, Helvetica, sans-serif; color: #1f2937; background: linear-gradient(to bottom, #e0f2fe, #f0fdf4, #fefce8); line-height: 1.5; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
.container { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }
.section { padding: 24px 0 48px; }
.tight-top { padding-top: 8px; }
.hero { position: relative; overflow: hidden; padding: 48px 0 40px; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(circle at top right, rgba(255,255,255,0.75), transparent 35%), radial-gradient(circle at left, rgba(255,221,87,0.28), transparent 30%); }
.hero-grid { position: relative; display: grid; gap: 40px; align-items: center; }
.pill { display: inline-flex; align-items: center; border-radius: 999px; background: rgba(255,255,255,0.85); padding: 10px 16px; font-size: 14px; font-weight: 600; box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08); border: 1px solid #e5e7eb; }
h1 { margin: 18px 0 0; font-size: clamp(2.5rem, 5vw, 4.25rem); line-height: 1.05; font-weight: 900; color: #0f172a; }
.lead { margin: 20px 0 0; max-width: 620px; font-size: 1.125rem; line-height: 1.75; color: #334155; }
.hero-actions, .button-row { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.wrap { flex-wrap: wrap; }
.btn { display: inline-flex; align-items: center; justify-content: center; border-radius: 18px; padding: 14px 24px; font-weight: 700; transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease; }
.btn:hover, .mini-card:hover, .buy-card:hover { transform: translateY(-2px); }
.btn-primary { background: #059669; color: white; box-shadow: 0 8px 20px rgba(5, 150, 105, 0.25); }
.btn-secondary { background: white; color: #1f2937; border: 1px solid #e5e7eb; box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06); }
.btn-light { background: white; color: #065f46; box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12); }
.btn-look { border: 1px dashed #cbd5e1; }
.trust-strip { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 10px; font-size: 0.95rem; color: #475569; align-items: center; }
.trust-strip .dot { opacity: 0.5; }
.quick-buy, .two-up, .three-up, .gallery, .split { display: grid; gap: 24px; }
.quick-buy { margin-top: 28px; }
.mini-card, .content-card, .info-card, .video-card, .gallery-card, .hero-image-card, .image-card { background: rgba(255,255,255,0.95); border: 1px solid #e5e7eb; box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06); }
.mini-card, .info-card, .content-card, .video-card, .buy-card, .school-card { border-radius: 28px; padding: 24px; }
.hero-image-card, .image-card, .gallery-card { overflow: hidden; border-radius: 32px; }
.hero-image-card { padding: 12px; background: rgba(255,255,255,0.7); backdrop-filter: blur(8px); box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12); }
.hero-image-card img, .image-card img { width: 100%; height: 100%; object-fit: cover; border-radius: 22px; }
.hero-copy h2, .content-card h2, .school-card h2, .banner h2, .cta h2 { margin: 0; font-size: clamp(1.75rem, 3vw, 2.4rem); line-height: 1.15; color: #0f172a; }
.section-intro { max-width: 760px; margin-bottom: 28px; }
.section-intro h2 { margin: 0; font-size: clamp(2rem, 3vw, 2.4rem); line-height: 1.15; color: #0f172a; }
.section-intro p, .content-card p, .info-card p, .video-card p, .gallery-copy p, .school-card p, .banner p, .cta p, .fine-print, .subheading, .feedback-line { color: #475569; }
.feedback-line { margin-top: 16px; font-size: 0.95rem; }
.inside-cta { margin-top: 24px; }
.section-label, .mini-label { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; }
.section-label { color: #047857; }
.section-label.warm { color: #fcd34d; }
.mini-label.amazon { color: #b45309; }
.mini-label.olympia { color: #0369a1; }
.mini-card h3, .content-card h3, .gallery-copy h3, .video-card h3, .buy-card h3 { margin: 12px 0 0; font-size: 1.35rem; line-height: 1.2; color: #0f172a; }
.buy-card { display: block; border: 1px solid #e5e7eb; transition: transform 0.18s ease, box-shadow 0.18s ease; }
.buy-amazon { background: #fffbeb; }
.buy-olympia { background: #f0f9ff; }
.buy-chip { display: inline-flex; margin-top: 18px; border-radius: 12px; background: rgba(255,255,255,0.85); padding: 10px 14px; font-size: 0.95rem; font-weight: 700; color: #047857; border: 1px solid #e5e7eb; }
.banner { display: grid; gap: 28px; align-items: center; background: #0f172a; color: white; border-radius: 32px; padding: 32px; box-shadow: 0 20px 40px rgba(15, 23, 42, 0.18); }
.banner h2, .banner p, .school-card h2, .school-card p, .school-card li, .cta h2, .cta p { color: white; }
.banner-box { border-radius: 28px; background: rgba(255,255,255,0.08); padding: 24px; border: 1px solid rgba(255,255,255,0.14); }
.banner-box ul, .school-card ul { margin: 18px 0 0; padding-left: 20px; }
.gallery { grid-template-columns: 1fr; }
.gallery-card img { width: 100%; height: 260px; object-fit: cover; }
.gallery-copy { padding: 20px; }
.video-embed { overflow: hidden; border-radius: 20px; border: 1px solid #e5e7eb; background: #f8fafc; }
.video-embed iframe { display: block; width: 100%; aspect-ratio: 16 / 9; border: 0; }
.ideas-btn { margin-top: 18px; }
.school-card { background: #0f172a; color: white; box-shadow: 0 20px 40px rgba(15, 23, 42, 0.18); }
.cta { display: flex; flex-direction: column; gap: 20px; align-items: flex-start; justify-content: space-between; border-radius: 32px; padding: 32px; background: linear-gradient(90deg, #059669, #84cc16); box-shadow: 0 20px 40px rgba(5, 150, 105, 0.22); }
.fine-print { margin-top: 20px; font-size: 0.95rem; }
@media (min-width: 760px) { .quick-buy, .two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); } .three-up { grid-template-columns: repeat(3, minmax(0, 1fr)); } .gallery { grid-template-columns: repeat(2, minmax(0, 1fr)); } .split, .hero-grid, .banner { grid-template-columns: 1fr 1fr; } .cta { flex-direction: row; align-items: center; } }
@media (min-width: 1100px) { .gallery { grid-template-columns: repeat(3, minmax(0, 1fr)); } .split { grid-template-columns: 0.9fr 1.1fr; } .banner { grid-template-columns: 1.3fr 0.7fr; { }
.idea-post {
  margin-top: 32px;
  padding: 24px;
  border-radius: 24px;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
}

.idea-post h2 {
  margin-top: 0;
  color: #0f172a;
}

.idea-post p {
  color: #475569;
  font-size: 1rem;
  line-height: 1.7;
}
