/* ============================================================
   LOWI Distribuidores · site styles
   Built on the Lowi Design System tokens (css/tokens.css).
   ============================================================ */

/* ---------- Layout ---------- */
.container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-pad); }
.section { padding: clamp(48px, 8vw, 96px) 0; }
.section--muted { background: var(--surface-muted); }
.section--dark { background: var(--surface-dark); color: var(--white); }
.section__head { max-width: 720px; margin: 0 auto clamp(32px, 5vw, 56px); text-align: center; }
.eyebrow { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-body); font-weight:700; font-size:0.75rem; letter-spacing:var(--ls-caps); text-transform:uppercase; color:var(--color-brand); margin-bottom:14px; }
.lead { font-size: var(--fs-lg); color: var(--text-secondary); }
.section--dark .lead { color: rgba(255,255,255,0.78); }

/* ---------- Buttons ---------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-body); font-weight:700; border-radius:var(--radius-pill); cursor:pointer; border:2px solid transparent; text-decoration:none; transition: all var(--dur-base) var(--ease-out); line-height:1.1; white-space:nowrap; }
.btn:hover { text-decoration:none; }
.btn:active { transform: scale(0.98); }
.btn--lg { padding:15px 32px; font-size:1.0625rem; }
.btn--md { padding:11px 22px; font-size:0.9375rem; }
.btn--primary { background:var(--color-brand); color:#fff; }
.btn--primary:hover { background:var(--color-brand-hover); box-shadow:var(--shadow-red); transform:translateY(-1px); color:#fff; }
.btn--outline { background:transparent; color:var(--text-primary); border-color:var(--border-default); }
.btn--outline:hover { background:var(--red-050); border-color:var(--color-brand); color:var(--color-brand); }
.btn--white { background:#fff; color:var(--color-brand); }
.btn--white:hover { background:var(--neutral-100); transform:translateY(-1px); color:var(--color-brand); }
.btn--ghost-light { background:transparent; color:#fff; border-color:rgba(255,255,255,0.5); }
.btn--ghost-light:hover { background:rgba(255,255,255,0.12); color:#fff; border-color:#fff; }

/* ---------- Tags ---------- */
.tag { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-body); font-weight:700; font-size:0.75rem; letter-spacing:var(--ls-caps); text-transform:uppercase; padding:8px 15px; border-radius:var(--radius-pill); }
.tag--dark { background:var(--black-900); color:#fff; }
.tag--red { background:var(--color-brand); color:#fff; }
.tag--tint { background:var(--red-050); color:var(--color-brand); }
.reddot { color: var(--color-brand); }

/* ---------- Header ---------- */
.site-header { position: sticky; top:0; z-index:60; background:rgba(255,255,255,0.92); backdrop-filter: saturate(180%) blur(10px); -webkit-backdrop-filter: saturate(180%) blur(10px); border-bottom:1px solid var(--border-subtle); }
.site-header__inner { display:flex; align-items:center; gap:24px; padding:12px var(--container-pad); max-width:var(--container-max); margin:0 auto; }
.site-header__brand { display:flex; align-items:center; flex:0 0 auto; }
.site-header__brand img { height:30px; }
.site-header__nav { display:flex; align-items:center; gap:28px; margin-left:auto; }
.site-header__nav a:not(.btn) { font-family:var(--font-body); font-size:0.9375rem; font-weight:700; color:var(--text-primary); white-space:nowrap; border-bottom:2px solid transparent; padding-bottom:2px; transition:color var(--dur-fast); }
.site-header__nav a:not(.btn):hover { color:var(--color-brand); text-decoration:none; border-color:var(--color-brand); }
.site-header__nav .btn { margin-left:4px; }
.hamburger { display:none; margin-left:auto; width:44px; height:44px; border:none; background:transparent; cursor:pointer; padding:10px; }
.hamburger span { display:block; height:2.5px; background:var(--black-900); border-radius:2px; transition: all var(--dur-base) var(--ease-out); }
.hamburger span + span { margin-top:5px; }
.site-header.is-open .hamburger span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.site-header.is-open .hamburger span:nth-child(2) { opacity:0; }
.site-header.is-open .hamburger span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

/* ---------- Hero (editorial centered) ---------- */
.hero { position:relative; overflow:hidden; padding: clamp(44px, 7vw, 76px) 0 clamp(40px, 6vw, 60px); text-align:center; }
.hero__blob { position:absolute; z-index:0; pointer-events:none; border-radius:50%; will-change:transform; }
.hero__blob--tl { background:var(--red-100); left:-60px; top:-50px; width:clamp(150px,20vw,260px); height:clamp(150px,20vw,260px); }
.hero__blob--br { background:var(--red-050); right:-50px; bottom:-90px; width:clamp(140px,18vw,220px); height:clamp(140px,18vw,220px); }
.hero__inner { position:relative; z-index:1; }
.hero h1 { font-size: clamp(2.1rem, 5.2vw, 3.7rem); line-height:1.04; max-width:18ch; margin:18px auto 16px; }
.hero p.lead { max-width:54ch; margin:0 auto 30px; }
.hero__cta { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.hero__pills { display:flex; gap:24px; justify-content:center; align-items:flex-end; margin-top: clamp(36px, 5vw, 56px); flex-wrap:wrap; }
.hero__pills img { width: clamp(150px, 19vw, 230px); }
.hero__trust { font-size:0.875rem; color:var(--text-muted); margin-top:18px; }

/* ---------- Feature grid ---------- */
.feature-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.feature-card { background:var(--surface-card); border-radius:var(--radius-xl); box-shadow:var(--shadow-md); padding:0 0 28px; overflow:hidden; display:flex; flex-direction:column; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.feature-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.feature-card__media { background:var(--neutral-050); display:flex; align-items:center; justify-content:center; padding:18px 18px 0; }
.feature-card__media img { width:auto; max-height:190px; }
.feature-card__body { padding:24px 28px 0; }
.feature-card h3 { font-size:var(--fs-h4); margin-bottom:10px; }
.feature-card p { color:var(--text-secondary); margin:0; }

/* ---------- Highlight band ---------- */
.highlight-band { background:var(--surface-dark); color:#fff; border-radius:var(--radius-xl); padding: clamp(32px,5vw,52px) clamp(28px,5vw,56px); margin-top:32px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:clamp(22px,3vw,30px); }
.highlight-band p { margin:0; max-width:none; font-size:var(--fs-lg); }
.balloons { display:flex; flex-wrap:wrap; justify-content:center; gap:14px 16px; }
.balloon { background:var(--red-100); color:var(--red-700); font-family:var(--font-display); font-weight:700; font-size:clamp(0.9rem,1.6vw,1.05rem); padding:13px 24px; border-radius:var(--radius-pill); box-shadow:0 8px 20px rgba(13,13,13,0.18); animation: balloonFloat 3.4s var(--ease-standard) infinite; will-change:transform; }
.balloon:nth-child(1){ animation-delay:0s; }
.balloon:nth-child(2){ animation-delay:.5s; }
.balloon:nth-child(3){ animation-delay:1s; }
.balloon:nth-child(4){ animation-delay:1.5s; }
@keyframes balloonFloat { 0%,100% { transform:translateY(0) rotate(-0.5deg); } 50% { transform:translateY(-9px) rotate(0.5deg); } }

/* ---------- Why Lowi / stat ---------- */
.why-statement { text-align:center; max-width:760px; margin:0 auto 48px; font-family:var(--font-display); font-weight:700; font-size:clamp(1.4rem,3vw,2rem); line-height:1.25; letter-spacing:var(--ls-tight); }
.why-grid { display:grid; grid-template-columns:0.9fr 1.1fr; gap:48px; align-items:center; }
.stat-card { background:var(--color-brand); color:#fff; border-radius:var(--radius-2xl); padding:clamp(32px,4vw,48px); text-align:center; box-shadow:var(--shadow-red); }
.stat-card .stat-num { font-family:var(--font-display); font-weight:800; font-size:clamp(2.6rem,6vw,4rem); line-height:1; letter-spacing:var(--ls-tight); }
.stat-card .stat-sub { font-weight:700; font-size:var(--fs-lg); margin-top:8px; }
.stat-card p { color:rgba(255,255,255,0.92); margin:18px 0 0; }
.why-points { display:flex; flex-direction:column; gap:18px; }
.why-points li { list-style:none; display:flex; gap:14px; align-items:flex-start; }
.why-points .check { flex:0 0 auto; width:28px; height:28px; border-radius:50%; background:var(--red-050); color:var(--color-brand); display:flex; align-items:center; justify-content:center; font-weight:800; margin-top:2px; }
.why-points h4 { margin:0 0 3px; font-size:1.0625rem; }
.why-points p { margin:0; color:var(--text-secondary); font-size:0.9375rem; }

/* ---------- App block ---------- */
.app-block { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; margin-top:64px; }
.app-block__media { position:relative; display:flex; justify-content:center; }
.app-block__media img { width:clamp(240px,34vw,360px); filter:drop-shadow(0 22px 44px rgba(13,13,13,0.22)); position:relative; z-index:1; }
.app-block h3 { font-size:clamp(1.6rem,3.2vw,2rem); }
.app-block p { color:rgba(255,255,255,0.78); font-size:var(--fs-lg); }
.app-badges { display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; }
.app-badge { display:inline-flex; align-items:center; gap:9px; background:#fff; color:var(--black-900); border-radius:var(--radius-md); padding:9px 16px; font-weight:700; font-size:0.875rem; }
.app-badge small { display:block; font-weight:500; font-size:0.65rem; color:var(--neutral-500); letter-spacing:var(--ls-wide); text-transform:uppercase; line-height:1; }
.app-badge span { line-height:1.15; }

/* ---------- Form section ---------- */
.form-section { background:var(--surface-tint); }
.form-card { background:#fff; border-radius:var(--radius-2xl); box-shadow:var(--shadow-lg); padding:clamp(28px,4vw,48px); max-width:880px; margin:36px auto 0; }
.form-frame { width:100%; border:none; min-height:780px; display:block; border-radius:var(--radius-md); }

/* ---------- Footer ---------- */
.site-footer { background:var(--surface-dark); color:#fff; }
.site-footer__top { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; max-width:var(--container-max); margin:0 auto; padding:64px var(--container-pad) 32px; }
.site-footer__brand img { height:30px; margin-bottom:16px; }
.site-footer__brand p { color:rgba(255,255,255,0.6); font-size:0.9375rem; max-width:34ch; }
.site-footer .authorized { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.16); border-radius:var(--radius-pill); padding:8px 16px; font-weight:700; font-size:0.8125rem; color:#fff; margin-top:6px; }
.site-footer__col h4 { color:#fff; font-size:0.8125rem; font-weight:700; letter-spacing:var(--ls-wide); text-transform:uppercase; margin-bottom:16px; }
.site-footer__col ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.site-footer__col a { color:rgba(255,255,255,0.7); font-size:0.9375rem; }
.site-footer__col a:hover { color:#fff; text-decoration:none; }
.site-footer__bottom { border-top:1px solid rgba(255,255,255,0.12); }
.site-footer__bottom-inner { max-width:var(--container-max); margin:0 auto; padding:20px var(--container-pad); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; color:rgba(255,255,255,0.45); font-size:var(--fs-xs); }
.site-footer__bottom-inner a { color:rgba(255,255,255,0.55); }

/* ---------- Cookie banner ---------- */
.cookie-banner { position:fixed; left:16px; right:16px; bottom:16px; z-index:90; background:#fff; border:1px solid var(--border-subtle); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:22px 24px; max-width:560px; margin:0 auto; display:none; }
.cookie-banner.is-visible { display:block; animation: cookieIn var(--dur-slow) var(--ease-out); }
@keyframes cookieIn { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:none; } }
.cookie-banner h4 { font-size:1.0625rem; margin:0 0 6px; }
.cookie-banner p { font-size:0.875rem; color:var(--text-secondary); margin:0 0 16px; }
.cookie-banner__actions { display:flex; gap:10px; flex-wrap:wrap; }
.cookie-banner__actions .btn { flex:1 1 auto; }
.cookie-link { background:none; border:none; color:var(--color-brand); font-family:var(--font-body); font-weight:700; font-size:0.875rem; cursor:pointer; padding:11px 14px; }
.cookie-link:hover { text-decoration:underline; }

/* Cookie preferences modal */
.cookie-modal { position:fixed; inset:0; z-index:95; background:rgba(13,13,13,0.5); display:none; align-items:center; justify-content:center; padding:16px; }
.cookie-modal.is-visible { display:flex; }
.cookie-modal__panel { background:#fff; border-radius:var(--radius-xl); max-width:540px; width:100%; max-height:90vh; overflow:auto; box-shadow:var(--shadow-lg); padding:clamp(24px,4vw,36px); }
.cookie-modal__panel h3 { font-size:var(--fs-h3); margin-bottom:8px; }
.cookie-option { display:flex; gap:16px; align-items:flex-start; justify-content:space-between; padding:18px 0; border-top:1px solid var(--border-subtle); }
.cookie-option h5 { margin:0 0 4px; font-size:1rem; font-family:var(--font-display); }
.cookie-option p { margin:0; font-size:0.875rem; color:var(--text-secondary); }
.cookie-modal__foot { display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; }

/* iOS-style switch */
.switch { position:relative; flex:0 0 auto; width:46px; height:26px; }
.switch input { opacity:0; width:0; height:0; }
.switch .track { position:absolute; inset:0; background:var(--neutral-300); border-radius:var(--radius-pill); transition:background var(--dur-base); cursor:pointer; }
.switch .track::before { content:""; position:absolute; width:20px; height:20px; left:3px; top:3px; background:#fff; border-radius:50%; transition:transform var(--dur-base) var(--ease-out); box-shadow:var(--shadow-sm); }
.switch input:checked + .track { background:var(--color-brand); }
.switch input:checked + .track::before { transform:translateX(20px); }
.switch input:disabled + .track { background:var(--color-brand); opacity:0.5; cursor:not-allowed; }

/* ---------- Legal pages ---------- */
.legal-hero { background:var(--surface-dark); color:#fff; padding: clamp(64px,9vw,104px) 0 clamp(40px,6vw,56px); }
.legal-hero h1 { color:#fff; font-size:clamp(2rem,5vw,3rem); margin:0; }
.legal-hero p { color:rgba(255,255,255,0.7); margin:12px 0 0; }
.legal-body { padding: clamp(40px,6vw,72px) 0 clamp(56px,8vw,96px); }
.legal-content { max-width:820px; margin:0 auto; }
.legal-content h2 { font-size:var(--fs-h3); margin:40px 0 14px; }
.legal-content h2:first-child { margin-top:0; }
.legal-content h3 { font-size:var(--fs-h4); margin:28px 0 10px; }
.legal-content p, .legal-content li { color:var(--text-secondary); font-size:1.0625rem; }
.legal-content ul { padding-left:22px; display:flex; flex-direction:column; gap:8px; margin:0 0 1em; }
.legal-content a { font-weight:700; }
.legal-content .updated { font-size:0.875rem; color:var(--text-muted); }
.legal-table { width:100%; border-collapse:collapse; margin:0 0 1em; font-size:0.9375rem; }
.legal-table th, .legal-table td { text-align:left; padding:12px 14px; border:1px solid var(--border-subtle); vertical-align:top; color:var(--text-secondary); }
.legal-table th { background:var(--neutral-050); color:var(--text-primary); font-family:var(--font-display); }
.legal-table thead th { background:var(--red-050); color:var(--color-brand); }

/* ---------- 404 ---------- */
.error-page { min-height:72vh; display:flex; align-items:center; justify-content:center; text-align:center; position:relative; overflow:hidden; padding:64px var(--container-pad); }
.error-page__blob { position:absolute; background:var(--red-050); border-radius:var(--radius-blob); z-index:0; }
.error-code { font-family:var(--font-display); font-weight:800; font-size:clamp(5rem,18vw,11rem); line-height:0.9; color:var(--black-900); letter-spacing:var(--ls-tight); }
.error-code .reddot { color:var(--color-brand); }

/* ---------- Reveal animation ---------- */
.reveal { opacity:0; transform:translateY(24px); transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out); will-change: opacity, transform; }
.reveal.is-in { opacity:1 !important; transform:none !important; }
.no-js .reveal { opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .site-header__nav { position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:#fff; border-bottom:1px solid var(--border-subtle); box-shadow:var(--shadow-md); padding:8px 0; max-height:0; overflow:hidden; transition:max-height var(--dur-base) var(--ease-out); }
  .site-header.is-open .site-header__nav { max-height:420px; }
  .site-header__nav a { padding:14px var(--container-pad); border-bottom:none; }
  .site-header__nav a:hover { background:var(--neutral-050); border-color:transparent; }
  .site-header__nav .btn { margin:10px var(--container-pad) 6px; }
  .hamburger { display:block; }
  .feature-grid { grid-template-columns:1fr; max-width:440px; margin:0 auto; }
  .why-grid { grid-template-columns:1fr; gap:32px; }
  .app-block { grid-template-columns:1fr; gap:32px; text-align:center; }
  .app-block__media { order:-1; }
  .app-badges { justify-content:center; }
  .site-footer__top { grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width: 560px) {
  .site-footer__top { grid-template-columns:1fr; }
  .cookie-banner__actions { flex-direction:column; }
  .cookie-banner__actions .btn { width:100%; }
}
