/* ============================================================================
   EDUCATIO · El sistema operativo del estudiante global
   Lopettia, LLC · design system
   Canonical brand tokens — source: corp/website/lopettia.css
   ============================================================================ */

:root {
  /* Warm accents */
  --oro:      #FCE28A;   /* numbers · highlights · links */
  --durazno:  #F7B285;   /* eyebrows · hover */
  --coral:    #F38281;   /* primary CTA · alerts */
  /* Cool accents */
  --teal:     #0D9488;
  --mint:     #5EEAD4;
  /* Neutrals */
  --bg:       #0B1120;
  --navy:     #182440;
  --cream:    #FAF6F1;
  --fg:       #F2F0EB;
  --fg-mute:  rgba(242, 240, 235, .70);
  --fg-dim:   rgba(242, 240, 235, .45);

  --navy-2:   #101a30;
  --line:     rgba(242, 240, 235, .10);
  --line-2:   rgba(242, 240, 235, .06);
  --card:     rgba(24, 36, 64, .55);
  --card-2:   rgba(16, 26, 48, .75);

  --grad-sun: linear-gradient(135deg, var(--oro) 0%, var(--durazno) 50%, var(--coral) 100%);
  --grad-cool: linear-gradient(135deg, var(--mint) 0%, var(--teal) 100%);

  --shadow:   0 24px 60px -28px rgba(0,0,0,.85);
  --glow-oro: 0 0 60px -12px rgba(252, 226, 138, .55);
  --glow-coral: 0 0 60px -14px rgba(243, 130, 129, .55);
  --glow-teal: 0 0 60px -14px rgba(13, 148, 136, .6);

  --font-ui: "Inter", system-ui, -apple-system, sans-serif;
  --font-display: "Quicksand", "Inter", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --maxw: 1240px;
  --r-lg: 26px;
  --r-md: 18px;
  --r-sm: 12px;
  --ease: cubic-bezier(.22, 1, .36, 1);
}

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

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-ui);
  background: var(--bg);
  color: var(--fg);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Ambient page background — deep field with two warm/cool nebulae */
body::before {
  content: "";
  position: fixed; inset: 0;
  background:
    radial-gradient(1100px 700px at 78% -8%,  rgba(243,130,129,.16), transparent 60%),
    radial-gradient(1000px 800px at 8% 12%,   rgba(13,148,136,.16),  transparent 58%),
    radial-gradient(900px 900px at 50% 120%,  rgba(252,226,138,.10), transparent 60%),
    var(--bg);
  z-index: -2;
  pointer-events: none;
}
/* faint dot grid */
body::after {
  content: "";
  position: fixed; inset: 0;
  background-image: radial-gradient(rgba(242,240,235,.05) 1px, transparent 1px);
  background-size: 44px 44px;
  z-index: -1;
  pointer-events: none;
  mask-image: linear-gradient(to bottom, transparent, #000 12%, #000 88%, transparent);
}

::selection { background: rgba(252,226,138,.28); color: #fff; }

a { color: var(--oro); text-decoration: none; }

/* ---- Typographic scale ---- */
.eyebrow {
  font-family: var(--font-mono);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--durazno);
  display: inline-flex; align-items: center; gap: .6rem;
}
.eyebrow::before {
  content: ""; width: 26px; height: 1px;
  background: linear-gradient(90deg, var(--durazno), transparent);
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 700; line-height: 1.05; letter-spacing: -.01em; }

.h-display {
  font-size: clamp(2.6rem, 6.4vw, 5.2rem);
  letter-spacing: -.02em;
}
.h-section {
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  letter-spacing: -.015em;
}
.text-grad {
  background: var(--grad-sun);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.text-cool {
  background: var(--grad-cool);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.lead { font-size: clamp(1.05rem, 1.7vw, 1.32rem); color: var(--fg-mute); max-width: 56ch; }
.mono { font-family: var(--font-mono); }
.num { font-family: var(--font-mono); color: var(--oro); font-variant-numeric: tabular-nums; }

/* ---- Layout ---- */
.section { position: relative; padding: clamp(5rem, 11vh, 9rem) 0; }
.wrap { width: min(var(--maxw), 92vw); margin-inline: auto; }
.section-head { max-width: 760px; margin-bottom: 3.2rem; }
.section-head .eyebrow { margin-bottom: 1.1rem; }
.section-head p { margin-top: 1.1rem; }
.center { text-align: center; margin-inline: auto; }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-ui); font-weight: 600; font-size: .96rem;
  padding: .92rem 1.5rem; border-radius: 999px; border: 1px solid transparent;
  cursor: pointer; transition: transform .25s var(--ease), box-shadow .3s var(--ease), background .25s;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primary {
  background: var(--grad-sun); color: #2a160f;
  box-shadow: var(--glow-coral);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 44px -10px rgba(243,130,129,.7); }
.btn-ghost {
  background: rgba(242,240,235,.04); color: var(--fg); border-color: var(--line);
  backdrop-filter: blur(6px);
}
.btn-ghost:hover { border-color: rgba(252,226,138,.5); color: #fff; transform: translateY(-2px); }
.btn svg { width: 18px; height: 18px; }

/* ---- Topbar ---- */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  transition: background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom: 1px solid transparent;
}
.topbar.scrolled {
  background: rgba(11,17,32,.72);
  backdrop-filter: blur(16px) saturate(140%);
  border-bottom-color: var(--line);
}
.topbar-inner {
  width: min(var(--maxw), 94vw); margin-inline: auto;
  height: 68px; display: flex; align-items: center; gap: 1.4rem;
}
.brand { display: flex; align-items: center; gap: .6rem; font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; letter-spacing: .01em; }
.brand .sun { width: 30px; height: 30px; filter: drop-shadow(0 0 10px rgba(252,226,138,.5)); }
.brand .by { font-family: var(--font-mono); font-size: .62rem; letter-spacing: .2em; color: var(--fg-dim); text-transform: uppercase; border-left: 1px solid var(--line); padding-left: .6rem; margin-left: .25rem; }
.topbar nav { margin-left: auto; display: flex; align-items: center; gap: 1.6rem; }
.topbar nav a { color: var(--fg-mute); font-size: .9rem; font-weight: 500; transition: color .2s; }
.topbar nav a:hover { color: var(--fg); }
.topbar nav a.cta {
  color: #2a160f; background: var(--grad-sun); padding: .5rem 1.05rem; border-radius: 999px; font-weight: 600;
}
.lang {
  display: flex; border: 1px solid var(--line); border-radius: 999px; overflow: hidden; font-family: var(--font-mono);
}
.lang button { background: transparent; border: none; color: var(--fg-dim); font-size: .68rem; font-weight: 700; letter-spacing: .1em; padding: .34rem .6rem; cursor: pointer; transition: .2s; }
.lang button[aria-pressed="true"] { background: var(--grad-sun); color: #2a160f; }
@media (max-width: 940px) { .topbar nav { gap: 1rem; } .topbar nav a:not(.cta):not(.keep) { display: none; } }

/* ---- Scroll progress ---- */
.progress { position: fixed; top: 0; left: 0; height: 2px; width: 0; z-index: 70; background: var(--grad-sun); box-shadow: 0 0 12px rgba(252,226,138,.7); }

/* ---- Watermark ---- */
.watermark {
  position: fixed; bottom: 16px; left: 16px; z-index: 55;
  font-family: var(--font-mono); font-size: .62rem; letter-spacing: .16em;
  color: var(--fg-dim); display: flex; align-items: center; gap: .5rem;
  padding: .4rem .7rem; border: 1px solid var(--line-2); border-radius: 999px;
  background: rgba(11,17,32,.5); backdrop-filter: blur(6px); pointer-events: none; text-transform: uppercase;
}
.watermark .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--coral); box-shadow: 0 0 8px var(--coral); animation: pulse 2.4s infinite; }

/* ============================================================================
   HERO
   ============================================================================ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; overflow: hidden; padding-top: 68px; }
#globe { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.hero-fallback { position: absolute; inset: 0; z-index: 0; background: radial-gradient(circle at 70% 40%, rgba(13,148,136,.25), transparent 55%); display: none; }
.hero-veil { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(90deg, rgba(11,17,32,.92) 0%, rgba(11,17,32,.6) 40%, rgba(11,17,32,.15) 70%, transparent 100%);
}
@media (max-width: 820px){ .hero-veil { background: linear-gradient(180deg, rgba(11,17,32,.5), rgba(11,17,32,.88)); } }
.hero-inner { position: relative; z-index: 2; width: min(var(--maxw), 92vw); margin-inline: auto; }
.hero-content { max-width: 680px; }
.hero h1 { margin: 1.4rem 0 1.5rem; }
.hero .lead { margin-bottom: 2.1rem; }
.hero-actions { display: flex; gap: .9rem; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 2.4rem; margin-top: 3rem; flex-wrap: wrap; }
.hero-stats .stat .n { font-family: var(--font-display); font-weight: 700; font-size: 1.9rem; color: #fff; }
.hero-stats .stat .l { font-size: .8rem; color: var(--fg-mute); }
.scroll-cue { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 2; color: var(--fg-dim); font-family: var(--font-mono); font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.scroll-cue .bar { width: 1px; height: 34px; background: linear-gradient(var(--durazno), transparent); animation: cueDown 2s infinite; }

.chiprow { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: 1.6rem; }
.chip {
  font-family: var(--font-mono); font-size: .72rem; letter-spacing: .04em;
  padding: .4rem .8rem; border-radius: 999px; border: 1px solid var(--line);
  background: rgba(242,240,235,.03); color: var(--fg-mute); display: inline-flex; gap: .45rem; align-items: center;
}
.chip i { width: 6px; height: 6px; border-radius: 50%; background: var(--mint); display: inline-block; }

/* ============================================================================
   GENERIC CARD
   ============================================================================ */
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-md);
  backdrop-filter: blur(14px); box-shadow: var(--shadow);
}
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
[data-delay="1"]{ transition-delay: .08s;} [data-delay="2"]{ transition-delay: .16s;}
[data-delay="3"]{ transition-delay: .24s;} [data-delay="4"]{ transition-delay: .32s;}
[data-delay="5"]{ transition-delay: .40s;} [data-delay="6"]{ transition-delay: .48s;}

/* ============================================================================
   SHIFT  (broken industry → one OS)
   ============================================================================ */
.shift-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; align-items: stretch; }
@media (max-width: 880px){ .shift-grid { grid-template-columns: 1fr; } }
.shift-col { padding: 2rem; border-radius: var(--r-lg); }
.shift-col.before { background: rgba(16,26,48,.5); border: 1px dashed rgba(243,130,129,.35); }
.shift-col.after  { background: linear-gradient(180deg, rgba(13,148,136,.12), rgba(24,36,64,.5)); border: 1px solid rgba(94,234,212,.3); box-shadow: var(--glow-teal); }
.shift-col h3 { font-size: 1.45rem; margin-bottom: .4rem; }
.shift-col .tag { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; }
.shift-col.before .tag { color: var(--coral); }
.shift-col.after .tag { color: var(--mint); }
.frag { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.4rem; }
.frag span { font-size: .82rem; padding: .42rem .7rem; border-radius: 8px; background: rgba(242,240,235,.05); color: var(--fg-mute); border: 1px solid var(--line-2); }
.shift-col.before .frag span { transform: rotate(var(--rot, 0deg)); }
.onebar { margin-top: 1.4rem; display: flex; align-items: center; gap: .8rem; padding: 1rem 1.2rem; border-radius: 12px; background: rgba(11,17,32,.5); border: 1px solid var(--line); }
.onebar .sun { width: 26px; height: 26px; }
.onebar b { font-family: var(--font-display); }
.shifts { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1rem; margin-top: 3rem; }
@media (max-width: 980px){ .shifts { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 560px){ .shifts { grid-template-columns: 1fr;} }
.shift-pill { padding: 1.3rem; border-radius: var(--r-md); background: var(--card); border: 1px solid var(--line); }
.shift-pill .from { font-size: .78rem; color: var(--fg-dim); text-decoration: line-through; }
.shift-pill .to { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: #fff; margin-top: .3rem; }
.shift-pill .ar { color: var(--mint); font-family: var(--font-mono); font-size: .8rem; margin: .2rem 0; }

/* ============================================================================
   LIFECYCLE  (the 360)
   ============================================================================ */
.lc { display: grid; grid-template-columns: 1.05fr .95fr; gap: 2.6rem; align-items: center; }
@media (max-width: 1000px){ .lc { grid-template-columns: 1fr; } }
.lc-ring-wrap { position: relative; aspect-ratio: 1; max-width: 540px; margin-inline: auto; width: 100%; }
.lc-ring { position: absolute; inset: 0; }
.lc-node {
  position: absolute; width: 64px; height: 64px; margin: -32px 0 0 -32px;
  border-radius: 50%; display: grid; place-items: center; cursor: pointer;
  background: var(--card-2); border: 1px solid var(--line); color: var(--fg-mute);
  transition: transform .35s var(--ease), border-color .3s, box-shadow .3s, color .3s;
}
.lc-node svg { width: 26px; height: 26px; }
.lc-node .idx { position: absolute; top: -6px; right: -6px; width: 20px; height: 20px; border-radius: 50%; background: var(--bg); border: 1px solid var(--line); font-family: var(--font-mono); font-size: .6rem; display: grid; place-items: center; color: var(--fg-dim); }
.lc-node:hover { transform: scale(1.12); color: #fff; }
.lc-node.active { color: #2a160f; background: var(--grad-sun); border-color: transparent; box-shadow: var(--glow-oro); transform: scale(1.16); }
.lc-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 40%; height: 40%; border-radius: 50%; display: grid; place-items: center; text-align: center;
  background: radial-gradient(circle, rgba(24,36,64,.9), rgba(11,17,32,.6)); border: 1px solid var(--line);
}
.lc-center .sun { width: 40px; height: 40px; animation: spin 36s linear infinite; }
.lc-center .lab { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .18em; color: var(--fg-dim); text-transform: uppercase; margin-top: .4rem; }
.lc-center .pct { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; color: #fff; }
.lc-orbit { position: absolute; inset: 8%; border: 1px dashed var(--line); border-radius: 50%; }

.lc-detail { min-height: 320px; }
.lc-detail .eyebrow { color: var(--mint); }
.lc-detail .stage-no { font-family: var(--font-mono); color: var(--oro); font-size: .8rem; }
.lc-detail h3 { font-size: clamp(1.7rem, 3vw, 2.3rem); margin: .5rem 0 .2rem; }
.lc-detail .agent-by { display: inline-flex; align-items: center; gap: .5rem; font-size: .85rem; color: var(--fg-mute); margin-bottom: 1.1rem; }
.lc-detail .agent-by b { color: var(--durazno); font-family: var(--font-display); }
.lc-detail .agent-by .av { width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; font-size: .7rem; }
.lc-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.3rem; }
@media (max-width: 480px){ .lc-cols { grid-template-columns: 1fr; } }
.lc-mini { padding: 1.1rem; border-radius: 14px; background: rgba(11,17,32,.5); border: 1px solid var(--line); }
.lc-mini .t { font-family: var(--font-mono); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-dim); margin-bottom: .5rem; display:flex; align-items:center; gap:.4rem;}
.lc-mini.you .t { color: var(--mint); } .lc-mini.co .t { color: var(--oro); }
.lc-mini p { font-size: .92rem; color: var(--fg); }
.lc-controls { display: flex; align-items: center; gap: 1rem; margin-top: 1.6rem; flex-wrap: wrap; }
.lc-bar { flex: 1; min-width: 120px; height: 4px; border-radius: 999px; background: var(--line); overflow: hidden; }
.lc-bar i { display: block; height: 100%; width: 10%; background: var(--grad-sun); transition: width .5s var(--ease); }

/* ============================================================================
   CONSTELLATION
   ============================================================================ */
.constel { position: relative; }
.constel-canvas-wrap { position: relative; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); background: radial-gradient(circle at 50% 40%, rgba(24,36,64,.6), rgba(11,17,32,.9)); min-height: 460px; }
#constellation { display: block; width: 100%; height: 460px; }
.constel-legend { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-top: 1.6rem; }
.constel-legend .a { font-family: var(--font-mono); font-size: .74rem; padding: .35rem .7rem; border-radius: 999px; border: 1px solid var(--line); color: var(--fg-mute); display: inline-flex; gap: .45rem; align-items: center; }
.constel-legend .a b { width: 8px; height: 8px; border-radius: 50%; }

/* ============================================================================
   ALIGNMENT  (dual dashboards)
   ============================================================================ */
.align-grid { display: grid; grid-template-columns: .82fr 1.18fr; gap: 2rem; align-items: center; }
@media (max-width: 1040px){ .align-grid { grid-template-columns: 1fr; } }

/* phone */
.phone { width: 300px; max-width: 84vw; margin-inline: auto; aspect-ratio: 300/620; border-radius: 42px; padding: 12px; background: linear-gradient(160deg,#1b2742,#0d1424); border: 1px solid rgba(242,240,235,.12); box-shadow: var(--shadow), inset 0 0 0 2px rgba(0,0,0,.4); position: relative; }
.phone::before { content:""; position:absolute; top:18px; left:50%; transform:translateX(-50%); width:96px; height:6px; border-radius:99px; background:rgba(0,0,0,.5);}
.phone-screen { height: 100%; border-radius: 32px; background: var(--bg); overflow: hidden; display: flex; flex-direction: column; position: relative; }
.ph-top { padding: 2.1rem 1.1rem .8rem; }
.ph-top .hi { font-size: .72rem; color: var(--fg-mute); }
.ph-top .nm { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; }
.ph-prog { display: flex; align-items: center; gap: .8rem; padding: .2rem 1.1rem 1rem; }
.ph-ring { --p: 60; width: 64px; height: 64px; border-radius: 50%; flex: 0 0 auto;
  background: conic-gradient(var(--mint) calc(var(--p)*1%), rgba(242,240,235,.1) 0); display: grid; place-items: center; }
.ph-ring span { width: 50px; height: 50px; border-radius: 50%; background: var(--bg); display: grid; place-items: center; font-family: var(--font-mono); font-size: .82rem; color: #fff; }
.ph-prog .meta .s { font-size: .72rem; color: var(--fg-dim); font-family: var(--font-mono); }
.ph-prog .meta .b { font-size: .92rem; font-weight: 600; }
.ph-body { flex: 1; overflow: hidden; padding: 0 1.1rem; display: flex; flex-direction: column; gap: .6rem; }
.ph-tile { padding: .75rem .85rem; border-radius: 14px; background: var(--card); border: 1px solid var(--line); }
.ph-tile .r { display: flex; justify-content: space-between; align-items: center; }
.ph-tile .k { font-size: .7rem; color: var(--fg-mute); font-family: var(--font-mono); letter-spacing: .04em; }
.ph-tile .v { font-size: .86rem; font-weight: 600; }
.ph-tile .v.ok { color: var(--mint); } .ph-tile .v.warn { color: var(--durazno); }
.ph-bar { height: 5px; border-radius: 99px; background: rgba(242,240,235,.1); margin-top: .55rem; overflow: hidden; }
.ph-bar i { display: block; height: 100%; border-radius: 99px; }
.ph-cta { margin: .2rem 1.1rem 1.1rem; padding: .7rem; text-align: center; border-radius: 14px; background: var(--grad-sun); color: #2a160f; font-weight: 700; font-size: .82rem; }
.ph-nav { display: flex; justify-content: space-around; padding: .7rem; border-top: 1px solid var(--line); }
.ph-nav i { width: 18px; height: 18px; border-radius: 5px; background: rgba(242,240,235,.12); }
.ph-nav i.on { background: var(--grad-sun); }

/* console */
.console { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); background: var(--card-2); box-shadow: var(--shadow); }
.console-bar { display: flex; align-items: center; gap: .5rem; padding: .7rem 1rem; border-bottom: 1px solid var(--line); background: rgba(11,17,32,.5); }
.console-bar .dts { display: flex; gap: .4rem; }
.console-bar .dts i { width: 10px; height: 10px; border-radius: 50%; background: rgba(242,240,235,.18); }
.console-bar .ttl { font-family: var(--font-mono); font-size: .72rem; color: var(--fg-mute); letter-spacing: .06em; }
.console-bar .live { margin-left: auto; font-family: var(--font-mono); font-size: .64rem; color: var(--mint); display: flex; align-items: center; gap: .4rem; }
.console-bar .live b { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 8px var(--mint); animation: pulse 2s infinite; }
.console-body { padding: 1.3rem; }
.kpi-row { display: grid; grid-template-columns: repeat(4,1fr); gap: .8rem; margin-bottom: 1.1rem; }
@media (max-width: 560px){ .kpi-row { grid-template-columns: repeat(2,1fr);} }
.kpi { padding: .9rem; border-radius: 14px; background: rgba(11,17,32,.5); border: 1px solid var(--line); }
.kpi .k { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-dim); }
.kpi .v { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; color: #fff; margin-top: .2rem; }
.kpi .d { font-size: .68rem; font-family: var(--font-mono); margin-top: .15rem; }
.kpi .d.up { color: var(--mint); } .kpi .d.warn { color: var(--durazno); }

.pipe { display: grid; grid-template-columns: repeat(6, 1fr); gap: .4rem; margin-bottom: 1.1rem; }
@media (max-width: 700px){ .pipe { grid-template-columns: repeat(3,1fr);} }
.pipe .st { padding: .7rem .5rem; border-radius: 10px; background: rgba(24,36,64,.5); border: 1px solid var(--line); text-align: center; position: relative; }
.pipe .st .n { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--oro); }
.pipe .st .l { font-size: .58rem; font-family: var(--font-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--fg-mute); }
.pipe .st .bar { height: 3px; border-radius: 99px; margin-top: .4rem; background: var(--grad-sun); opacity: .7; }

.tbl { width: 100%; border-collapse: collapse; font-size: .8rem; }
.tbl th { text-align: left; font-family: var(--font-mono); font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: var(--fg-dim); padding: .5rem .6rem; border-bottom: 1px solid var(--line); }
.tbl td { padding: .55rem .6rem; border-bottom: 1px solid var(--line-2); color: var(--fg-mute); }
.tbl td .who { color: var(--fg); font-weight: 600; }
.tbl .pay { font-family: var(--font-mono); }
.badge { font-family: var(--font-mono); font-size: .62rem; padding: .18rem .5rem; border-radius: 999px; }
.badge.paid { color: var(--mint); background: rgba(94,234,212,.12); }
.badge.due { color: var(--durazno); background: rgba(247,178,133,.14); }
.badge.hold { color: var(--coral); background: rgba(243,130,129,.14); }

/* ============================================================================
   FINANCE / MONEY FLOW
   ============================================================================ */
.fin-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 2rem; }
@media (max-width: 1000px){ .fin-grid { grid-template-columns: 1fr; } }
.flow { position: relative; border-radius: var(--r-lg); border: 1px solid var(--line); background: var(--card-2); padding: 1.4rem; }
.flow svg { width: 100%; height: auto; display: block; }
.flow .lab { font-family: var(--font-mono); font-size: .72rem; }
.fin-stats { display: grid; gap: 1rem; }
.fin-stat { padding: 1.3rem 1.5rem; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--card); }
.fin-stat .k { font-family: var(--font-mono); font-size: .66rem; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-dim); }
.fin-stat .v { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.8rem,3.4vw,2.6rem); margin-top: .2rem; }
.fin-stat .v.in { color: var(--mint); } .fin-stat .v.out { color: var(--coral); } .fin-stat .v.net { color: var(--oro); }
.fin-stat .sub { font-size: .8rem; color: var(--fg-mute); margin-top: .35rem; }

.tiers { display: flex; gap: .6rem; margin-top: 1.2rem; flex-wrap: wrap; }
.tier { flex: 1; min-width: 130px; padding: 1rem; border-radius: 14px; background: rgba(11,17,32,.5); border: 1px solid var(--line); }
.tier .lvl { font-family: var(--font-mono); font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-dim); }
.tier .nm { font-weight: 600; margin: .25rem 0; }
.tier .sp { font-family: var(--font-mono); color: var(--oro); font-size: 1.1rem; }

/* ============================================================================
   COMPARE  (industry shift)
   ============================================================================ */
.cmp { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
@media (max-width: 880px){ .cmp { grid-template-columns: 1fr; } }
.cmp-col { padding: 2rem; border-radius: var(--r-lg); }
.cmp-col.old { background: rgba(16,26,48,.45); border: 1px solid var(--line); }
.cmp-col.new { background: linear-gradient(180deg, rgba(243,130,129,.1), rgba(24,36,64,.55)); border: 1px solid rgba(243,130,129,.32); box-shadow: var(--glow-coral); }
.cmp-col h3 { font-size: 1.4rem; }
.cmp-col .sb { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; margin-bottom: 1.2rem; }
.cmp-col.old .sb { color: var(--fg-dim);} .cmp-col.new .sb { color: var(--coral);}
.cmp-col ul { list-style: none; display: grid; gap: .7rem; }
.cmp-col li { display: flex; gap: .7rem; font-size: .92rem; align-items: flex-start; }
.cmp-col li svg { width: 18px; height: 18px; flex: 0 0 auto; margin-top: 3px; }
.cmp-col.old li { color: var(--fg-mute); } .cmp-col.old li svg { color: var(--coral); }
.cmp-col.new li svg { color: var(--mint); }

.metrics { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; margin-top: 2.4rem; }
@media (max-width: 760px){ .metrics { grid-template-columns: repeat(2,1fr);} }
.metric { text-align: center; padding: 1.6rem 1rem; border-radius: var(--r-md); background: var(--card); border: 1px solid var(--line); }
.metric .v { font-family: var(--font-display); font-weight: 700; font-size: 2.2rem; }
.metric .l { font-size: .78rem; color: var(--fg-mute); margin-top: .3rem; }

/* ============================================================================
   CLOSE
   ============================================================================ */
.close { text-align: center; position: relative; overflow: hidden; }
.close::before { content:""; position:absolute; inset:0; background: radial-gradient(700px 360px at 50% 0%, rgba(252,226,138,.14), transparent 60%); pointer-events:none; }
.close .sun-xl { width: 76px; height: 76px; margin: 0 auto 1.6rem; filter: drop-shadow(0 0 24px rgba(252,226,138,.6)); animation: float 6s ease-in-out infinite; }
.close h2 { font-size: clamp(2.2rem, 5.5vw, 4rem); }
.close .lead { margin: 1.4rem auto 2.4rem; }
.close-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
footer { border-top: 1px solid var(--line); padding: 2.4rem 0; margin-top: 4rem; }
.foot { display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; font-size: .82rem; color: var(--fg-mute); }
.foot .brand { font-size: 1rem; }

/* ============================================================================
   ANIMATIONS
   ============================================================================ */
@keyframes pulse { 0%,100%{ opacity:1; transform:scale(1);} 50%{ opacity:.4; transform:scale(.8);} }
@keyframes spin { to { transform: rotate(360deg);} }
@keyframes float { 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-12px);} }
@keyframes cueDown { 0%{ transform: scaleY(0); transform-origin: top;} 50%{ transform: scaleY(1); transform-origin: top;} 50.1%{ transform-origin: bottom;} 100%{ transform: scaleY(0); transform-origin: bottom;} }
@keyframes dash { to { stroke-dashoffset: 0; } }
@keyframes flowdot { to { offset-distance: 100%; } }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
}

/* ============================================================================
   v2 · full-width standard · flags · agent tiles · finance wow
   ============================================================================ */
:root { --maxw: 1320px; }

/* compact, FULL-WIDTH section heads (title left, lead right — no wasted column) */
.section-head { max-width: none; display: grid; grid-template-columns: minmax(0,1.12fr) minmax(0,.88fr); gap: 1rem 2.6rem; align-items: end; margin-bottom: 2.6rem; }
.section-head .sh-main { min-width: 0; }
.section-head .eyebrow { margin-bottom: 1rem; }
.section-head .sh-aside { margin-top: 0; padding-bottom: .35rem; }
.section-head.center { display: block; text-align: center; max-width: 780px; margin-inline: auto; }
.section-head.center .lead { margin-top: 1.1rem; }
@media (max-width: 880px){ .section-head { grid-template-columns: 1fr; align-items: start; } }
.h-section { font-size: clamp(1.9rem, 3.6vw, 2.9rem); }
.lc-detail { padding: 1.7rem; }

/* language toggle with flags */
.lang { gap: 2px; padding: 2px; }
.lang button { display: inline-flex; align-items: center; gap: .4rem; padding: .34rem .58rem; border-radius: 999px; }
.flag { width: 18px; height: 12px; border-radius: 2px; box-shadow: 0 0 0 1px rgba(0,0,0,.3); display: inline-block; }
.film-row .flag { width: 20px; height: 13px; vertical-align: middle; }

/* ----- agents ----- */
.agents-hint { text-align: center; color: var(--fg-dim); font-size: .9rem; margin: 1.6rem auto .2rem; }
.agent-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(234px, 1fr)); gap: .9rem; margin-top: 1.4rem; }
.atile { position: relative; text-align: left; cursor: pointer; padding: 1.1rem 1.1rem 1.25rem; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--card); color: var(--fg); transition: transform .3s var(--ease), border-color .3s, box-shadow .3s, background .3s; overflow: hidden; font-family: var(--font-ui); }
.atile::before { content:""; position:absolute; top:0; bottom:0; left:0; width:3px; background: var(--c); opacity:.85; }
.atile:hover, .atile:focus-within, .atile.open { transform: translateY(-3px); border-color: color-mix(in srgb, var(--c) 55%, transparent); box-shadow: 0 18px 42px -22px rgba(0,0,0,.85); background: var(--card-2); }
.atile.core { border-color: color-mix(in srgb, var(--oro) 42%, var(--line)); background: linear-gradient(180deg, rgba(252,226,138,.07), var(--card)); }
.atile-top { display:flex; align-items:center; gap:.55rem; margin-bottom:.7rem; }
.atile-ic { width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; color: var(--c); background: color-mix(in srgb, var(--c) 15%, transparent); flex: 0 0 auto; }
.atile-ic svg { width: 19px; height: 19px; }
.atile-arch { font-family: var(--font-mono); font-size: .57rem; letter-spacing: .08em; text-transform: uppercase; color: var(--fg-dim); line-height: 1.25; }
.atile-core { margin-left:auto; font-family: var(--font-mono); font-size:.52rem; letter-spacing:.12em; color:#2a160f; background: var(--grad-sun); padding:.12rem .42rem; border-radius:6px; flex:0 0 auto; }
.atile-name { font-family: var(--font-display); font-weight: 700; font-size: 1.22rem; line-height:1; }
.atile-role { color: var(--c); font-size: .8rem; font-weight: 600; margin: .22rem 0 .6rem; }
.atile-line { font-size: .85rem; color: var(--fg-mute); line-height: 1.46; }
.atile-card { max-height: 0; opacity: 0; overflow: hidden; transition: max-height .42s var(--ease), opacity .3s, margin .3s; display: grid; gap: .5rem; }
.atile:hover .atile-card, .atile:focus-within .atile-card, .atile.open .atile-card { max-height: 280px; opacity: 1; margin-top: .9rem; }
.atile-row { display: grid; grid-template-columns: 52px 1fr; gap: .55rem; align-items: start; padding-top:.5rem; border-top: 1px solid var(--line-2); }
.atile-k { font-family: var(--font-mono); font-size: .55rem; letter-spacing: .08em; text-transform: uppercase; color: var(--fg-dim); padding-top:1px; }
.atile-k.warn { color: var(--coral); }
.atile-v { font-size: .79rem; color: var(--fg); line-height:1.4; }
.atile-more { position:absolute; top: 1.15rem; right: 1.1rem; font-family: var(--font-mono); font-size:.56rem; color: var(--fg-dim); opacity:.55; transition:.3s; }
.atile:hover .atile-more, .atile.open .atile-more, .atile:focus-within .atile-more { opacity: 0; }

/* ----- finance wow ----- */
.fin-results { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 1.4rem; }
@media (max-width: 900px){ .fin-results { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 520px){ .fin-results { grid-template-columns: 1fr;} }
.fin-result { padding: 1.4rem 1.5rem; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--card); position: relative; overflow: hidden; }
.fin-result .k { font-family: var(--font-mono); font-size: .63rem; letter-spacing: .12em; text-transform: uppercase; color: var(--fg-dim); }
.fin-result .v { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.7rem, 3vw, 2.5rem); margin-top: .25rem; line-height: 1; }
.fin-result .v.in { color: var(--mint); } .fin-result .v.collect { color: var(--oro);} .fin-result .v.out { color: var(--coral);} .fin-result .v.net { color: var(--oro); }
.fin-result .sub { font-size: .74rem; color: var(--fg-mute); margin-top: .55rem; }
.fin-result .spark { font-family: var(--font-mono); font-size: .68rem; margin-top: .5rem; color: var(--mint); }
.fin-result .meter { height: 5px; border-radius: 99px; background: rgba(242,240,235,.1); margin-top: .7rem; overflow: hidden; }
.fin-result .meter i { display:block; height:100%; background: var(--grad-sun); border-radius:99px; }
.fin-result.net-card { background: linear-gradient(180deg, rgba(252,226,138,.13), var(--card-2)); border-color: rgba(252,226,138,.42); box-shadow: var(--glow-oro); }

.panel-h { display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; font-family: var(--font-mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 1.1rem; }
.settle.card, .flow.card { padding: 1.5rem; border-radius: var(--r-lg); }
.auto-pill { margin-left:auto; display:inline-flex; align-items:center; gap:.45rem; font-size:.56rem; letter-spacing:.04em; text-transform:none; color: var(--mint); background: rgba(94,234,212,.1); border:1px solid rgba(94,234,212,.25); padding:.28rem .6rem; border-radius:999px; }
.auto-pill b { width:7px; height:7px; border-radius:50%; background: var(--mint); box-shadow:0 0 8px var(--mint); animation: pulse 2s infinite; }
.tiers-label { font-family: var(--font-mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color: var(--fg-dim); margin-bottom:.6rem; }
.po-h { font-family: var(--font-mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color: var(--fg-dim); margin: 1.4rem 0 .6rem; }
.payouts { display:grid; gap:.5rem; }
.po { display:grid; grid-template-columns: 1fr auto auto auto; gap:.8rem; align-items:center; padding:.62rem .85rem; border-radius:12px; background: rgba(11,17,32,.5); border:1px solid var(--line); }
.po .who { font-weight:600; font-size:.86rem; }
.po .amt { color: var(--oro); font-size:.86rem; }
.po .dt { font-family: var(--font-mono); font-size:.7rem; color: var(--fg-dim); }
.po .pst { font-family: var(--font-mono); font-size:.6rem; padding:.2rem .55rem; border-radius:999px; white-space:nowrap; }
.po .pst.ready { color: var(--mint); background: rgba(94,234,212,.12);}
.po .pst.sched { color: var(--durazno); background: rgba(247,178,133,.14);}
.po .pst.hold { color: var(--coral); background: rgba(243,130,129,.14);}
.po-total { display:flex; justify-content:space-between; align-items:center; margin-top:1.1rem; padding-top:1.1rem; border-top:1px solid var(--line); font-family: var(--font-mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color: var(--fg-mute); }
.po-total b { font-family: var(--font-display); font-size:1.55rem; color: var(--oro); }

/* film download row */
.film-row { display:flex; align-items:center; justify-content:center; gap:.9rem; flex-wrap:wrap; margin-top:1.7rem; font-family: var(--font-mono); font-size:.78rem; }
.film-row .film-lbl { color: var(--fg-dim); letter-spacing:.06em; }
.film-row a { display:inline-flex; align-items:center; gap:.45rem; color: var(--fg-mute); border:1px solid var(--line); padding:.42rem .8rem; border-radius:999px; transition:.2s; }
.film-row a:hover { color:#fff; border-color: rgba(252,226,138,.5); }

/* mobile polish */
@media (max-width: 600px){
  .topbar nav { gap:.55rem; }
  .agent-tiles { grid-template-columns: 1fr; }
  .lc-detail { min-height: auto; }
  .po { grid-template-columns: 1fr auto; row-gap:.15rem; }
  .po .dt { display:none; }
  .hero-stats { gap: 1.4rem; }
}

/* prevent any horizontal scroll on phones; let wide tables scroll inside */
html { overflow-x: hidden; }
.align-grid > div, .fin-grid > div, .cmp > div, .lc > div { min-width: 0; }
.console-body { overflow-x: auto; -webkit-overflow-scrolling: touch; }
@media (max-width: 640px){
  .tbl { min-width: 420px; }
  .console-body { padding: 1rem; }
}

/* ============================================================================
   v3 · fit-in-viewport compaction · smaller right-column lead · film player
   ============================================================================ */
.section { padding: clamp(2.6rem, 6vh, 4.6rem) 0; }
.section-head { margin-bottom: 1.7rem; gap: .7rem 2.4rem; align-items: start; }
.section-head .sh-aside { font-size: clamp(.86rem, 1vw, .98rem); line-height: 1.5; color: var(--fg-mute); }
.section-head.center .lead { font-size: clamp(.92rem, 1.25vw, 1.05rem); }
.h-section { font-size: clamp(1.6rem, 2.9vw, 2.35rem); }
.lead { font-size: clamp(1rem, 1.35vw, 1.12rem); }

/* lifecycle — whole 360 ring always visible (cap by viewport height) */
.lc { gap: 1.8rem; align-items: center; }
.lc-ring-wrap { max-width: min(430px, 52vh); }
.lc-node { width: 52px; height: 52px; margin: -26px 0 0 -26px; }
.lc-node svg { width: 21px; height: 21px; }
.lc-node .idx { width: 18px; height: 18px; }
.lc-detail { padding: 1.4rem; min-height: 0; }
.lc-detail h3 { font-size: clamp(1.45rem, 2.5vw, 1.95rem); margin: .3rem 0 .1rem; }
.lc-detail .agent-by { margin-bottom: .75rem; }
.lc-mini { padding: .85rem; }
.lc-mini p { font-size: .86rem; }
.lc-controls { margin-top: 1rem; }

/* alignment — phone + console fit together */
.align-grid { gap: 1.6rem; align-items: center; }
.phone { width: 272px; }
.console-body { padding: 1.05rem; }
.kpi-row { gap: .6rem; margin-bottom: .8rem; }
.kpi { padding: .68rem .8rem; }
.kpi .v { font-size: 1.28rem; }
.kpi .k { font-size: .56rem; }
.pipe { margin-bottom: .8rem; gap: .35rem; }
.pipe .st { padding: .5rem .35rem; }
.pipe .st .n { font-size: 1.02rem; }
.tbl th { padding: .38rem .5rem; }
.tbl td { padding: .4rem .5rem; font-size: .76rem; }

/* finance — results + flow + settlement fit */
.fin-results { gap: .8rem; margin-bottom: 1rem; }
.fin-result { padding: 1.05rem 1.2rem; }
.fin-result .v { font-size: clamp(1.45rem, 2.5vw, 2.15rem); }
.fin-result .sub { margin-top: .4rem; }
.fin-grid { gap: 1.2rem; }
.flow.card, .settle.card { padding: 1.15rem; }
.tiers { margin-top: .75rem; gap: .5rem; }
.tier { padding: .75rem; }
.po-h { margin: .9rem 0 .5rem; }
.po { padding: .5rem .75rem; }
.po-total { margin-top: .8rem; padding-top: .8rem; }

/* inline narrated film player (with audio) */
.film { max-width: 470px; margin: 1.6rem auto .5rem; border-radius: 16px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); background: #05080f; aspect-ratio: 16 / 9; }
.film video { display: block; width: 100%; height: 100%; object-fit: cover; background: #05080f; }
.film-cap { text-align: center; color: var(--fg-dim); font-family: var(--font-mono); font-size: .64rem; letter-spacing: .1em; margin-top: .7rem; text-transform: uppercase; }
.films { display: grid; grid-template-columns: 1fr 1fr; gap: 1.8rem; max-width: 1000px; margin: 1.6rem auto .4rem; }
@media (max-width: 760px){ .films { grid-template-columns: 1fr; } }
.film-block .film { margin: .15rem auto .5rem; }
.film-label { text-align: center; font-family: var(--font-mono); font-size: .66rem; letter-spacing: .14em; text-transform: uppercase; color: var(--durazno); margin-bottom: .25rem; }

/* Day-in-the-life persona selector (product funnel on the demo) */
.day-persona{font:inherit;font-size:.82rem;cursor:pointer;padding:.34rem .72rem;border-radius:999px;background:rgba(255,255,255,.05);color:rgba(242,240,235,.7);border:1px solid rgba(255,255,255,.12);transition:background .2s,color .2s,border-color .2s;}
.day-persona:hover{color:#F2F0EB;border-color:rgba(252,226,138,.45);}
.day-persona[aria-pressed="true"]{background:rgba(252,226,138,.15);color:#FCE28A;border-color:rgba(252,226,138,.55);}
