/* =====================================================================
   roboteca · landing premium (kituri + magazin de piese)
   Tokens din brand-guide.md
   ===================================================================== */
:root {
  --indigo: #3730A3;
  --indigo-deep: #2A2480;
  --indigo-night: #1C1A4D;
  --amber: #FFB300;
  --amber-deep: #FF8A00;
  --ink: #111827;
  --cloud: #F8FAFC;
  --white: #FFFFFF;
  --muted: #6B7280;
  --line: rgba(17, 24, 39, 0.08);

  --maxw: 1120px;
  --gap: clamp(1rem, 3vw, 2rem);
  --radius: 20px;
  --radius-sm: 12px;

  --font-head: 'Poppins', 'Trebuchet MS', sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  --shadow-sm: 0 2px 8px rgba(17, 24, 39, 0.06);
  --shadow-md: 0 12px 32px rgba(28, 26, 77, 0.12);
  --shadow-lg: 0 28px 60px rgba(28, 26, 77, 0.22);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0; font-family: var(--font-body); color: var(--ink); background: var(--cloud);
  line-height: 1.6; font-size: clamp(1rem, 0.97rem + 0.2vw, 1.075rem); overflow-x: clip;
}
img, svg { display: block; max-width: 100%; }
h1, h2, h3 { font-family: var(--font-head); line-height: 1.1; margin: 0; letter-spacing: -0.02em; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
ol { margin: 0; padding: 0; list-style: none; }
fieldset { margin: 0; padding: 0; border: 0; }
legend { padding: 0; }

.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2rem); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

.scroll-progress { position: fixed; top: 0; left: 0; height: 3px; width: 100%; z-index: 90; background: linear-gradient(90deg, var(--amber), var(--amber-deep)); transform: scaleX(0); transform-origin: 0 50%; }

/* ---------- buttons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-head); font-weight: 600; font-size: 1rem; padding: 0.85rem 1.5rem; border-radius: 999px; border: 0; cursor: pointer; transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease), background 0.25s var(--ease); white-space: nowrap; }
.btn-amber { background: var(--amber); color: var(--ink); box-shadow: 0 8px 20px rgba(255, 179, 0, 0.35); }
.btn-amber:hover { background: var(--amber-deep); transform: translateY(-2px); box-shadow: 0 12px 26px rgba(255, 138, 0, 0.45); }
.btn-lg { padding: 1.05rem 2.2rem; font-size: 1.1rem; margin-top: 0.4rem; }
.btn-ghost { background: rgba(255,255,255,0.1); color: var(--white); border: 1px solid rgba(255,255,255,0.3); padding: 0.6rem 1.1rem; font-size: 0.95rem; }
.btn-ghost:hover { background: rgba(255,255,255,0.2); }

/* ---------- header ---------- */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 80; transition: background 0.3s var(--ease), backdrop-filter 0.3s var(--ease), box-shadow 0.3s var(--ease); }
.site-header.scrolled { background: rgba(28, 26, 77, 0.72); backdrop-filter: saturate(140%) blur(12px); box-shadow: 0 1px 0 rgba(255,255,255,0.08); }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding-block: 0.9rem; }
.brand img { height: 40px; width: auto; }
.site-header .brand img { filter: brightness(0) invert(1); }

/* ---------- eyebrow / heads ---------- */
.eyebrow { font-family: var(--font-head); font-weight: 600; font-size: 0.8rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--amber); margin: 0 0 0.9rem; }
.eyebrow-dark { color: var(--indigo); }
.section-head { max-width: 680px; margin: 0 auto clamp(2.2rem, 5vw, 3.5rem); text-align: center; }
.section-title { font-size: clamp(1.9rem, 1.2rem + 3vw, 3.1rem); font-weight: 700; color: var(--ink); }
.section-title-light { color: var(--white); }
.section-sub { margin-top: 0.9rem; color: var(--muted); font-size: 1.05rem; }
.giveaway .section-sub, .signup .section-sub { color: rgba(255,255,255,0.78); }
.section-cta { text-align: center; margin-top: clamp(2rem, 4vw, 3rem); }

/* =====================================================================
   1. HERO
   ===================================================================== */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; background: radial-gradient(120% 90% at 50% 0%, var(--indigo) 0%, var(--indigo-deep) 45%, var(--indigo-night) 100%); color: var(--white); overflow: hidden; isolation: isolate; }
.hero-bg { position: absolute; inset: 0; z-index: -1; }
.hero-aurora { position: absolute; inset: -30%; background: radial-gradient(40% 40% at 20% 30%, rgba(91,82,214,0.55), transparent 70%), radial-gradient(35% 35% at 80% 20%, rgba(255,179,0,0.22), transparent 70%), radial-gradient(45% 45% at 65% 80%, rgba(55,48,163,0.6), transparent 70%); filter: blur(20px); }
.hero-grid { position: absolute; inset: -10% 0 0 0; background-image: linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(120% 80% at 50% 20%, #000 30%, transparent 75%); -webkit-mask-image: radial-gradient(120% 80% at 50% 20%, #000 30%, transparent 75%); }
.glow { position: absolute; border-radius: 50%; filter: blur(70px); }
.glow-amber { width: 460px; height: 460px; background: var(--amber); top: -120px; right: -80px; opacity: 0.3; }
.glow-indigo { width: 520px; height: 520px; background: #5B52D6; bottom: -180px; left: -120px; opacity: 0.5; }
.chip { position: absolute; font-family: var(--font-head); font-weight: 700; color: rgba(255,255,255,0.16); user-select: none; line-height: 1; }
.chip-1 { top: 24%; left: 12%; font-size: 3.4rem; }
.chip-2 { top: 62%; left: 22%; font-size: 2rem; color: rgba(255,179,0,0.35); }
.chip-3 { top: 38%; right: 24%; font-size: 1.4rem; color: rgba(255,179,0,0.4); }
.chip-4 { top: 70%; right: 14%; font-size: 2.6rem; }
.hero-robot { position: absolute; top: 14%; right: 8%; filter: drop-shadow(0 24px 40px rgba(0,0,0,0.35)); }
.hero-robot svg { width: clamp(150px, 22vw, 260px); height: auto; }
.robot-eye { transform-origin: center; transform-box: fill-box; }

.hero-inner { position: relative; max-width: 720px; padding-block: 7rem 4rem; }
.hero-title { font-size: clamp(2.4rem, 1.1rem + 5.4vw, 4.4rem); font-weight: 700; margin-bottom: 1.3rem; }
.hero-title .hl { color: var(--amber); }
.hero-sub { font-size: clamp(1.05rem, 1rem + 0.6vw, 1.25rem); color: rgba(255,255,255,0.82); max-width: 50ch; margin-bottom: 1.5rem; }

.lead-perk { display: flex; align-items: flex-start; gap: 0.6rem; background: rgba(255,179,0,0.12); border: 1px solid rgba(255,179,0,0.35); color: #FFE7B3; padding: 0.7rem 1.1rem; border-radius: 14px; font-size: 0.92rem; line-height: 1.5; margin-bottom: 1.5rem; max-width: 520px; }
.lead-perk strong { color: var(--amber); font-weight: 600; }
.lead-perk-ico { flex: 0 0 auto; color: var(--amber); display: flex; }
.lead-perk-text { flex: 1 1 auto; }

/* =====================================================================
   LEAD/CONTACT (email SAU telefon) - hero + signup
   ===================================================================== */
.lead { max-width: 480px; }
.lead-toggle { display: inline-flex; gap: 4px; padding: 4px; margin-bottom: 0.7rem; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.18); border-radius: 999px; }
.lead-tab { font-family: var(--font-head); font-weight: 600; font-size: 0.9rem; color: rgba(255,255,255,0.7); background: transparent; border: 0; cursor: pointer; padding: 0.45rem 1.1rem; border-radius: 999px; transition: background 0.25s var(--ease), color 0.25s var(--ease); }
.lead-tab.is-active { background: var(--white); color: var(--indigo); box-shadow: var(--shadow-sm); }
.lead-form { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.lead-input { flex: 1 1 220px; min-width: 0; display: flex; }
.lead-input[hidden] { display: none; }
.lead-input input { width: 100%; padding: 0.9rem 1.1rem; border-radius: 999px; border: 1px solid rgba(255,255,255,0.25); background: rgba(255,255,255,0.1); color: var(--white); font-family: var(--font-body); font-size: 1rem; transition: border 0.2s, background 0.2s; }
.lead-input input::placeholder { color: rgba(255,255,255,0.55); }
.lead-input input:focus { outline: none; border-color: var(--amber); background: rgba(255,255,255,0.16); }
.lead-input input.invalid { border-color: #FCA5A5; background: rgba(252,165,165,0.12); }
.form-note { font-size: 0.85rem; color: rgba(255,255,255,0.6); margin-top: 0.9rem; }
.form-note-light { color: rgba(255,255,255,0.6); }

/* =====================================================================
   2. CE PREGATIM (offer) - carduri albe pe fundal cloud
   ===================================================================== */
.offer { padding-block: clamp(3.5rem, 8vw, 6rem); background: var(--cloud); border-bottom: 1px solid var(--line); }
.offer-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 2.4vw, 1.6rem); align-items: stretch; }
.offer-card { display: flex; gap: 1.2rem; background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1.6rem, 3vw, 2.2rem); box-shadow: var(--shadow-sm); transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease); }
.offer-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.offer-card-primary { border-color: rgba(55,48,163,0.25); box-shadow: 0 12px 30px rgba(55,48,163,0.1); }
.offer-ico { flex: 0 0 auto; width: 60px; height: 60px; display: grid; place-items: center; border-radius: 16px; background: rgba(55,48,163,0.1); color: var(--indigo); }
.offer-ico-amber { background: rgba(255,179,0,0.16); color: var(--amber-deep); }
.offer-body { flex: 1 1 auto; }
.offer-badge { display: inline-block; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--indigo); background: rgba(55,48,163,0.1); padding: 0.3rem 0.75rem; border-radius: 999px; margin-bottom: 0.7rem; }
.offer-badge-soon { color: var(--amber-deep); background: rgba(255,179,0,0.16); }
.offer-card h3 { font-size: 1.35rem; font-weight: 600; margin-bottom: 0.5rem; }
.offer-card p { color: var(--muted); }
.offer-for { margin-top: 0.7rem; font-weight: 500; color: var(--ink); font-size: 0.92rem; }

/* =====================================================================
   3. STEPS
   ===================================================================== */
.steps { padding-block: clamp(3.5rem, 8vw, 6.5rem); background: var(--white); }
.steps-wrap { position: relative; }
.steps-line { position: absolute; top: 28px; left: 8%; right: 8%; height: 3px; background: var(--line); border-radius: 999px; }
.steps-progress { display: block; height: 100%; width: 0%; background: linear-gradient(90deg, var(--indigo), var(--amber)); border-radius: 999px; }
.steps-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.4rem, 3vw, 2.6rem); }
.step { text-align: center; padding-inline: 0.5rem; }
.step-num { width: 58px; height: 58px; display: grid; place-items: center; margin: 0 auto 1.1rem; font-family: var(--font-head); font-weight: 700; font-size: 1.5rem; color: var(--white); background: var(--indigo); border-radius: 50%; box-shadow: 0 8px 20px rgba(55,48,163,0.35); border: 4px solid var(--white); position: relative; z-index: 1; }
.step h3 { font-size: 1.3rem; font-weight: 600; margin-bottom: 0.5rem; }
.step p { color: var(--muted); }

/* =====================================================================
   4. BENTO
   ===================================================================== */
.bento-section { padding-block: clamp(3.5rem, 8vw, 6.5rem); background: var(--cloud); }
.bento { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(0.8rem, 1.6vw, 1.2rem); }
.bento-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1.4rem, 2.4vw, 2rem); box-shadow: var(--shadow-sm); transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease); grid-column: span 2; }
.bento-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.bento-card h3 { font-size: 1.25rem; font-weight: 600; margin-bottom: 0.5rem; }
.bento-card p { color: var(--muted); font-size: 0.98rem; }
.card-icon { width: 52px; height: 52px; display: grid; place-items: center; background: rgba(55,48,163,0.08); color: var(--indigo); border-radius: 14px; margin-bottom: 1.1rem; }
.card-wow { background: linear-gradient(150deg, var(--indigo) 0%, var(--indigo-deep) 100%); color: var(--white); border-color: transparent; }
.card-wow p { color: rgba(255,255,255,0.82); }
.card-wow .card-icon { background: rgba(255,255,255,0.15); color: var(--amber); }
.card-wide { grid-column: span 4; display: flex; flex-direction: column; }
.card-parent { background: linear-gradient(150deg, #FFF7E6 0%, var(--white) 60%); border-color: rgba(255,179,0,0.3); }
.card-parent .card-icon { background: rgba(255,179,0,0.2); color: var(--amber-deep); }

/* =====================================================================
   5. GIVEAWAY
   ===================================================================== */
.giveaway { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--indigo) 0%, var(--indigo-deep) 100%); color: var(--white); padding-block: clamp(3.5rem, 8vw, 6.5rem); }
.giveaway-inner { position: relative; z-index: 1; text-align: center; display: flex; flex-direction: column; align-items: center; }
.perks { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.6rem); width: 100%; margin-bottom: 2.4rem; }
.perk { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.14); border-radius: var(--radius); padding: clamp(1.6rem, 2.6vw, 2.2rem); text-align: left; transition: transform 0.3s var(--ease), background 0.3s var(--ease); }
.perk:hover { transform: translateY(-4px); background: rgba(255,255,255,0.1); }
.perk-ico { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 14px; background: rgba(255,255,255,0.12); color: var(--amber); margin-bottom: 0.9rem; }
.perk h3 { font-size: 1.3rem; font-weight: 600; margin-bottom: 0.5rem; }
.perk p { color: rgba(255,255,255,0.78); font-size: 0.98rem; }
.perk-amber { background: linear-gradient(150deg, rgba(255,179,0,0.22), rgba(255,179,0,0.06)); border-color: rgba(255,179,0,0.4); }
.giveaway-fineprint { margin-top: 1.2rem; font-size: 0.8rem; color: rgba(255,255,255,0.5); max-width: 46ch; }

/* =====================================================================
   6. SIGNUP (CTA final + parere)
   ===================================================================== */
.signup { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--indigo-deep) 0%, var(--indigo-night) 100%); color: var(--white); padding-block: clamp(3.5rem, 8vw, 6.5rem); }
.signup-inner { position: relative; z-index: 1; }
.signup-form { max-width: 640px; margin: 0 auto; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius); padding: clamp(1.4rem, 3.4vw, 2.4rem); }
.sf-block { margin-bottom: 1.7rem; }
.sf-block:last-of-type { margin-bottom: 1.2rem; }
.q-label { display: block; font-family: var(--font-head); font-weight: 600; font-size: 1.02rem; margin-bottom: 0.8rem; }
.q-label .muted { font-family: var(--font-body); font-weight: 400; color: rgba(255,255,255,0.5); }

/* choices (carduri radio) */
.choices { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.choice { position: relative; cursor: pointer; display: block; }
.choice input { position: absolute; opacity: 0; pointer-events: none; }
.choice-body { display: block; height: 100%; padding: 1.1rem 1.2rem 1.2rem; border: 1.5px solid rgba(255,255,255,0.18); border-radius: var(--radius-sm); background: rgba(255,255,255,0.04); transition: border-color 0.2s var(--ease), background 0.2s var(--ease); }
.choice:hover .choice-body { border-color: rgba(255,255,255,0.4); }
.choice-check { display: inline-block; width: 18px; height: 18px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.4); margin-bottom: 0.6rem; transition: border-color 0.2s, background 0.2s; position: relative; }
.choice.is-selected .choice-body, .choice:has(input:checked) .choice-body { border-color: var(--amber); background: rgba(255,179,0,0.12); }
.choice.is-selected .choice-check, .choice:has(input:checked) .choice-check { border-color: var(--amber); background: var(--amber); }
.choice.is-selected .choice-check::after, .choice:has(input:checked) .choice-check::after { content: ""; position: absolute; inset: 3px; border-radius: 50%; background: var(--indigo-deep); }
.choice input:focus-visible + .choice-body { outline: 2px solid var(--amber); outline-offset: 2px; }
.choice-title { display: block; font-family: var(--font-head); font-weight: 600; font-size: 1.05rem; margin-bottom: 0.25rem; }
.choice-desc { display: block; font-size: 0.9rem; color: rgba(255,255,255,0.72); }

/* pills (interes magazin) */
.pills { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.pill { position: relative; cursor: pointer; }
.pill input { position: absolute; opacity: 0; pointer-events: none; }
.pill span { display: inline-block; padding: 0.55rem 1.2rem; border-radius: 999px; border: 1.5px solid rgba(255,255,255,0.2); background: rgba(255,255,255,0.05); font-family: var(--font-head); font-weight: 500; font-size: 0.95rem; transition: border-color 0.2s, background 0.2s, color 0.2s; }
.pill:hover span { border-color: rgba(255,255,255,0.45); }
.pill.is-selected span, .pill:has(input:checked) span { border-color: var(--amber); background: rgba(255,179,0,0.18); color: var(--white); }
.pill input:focus-visible + span { outline: 2px solid var(--amber); outline-offset: 2px; }

/* age */
.sf-age { width: 150px; max-width: 100%; padding: 0.85rem 1.1rem; border-radius: var(--radius-sm); border: 1px solid rgba(255,255,255,0.25); background: rgba(255,255,255,0.1); color: var(--white); font-family: var(--font-body); font-size: 1rem; }
.sf-age:focus { outline: none; border-color: var(--amber); }
.sf-age::placeholder { color: rgba(255,255,255,0.5); }

.signup-form .btn-lg { width: 100%; }

/* ramuri + nota voucher */
.sf-branch[hidden], .sf-tail[hidden] { display: none; }
.sf-note { display: flex; align-items: flex-start; gap: 0.6rem; background: rgba(255,179,0,0.12); border: 1px solid rgba(255,179,0,0.35); color: #FFE7B3; padding: 0.9rem 1.1rem; border-radius: 12px; line-height: 1.5; font-size: 0.95rem; }
.sf-note strong { color: var(--amber); font-weight: 600; }
.sf-note-ico { flex: 0 0 auto; color: var(--amber); display: flex; margin-top: 1px; }

/* =====================================================================
   FLOAT FIELDS (decor care coboara la scroll - doar desktop)
   ===================================================================== */
.float-field { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.float { position: absolute; opacity: 0.5; }
.float-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--amber); opacity: 0.6; }
.float-ring { width: 46px; height: 46px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.25); }
.float-plus { font-family: var(--font-head); font-weight: 700; font-size: 2.4rem; color: rgba(255,179,0,0.4); line-height: 1; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer { background: var(--indigo-night); color: rgba(255,255,255,0.7); padding-block: clamp(2.6rem, 5vw, 3.6rem) 1.6rem; }
.footer-inner { display: flex; justify-content: space-between; align-items: flex-start; gap: 2rem; flex-wrap: wrap; padding-bottom: 2rem; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer-brand img { height: 38px; width: auto; margin-bottom: 0.7rem; }
.footer-tag { font-family: var(--font-head); color: rgba(255,255,255,0.85); }
.footer-social { display: flex; gap: 1.4rem; }
.footer-social a { font-weight: 500; transition: color 0.2s; }
.footer-social a:hover { color: var(--amber); }
.footer-bottom { display: flex; justify-content: space-between; font-size: 0.85rem; color: rgba(255,255,255,0.45); padding-top: 1.4rem; }

/* ---------- toast ---------- */
.toast { position: fixed; left: 50%; bottom: 2rem; transform: translate(-50%, 140%); background: var(--ink); color: var(--white); padding: 0.9rem 1.4rem; border-radius: 999px; box-shadow: var(--shadow-lg); font-size: 0.95rem; z-index: 100; opacity: 0; transition: transform 0.4s var(--ease), opacity 0.4s var(--ease); max-width: calc(100vw - 2rem); text-align: center; }
.toast.show { transform: translate(-50%, 0); opacity: 1; }
.toast.ok { background: var(--indigo); }

/* =====================================================================
   ANIMATII (doar .has-anim = desktop + motion ok)
   ===================================================================== */
.has-anim .reveal { opacity: 0; transform: translateY(26px); will-change: transform, opacity; }
.has-anim .hero-aurora { animation: aurora 18s ease-in-out infinite alternate; }
@keyframes aurora { 0% { transform: translate3d(-2%, -1%, 0) scale(1); } 100% { transform: translate3d(3%, 2%, 0) scale(1.08); } }
@keyframes blink { 0%, 92%, 100% { transform: scaleY(1); } 96% { transform: scaleY(0.1); } }
.has-anim .robot-eye { animation: blink 5.5s ease-in-out infinite; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 880px) {
  .offer-grid { grid-template-columns: 1fr; }
  .bento { grid-template-columns: 1fr 1fr; }
  .bento-card { grid-column: span 1; }
  .card-wide { grid-column: span 2; }
  .steps-list { grid-template-columns: 1fr; gap: 2.4rem; }
  .steps-line { display: none; }
  .perks { grid-template-columns: 1fr; }
  .choices { grid-template-columns: 1fr; }
  .header-cta { display: none; }
  /* robot in colt sus-dreapta, deasupra continutului (nu sub buton) */
  .hero-inner { padding-top: 9.5rem; }
  .hero-robot { top: 4.5rem; right: 0.85rem; bottom: auto; left: auto; opacity: 1; }
  .hero-robot svg { width: 76px; }
  .chip { display: none; }
  .float { display: none; }
}
@media (max-width: 520px) {
  .bento { grid-template-columns: 1fr; }
  .card-wide { grid-column: span 1; }
  .footer-bottom, .footer-inner { flex-direction: column; }
  .offer-card { flex-direction: column; gap: 1rem; }
  .lead-form { flex-direction: column; }
  .lead-input, .lead-form .btn { width: 100%; flex: 0 0 auto; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
}
