/*
Theme Name: Hello Elementor Child — Your Help UA
Template: hello-elementor
Description: Your Help UA — child trauma rehabilitation. Deep navy + warm gold.
Version: 1.0.0
Author: croscor
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Cormorant+Garamond:wght@500;600;700&display=swap');

:root {
  --c-primary:  #0a1d3d;
  --c-primary-2: #142a52;
  --c-accent:   #D4A94A;
  --c-bg:       #FAF8F2;
  --c-ink:      #1A1815;
  --c-muted:    #6B6157;
  --c-line:     rgba(26,24,21,.08);
  --c-soft:     #FFFFFF;
  --r-soft:     12px;
  --r-pill:     999px;
  --w-max:      1180px;
  --gap-sec:    clamp(64px, 9vw, 120px);
  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'Inter', system-ui, sans-serif;
}

html { scroll-behavior: smooth; }
body { margin: 0; background: var(--c-bg); color: var(--c-ink); font: 16px/1.65 var(--font-body); -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--c-primary); transition: color .15s ease; }
a:hover { color: var(--c-accent); }

h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); letter-spacing: -0.005em; line-height: 1.1; margin: 0 0 .5em; }
h1 { font-size: clamp(44px, 7vw, 84px); font-weight: 600; }
h2 { font-size: clamp(30px, 4.5vw, 52px); font-weight: 600; }
h3 { font-size: clamp(20px, 2.4vw, 28px); font-weight: 600; }

p { margin: 0 0 1em; }
p.sec-label { font: 600 13px/1.2 var(--font-body); letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-accent); margin-bottom: 18px; }

.btn { display: inline-block; padding: 14px 30px; background: var(--c-accent); color: var(--c-primary); border-radius: var(--r-pill); font: 600 15px/1 var(--font-body); border: 0; cursor: pointer; transition: background .15s ease, color .15s ease, transform .15s ease; }
.btn:hover { background: var(--c-primary); color: var(--c-accent); transform: translateY(-1px); }

section[data-block] { padding: var(--gap-sec) 0; }
section[data-block] > * { max-width: var(--w-max); margin: 0 auto; padding: 0 24px; box-sizing: border-box; }

/* Hero */
section[data-block="hero"] {
  position: relative; padding: clamp(96px, 14vw, 168px) 0 clamp(72px, 10vw, 136px);
  background: var(--c-primary); color: #fff; overflow: hidden;
}
section[data-block="hero"]::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(800px 500px at 85% 25%, rgba(212,169,74,.18) 0%, transparent 60%),
    radial-gradient(600px 400px at 15% 80%, rgba(20,42,82,.6) 0%, transparent 70%);
}
section[data-block="hero"] > * { position: relative; z-index: 2; }
section[data-block="hero"] .badge { display: inline-block; padding: 8px 18px; background: rgba(212,169,74,.14); color: var(--c-accent); border: 1px solid rgba(212,169,74,.4); border-radius: var(--r-pill); font: 500 12px/1 var(--font-body); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 32px; }
section[data-block="hero"] h1 { color: #fff; }
section[data-block="hero"] h1 em { font-style: italic; color: var(--c-accent); }
section[data-block="hero"] p { color: rgba(255,255,255,.82); max-width: 660px; font-size: clamp(16px, 2vw, 19px); }

/* Stats row — light, paper-like */
section[data-block="stats-row"] {
  background: var(--c-soft); padding: clamp(48px, 7vw, 80px) 0;
  border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line);
}
section[data-block="stats-row"] > * { display: grid; grid-template-columns: 1fr; gap: 32px; }
@media (min-width: 640px) { section[data-block="stats-row"] > * { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { section[data-block="stats-row"] > * { grid-template-columns: repeat(4, 1fr); } }
.stat { padding: 0 24px; text-align: left; }
.stat .n { display: block; font: 600 clamp(40px, 6vw, 64px)/1 var(--font-display); color: var(--c-primary); }
.stat .l { display: block; font-size: 14px; color: var(--c-muted); margin-top: 8px; line-height: 1.4; }

/* About-split */
section[data-block="about-split"] > div { display: grid; grid-template-columns: 1fr; gap: clamp(32px, 6vw, 80px); align-items: center; }
@media (min-width: 768px) { section[data-block="about-split"] > div { grid-template-columns: 6fr 5fr; } }
section[data-block="about-split"] h2 em { font-style: italic; color: var(--c-accent); }
section[data-block="about-split"] .media img { border-radius: var(--r-soft); }

/* Cards (services + benefits) */
section[data-block="services-grid"] .cards,
section[data-block="benefits"] .cards {
  display: grid; gap: 20px; grid-template-columns: 1fr; margin-top: 32px;
}
@media (min-width: 640px) { section[data-block="services-grid"] .cards, section[data-block="benefits"] .cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { section[data-block="services-grid"] .cards, section[data-block="benefits"] .cards { grid-template-columns: repeat(3, 1fr); } }

.card, .b-card {
  padding: 28px 24px; background: var(--c-soft); border: 1px solid var(--c-line); border-radius: var(--r-soft);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.card:hover, .b-card:hover { transform: translateY(-3px); border-color: var(--c-accent); box-shadow: 0 12px 28px rgba(10,29,61,.08); }
.card h3, .b-card h3 { color: var(--c-primary); margin-bottom: 12px; }
.card p strong, .b-card p strong { color: var(--c-accent); font-weight: 600; }
.card p, .b-card p { font-size: 15px; line-height: 1.6; color: var(--c-muted); margin-bottom: 8px; }
.card .btn { margin-top: 14px; }

/* How-grid (program days, timeline) */
section[data-block="how-grid"] {
  background: var(--c-soft);
  padding-top: clamp(72px, 10vw, 128px); padding-bottom: clamp(72px, 10vw, 128px);
}
section[data-block="how-grid"] > .step {
  display: grid; grid-template-columns: 100px 1fr; gap: 24px; align-items: start;
  max-width: 820px; margin: 16px auto; padding: 24px;
  background: var(--c-bg); border-radius: var(--r-soft); border: 1px solid var(--c-line);
}
.step .num { font: 600 18px/1.1 var(--font-display); color: var(--c-accent); background: var(--c-primary); width: 88px; padding: 14px 12px; border-radius: var(--r-soft); text-align: center; color: var(--c-accent); }
.step h3 { margin-bottom: 8px; color: var(--c-primary); }
.step ul { padding: 0; margin: 0; list-style: none; }
.step ul li { color: var(--c-muted); font-size: 15px; line-height: 1.6; }

/* CTA */
section[data-block="cta-section"] { text-align: center; padding: clamp(72px, 10vw, 128px) 24px; color: #fff; }
section[data-block="cta-section"] h2 { color: #fff; }
section[data-block="cta-section"] h2 em { font-style: italic; color: var(--c-accent); }
section[data-block="cta-section"] p { color: rgba(255,255,255,.88); max-width: 640px; margin: 0 auto; font-size: 17px; }
section[data-block="cta-section"] .btn { background: var(--c-accent); color: var(--c-primary); margin-top: 24px; }
section[data-block="cta-section"] .btn:hover { background: #fff; color: var(--c-primary); }

/* FAQ */
section[data-block="faq"] > .faq-item {
  max-width: 800px; margin: 12px auto; padding: 24px; background: var(--c-soft);
  border-radius: var(--r-soft); border: 1px solid var(--c-line);
}
.faq-item .q { font: 600 18px/1.4 var(--font-display); color: var(--c-primary); margin-bottom: 8px; }
.faq-item .a { color: var(--c-muted); line-height: 1.6; }

/* Contacts */
section[data-block="contacts-form"] { display: grid; grid-template-columns: 1fr; gap: 48px; max-width: var(--w-max); margin: 0 auto; padding: var(--gap-sec) 24px; }
@media (min-width: 900px) { section[data-block="contacts-form"] { grid-template-columns: 1fr 1fr; align-items: start; } }
section[data-block="contacts-form"] .info p { color: var(--c-muted); margin-bottom: 24px; max-width: 480px; }
section[data-block="contacts-form"] .contact-item { display: flex; flex-direction: column; gap: 4px; padding: 14px 0; border-bottom: 1px solid var(--c-line); }
.ci-label { color: var(--c-accent); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; }
.ci-val { color: var(--c-ink); font-size: 16px; }
section[data-block="contacts-form"] form { background: var(--c-soft); padding: 32px; border-radius: var(--r-soft); border: 1px solid var(--c-line); }
section[data-block="contacts-form"] input, section[data-block="contacts-form"] textarea {
  display: block; width: 100%; background: var(--c-bg); border: 1px solid var(--c-line); color: var(--c-ink);
  padding: 14px 16px; border-radius: 8px; font: 400 15px/1.4 var(--font-body); margin-bottom: 16px; box-sizing: border-box;
}
section[data-block="contacts-form"] textarea { min-height: 140px; resize: vertical; }
section[data-block="contacts-form"] input:focus, section[data-block="contacts-form"] textarea:focus { outline: none; border-color: var(--c-accent); }

@media (max-width: 640px) {
  h1 { font-size: 44px; }
  h2 { font-size: 32px; }
  .btn { width: 100%; box-sizing: border-box; text-align: center; }
}
