/* ============================================================
   CO.INO — Site institucional · v2
   Sistema editorial · data-forward · zero sombra
   Derivado da Identidade Visual v2.0
   ============================================================ */

:root{
  --orange:     #E8600A;
  --orange-deep:#B84A00;
  --orange-mid: #F07020;
  --orange-50:  #FFF7F2;
  --orange-100: #FEE6CC;

  --ink:        #1C1A18;
  --ink-2:      #2A2825;
  --ink-3:      #3A3835;
  --stone:      #6A6865;
  --mist:       #9A9895;

  --paper:      #FAFAF8;
  --warm-100:   #F2F0ED;
  --warm-200:   #E5E3DF;
  --warm-300:   #C8C6C2;

  --green:      #3B6D11;
  --green-lt:   #EAF3DE;
  --danger:     #A32D2D;
  --blue:       #185FA5;

  --font-display:'Barlow', sans-serif;
  --font-cond:   'Barlow Condensed', 'Barlow', sans-serif;
  --font-body:   'DM Sans', sans-serif;

  --maxw: 1320px;
  --gut: 48px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  font-size:18px; line-height:1.62;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{ background:var(--orange); color:#fff; }

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:1.02; letter-spacing:-.02em; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--gut); }

/* ── structural micro-label (Barlow Condensed, the brand's report texture) ── */
.kicker{
  font-family:var(--font-cond); font-weight:700; font-size:15px;
  letter-spacing:.22em; text-transform:uppercase; color:var(--orange);
  display:inline-flex; align-items:center; gap:14px;
}
.kicker .idx{ color:var(--ink); }
.dark .kicker{ color:var(--orange-mid); }
.dark .kicker .idx{ color:rgba(255,255,255,.5); }
.kicker.bare{ color:var(--stone); }

/* hairline rule helper */
.rule-h{ height:1px; background:var(--warm-200); width:100%; }
.dark .rule-h{ background:var(--ink-3); }

/* ── logo ── */
.logo{
  display:inline-flex; align-items:baseline; font-family:var(--font-display);
  font-weight:800; font-size:25px; letter-spacing:-.01em; line-height:1; color:var(--ink);
}
.logo .box{ background:var(--orange); color:var(--ink); padding:1px 6px 3px; margin-left:2px; }
.logo.on-dark, .dark .logo{ color:#fff; }

/* ── buttons ── */
.btn{
  --bg:var(--orange); --fg:#fff;
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--font-cond); font-weight:700; font-size:18px; letter-spacing:.04em; text-transform:uppercase;
  background:var(--bg); color:var(--fg); padding:17px 28px; border:0; cursor:pointer;
  position:relative; overflow:hidden; isolation:isolate; white-space:nowrap;
  transition:color .35s var(--ease);
}
.btn .arrow{ transition:transform .4s var(--ease-out); }
.btn::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--ink); transform:translateY(101%); transition:transform .42s var(--ease-out); }
.btn:hover::before{ transform:translateY(0); }
.btn:hover{ color:#fff; }
.btn:hover .arrow{ transform:translateX(7px); }
.btn.ink{ --bg:var(--ink); --fg:var(--orange-mid); }
.btn.ink::before{ background:var(--orange); }
.btn.ink:hover{ color:var(--ink); }
.btn.line{ --bg:transparent; --fg:#fff; box-shadow:inset 0 0 0 2px rgba(255,255,255,.3); }
.btn.line::before{ background:#fff; }
.btn.line:hover{ color:var(--ink); }

/* link with wipe underline */
.ul{ position:relative; }
.ul::after{ content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:100%; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease-out); }
.ul:hover::after{ transform:scaleX(1); }

/* ============================================================
   SPINE — fixed left progress index
   ============================================================ */
.spine{
  position:fixed; left:0; top:0; bottom:0; width:var(--gut); z-index:80;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  pointer-events:none;
}
.spine .track{ position:relative; width:2px; height:46vh; background:var(--warm-200); }
.dark-context .spine .track{ background:rgba(255,255,255,.16); }
.spine .fill{ position:absolute; left:0; top:0; width:100%; height:0; background:var(--orange); transition:height .15s linear; }
.spine .fcount{
  position:absolute; left:50%; transform:translateX(-50%); top:calc(46vh + 18px);
  font-family:var(--font-cond); font-weight:700; font-size:13px; letter-spacing:.12em; color:var(--stone);
  white-space:nowrap;
}
.spine .ftop{
  position:absolute; left:50%; transform:translateX(-50%); bottom:calc(46vh + 18px);
  font-family:var(--font-cond); font-weight:700; font-size:11px; letter-spacing:.24em; color:var(--mist);
  writing-mode:vertical-rl; text-transform:uppercase;
}
@media (max-width:1180px){ .spine{ display:none; } }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--gut); transition:padding .4s var(--ease), background .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{ padding:13px var(--gut); background:rgba(250,250,248,.85); backdrop-filter:saturate(1.4) blur(16px); border-color:var(--warm-200); }
.nav-links{ display:flex; align-items:center; gap:38px; }
.nav-link{ font-family:var(--font-cond); font-weight:600; font-size:17px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink); position:relative; padding:3px 0; white-space:nowrap; }
.nav-link::after{ content:""; position:absolute; left:0; bottom:-1px; height:2px; width:100%; background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease-out); }
.nav-link:hover::after{ transform:scaleX(1); }
.nav .btn{ padding:11px 20px; font-size:16px; }
.nav-burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; z-index:130; }
.nav-burger span{ width:26px; height:2px; background:var(--ink); display:block; transition:.3s var(--ease); }
.nav:not(.scrolled).over-dark{ color:#fff; }
.nav:not(.scrolled).over-dark .logo{ color:#fff; }
.nav:not(.scrolled).over-dark .nav-link{ color:rgba(255,255,255,.85); }
.nav:not(.scrolled).over-dark .nav-burger span{ background:#fff; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; background:var(--ink); color:#fff; min-height:100svh; display:flex; flex-direction:column; justify-content:center; overflow:hidden; padding:140px 0 0; }
.hero .dotgrid{ position:absolute; inset:0; z-index:0; opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.10) 1.2px, transparent 1.2px); background-size:34px 34px;
  mask-image:radial-gradient(circle at 30% 40%, #000, transparent 78%); }
.hero .glow{ position:absolute; top:-180px; right:-140px; width:620px; height:620px; border-radius:50%;
  background:radial-gradient(circle, rgba(232,96,10,.20), rgba(232,96,10,0) 64%); z-index:0; pointer-events:none; }

.hero .wrap{ position:relative; z-index:2; display:grid; grid-template-columns:1.18fr .82fr; gap:64px; align-items:center; flex:1; }

.hero h1{ font-size:clamp(38px, 5.4vw, 82px); font-weight:900; line-height:1.0; letter-spacing:-.035em; }
.hero h1 .ln{ display:block; overflow:hidden; }
.hero h1 .ln > span{ display:block; transform:translateY(105%); transition:transform 1s var(--ease-out); }
body.loaded .hero h1 .ln1 > span{ transition-delay:.15s } body.loaded .hero h1 .ln2 > span{ transition-delay:.28s }
body.loaded .hero h1 .ln > span{ transform:translateY(0); }
.hero h1 .boxword{ background:var(--orange); color:var(--ink); padding:0 .12em .04em; }
html:not(.js) .hero h1 .ln > span{ transform:none; }

.hero .sub{ margin-top:30px; max-width:520px; font-size:20px; line-height:1.55; color:rgba(255,255,255,.6);
  opacity:0; transform:translateY(20px); transition:opacity .9s var(--ease-out) .55s, transform .9s var(--ease-out) .55s; }
body.loaded .hero .sub{ opacity:1; transform:none; }
html:not(.js) .hero .sub{ opacity:1; transform:none; }

.hero .cta-row{ margin-top:38px; display:flex; align-items:center; gap:24px; flex-wrap:wrap;
  opacity:0; transform:translateY(20px); transition:opacity .9s var(--ease-out) .7s, transform .9s var(--ease-out) .7s; }
body.loaded .hero .cta-row{ opacity:1; transform:none; }
html:not(.js) .hero .cta-row{ opacity:1; transform:none; }
.hero .cta-note{ font-size:14px; color:var(--mist); max-width:180px; line-height:1.4; }

/* hero phase list (right) */
.phase-list{ border-top:1px solid var(--ink-3); opacity:0; transform:translateY(24px);
  transition:opacity 1s var(--ease-out) .5s, transform 1s var(--ease-out) .5s; }
body.loaded .phase-list{ opacity:1; transform:none; }
html:not(.js) .phase-list{ opacity:1; transform:none; }
.phase-list .ph{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:18px;
  padding:18px 4px; border-bottom:1px solid var(--ink-3); position:relative; transition:padding-left .4s var(--ease); }
.phase-list .ph .code{ font-family:var(--font-display); font-weight:800; font-size:22px; color:var(--mist); transition:color .4s var(--ease); width:36px; }
.phase-list .ph .nm{ font-family:var(--font-cond); font-weight:700; font-size:19px; letter-spacing:.04em; text-transform:uppercase; color:#fff; }
.phase-list .ph .nm small{ display:block; font-family:var(--font-body); font-weight:400; font-size:13px; letter-spacing:0; text-transform:none; color:var(--mist); margin-top:2px; }
.phase-list .ph .dot{ width:9px; height:9px; background:var(--ink-3); transition:background .4s var(--ease), transform .4s var(--ease); }
.phase-list .ph:hover{ padding-left:14px; }
.phase-list .ph:hover .code{ color:var(--orange-mid); }
.phase-list .ph:hover .dot{ background:var(--orange); transform:scale(1.3); }
.phase-list .ph.active .code{ color:var(--orange); }
.phase-list .ph.active .dot{ background:var(--orange); }

/* hero data strip */
.hero-strip{ position:relative; z-index:2; border-top:1px solid var(--ink-3); margin-top:60px; }
.hero-strip .wrap{ display:flex; flex-wrap:wrap; }
.hero-strip .it{ flex:1; min-width:160px; padding:24px 0; display:flex; align-items:baseline; gap:12px; border-right:1px solid var(--ink-3); }
.hero-strip .it:last-child{ border-right:0; }
.hero-strip .n{ font-family:var(--font-display); font-weight:800; font-size:30px; color:var(--orange-mid); }
.hero-strip .l{ font-family:var(--font-cond); font-weight:600; font-size:15px; letter-spacing:.1em; text-transform:uppercase; color:var(--mist); }
@media (max-width:760px){ .hero-strip .it{ flex:1 1 50%; border-right:0; padding:18px 0; } }

.scroll-hint{ position:relative; z-index:2; }

/* ── marquee ── */
.ticker{ background:var(--orange); overflow:hidden; }
.ticker-track{ display:inline-flex; white-space:nowrap; will-change:transform; animation:marquee 30s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state:paused; }
.ticker span{ font-family:var(--font-cond); font-weight:700; font-size:19px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); padding:15px 0; display:inline-flex; align-items:center; }
.ticker span::after{ content:""; width:6px; height:6px; background:rgba(28,26,24,.5); margin:0 32px; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ============================================================
   SECTION SHELL
   ============================================================ */
section.block{ padding:130px 0; position:relative; }
.bg-paper{ background:var(--paper); }
.bg-warm{ background:var(--warm-100); }
.bg-ink{ background:var(--ink); color:#fff; }
.dark{ color:#fff; }

.sec-head{ display:grid; grid-template-columns:1fr; gap:0; max-width:900px; }
.sec-head h2{ font-size:clamp(34px,5vw,68px); margin-top:26px; line-height:1.0; }
.dark .sec-head h2{ color:#fff; }
.sec-head .lead{ margin-top:26px; font-size:20px; color:var(--stone); max-width:640px; }
.dark .sec-head .lead{ color:rgba(255,255,255,.6); }

/* reveal util */
[data-reveal]{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
[data-reveal].in{ opacity:1; transform:none; }
[data-rd="1"]{ transition-delay:.08s } [data-rd="2"]{ transition-delay:.16s }
[data-rd="3"]{ transition-delay:.24s } [data-rd="4"]{ transition-delay:.32s } [data-rd="5"]{ transition-delay:.40s }
html:not(.js) [data-reveal]{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
  .hero h1 .ln > span,.hero .sub,.hero .cta-row,.phase-list{ opacity:1 !important; transform:none !important; transition:none !important; }
}

/* ============================================================
   2 · PROBLEMA — editorial list
   ============================================================ */
.statement{ font-family:var(--font-display); font-weight:800; font-size:clamp(30px,4.2vw,58px); line-height:1.08; letter-spacing:-.02em; max-width:1040px; margin-top:30px; }
.statement .hl{ color:var(--orange); }
.statement .strike{ color:var(--mist); text-decoration:line-through; text-decoration-thickness:3px; text-decoration-color:var(--warm-300); }

.fail{ margin-top:80px; border-top:1px solid var(--warm-200); }
.frow{ display:grid; grid-template-columns:90px 1fr 1.1fr; gap:40px; align-items:start; padding:40px 0; border-bottom:1px solid var(--warm-200); transition:background .4s var(--ease), padding-left .4s var(--ease); }
.frow:hover{ padding-left:18px; }
.frow .fn{ font-family:var(--font-display); font-weight:800; font-size:34px; color:var(--warm-300); transition:color .4s var(--ease); }
.frow:hover .fn{ color:var(--orange); }
.frow h3{ font-size:25px; line-height:1.12; }
.frow p{ color:var(--stone); font-size:17px; line-height:1.55; }
.problem-foot{ margin-top:64px; display:flex; align-items:center; gap:26px; flex-wrap:wrap; }
.problem-foot .q{ font-family:var(--font-display); font-weight:800; font-size:clamp(22px,2.6vw,30px); letter-spacing:-.01em; max-width:620px; line-height:1.18; }
.problem-foot .q em{ font-style:normal; color:var(--orange); }
@media (max-width:820px){ .frow{ grid-template-columns:60px 1fr; gap:18px 22px; } .frow p{ grid-column:1/-1; } }

/* ============================================================
   3 · O SISTEMA — journey rail (centerpiece)
   ============================================================ */
.journey{ margin-top:80px; }
.jrail{ position:relative; }
.jrail .baseline{ position:absolute; left:0; right:0; top:54px; height:2px; background:var(--ink-3); }
.jrail .baseline .prog{ position:absolute; left:0; top:0; height:100%; width:0; background:var(--orange); transition:width .9s var(--ease-out); }
.jsteps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.jstep{ position:relative; padding:0 26px 0 0; }
.jstep .node{ position:relative; z-index:2; width:108px; }
.jstep .ncode{ font-family:var(--font-display); font-weight:900; font-size:30px; color:#fff; background:var(--ink-2); display:inline-flex; align-items:center; justify-content:center; width:108px; height:108px; border:2px solid var(--ink-3); transition:background .5s var(--ease), border-color .5s var(--ease), color .5s var(--ease); }
.jstep.lit .ncode{ background:var(--orange); border-color:var(--orange); color:var(--ink); }
.jstep .body{ margin-top:30px; padding-right:20px; }
.jstep .ptag{ font-family:var(--font-cond); font-weight:700; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange-mid); }
.jstep .pname{ font-family:var(--font-display); font-weight:800; font-size:26px; color:#fff; margin-top:10px; line-height:1.04; }
.jstep .pdesc{ color:rgba(255,255,255,.58); font-size:15.5px; line-height:1.5; margin-top:14px; }
.jstep .pmeta{ margin-top:20px; padding-top:16px; border-top:1px solid var(--ink-3); display:flex; justify-content:space-between; gap:10px; }
.jstep .pmeta .k{ font-family:var(--font-cond); font-weight:600; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--mist); }
.jstep .pmeta .v{ font-family:var(--font-display); font-weight:700; font-size:16px; color:#fff; margin-top:3px; }

/* parallel band P3 */
.parallel{ margin-top:56px; display:grid; grid-template-columns:auto 1fr auto; gap:32px; align-items:center; padding:30px 34px; background:#fff; color:var(--ink); position:relative; }
.parallel .ptag{ font-family:var(--font-cond); font-weight:700; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:#fff; background:var(--orange); padding:7px 13px; align-self:flex-start; }
.parallel h3{ font-size:23px; }
.parallel h3 small{ display:block; font-family:var(--font-body); font-weight:400; font-size:15px; color:var(--stone); margin-top:5px; }
.parallel p{ color:var(--stone); font-size:16px; max-width:540px; }
.parallel .meta{ text-align:right; }
.parallel .meta .v{ font-family:var(--font-display); font-weight:800; font-size:18px; color:var(--orange-deep); }
.parallel .meta .k{ font-family:var(--font-cond); font-weight:600; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--mist); }
.journey-note{ margin-top:36px; font-family:var(--font-cond); font-weight:600; font-size:16px; letter-spacing:.04em; text-transform:uppercase; color:var(--mist); display:flex; align-items:center; gap:14px; }
.journey-note::before{ content:""; width:30px; height:2px; background:var(--orange); }

@media (max-width:900px){
  .jsteps{ grid-template-columns:1fr; }
  .jrail .baseline{ left:53px; right:auto; top:0; bottom:0; width:2px; height:auto; }
  .jrail .baseline .prog{ width:100% !important; height:0; }
  .jstep{ padding:0 0 44px 0; }
  .jstep .body{ margin-top:18px; margin-left:0; }
  .parallel{ grid-template-columns:1fr; gap:16px; text-align:left; }
  .parallel .meta{ text-align:left; }
}

/* ============================================================
   4 · MÉTODO — measurement / gauge
   ============================================================ */
.method-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:72px; margin-top:70px; align-items:center; }
.gauge-card{ background:#fff; border:1px solid var(--warm-200); padding:44px; }
.gauge-top{ display:flex; justify-content:space-between; align-items:baseline; }
.gauge-top .lbl{ font-family:var(--font-cond); font-weight:700; font-size:14px; letter-spacing:.14em; text-transform:uppercase; color:var(--stone); }
.gauge-top .scale{ font-family:var(--font-cond); font-weight:600; font-size:13px; letter-spacing:.1em; color:var(--mist); }
.gauge-score{ font-family:var(--font-display); font-weight:900; font-size:96px; line-height:1; letter-spacing:-.03em; color:var(--ink); margin:18px 0 4px; }
.gauge-score .den{ font-size:40px; color:var(--warm-300); }
.gauge-bar{ height:14px; background:var(--warm-100); position:relative; margin-top:24px; overflow:hidden; }
.gauge-bar .fillb{ position:absolute; left:0; top:0; height:100%; width:0; background:var(--orange); transition:width 1.4s var(--ease-out); }
.gauge-ticks{ display:flex; justify-content:space-between; margin-top:10px; }
.gauge-ticks span{ font-family:var(--font-cond); font-weight:600; font-size:12px; color:var(--mist); }
.gauge-dims{ margin-top:30px; border-top:1px solid var(--warm-200); padding-top:24px; display:grid; grid-template-columns:repeat(2,1fr); gap:14px 28px; }
.gauge-dims .dim{ display:flex; align-items:center; gap:12px; font-size:15px; color:var(--ink-2); }
.gauge-dims .dim .b{ width:7px; height:7px; background:var(--orange); }

.diffs{ display:grid; gap:0; }
.diff{ display:grid; grid-template-columns:auto 1fr; gap:26px; padding:30px 0; border-bottom:1px solid var(--warm-200); }
.diff:first-child{ border-top:1px solid var(--warm-200); }
.diff .dn{ font-family:var(--font-cond); font-weight:700; font-size:15px; letter-spacing:.1em; color:var(--orange); padding-top:6px; }
.diff h3{ font-size:25px; line-height:1.1; }
.diff h3 em{ font-style:normal; color:var(--orange); }
.diff p{ margin-top:12px; color:var(--stone); font-size:16px; line-height:1.55; }
.diff .tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.diff .tags span{ font-family:var(--font-cond); font-weight:600; font-size:13px; letter-spacing:.06em; text-transform:uppercase; padding:5px 11px; background:var(--warm-100); color:var(--ink-3); border:1px solid var(--warm-200); }
@media (max-width:900px){ .method-grid{ grid-template-columns:1fr; gap:48px; } }

/* ============================================================
   5 · CASE — data hero
   ============================================================ */
.case-head{ display:grid; grid-template-columns:1fr auto; align-items:end; gap:30px; }
.case-tag{ display:inline-flex; gap:11px; align-items:center; font-family:var(--font-cond); font-weight:600; font-size:15px; letter-spacing:.06em; text-transform:uppercase; color:var(--mist); }
.case-tag .dot{ width:8px; height:8px; background:var(--orange); }
.case-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:80px; margin-top:60px; align-items:start; }
.case-story h3{ font-family:var(--font-cond); font-weight:700; font-size:15px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange-mid); margin:34px 0 12px; }
.case-story h3:first-child{ margin-top:0; }
.case-story p{ color:rgba(255,255,255,.72); font-size:17.5px; line-height:1.6; }
.case-flow{ display:flex; align-items:center; gap:12px; margin:28px 0 6px; flex-wrap:wrap; }
.case-flow .pill{ font-family:var(--font-display); font-weight:800; font-size:15px; color:#fff; border:1px solid var(--ink-3); padding:8px 15px; transition:.4s var(--ease); }
.case-flow .pill.on{ background:var(--orange); border-color:var(--orange); color:var(--ink); }
.case-flow .ar{ color:var(--orange); font-size:14px; }
.metrics{ border-top:2px solid var(--orange); }
.metric{ padding:34px 0; border-bottom:1px solid var(--ink-3); }
.metric .num{ font-family:var(--font-display); font-weight:900; font-size:clamp(48px,5.4vw,72px); line-height:.95; letter-spacing:-.03em; color:#fff; }
.metric .num .u{ color:var(--orange-mid); }
.metric .lbl{ margin-top:12px; font-family:var(--font-cond); font-weight:600; font-size:15px; letter-spacing:.08em; text-transform:uppercase; color:var(--mist); }
.case-cta{ margin-top:64px; display:flex; align-items:center; gap:28px; flex-wrap:wrap; }
.case-cta .q{ font-family:var(--font-display); font-weight:800; font-size:24px; color:#fff; }
@media (max-width:760px){ .case-grid{ grid-template-columns:1fr; gap:48px; } .case-head{ grid-template-columns:1fr; gap:18px; } }

/* ============================================================
   6 · RAFAEL
   ============================================================ */
.rafael-grid{ display:grid; grid-template-columns:34% 1fr; gap:64px; margin-top:64px; align-items:start; }
.rafael-photo{ position:relative; aspect-ratio:4/5; background:var(--ink); overflow:hidden; }
.rafael-photo img{ width:100%; height:100%; object-fit:cover; object-position:50% 22%; filter:grayscale(1) contrast(1.05) brightness(.92); transform:scale(1.05); transition:transform 1.3s var(--ease-out), filter .8s var(--ease); }
.rafael-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(28,26,24,.06), rgba(28,26,24,.5)), linear-gradient(0deg, rgba(232,96,10,.14), rgba(232,96,10,.02)); mix-blend-mode:multiply; }
.rafael-grid:hover .rafael-photo img{ transform:scale(1); filter:grayscale(.65) contrast(1.04) brightness(.95); }
.rafael-photo .name-tag{ position:absolute; left:0; bottom:0; z-index:2; background:var(--orange); color:var(--ink); font-family:var(--font-display); font-weight:800; font-size:21px; padding:10px 18px; }
.rafael-content .role{ font-family:var(--font-cond); font-weight:700; font-size:15px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange-deep); }
.rafael-content .bio{ font-size:18.5px; line-height:1.68; color:var(--ink-2); margin-top:20px; }
.rafael-content .bio strong{ color:var(--ink); font-weight:600; }
.rafael-quote{ margin-top:36px; padding:30px 34px; background:var(--ink); color:#fff; position:relative; font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.3vw,27px); line-height:1.3; letter-spacing:-.01em; }
.rafael-quote::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--orange); }
.rafael-creds{ display:flex; flex-wrap:wrap; gap:9px; margin-top:30px; }
.rafael-creds .cred{ font-family:var(--font-cond); font-weight:600; font-size:14px; letter-spacing:.04em; text-transform:uppercase; padding:8px 14px; border:1px solid var(--warm-300); color:var(--ink-3); }
.rafael-creds .cred.fill{ background:var(--ink); color:#fff; border-color:var(--ink); }
@media (max-width:900px){ .rafael-grid{ grid-template-columns:1fr; gap:36px; } .rafael-photo{ max-width:360px; } }

/* ============================================================
   7 · CTA
   ============================================================ */
.cta-final{ background:var(--orange); color:var(--ink); padding:140px 0; text-align:center; position:relative; overflow:hidden; }
.cta-final .ring{ position:absolute; border:2px solid rgba(28,26,24,.12); border-radius:50%; }
.cta-final .ring.r1{ width:540px; height:540px; top:-210px; left:-170px; }
.cta-final .ring.r2{ width:700px; height:700px; bottom:-360px; right:-200px; }
.cta-final h2{ font-size:clamp(36px,5.4vw,76px); line-height:.98; max-width:960px; margin:0 auto; position:relative; }
.cta-final .sub{ margin:28px auto 0; max-width:560px; font-size:20px; color:rgba(28,26,24,.74); position:relative; }
.cta-final .btn-wrap{ margin-top:46px; position:relative; }
.cta-final .contact{ margin-top:56px; display:flex; justify-content:center; gap:16px 44px; flex-wrap:wrap; font-family:var(--font-cond); font-weight:700; font-size:18px; letter-spacing:.04em; text-transform:uppercase; position:relative; }
.cta-final .contact a{ display:inline-flex; align-items:center; gap:11px; white-space:nowrap; }
.cta-final .contact .ic{ width:7px; height:7px; background:var(--ink); }

/* footer */
.foot{ background:var(--ink); color:#fff; padding:84px 0 36px; }
.foot-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:50px; }
.foot .logo{ font-size:34px; }
.foot .tagline{ margin-top:20px; color:rgba(255,255,255,.5); font-size:16px; max-width:300px; line-height:1.5; }
.foot h4{ font-family:var(--font-cond); font-weight:700; font-size:14px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange-mid); margin-bottom:20px; }
.foot ul{ list-style:none; }
.foot li{ margin-bottom:12px; }
.foot a{ color:rgba(255,255,255,.66); font-size:15px; transition:color .3s; }
.foot a:hover{ color:#fff; }
.foot-bottom{ margin-top:64px; padding-top:26px; border-top:1px solid var(--ink-3); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; color:var(--mist); font-family:var(--font-cond); font-weight:500; font-size:14px; letter-spacing:.06em; text-transform:uppercase; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hero .wrap{ grid-template-columns:1fr; gap:48px; }
  .hero-visual{ order:2; }
  :root{ --gut:32px; }
}
@media (max-width:760px){
  body{ font-size:17px; }
  :root{ --gut:22px; }
  .nav-links{ position:fixed; inset:0 0 0 auto; width:min(82vw,330px); background:var(--ink); flex-direction:column; align-items:flex-start; justify-content:center; gap:30px; padding:44px; transform:translateX(100%); transition:transform .42s var(--ease-out); z-index:120; }
  .nav-links.open{ transform:translateX(0); }
  .nav-links .nav-link{ color:#fff !important; font-size:23px; }
  .nav-burger{ display:flex; }
  .nav-burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); background:#fff; }
  .nav-burger.open span:nth-child(2){ opacity:0; }
  .nav-burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); background:#fff; }
  section.block{ padding:84px 0; }
  .gauge-card{ padding:30px 24px; }
  .gauge-score{ font-size:74px; }
  .foot-grid{ grid-template-columns:1fr; gap:40px; }
}
