/* ============================================================
   Rinus · Propuesta NICE Success Copilot
   Microsite scrolleable — sistema de diseño de marca Rinus
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500&family=Outfit:wght@400;500;600;700&display=swap");

:root {
  --pitch-950:#0B1410; --pitch-900:#0F1C17; --pitch-800:#15261F; --pitch-700:#1C3329;
  --pitch-600:#234234; --pitch-500:#2D5442; --pitch-400:#4A7860; --pitch-300:#7CA892;
  --pitch-200:#B4D3C3; --pitch-100:#DCEAE2; --pitch-50:#EEF4F0;

  --paper-50:#FAF8F3; --paper-100:#F3EFE6; --paper-200:#E8E2D4; --paper-300:#D4CCB9;
  --paper-400:#A89E88; --paper-500:#7A7260; --paper-600:#524C3F; --paper-700:#34302A;

  --patina:#D9E5DA; --signal:#E8613C; --signal-ink:#B8421F;
  --peach:#F7E6DF; --sage:#8FB39B; --tan:#B3A589;

  --ink:var(--pitch-950); --line:var(--paper-200); --line-strong:var(--paper-300);

  --font-sans:"Geist",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-display:"Outfit","Geist",ui-sans-serif,system-ui,sans-serif;
  --font-mono:"Geist Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;

  --ease-out:cubic-bezier(0.2,0.8,0.2,1);
  --dur-fast:140ms; --dur-med:240ms; --dur-slow:560ms;
}

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

html { scroll-behavior:smooth; scroll-snap-type:y proximity; }
body {
  font-family:var(--font-sans);
  background:var(--pitch-950); color:var(--paper-50);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection { background:var(--signal); color:#fff; }

/* ── Slide scaffold ───────────────────────────────────────── */
.slide {
  min-height:100vh; scroll-snap-align:start;
  display:flex; align-items:center; position:relative;
  padding:96px clamp(24px,6vw,118px); overflow:hidden;
}
.slide-inner { width:100%; max-width:1300px; margin:0 auto; }

.slide--dark  { background:var(--pitch-950); color:var(--paper-50); }
.slide--paper { background:var(--paper-50);  color:var(--pitch-950); }

.slide--dark::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 90% at 82% 8%, rgba(124,168,146,.10), transparent 55%);
}

/* ── Section header ───────────────────────────────────────── */
.kicker {
  font-family:var(--font-mono); font-size:12px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--paper-500); display:block; margin-bottom:18px;
}
.slide--dark .kicker { color:var(--pitch-300); }
.kicker.hot { color:var(--signal-ink); }
.slide--dark .kicker.hot { color:var(--signal); }

.shead { display:flex; justify-content:space-between; align-items:flex-end; gap:28px; flex-wrap:wrap; }
.shead .meta-r {
  font-family:var(--font-mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--paper-400); white-space:nowrap; padding-bottom:6px;
}
.slide--dark .shead .meta-r { color:var(--pitch-400); }

/* ── Headlines ────────────────────────────────────────────── */
.h-display {
  font-family:var(--font-display); font-weight:600; line-height:1.02;
  letter-spacing:-0.02em; font-size:clamp(42px,6.6vw,96px);
}
.h-title {
  font-family:var(--font-display); font-weight:600; line-height:1.05;
  letter-spacing:-0.018em; font-size:clamp(30px,4.2vw,56px);
}
.h-sub {
  font-family:var(--font-display); font-weight:500; line-height:1.12;
  letter-spacing:-0.01em; font-size:clamp(20px,2.2vw,30px);
}
.accent { color:var(--signal); }
.accent-green { color:var(--pitch-400); }
.slide--dark .accent-green { color:var(--pitch-300); }
em.soft { font-style:normal; color:var(--pitch-400); }
.slide--dark em.soft { color:var(--pitch-300); }

.lede {
  font-size:clamp(16px,1.4vw,20px); line-height:1.6; color:var(--paper-600); max-width:62ch;
}
.slide--dark .lede { color:var(--pitch-100); }
.lede strong { color:var(--pitch-800); font-weight:600; }
.slide--dark .lede strong { color:#fff; }

/* ── Topbar + progress + dots ─────────────────────────────── */
.progress { position:fixed; top:0; left:0; height:3px; z-index:60; background:var(--signal); width:0; transition:width .12s linear; }
.topbar {
  position:fixed; top:0; left:0; right:0; z-index:50; pointer-events:none;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px clamp(24px,6vw,118px);
}
.topbar .brand { display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600; font-size:18px; text-decoration:none; pointer-events:auto; }
.topbar .brand img { width:26px; height:26px; display:block; }
/* el logo nunca cambia; solo el texto se adapta al fondo de la slide */
.topbar .brand span, .topbar .meta { color:#fff; transition:color var(--dur-med) var(--ease-out); }
.topbar .meta { font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; }
.topbar.on-paper .brand span, .topbar.on-paper .meta { color:var(--pitch-900); }

.dots { position:fixed; right:26px; top:50%; transform:translateY(-50%); z-index:50; display:flex; flex-direction:column; gap:13px; }
.dots a { width:9px; height:9px; border-radius:50%; background:rgba(255,255,255,.30); transition:all var(--dur-med) var(--ease-out); display:block; }
.dots a:hover { transform:scale(1.25); }
.dots a.is-active { background:var(--signal); transform:scale(1.4); }
.dots.on-paper a { background:rgba(11,20,16,.20); }
.dots.on-paper a.is-active { background:var(--signal); }

/* ── Reveal ───────────────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); transition-delay:var(--d,0ms); }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto;} .reveal{opacity:1;transform:none;transition:none;} }

/* ── Layout helpers ───────────────────────────────────────── */
.grid { display:grid; gap:clamp(16px,1.8vw,26px); }
.cols-2 { grid-template-columns:repeat(2,1fr); }
.cols-3 { grid-template-columns:repeat(3,1fr); }
.stack { display:flex; flex-direction:column; }
.row { display:flex; align-items:center; }
.mono { font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-500); }
.slide--dark .mono { color:var(--pitch-300); }
.note { font-size:13px; line-height:1.55; color:var(--paper-500); }
.slide--dark .note { color:var(--pitch-300); }
.rule { height:1px; background:var(--line); border:0; }
.slide--dark .rule { background:rgba(255,255,255,.12); }

/* ── Cards ────────────────────────────────────────────────── */
.card {
  border:1px solid var(--line); border-radius:16px; background:#fff;
  padding:clamp(20px,1.9vw,28px);
  transition:border-color var(--dur-med), box-shadow var(--dur-med), transform var(--dur-med);
}
.card:hover { border-color:var(--pitch-300); box-shadow:0 16px 40px -26px rgba(11,20,16,.30); transform:translateY(-3px); }
.slide--dark .card { background:rgba(255,255,255,.03); border-color:rgba(255,255,255,.10); }
.slide--dark .card:hover { border-color:rgba(124,168,146,.5); }
.card--peach { background:var(--peach); border-color:rgba(232,97,60,.35); }
.card--green { background:rgba(143,179,155,.16); border-color:rgba(124,168,146,.4); }
.card--dark  { background:var(--pitch-950); border-color:var(--pitch-950); color:var(--paper-50); }

/* slide 4 · highlight de fase en hover → naranja */
#s4 .card { cursor:default; }
#s4 .card:hover { border-color:var(--signal); background:var(--peach); box-shadow:0 18px 44px -26px rgba(232,97,60,.5); }
#s4 .card:hover .card-h { color:var(--signal-ink); }
#s4 .card:hover .kicker { color:var(--signal-ink); }
#s4 .card:hover .tag-out { border-color:var(--signal); color:var(--signal-ink); }
#s4 .card:hover .bullets li { color:var(--pitch-800); }
#s4 .card:hover .bullets li::before { background:var(--signal); }
.card-h { font-family:var(--font-display); font-weight:600; font-size:19px; margin-bottom:8px; display:flex; align-items:center; gap:10px; }
.card-b { font-size:14.5px; line-height:1.55; color:var(--paper-600); }
.slide--dark .card-b, .card--dark .card-b { color:var(--pitch-200); }

.card-ico { width:30px; height:30px; border-radius:8px; display:grid; place-items:center; flex:none; background:var(--pitch-100); color:var(--pitch-600); }
.card--peach .card-ico { background:rgba(232,97,60,.16); color:var(--signal-ink); }
.card--green .card-ico { background:rgba(124,168,146,.25); color:var(--pitch-700); }

/* ── Lists ────────────────────────────────────────────────── */
.checklist, .bullets { list-style:none; display:flex; flex-direction:column; gap:11px; }
.checklist li { display:flex; gap:11px; align-items:flex-start; font-size:15px; line-height:1.45; }
.checklist .ck { flex:none; width:19px; height:19px; border-radius:5px; background:rgba(232,97,60,.14); color:var(--signal-ink); display:grid; place-items:center; margin-top:1px; font-size:11px; }
.card--green .checklist .ck { background:rgba(124,168,146,.28); color:var(--pitch-700); }
.slide--dark .checklist .ck, .card--dark .checklist .ck { background:rgba(124,168,146,.2); color:var(--pitch-200); }
.bullets li { display:flex; gap:12px; align-items:flex-start; font-size:15.5px; line-height:1.5; color:var(--paper-700); }
.bullets li::before { content:""; flex:none; width:6px; height:6px; border-radius:50%; background:var(--pitch-300); margin-top:9px; }
.card--peach .bullets li { color:var(--pitch-800); }
.card--peach .bullets li::before { background:var(--signal); }

/* ── Stats ────────────────────────────────────────────────── */
.stat-n { font-family:var(--font-display); font-weight:700; font-size:clamp(40px,5vw,68px); line-height:1; letter-spacing:-0.03em; color:var(--pitch-700); }
.stat-n.accent { color:var(--signal); }
.stat-n.stat-alt { color:var(--pitch-400); }
.stat-n small { font-size:.42em; font-weight:600; letter-spacing:-0.01em; }
.stat-l { font-size:14.5px; line-height:1.45; color:var(--paper-600); margin-top:12px; }
.slide--dark .stat-l { color:var(--pitch-200); }

/* ── Pills / chips ────────────────────────────────────────── */
.pill { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:7px 13px; border-radius:999px; border:1px solid currentColor; color:var(--paper-500); }
.slide--dark .pill { color:var(--pitch-300); }
.pill.hot { color:var(--signal); }
.pill .dot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.tag-solid { font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:7px 13px; border-radius:7px; background:var(--signal); color:#fff; }
.tag-out { font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:6px 13px; border-radius:7px; border:1px solid var(--line-strong); color:var(--paper-500); }

.chips { display:flex; flex-wrap:wrap; gap:9px; }
.chip { font-family:var(--font-mono); font-size:12.5px; padding:8px 13px; border-radius:9px; border:1px solid var(--line-strong); background:var(--paper-100); color:var(--pitch-700); transition:border-color var(--dur-med), transform var(--dur-med); }
.chip:hover { border-color:var(--pitch-300); transform:translateY(-2px); }
.slide--dark .chip { background:rgba(255,255,255,.03); border-color:rgba(255,255,255,.14); color:var(--paper-100); }

/* ── Sprint calendar (slide 5) ────────────────────────────── */
.sprint { display:flex; flex-direction:column; gap:14px; }
.sprint-weeks { display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2vw,34px); }
.week-lbl { font-family:var(--font-mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-400); text-align:center; margin-bottom:8px; }
.days { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin-top:96px; }
.day { position:relative; aspect-ratio:1.4/1; border-radius:11px; background:var(--paper-100); border:1px solid var(--line); display:grid; place-items:center; font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--paper-500); }
.day.is-inicio { background:var(--signal); color:#fff; border-color:var(--signal); }
.day.is-check { background:var(--tan); color:#fff; border-color:var(--tan); }
.day.is-demo { background:var(--pitch-800); color:#fff; border-color:var(--pitch-800); }

.day .mk { position:absolute; bottom:calc(100% + 16px); left:50%; transform:translateX(-50%); width:158px; text-align:center; pointer-events:none; }
.day .mk::after { content:""; position:absolute; top:calc(100% + 2px); left:50%; transform:translateX(-50%); width:2px; height:12px; background:currentColor; opacity:.5; }
.day.is-inicio .mk { color:var(--signal); }
.day.is-check  .mk { color:var(--tan); }
.day.is-demo   .mk { color:var(--pitch-800); }
.day .mk-day { font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-500); display:block; }
.day .mk-title { font-family:var(--font-display); font-weight:600; font-size:16px; display:block; margin-top:1px; color:currentColor; }
.day .mk-sub { font-size:11px; color:var(--paper-500); display:block; }

.sprint-bars { display:flex; flex-direction:column; gap:7px; margin-top:4px; }
.sbar { height:34px; border-radius:8px; display:flex; align-items:center; padding:0 14px; font-size:13px; font-weight:600; color:#fff; transform-origin:left; }
.sbar.is-dev { background:var(--pitch-800); }
.sbar.is-design { background:var(--sage); color:var(--pitch-900); }
.sbar.is-qa { background:var(--tan); color:var(--pitch-900); }
.sbar.is-buffer { background:transparent; border:1px dashed var(--line-strong); color:var(--paper-500); }
.sbar-track { display:flex; gap:8px; }

/* ── Gantt (slide 6 · paper) ──────────────────────────────── */
.gantt-wrap { overflow-x:visible; padding-bottom:6px; }
.gantt { width:100%; }
.gantt-axis { display:grid; grid-template-columns:172px 1fr; align-items:end; margin-bottom:12px; }
.gantt-months { position:relative; height:44px; }
.gantt-month { position:absolute; top:0; font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-500); transform:translateX(-50%); }
.gantt-date { position:absolute; bottom:0; font-family:var(--font-mono); font-size:11px; color:var(--paper-500); }
.gantt-date.hot { color:var(--signal); }
.gantt-body { position:relative; }
.glines { position:absolute; top:0; bottom:0; left:172px; right:0; pointer-events:none; }
.gline { position:absolute; top:0; bottom:0; width:1px; background:var(--line); }
.gline.hot { background:var(--signal); width:2px; opacity:.7; }
.grow { display:grid; grid-template-columns:172px 1fr; align-items:center; height:40px; position:relative; }
.grow-lbl { font-size:13.5px; color:var(--pitch-700); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; padding-right:12px; }
.grow-lbl b { font-weight:600; color:var(--pitch-900); }
.grow-lbl span { color:var(--paper-500); }
.grow-lbl.hot b { color:var(--signal-ink); }
.gtrack { position:relative; height:100%; }
.gbar { position:absolute; top:50%; transform:translateY(-50%) scaleX(0); transform-origin:left; height:27px; border-radius:6px; display:flex; align-items:center; padding:0 12px; font-size:12.5px; font-weight:600; color:#fff; white-space:nowrap; overflow:hidden; transition:transform .7s var(--ease-out); }
.gbar.in { transform:translateY(-50%) scaleX(1); }
.gbar.b-dev { background:var(--pitch-700); }
.gbar.b-design { background:var(--sage); color:var(--pitch-900); }
.gbar.b-qa { background:var(--tan); color:var(--pitch-900); }
.gbar.b-test { background:var(--pitch-800); }
.gbar.b-pen { background:var(--sage); color:var(--pitch-900); }
.gbuf { position:absolute; top:50%; transform:translateY(-50%); height:27px; border:1px dashed var(--line-strong); border-radius:6px; }
.gdia { position:absolute; top:50%; width:14px; height:14px; background:var(--signal); transform:translate(-50%,-50%) rotate(45deg) scale(0); border-radius:2px; transition:transform .5s var(--ease-out); box-shadow:0 2px 6px rgba(232,97,60,.4); }
.gdia.in { transform:translate(-50%,-50%) rotate(45deg) scale(1); }
.gbuf-pill { position:absolute; top:50%; transform:translateY(-50%); font-family:var(--font-mono); font-size:10.5px; color:var(--signal-ink); border:1px solid rgba(232,97,60,.55); border-radius:6px; padding:5px 9px; }

/* ── Price rows (slide 7) ─────────────────────────────────── */
.price-rows { display:flex; flex-direction:column; }
.prow { display:flex; justify-content:space-between; align-items:center; padding:13px 0; border-top:1px solid var(--line); font-size:16px; color:var(--paper-700); }
.prow:first-child { border-top:0; }
.prow b { font-weight:600; }
.card--dark .prow { border-color:rgba(255,255,255,.10); color:var(--pitch-100); }
.prow--total { border-top:1px solid var(--line-strong); margin-top:6px; padding-top:18px; align-items:flex-end; }
.card--dark .prow--total { border-color:rgba(255,255,255,.16); }
.prow--total span { font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-500); }
.card--dark .prow--total span { color:var(--pitch-300); }
.prow--total b { font-family:var(--font-display); font-size:clamp(28px,3vw,40px); font-weight:700; letter-spacing:-0.02em; line-height:1; }

/* ── Team table (slide 8) ─────────────────────────────────── */
.team-table { display:flex; flex-direction:column; border-radius:14px; overflow:hidden; }
.trow { display:grid; grid-template-columns:1.3fr 2fr .8fr .8fr; align-items:center; padding:16px clamp(14px,1.6vw,24px); gap:14px; }
.trow .num { text-align:right; font-variant-numeric:tabular-nums; }
.trow--head span { font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-500); }
.trow:nth-child(even):not(.trow--head):not(.trow--total) { background:var(--paper-100); }
.trow span b { font-weight:600; display:block; font-size:16px; color:var(--pitch-900); }
.trow span i { font-style:normal; font-size:13px; color:var(--paper-500); }
.trow .num { font-size:16px; color:var(--pitch-800); font-weight:600; }
.trow--total { background:var(--pitch-800); color:#fff; margin-top:8px; border-radius:12px; }
.trow--total span b { color:#fff; }
.trow--total span i { color:var(--pitch-200); }
.trow--total .num { color:#fff; }
.trow--total .num.accent { color:var(--signal); }

/* ── CTA ──────────────────────────────────────────────────── */
.cta-btn { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600; font-size:17px; padding:15px 26px; border-radius:12px; background:var(--signal); color:#fff; text-decoration:none; transition:background var(--dur-med), transform var(--dur-med); }
.cta-btn:hover { background:var(--signal-ink); transform:translateY(-2px); }
.cta-btn .arrow { transition:transform var(--dur-med); }
.cta-btn:hover .arrow { transform:translateX(4px); }

/* closing wordmark */
.wordmark { display:flex; align-items:center; gap:22px; }
.wordmark img { width:clamp(64px,8vw,104px); height:clamp(64px,8vw,104px); }
.wordmark span { font-family:var(--font-display); font-weight:600; font-size:clamp(56px,10vw,128px); letter-spacing:-0.03em; color:var(--paper-50); }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width:880px){
  html { scroll-snap-type:none; }
  .slide { min-height:auto; padding:74px 22px; }
  .cols-2, .cols-3 { grid-template-columns:1fr; }
  .dots { display:none; }
  .topbar .meta { display:none; }
  .shead .meta-r { display:none; }
  .sprint-weeks { grid-template-columns:1fr; gap:22px; }
  .gantt-wrap { overflow-x:auto; }
  .gantt { min-width:680px; }
  .trow { grid-template-columns:1.4fr .6fr .7fr; }
  .trow .resp { display:none; }
  .wordmark span { font-size:clamp(48px,16vw,80px); }
}
