/* ============================================================
   MasterPack do Brasil — Site
   Reaproveita os tokens do Brand Board.
   ============================================================ */
:root{
  --paper: oklch(0.985 0.003 255);
  --bg:    oklch(0.965 0.004 255);
  --cloud: oklch(0.945 0.006 255);
  --line:  oklch(0.895 0.008 255);
  --line-2:oklch(0.83 0.012 255);
  --ink:   oklch(0.255 0.035 262);
  --muted: oklch(0.50 0.025 262);
  --faint: oklch(0.62 0.02 262);

  --navy:  oklch(0.315 0.075 262);
  --navy-2:oklch(0.255 0.06 262);
  --blue:  oklch(0.505 0.155 262);
  --blue-deep: oklch(0.43 0.14 262);
  --azure: oklch(0.64 0.135 256);
  --azure-soft: oklch(0.94 0.03 256);

  --gold:  oklch(0.76 0.095 82);
  --gold-deep: oklch(0.62 0.10 74);
  --gold-soft: oklch(0.94 0.04 88);

  --wa: #25d366;

  --font-display: 'Archivo', sans-serif;
  --font-text: 'IBM Plex Sans', sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;
  --container: 1200px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; }
body{ margin:0; font-family:var(--font-text); background:var(--paper); color:var(--ink);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.wrap{ max-width:var(--container); margin:0 auto; padding:0 28px; }
section{ position:relative; }

/* ---------- logo mark ---------- */
.mark{ display:block; flex:none; }
.mark .box{ fill:var(--navy); }
.mark .band{ fill:var(--gold); }
.mark .seam{ fill:rgba(255,255,255,.16); }
.mark .shine{ fill:rgba(255,255,255,.22); }
.lock{ display:inline-flex; align-items:center; gap:11px; }
.wm{ font-family:var(--font-display); line-height:.86; color:var(--ink); }
.wm .r1{ font-size:var(--wms,22px); letter-spacing:-.02em; display:block; }
.wm .r1 .lt{ font-weight:500; } .wm .r1 .bd{ font-weight:800; }
.wm .tg{ display:flex; align-items:center; gap:6px; margin-top:3px; }
.wm .tg i{ height:2px; width:13px; background:var(--gold); }
.wm .tg span{ font-family:var(--font-mono); font-weight:500; font-size:calc(var(--wms,22px)*.27);
  letter-spacing:.3em; color:var(--blue); text-transform:uppercase; white-space:nowrap; }
.on-dark .mark .box{ fill:#fff; } .on-dark .wm{ color:#fff; }
.on-dark .wm .tg span{ color:var(--azure-soft); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-text); font-weight:600;
  font-size:15px; padding:13px 22px; border-radius:11px; cursor:pointer; border:1.5px solid transparent;
  transition:transform .15s, box-shadow .15s, background .15s, color .15s; white-space:nowrap; }
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--blue); color:#fff; box-shadow:0 12px 24px -14px var(--blue); }
.btn-primary:hover{ background:var(--blue-deep); box-shadow:0 16px 30px -14px var(--blue); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--blue); color:var(--blue); }
.btn-wa{ background:var(--wa); color:#fff; box-shadow:0 12px 24px -14px var(--wa); }
.btn-wa:hover{ filter:brightness(.96); }
.btn-light{ background:#fff; color:var(--navy); }
.btn-light:hover{ background:var(--azure-soft); }

/* ---------- eyebrow / headings ---------- */
.eyebrow{ font-family:var(--font-mono); font-size:12px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold-deep); display:inline-flex; align-items:center; gap:11px; margin:0 0 16px; }
.eyebrow::before{ content:""; width:24px; height:2px; background:var(--gold); }
.eyebrow.blue{ color:var(--blue); } .eyebrow.blue::before{ background:var(--blue); }
h2.title{ font-family:var(--font-display); font-weight:800; letter-spacing:-.025em; line-height:1.0;
  font-size:clamp(30px,4.4vw,48px); margin:0 0 16px; }
.lead{ font-size:17px; line-height:1.6; color:var(--muted); max-width:60ch; margin:0; text-wrap:pretty; }

/* ============ HEADER ============ */
.hdr{ position:sticky; top:0; z-index:50; background:oklch(0.985 0.003 255 / .82);
  backdrop-filter:blur(14px) saturate(1.3); border-bottom:1px solid var(--line); }
.hdr .wrap{ height:72px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
.nav{ display:flex; align-items:center; gap:30px; }
.nav a{ font-size:14.5px; font-weight:500; color:var(--muted); transition:color .15s; }
.nav a:hover{ color:var(--ink); }
.hdr-cta{ display:flex; align-items:center; gap:12px; }
.burger{ display:none; }

/* ============ HERO ============ */
.hero{ background:linear-gradient(180deg,var(--paper),var(--cloud)); border-bottom:1px solid var(--line);
  overflow:hidden; }
.hero .wrap{ display:grid; grid-template-columns:1.05fr .95fr; gap:50px; align-items:center;
  padding-top:64px; padding-bottom:64px; }
.hero h1{ font-family:var(--font-display); font-weight:800; letter-spacing:-.03em; line-height:.96;
  font-size:clamp(40px,5.6vw,68px); margin:0 0 22px; }
.hero h1 .hl{ color:var(--blue); position:relative; }
.hero h1 .hl::after{ content:""; position:absolute; left:0; right:0; bottom:.06em; height:.10em;
  background:var(--gold); opacity:.85; border-radius:2px; }
.hero p.sub{ font-size:18.5px; line-height:1.55; color:var(--muted); max-width:48ch; margin:0 0 30px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:30px; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:10px 22px; }
.hero-trust span{ display:inline-flex; align-items:center; gap:8px; font-size:13.5px; color:var(--faint);
  font-weight:500; }
.hero-trust .dot{ width:7px; height:7px; border-radius:2px; background:var(--blue); }

.hero-art{ position:relative; }
.hero-panel{ position:relative; border-radius:26px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 40px 80px -50px oklch(0.3 0.08 262 / .6); aspect-ratio:5/4.9; background:var(--cloud); }
.hero-slides{ position:absolute; inset:0; }
.hero-photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transform:scale(1.04); transition:opacity .8s ease, transform 6s ease; }
.hero-photo.on{ opacity:1; transform:scale(1); }
.hero-dots{ position:absolute; left:0; right:0; bottom:14px; z-index:3; display:flex;
  justify-content:center; gap:8px; }
.hero-dots button{ width:9px; height:9px; border-radius:50%; border:0; padding:0; cursor:pointer;
  background:rgba(255,255,255,.45); transition:background .3s ease, width .3s ease; }
.hero-dots button.on{ background:#fff; width:24px; border-radius:5px; }
.hero-grad{ position:absolute; inset:0;
  background:linear-gradient(180deg, oklch(0.3 0.06 262 / .06), transparent 38%, oklch(0.22 0.06 262 / .42)); }
.hero-inset{ position:absolute; right:14px; bottom:14px; width:42%; background:#fff; border:1px solid var(--line);
  border-radius:14px; padding:9px 9px 8px; box-shadow:0 18px 36px -20px rgba(20,30,60,.7); }
.hero-inset img{ width:100%; border-radius:8px; mix-blend-mode:multiply; aspect-ratio:16/11; object-fit:cover; }
.hero-inset span{ display:block; font-family:var(--font-mono); font-size:10px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--blue); margin-top:7px; padding:0 2px; }
.hero-badge{ position:absolute; left:14px; top:14px; z-index:3; background:#fff; border:1px solid var(--line);
  border-radius:14px; padding:12px 16px; box-shadow:0 18px 36px -22px rgba(20,30,60,.6); display:flex;
  align-items:center; gap:11px; }
.hero-badge .ic{ width:34px; height:34px; border-radius:9px; background:var(--gold-soft); display:grid;
  place-items:center; }
.hero-badge .ic b{ width:14px; height:14px; border-radius:3px; background:var(--gold-deep); }
.hero-badge .tx b{ display:block; font-size:13.5px; font-weight:700; color:var(--ink); }
.hero-badge .tx span{ font-size:12px; color:var(--muted); }

/* ============ STRIP (segmentos) ============ */
.strip{ background:var(--navy); color:#fff; }
.strip .wrap{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px;
  padding:22px 28px; }
.strip .lab{ font-family:var(--font-mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--azure-soft); }
.strip .items{ display:flex; flex-wrap:wrap; gap:14px 30px; }
.strip .items b{ font-family:var(--font-display); font-weight:700; font-size:17px; letter-spacing:-.01em;
  color:#fff; opacity:.92; }

/* ============ SECTION SCAFFOLD ============ */
.sec{ padding:clamp(64px,9vw,108px) 0; }
.sec-head{ max-width:760px; margin-bottom:48px; }
.sec.alt{ background:var(--bg); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }

/* differentials */
.feat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.feat{ background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:28px 24px 26px; }
.feat .ic{ width:46px; height:46px; border-radius:12px; background:var(--azure-soft); display:grid;
  place-items:center; margin-bottom:18px; }
.feat .ic .s-sq{ width:18px; height:18px; border-radius:4px; background:var(--blue); }
.feat .ic .s-ci{ width:18px; height:18px; border-radius:50%; border:4px solid var(--blue); }
.feat .ic .s-di{ width:16px; height:16px; background:var(--blue); transform:rotate(45deg); border-radius:3px; }
.feat .ic .s-ck{ width:20px; height:11px; border-left:4px solid var(--blue); border-bottom:4px solid var(--blue);
  transform:rotate(-45deg); margin-top:-4px; }
.feat h3{ font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:-.01em; margin:0 0 8px; }
.feat p{ margin:0; font-size:14.5px; line-height:1.55; color:var(--muted); }

/* ============ PRODUCTS ============ */
.filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:34px; }
.filters button{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  padding:9px 16px; border-radius:999px; border:1.5px solid var(--line-2); background:transparent; color:var(--muted);
  cursor:pointer; transition:all .15s; }
.filters button:hover{ border-color:var(--blue); color:var(--blue); }
.filters button.on{ background:var(--navy); border-color:var(--navy); color:#fff; }

.prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.card{ background:var(--paper); border:1px solid var(--line); border-radius:20px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .18s, box-shadow .18s, border-color .18s; }
.card:hover{ transform:translateY(-4px); box-shadow:0 30px 50px -36px oklch(0.3 0.05 262 / .7); border-color:var(--line-2); }
.card .ph{ aspect-ratio:4/3; background:radial-gradient(120% 120% at 50% 25%, #f3f4f7, #e7e9ee);
  display:flex; align-items:center; justify-content:center; position:relative; padding:18px; }
.card .ph img{ max-height:100%; width:auto; object-fit:contain; mix-blend-mode:multiply; }
.card .tag{ position:absolute; left:14px; top:14px; font-family:var(--font-mono); font-size:10.5px;
  letter-spacing:.14em; text-transform:uppercase; background:rgba(255, 255, 255, 0.85); border:1px solid rgba(255, 255, 255, 0.6);
  color:var(--blue); padding:5px 10px; border-radius:7px; z-index:3; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  box-shadow:0 4px 12px rgba(0, 0, 0, 0.05); }
.card .hot{ position:absolute; right:14px; top:14px; font-family:var(--font-mono); font-size:10.5px;
  letter-spacing:.12em; text-transform:uppercase; background:rgba(218, 165, 32, 0.85); color:#3a2c08; padding:5px 10px;
  border-radius:7px; font-weight:600; white-space:nowrap; z-index:3; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  box-shadow:0 4px 12px rgba(0, 0, 0, 0.05); }
.card .body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.card .body h3{ font-family:var(--font-display); font-weight:800; font-size:21px; letter-spacing:-.02em; margin:0 0 4px; }
.card .body .code{ font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; color:var(--gold-deep); margin-bottom:11px; }
.card .body p{ margin:0 0 16px; font-size:14px; line-height:1.55; color:var(--muted); flex:1; }
.card .meds{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:18px; }
.card .meds span{ font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--ink);
  background:var(--cloud); border:1px solid var(--line); padding:4px 9px; border-radius:6px; white-space:nowrap; }
.card .more{ display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:14px; color:var(--blue); }
.card .more .ar{ transition:transform .15s; } .card:hover .more .ar{ transform:translateX(3px); }

/* ============ CUSTOM (personalização) ============ */
.custom{ background:linear-gradient(165deg,var(--navy),var(--navy-2)); color:#fff; overflow:hidden; }
.custom .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.custom h2{ font-family:var(--font-display); font-weight:800; letter-spacing:-.025em; line-height:1.02;
  font-size:clamp(30px,4.2vw,46px); margin:0 0 20px; }
.custom h2 .hl{ color:var(--azure); }
.custom .lead{ color:oklch(0.86 0.03 256); max-width:50ch; }
.custom .clist{ list-style:none; margin:26px 0 32px; padding:0; display:flex; flex-direction:column; gap:16px; }
.custom .clist li{ display:flex; gap:14px; align-items:flex-start; }
.custom .clist .ck{ width:26px; height:26px; border-radius:8px; background:rgba(255,255,255,.10);
  display:grid; place-items:center; flex:none; margin-top:2px; }
.custom .clist .ck b{ width:11px; height:6px; border-left:3px solid var(--gold); border-bottom:3px solid var(--gold);
  transform:rotate(-45deg); margin-top:-3px; }
.custom .clist h4{ margin:0 0 3px; font-size:16.5px; font-weight:700; }
.custom .clist p{ margin:0; font-size:14px; color:oklch(0.80 0.03 256); line-height:1.5; }
.custom-art{ position:relative; border-radius:24px; overflow:hidden;
  background:var(--navy-2); border:1px solid rgba(255,255,255,.14); aspect-ratio:1/1;
  box-shadow:0 40px 80px -50px rgba(0,0,0,.6); }
.custom-art img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.custom-art::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, oklch(0.22 0.06 262 / .55)); }
.custom-art .cap{ position:absolute; left:24px; bottom:22px; z-index:2; font-family:var(--font-mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--azure-soft); }

/* ============ SEGMENTS ============ */
.seg-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.seg{ background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:26px 24px;
  position:relative; overflow:hidden; min-height:180px; display:flex; flex-direction:column; justify-content:space-between; }
.seg .num{ font-family:var(--font-mono); font-size:12px; color:var(--gold-deep); letter-spacing:.1em; }
.seg h3{ font-family:var(--font-display); font-weight:700; font-size:20px; letter-spacing:-.01em; margin:14px 0 8px; }
.seg p{ margin:0; font-size:14px; line-height:1.5; color:var(--muted); }

/* ============ ABOUT / quote ============ */
.about .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.about-art{ position:relative; border-radius:22px; overflow:hidden; border:1px solid var(--line);
  background:var(--cloud); aspect-ratio:4/3.4; }
.about-art img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.about ul.checks{ list-style:none; margin:24px 0 0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.about ul.checks li{ display:flex; gap:10px; align-items:center; font-size:14.5px; font-weight:500; color:var(--ink); }
.about ul.checks .ck{ width:20px; height:20px; border-radius:6px; background:var(--azure-soft); display:grid; place-items:center; flex:none; }
.about ul.checks .ck b{ width:9px; height:5px; border-left:2.5px solid var(--blue); border-bottom:2.5px solid var(--blue); transform:rotate(-45deg); margin-top:-2px; }

/* ============ CTA / CONTACT ============ */
.cta{ background:var(--cloud); border-top:1px solid var(--line); }
.cta .wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.cta h2{ font-family:var(--font-display); font-weight:800; letter-spacing:-.025em; line-height:1.0;
  font-size:clamp(30px,4.2vw,46px); margin:0 0 16px; }
.form{ background:var(--paper); border:1px solid var(--line); border-radius:22px; padding:30px;
  box-shadow:0 30px 60px -44px oklch(0.3 0.05 262 / .7); }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field{ margin-bottom:14px; } .field.full{ grid-column:1 / -1; }
.field label{ display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--faint); margin-bottom:7px; }
.field input, .field textarea, .field select{ width:100%; font-family:var(--font-text); font-size:15px;
  color:var(--ink); background:var(--bg); border:1.5px solid var(--line); border-radius:10px; padding:12px 14px;
  outline:none; transition:border-color .15s, background .15s; }
.field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--blue); background:#fff; }
.field textarea{ resize:vertical; min-height:90px; }
.cta-side .lead{ margin-bottom:24px; }
.cta-side .ways{ display:flex; flex-direction:column; gap:14px; }
.way{ display:flex; align-items:center; gap:14px; }
.way .ic{ width:42px; height:42px; border-radius:11px; background:var(--azure-soft); display:grid; place-items:center; flex:none; }
.way .ic .s-sq{ width:16px; height:16px; border-radius:4px; background:var(--blue); }
.way b{ display:block; font-size:15px; } .way span{ font-size:13px; color:var(--muted); }

/* ============ FOOTER ============ */
.ft{ background:var(--navy-2); color:#fff; padding:56px 0 30px; }
.ft .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; padding-bottom:36px;
  border-bottom:1px solid rgba(255,255,255,.12); }
.ft p.desc{ margin:18px 0 0; font-size:14px; line-height:1.6; color:oklch(0.80 0.03 256); max-width:34ch; }
.ft h5{ font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--azure-soft); margin:0 0 16px; }
.ft a.fl{ display:block; font-size:14px; color:oklch(0.84 0.02 256); margin-bottom:11px; }
.ft a.fl:hover{ color:#fff; }
.ft .bot{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; padding-top:24px;
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:.06em; color:oklch(0.72 0.03 256); }

/* ---------- floating whatsapp ---------- */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:60; width:58px; height:58px; border-radius:50%;
  background:var(--wa); display:grid; place-items:center; box-shadow:0 16px 30px -10px rgba(37,211,102,.6);
  transition:transform .15s; }
.wa-float:hover{ transform:scale(1.06); }
.wa-bubble{ width:28px; height:27px; border-radius:50% 50% 50% 4px; background:#fff; position:relative; }
.wa-bubble::after{ content:""; position:absolute; inset:7px; border-radius:50%; border:3px solid var(--wa);
  border-right-color:transparent; transform:rotate(35deg); }
.wa-ic{ width:20px; height:19px; border-radius:50% 50% 50% 3px; background:#fff; }

/* ---------- reveal: static-visible (entrance only with motion pref) ---------- */
.reveal{ opacity:1; transform:none; }
@media (prefers-reduced-motion:no-preference){
  @keyframes mp-rise{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:none; } }
}
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  .feat-grid{ grid-template-columns:repeat(2,1fr); }
  .prod-grid{ grid-template-columns:repeat(2,1fr); }
  .seg-grid{ grid-template-columns:repeat(2,1fr); }
  .ft .top{ grid-template-columns:1fr 1fr; }
  .nav{ display:none; }
  .hdr-cta .btn-ghost{ display:none; }
}
@media (max-width:860px){
  .hero .wrap, .custom .wrap, .about .wrap, .cta .wrap{ grid-template-columns:1fr; gap:40px; }
  /* hero mobile: eyebrow + título → slide → subtítulo → CTAs → trust */
  .hero .wrap{ display:flex; flex-direction:column; gap:0; }
  .hero-copy{ display:contents; }
  .hero-copy .eyebrow{ order:1; }
  .hero h1{ order:2; }
  .hero-art{ order:3; max-width:440px; width:100%; margin:4px 0 28px; }
  .hero p.sub{ order:4; }
  .hero-cta{ order:5; }
  .hero-trust{ order:6; }
}
@media (max-width:560px){
  .prod-grid, .feat-grid, .seg-grid, .form .row, .about ul.checks{ grid-template-columns:1fr; }
  .wrap{ padding:0 20px; }
}
