/* ============================================================
   home-v2.css — CSS do layout home premium
   Extraído de preview-home-v2/index.php
   ============================================================ */

:root {
  --mi-black: #0f0f0f;
  --mi-carbon: #151515;
  --mi-carbon-2: #1d1d1f;

  --mi-white: #ffffff;
  --mi-porcelain: #f6f3ed;
  --mi-porcelain-2: #ebe5da;
  --mi-stone: #d8cfc1;

  --mi-text: #f7f2ea;
  --mi-text-soft: rgba(247,242,234,.72);
  --mi-text-faint: rgba(247,242,234,.52);

  --mi-dark-text: #191917;

  --mi-terracotta: #a96f56;
  --mi-terracotta-2: #8f5646;
  --mi-champagne: #d9c6ad;

  --line-light: rgba(247,242,234,.13);
  --line-dark: rgba(25,25,23,.10);

  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --radius-sm: 10px;

  --shadow-deep: 0 34px 90px rgba(0,0,0,.38);
  --shadow-soft: 0 22px 60px rgba(0,0,0,.12);

  --container: 1180px;
  --shell: 1280px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--mi-text);
  background: var(--mi-black);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.container {
  width: min(var(--container), calc(100% - 40px));
  margin: 0 auto;
}

/* ── Buttons ───────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 650;
  letter-spacing: -.01em;
  border: 1px solid transparent;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
  white-space: nowrap;
  cursor: pointer;
}

.btn:active { transform: translateY(1px) scale(.99); }

.btn-primary {
  color: #141414;
  background: var(--mi-porcelain);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 10px 26px rgba(0,0,0,.14);
}

.btn-primary:hover { background: var(--mi-white); }

.btn-outline {
  color: rgba(247,242,234,.78);
  background: rgba(247,242,234,.04);
  border-color: rgba(247,242,234,.16);
}

.btn-outline:hover {
  background: rgba(247,242,234,.09);
  border-color: rgba(247,242,234,.30);
}

.btn-terra {
  color: #fff;
  background: var(--mi-terracotta);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 10px 28px rgba(169,111,86,.28);
}

.btn-terra:hover { background: var(--mi-terracotta-2); }

/* ── Hero ──────────────────────────────────────────────── */

.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(15,15,15,.96) 0%, rgba(15,15,15,.88) 34%, rgba(15,15,15,.44) 62%, rgba(15,15,15,.70) 100%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.46)),
    var(--home-hero-img) center center / cover no-repeat;
  filter: saturate(.76) contrast(.95) brightness(.82);
  transform: scale(1.016);
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 26%, rgba(169,111,86,.10), transparent 28%),
    radial-gradient(circle at 82% 74%, rgba(217,198,173,.07), transparent 30%);
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 2;
  width: min(var(--shell), calc(100% - 48px));
  margin: 0 auto;
  padding: 132px 0 72px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(380px, .84fr);
  gap: clamp(40px, 7vw, 100px);
  align-items: center;
}

.hero-copy { max-width: 760px; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  font-size: 11px;
  line-height: 1.2;
  font-weight: 760;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(247,242,234,.54);
}

.eyebrow::before {
  content: "";
  width: 38px;
  height: 1px;
  background: var(--mi-terracotta);
  flex-shrink: 0;
}

.hero h1 {
  max-width: 740px;
  font-size: clamp(52px, 6.6vw, 100px);
  line-height: .94;
  letter-spacing: -.072em;
  font-weight: 720;
  color: var(--mi-porcelain);
  text-wrap: balance;
}

.hero-lead {
  max-width: 600px;
  margin-top: 26px;
  color: rgba(247,242,234,.72);
  font-size: clamp(16px, 1.5vw, 20px);
  line-height: 1.60;
  font-weight: 420;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 34px;
}

.hero-note {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 26px;
}

.note-pill {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(247,242,234,.12);
  background: rgba(247,242,234,.04);
  color: rgba(247,242,234,.56);
  font-size: 11px;
  letter-spacing: .01em;
  backdrop-filter: blur(12px);
}

/* Showcase */

.hero-showcase {
  position: relative;
  min-height: 540px;
  display: grid;
  align-items: center;
}

.showcase-frame {
  position: relative;
  border-radius: 38px;
  border: 1px solid rgba(247,242,234,.15);
  background: rgba(247,242,234,.05);
  box-shadow: var(--shadow-deep);
  backdrop-filter: blur(26px);
  padding: 13px;
}

.showcase-main {
  position: relative;
  min-height: 400px;
  border-radius: 28px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(15,15,15,.03), rgba(15,15,15,.28)),
    url('/assets/img/site/cinema.webp') center center / cover no-repeat;
}

.showcase-main::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,.54) 100%);
}

.showcase-label {
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 22px;
  z-index: 2;
  display: grid;
  gap: 6px;
}

.showcase-label span {
  color: rgba(247,242,234,.56);
  font-size: 11px;
  font-weight: 760;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.showcase-label strong {
  color: var(--mi-porcelain);
  font-size: 23px;
  line-height: 1.08;
  letter-spacing: -.044em;
  font-weight: 680;
}

.floating-card {
  position: absolute;
  left: -42px;
  bottom: 40px;
  z-index: 4;
  width: min(268px, 46vw);
  padding: 20px;
  border-radius: 22px;
  background: rgba(246,243,237,.95);
  color: var(--mi-dark-text);
  box-shadow: 0 22px 66px rgba(0,0,0,.24);
  border: 1px solid rgba(255,255,255,.42);
}

.floating-card small {
  display: block;
  margin-bottom: 9px;
  color: var(--mi-terracotta);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .17em;
  text-transform: uppercase;
}

.floating-card strong {
  display: block;
  font-size: 19px;
  line-height: 1.12;
  letter-spacing: -.044em;
  font-weight: 700;
  margin-bottom: 9px;
  color: var(--mi-dark-text);
}

.floating-card p {
  color: rgba(25,25,23,.58);
  font-size: 13px;
  line-height: 1.50;
}

.system-strip {
  position: absolute;
  right: -16px;
  top: 32px;
  z-index: 5;
  display: grid;
  gap: 8px;
}

.system-pill {
  min-height: 33px;
  padding: 0 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(15,15,15,.76);
  border: 1px solid rgba(247,242,234,.13);
  color: rgba(247,242,234,.70);
  font-size: 12px;
  backdrop-filter: blur(16px);
}

/* ── Trust ─────────────────────────────────────────────── */

.trust-section {
  background: var(--mi-porcelain);
  color: var(--mi-dark-text);
  padding: 36px 0 96px;
}

.trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--line-dark);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.60);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}

.trust-item {
  min-height: 126px;
  padding: 26px;
  border-right: 1px solid var(--line-dark);
}

.trust-item:last-child { border-right: 0; }

.trust-number {
  margin-bottom: 11px;
  color: var(--mi-terracotta);
  font-size: 30px;
  line-height: 1;
  font-weight: 720;
  letter-spacing: -.06em;
}

.trust-number.sm {
  font-size: 20px;
  letter-spacing: -.04em;
  line-height: 1.16;
}

.trust-label {
  color: rgba(25,25,23,.62);
  font-size: 14px;
  line-height: 1.50;
  font-weight: 600;
}

/* ── Section commons ───────────────────────────────────── */

.section { padding: 100px 0; }

.section-light {
  background: var(--mi-porcelain);
  color: var(--mi-dark-text);
}

.section-dark {
  background:
    radial-gradient(circle at 18% 16%, rgba(169,111,86,.11), transparent 28%),
    radial-gradient(circle at 86% 10%, rgba(217,198,173,.06), transparent 32%),
    linear-gradient(180deg, #101010 0%, #171717 100%);
  color: var(--mi-text);
}

.section-head {
  max-width: 780px;
  margin-bottom: 46px;
}

.kicker {
  margin-bottom: 16px;
  color: var(--mi-terracotta);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.section-dark .kicker { color: var(--mi-champagne); }

.section-title {
  font-size: clamp(38px, 4.8vw, 68px);
  line-height: 1.01;
  letter-spacing: -.066em;
  font-weight: 720;
  text-wrap: balance;
}

.section-text {
  margin-top: 20px;
  color: rgba(25,25,23,.64);
  font-size: 17px;
  line-height: 1.66;
}

.section-dark .section-text { color: rgba(247,242,234,.68); }

/* ── Solutions ─────────────────────────────────────────── */

.solutions-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 13px;
}

.sol-card {
  position: relative;
  min-height: 252px;
  padding: 26px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(255,255,255,.66);
  border: 1px solid var(--line-dark);
  box-shadow: 0 16px 48px rgba(0,0,0,.05);
  transition: transform .18s ease, box-shadow .18s ease;
  display: flex;
  flex-direction: column;
}

.sol-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 26px 68px rgba(0,0,0,.10);
}

.sol-card.photo {
  background:
    linear-gradient(90deg, rgba(15,15,15,.90) 0%, rgba(15,15,15,.42) 100%),
    url('/assets/img/site/cinema.webp') center center / cover no-repeat;
  color: var(--mi-text);
  border-color: rgba(247,242,234,.10);
}

.sol-card.wide {
  grid-column: span 2;
  min-height: 310px;
}

.sol-card.full {
  grid-column: 1 / -1;
  min-height: 160px;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  padding: 32px 40px;
}

.sol-card.full.dark {
  background:
    linear-gradient(90deg, rgba(15,15,15,.86) 0%, rgba(15,15,15,.58) 100%),
    url('/assets/img/site/projetos.webp') center center / cover no-repeat;
  color: var(--mi-text);
  border-color: rgba(247,242,234,.10);
}

.sol-idx {
  margin-bottom: 38px;
  color: var(--mi-terracotta);
  font-size: 22px;
  line-height: 1;
  font-weight: 720;
  letter-spacing: -.06em;
}

.sol-card.photo .sol-idx,
.sol-card.full.dark .sol-idx {
  color: var(--mi-champagne);
}

.sol-card h3 {
  margin-bottom: 10px;
  font-size: 20px;
  line-height: 1.10;
  letter-spacing: -.042em;
  font-weight: 700;
}

.sol-card p {
  color: rgba(25,25,23,.62);
  font-size: 14px;
  line-height: 1.56;
  flex: 1;
}

.sol-card.photo p,
.sol-card.full.dark p {
  color: rgba(247,242,234,.68);
}

.sol-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 18px;
}

.sol-tag {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: .01em;
}

.sol-card.photo .sol-tag,
.sol-card.full.dark .sol-tag {
  border: 1px solid rgba(247,242,234,.17);
  background: rgba(247,242,234,.08);
  color: rgba(247,242,234,.70);
}

.sol-card:not(.photo):not(.full) .sol-tag {
  border: 1px solid rgba(25,25,23,.12);
  background: rgba(25,25,23,.05);
  color: rgba(25,25,23,.60);
}

.sol-arrow {
  margin-top: auto;
  padding-top: 16px;
  color: var(--mi-terracotta);
  font-size: 13px;
  font-weight: 600;
}

.sol-card.photo .sol-arrow { color: var(--mi-champagne); }

.full-content { flex: 1; min-width: 0; }
.full-cta { flex-shrink: 0; }

/* ── Brands ────────────────────────────────────────────── */

.brands-section {
  padding: 76px 0;
  background:
    radial-gradient(circle at 60% 50%, rgba(169,111,86,.06), transparent 44%),
    #111111;
  border-top: 1px solid rgba(247,242,234,.06);
  border-bottom: 1px solid rgba(247,242,234,.06);
}

.brands-head { margin-bottom: 44px; }

.brands-rows { display: grid; gap: 26px; }

.brands-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  align-items: baseline;
  gap: 24px;
}

.brands-category {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mi-terracotta);
  padding-top: 2px;
}

.brands-list {
  color: rgba(247,242,234,.52);
  font-size: 17px;
  letter-spacing: -.01em;
  line-height: 1.6;
}

.brands-list strong {
  color: rgba(247,242,234,.82);
  font-weight: 500;
}

.brands-dot {
  color: rgba(247,242,234,.20);
  margin: 0 10px;
}

/* ── Ecosystem ─────────────────────────────────────────── */

.eco-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.eco-card {
  padding: 42px;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(247,242,234,.10);
  background: rgba(247,242,234,.042);
  backdrop-filter: blur(24px);
}

.eco-brand-name {
  display: inline-block;
  margin-bottom: 22px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .20em;
  text-transform: uppercase;
  color: var(--mi-champagne);
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid rgba(217,198,173,.20);
  background: rgba(217,198,173,.07);
}

.eco-card h3 {
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.08;
  letter-spacing: -.054em;
  font-weight: 720;
  margin-bottom: 14px;
}

.eco-card p {
  color: rgba(247,242,234,.62);
  font-size: 15px;
  line-height: 1.64;
  margin-bottom: 26px;
}

.eco-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.eco-badge {
  padding: 6px 13px;
  border-radius: 999px;
  border: 1px solid rgba(247,242,234,.13);
  background: rgba(247,242,234,.07);
  color: rgba(247,242,234,.68);
  font-size: 12px;
  letter-spacing: .01em;
}

/* ── CTA ───────────────────────────────────────────────── */

.cta-section {
  padding: 112px 0;
  background:
    radial-gradient(circle at 28% 52%, rgba(169,111,86,.20), transparent 48%),
    radial-gradient(circle at 80% 20%, rgba(217,198,173,.07), transparent 36%),
    #0f0f0f;
  border-top: 1px solid rgba(247,242,234,.06);
}

.cta-box { max-width: 820px; }

.cta-title {
  font-size: clamp(42px, 5.5vw, 80px);
  line-height: .98;
  letter-spacing: -.070em;
  font-weight: 720;
  text-wrap: balance;
}

.cta-title em {
  font-style: normal;
  color: var(--mi-terracotta);
}

.cta-text {
  max-width: 620px;
  margin-top: 22px;
  color: rgba(247,242,234,.66);
  font-size: 17px;
  line-height: 1.66;
}

.cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}

/* ── Responsive ────────────────────────────────────────── */

@media (max-width: 1120px) {
  .hero-inner { grid-template-columns: 1fr; }

  .hero-showcase {
    max-width: 660px;
    margin: 0 auto;
  }

  .solutions-grid { grid-template-columns: repeat(2, 1fr); }

  .sol-card.wide,
  .sol-card.full { grid-column: span 2; }

  .sol-card.full { flex-direction: column; align-items: flex-start; min-height: 200px; }

  .eco-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .btn { min-height: 40px; padding: 0 14px; font-size: 12px; }

  .hero { min-height: auto; }

  .hero-inner {
    width: calc(100% - 28px);
    padding: 106px 0 44px;
    gap: 36px;
  }

  .hero h1 { font-size: clamp(42px, 12vw, 64px); }
  .hero-lead { font-size: 15px; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-showcase { min-height: auto; }
  .showcase-main { min-height: 300px; }

  .floating-card {
    position: relative;
    left: auto;
    bottom: auto;
    width: auto;
    margin-top: 13px;
  }

  .system-strip {
    position: static;
    display: flex;
    flex-wrap: wrap;
    margin-top: 13px;
  }

  .trust-section { padding: 24px 0 68px; }

  .trust-grid { grid-template-columns: 1fr 1fr; }

  .trust-item:nth-child(2) { border-right: 0; }
  .trust-item:nth-child(n+3) { border-top: 1px solid var(--line-dark); }

  .section { padding: 72px 0; }
  .section-title { font-size: clamp(36px, 10vw, 56px); }

  .solutions-grid { grid-template-columns: 1fr; }

  .sol-card.wide,
  .sol-card.full { grid-column: auto; }

  .sol-card.full {
    flex-direction: column;
    align-items: flex-start;
    min-height: 200px;
    padding: 26px;
    gap: 20px;
  }

  .brands-row {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .brands-list { font-size: 15px; }

  .eco-card { padding: 28px; }

  .cta-section { padding: 80px 0; }
}

@media (max-width: 420px) {
  .trust-grid { grid-template-columns: 1fr; }
  .trust-item { border-right: 0; border-bottom: 1px solid var(--line-dark); }
  .trust-item:last-child { border-bottom: 0; }
}
