
:root {
  --red: #E4002B;
  --bg: #ffffff;
  --text: #111111;
  --muted: #666666;
  --border: #e9e9e9;
  --shadow: 0 10px 30px rgba(0,0,0,.06);
}

* { box-sizing: border-box; }
html, body { margin:0; padding:0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: var(--text); background: var(--bg); }

a { color: var(--red); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { width: min(1100px, 92%); margin: 0 auto; }

.header { position: sticky; top:0; background:#fff; z-index:10; border-bottom: 1px solid var(--border); }
.header-inner { display:flex; align-items:center; justify-content:space-between; padding: 14px 0; gap:16px; }
.brand { display:flex; align-items:center; gap:10px; }
.brand img { height:32px; width:auto; }
.brand-name { font-weight: 700; letter-spacing:.3px; color: var(--red); font-size: 1.1rem; }

.nav { display:flex; gap:20px; align-items:center; }
.nav a { font-weight:600; color:#222; }
.cta-btn { display:inline-block; background: var(--red); color:#fff; padding: 10px 16px; border-radius: 8px; border: 2px solid var(--red); }
.cta-btn:hover { background:#fff; color:var(--red); text-decoration:none; }

.hero { padding: 56px 0 24px; background: linear-gradient(180deg, rgba(228,0,43,.05), transparent 60%); }
.hero-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap: 40px; align-items:center; }
.hero h1 { font-size: clamp(28px, 5vw, 44px); line-height:1.1; margin:0 0 12px; }
.hero p.lead { font-size: 1.15rem; color:#333; margin: 0 0 20px; }

.badges { display:flex; gap:16px; flex-wrap:wrap; margin: 12px 0 0; }
.badge { background:#fff; border:1px solid var(--border); padding:8px 12px; border-radius: 999px; font-weight:600; font-size:.9rem; box-shadow: var(--shadow); }

.card { background:#fff; border:1px solid var(--border); border-radius: 14px; padding: 18px; box-shadow: var(--shadow); }
.card h3 { margin-top:0; }

.form { display:grid; gap:12px; }
.form label { font-weight: 600; font-size:.92rem; }
.form input[type="text"],
.form input[type="email"],
.form input[type="date"],
.form input[type="number"],
.form select,
.form textarea { width:100%; padding:12px; border:1px solid var(--border); border-radius:10px; font-size:1rem; }
.form textarea { min-height:110px; }
.form .row { display:grid; gap:12px; grid-template-columns: 1fr 1fr; }
.form .row-3 { display:grid; gap:12px; grid-template-columns: 1fr 1fr 1fr; }
.form .actions { display:flex; align-items:center; gap:12px; }
.button { background: var(--red); color:#fff; border:2px solid var(--red); padding: 12px 18px; border-radius: 10px; font-weight:700; cursor:pointer; }
.button.secondary { background:#fff; color: var(--red); }
.helper { color: var(--muted); font-size:.9rem; }

.features { padding: 36px 0; }
.features-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:16px; }
.feature { background:#fff; border:1px solid var(--border); border-radius:14px; padding:16px; box-shadow: var(--shadow); }
.feature h4 { margin:6px 0; }
.feature p { color:#333; margin:0; font-size:.95rem; }

.steps { padding: 16px 0 48px; }
.stepper { display:grid; grid-template-columns: repeat(3, 1fr); gap:20px; }
.step { padding:16px; border:1px solid var(--border); border-radius:14px; background:#fff; box-shadow: var(--shadow); }
.kicker { text-transform:uppercase; letter-spacing:.12em; color: var(--muted); font-weight:700; font-size:.72rem; }

.footer { margin-top: 40px; border-top:1px solid var(--border); background:#fff; }
.footer-inner { padding: 24px 0; display:grid; grid-template-columns: 1.2fr .8fr; gap:20px; }
.copy { color: var(--muted); font-size:.9rem; }

.notice { border-left: 4px solid var(--red); background: rgba(228,0,43,.05); padding: 12px 14px; border-radius: 8px; }
small.required { color: var(--muted); }
.required-asterisk::after { content:" *"; color: var(--red); }

@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; }
  .features-grid { grid-template-columns: 1fr 1fr; }
  .stepper { grid-template-columns: 1fr; }
  .form .row, .form .row-3 { grid-template-columns: 1fr; }
  .nav { display:none; }
  .nav.is-open { display:flex; flex-direction:column; align-items:flex-start; gap:12px; padding-bottom:12px; }
  .menu-btn { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--border); border-radius:10px; padding:10px 12px; background:#fff; }
}
