/* Home page specific styles for ItTakesTwoPl. Prefixed with .home- to avoid conflicts. */
:root {
  --home-bg: #0b0f1a;
  --home-grad-1: #ff7a59;
  --home-grad-2: #ffd166;
  --home-grad-3: #70e1f5;
  --home-text: #0d0d0d;
  --home-surface: #ffffff;
  --home-surface-alt: #0f1424;
  --home-border: rgba(13, 18, 31, 0.1);
  --home-shadow: 0 10px 30px rgba(10, 10, 10, 0.1);
  --home-radius: 14px;
}

/* Hero */
.home-hero {
  background: radial-gradient(1200px 600px at 10% 10%, rgba(255, 218, 185, 0.4), transparent),
              radial-gradient(900px 500px at 90% 20%, rgba(112, 225, 245, 0.35), transparent),
              linear-gradient(180deg, #fefefe 0%, #f9fbff 100%);
  color: var(--home-text);
  padding: clamp(2rem, 4vw, 4rem) 0;
}
.home-hero__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(1rem, 3vw, 2rem);
}
.home-hero__content h1 {
  font-size: clamp(1.8rem, 3.4vw, 3rem);
  line-height: 1.15;
  margin: 0 0 0.75rem 0;
}
.home-hero__lead {
  font-size: clamp(1rem, 1.4vw, 1.125rem);
  color: #333;
  margin: 0 0 1rem 0;
}
.home-hero__media img {
  width: 100%;
  height: auto;
  border-radius: var(--home-radius);
  box-shadow: var(--home-shadow);
}

/* Buttons */
.home-cta { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.home-btn {
  --btn-bg: #111827; --btn-fg: #fff; --btn-bd: transparent;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.75rem 1rem; border-radius: 999px; text-decoration: none;
  font-weight: 600; border: 1px solid var(--btn-bd); transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, color .15s ease;
}
.home-btn:focus-visible { outline: 3px solid #111; outline-offset: 2px; }
.home-btn--primary { background: var(--home-grad-1); color: #111; border-color: rgba(0,0,0,0.06); }
.home-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 8px 18px rgba(255, 122, 89, 0.3); }
.home-btn--secondary { background: #111827; color: #fff; }
.home-btn--secondary:hover { transform: translateY(-1px); box-shadow: 0 8px 18px rgba(17, 24, 39, 0.3); }
.home-btn--ghost { background: #ffffff; color: #111827; border-color: rgba(17,24,39,0.15); }
.home-btn--ghost:hover { background: #f7f7f9; }

/* Quicklinks */
.home-quicklinks ul { display: flex; gap: 1rem; flex-wrap: wrap; padding: 0; margin: 0.5rem 0 0; list-style: none; }
.home-quicklinks a { color: #0a66c2; font-weight: 600; }
.home-quicklinks a:focus-visible { outline: 3px solid #0a66c2; outline-offset: 2px; border-radius: 6px; }

/* Generic sections */
.home-section { padding: clamp(2rem, 5vw, 4rem) 0; background: #fff; }
.home-section--alt { background: linear-gradient(180deg, #f7faff 0%, #ffffff 100%); }
.home-section__header { max-width: 1200px; margin: 0 auto; padding: 0 clamp(1rem, 3vw, 2rem) 1rem; }
.home-section__header h2 { margin: 0 0 .25rem 0; font-size: clamp(1.5rem, 2.4vw, 2rem); }
.home-section__header p { margin: 0; color: #444; }
.home-section__inner { max-width: 1200px; margin: 0 auto; padding: 0 clamp(1rem, 3vw, 2rem); display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1rem, 3vw, 2rem); align-items: center; }

/* Grid & cards */
.home-grid { max-width: 1200px; margin: 1rem auto 0; padding: 0 clamp(1rem, 3vw, 2rem); display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.5vw, 1.5rem); }
.home-grid--list { grid-template-columns: 1fr; }
.home-card { background: var(--home-surface); border: 1px solid var(--home-border); border-radius: var(--home-radius); padding: clamp(1rem, 2.5vw, 1.25rem); box-shadow: var(--home-shadow); }
.home-card h3 { margin: 0 0 .25rem 0; font-size: 1.1rem; }
.home-card p { margin: 0 0 .5rem 0; color: #444; }
.home-link { color: #0a66c2; font-weight: 600; text-decoration: none; }
.home-link:hover { text-decoration: underline; }

/* Lists */
.home-list { margin: .75rem 0 1rem; padding-left: 1.25rem; }
.home-bullets { max-width: 900px; margin: 0.5rem auto 0; padding: 0 clamp(1rem, 3vw, 2rem); list-style: disc; color: #333; }
.home-bullets li { margin: 0.25rem 0; }

/* Figures */
.home-figure { max-width: 1200px; margin: 1rem auto 0; padding: 0 clamp(1rem, 3vw, 2rem); }
.home-figure img { width: 100%; height: auto; border-radius: var(--home-radius); box-shadow: var(--home-shadow); }
.home-figure figcaption { font-size: .9rem; color: #555; margin-top: .375rem; }
.home-figure--right { order: 2; }

/* List cards */
.home-listcard { background: #fff; border: 1px solid var(--home-border); border-radius: var(--home-radius); padding: 1rem; box-shadow: var(--home-shadow); }
.home-listcard h3 { margin: 0 0 .25rem 0; font-size: 1.05rem; }
.home-listcard p { margin: 0; color: #555; }

/* Final CTA */
.home-cta-final { text-align: center; background: radial-gradient(800px 400px at 50% 0%, rgba(255, 209, 102, 0.35), transparent), #fff; }
.home-cta-final h2 { margin: 0 0 .5rem 0; }
.home-center { max-width: 1200px; margin: 1rem auto 0; padding: 0 clamp(1rem, 3vw, 2rem); text-align: center; }

/* Accessibility helpers */
.skip-link { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.skip-link:focus { position: fixed; left: 1rem; top: 1rem; width: auto; height: auto; background: #111; color: #fff; padding: .5rem .75rem; border-radius: 6px; z-index: 10000; }
.visually-hidden { position: absolute !important; height: 1px; width: 1px; overflow: hidden; clip: rect(1px, 1px, 1px, 1px); white-space: nowrap; }

/* Responsive */
@media (max-width: 980px) {
  .home-hero__inner { grid-template-columns: 1fr; }
  .home-section__inner { grid-template-columns: 1fr; }
  .home-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .home-grid { grid-template-columns: 1fr; }
  .home-quicklinks ul { gap: .5rem; }
}
