/* ============================================================
   AsistenteListo · «La Ley de la Permanencia»
   Sistema visual — geometría sagrada, cripta y custodia
   ============================================================ */
:root{
  --black:#08070a;
  --black-2:#0d0b0e;
  --crypt:#0a0809;
  --panel:rgba(18,15,12,.66);
  --panel-solid:#14110d;
  --line:#231e16;
  --line-2:#332b1d;
  --honey:#e7a42c;
  --honey-deep:#c47e1c;
  --gold:#f3c659;
  --gold-soft:#caa861;
  --comb:#f0e2c2;
  --q-teal:#3fdcc6;
  --q-violet:#8a6cff;
  --ink:#efe7d6;
  --muted:#9c8f78;
  --muted-2:#665c49;
  --sans:"Helvetica Neue",Helvetica,Arial,sans-serif;
  --display:"Cormorant Garamond",Georgia,serif;
  --grotesk:"Space Grotesk",var(--sans);
  --mono:"Space Mono",ui-monospace,monospace;
  --q-intensity:1;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  background:var(--black);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 44px}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 44px}

.mono{font-family:var(--mono);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--honey)}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.04;letter-spacing:.002em}
.serif-em{font-style:italic;color:var(--gold)}
em.h{font-style:italic;color:var(--gold);font-family:var(--display)}

/* ---------- capas fijas ---------- */
.bgcomb{position:fixed;inset:0;z-index:0;opacity:.13;pointer-events:none}
.bgglow{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(820px 620px at 50% -8%, rgba(231,164,44,.10), transparent 62%),
    radial-gradient(900px 800px at 50% 118%, rgba(138,108,255,.06), transparent 60%);}
/* penumbra que se profundiza con el descenso (controlada por JS) */
.depth-veil{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.18;
  background:radial-gradient(120% 90% at 50% 42%, transparent 36%, rgba(4,3,5,.92) 100%);}
.hive-layer{position:fixed;inset:0;z-index:2;pointer-events:none;overflow:hidden}
main{position:relative;z-index:3}

/* ---------- descenso (línea vertical de iniciación) ---------- */
.descent{position:fixed;top:0;left:26px;bottom:0;width:1px;z-index:60;
  background:linear-gradient(var(--line),transparent);display:flex;flex-direction:column;align-items:center}
.descent-track{position:absolute;top:0;bottom:0;width:1px;background:var(--line)}
.descent-fill{position:absolute;top:0;width:1px;height:0;
  background:linear-gradient(var(--gold),var(--honey-deep));box-shadow:0 0 10px rgba(231,164,44,.6)}
.descent-node{position:absolute;top:0;width:7px;height:8px;left:-3px;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:var(--gold);box-shadow:0 0 12px var(--gold);transition:none}
@media(max-width:900px){.descent{display:none}}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:22px 44px;backdrop-filter:blur(9px);background:linear-gradient(180deg,rgba(8,7,10,.86),transparent)}
.brand{display:flex;align-items:center;gap:13px;font-family:var(--display);font-weight:500;font-size:21px;letter-spacing:.01em}
.brand .mark{position:relative;width:24px;height:28px;background:transparent;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);border:1px solid var(--gold)}
.brand .mark::after{content:"";position:absolute;inset:30%;background:var(--gold);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);box-shadow:0 0 8px var(--gold)}
.nav-links{display:flex;gap:32px;font-family:var(--grotesk);font-size:13px;letter-spacing:.02em;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{font-family:var(--grotesk);font-weight:500;font-size:13px;letter-spacing:.04em;border:1px solid var(--line-2);
  padding:11px 19px;border-radius:2px;color:var(--ink);transition:.25s}
.nav-cta:hover{background:var(--gold);color:#1a1206;border-color:var(--gold)}
/* ===== Menú móvil (hamburguesa) ===== */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  background:transparent;border:1px solid var(--line-2);border-radius:9px;cursor:pointer;padding:0 10px}
.nav-burger span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;position:fixed;top:62px;left:0;right:0;z-index:49;flex-direction:column;
  padding:14px 24px 26px;background:var(--panel-solid,#14110d);border-bottom:1px solid var(--line-2);
  box-shadow:0 18px 40px rgba(0,0,0,.5);max-height:calc(100vh - 62px);overflow-y:auto}
.nav-mobile.open{display:flex}
.nav-mobile a{font-family:var(--grotesk);font-size:16px;color:var(--ink);padding:13px 4px;
  border-bottom:1px solid rgba(255,255,255,.06);text-decoration:none}
.nav-mobile a:hover{color:var(--gold)}
.nav-mobile hr{border:0;border-top:1px solid var(--line-2);margin:10px 0;width:100%}
.nav-mobile .nav-mobile-cta{margin-top:16px;text-align:center;border:1px solid var(--gold);border-radius:3px;
  font-weight:600;color:var(--gold);letter-spacing:.04em}
.nav-mobile .nav-mobile-cta:hover{background:var(--gold);color:#1a1206}
@media(max-width:920px){
  .nav-links{display:none}
  .nav-right{display:none!important}
  .nav-burger{display:flex}
  .nav{padding:16px 22px}
}
/* en desktop el drawer nunca se muestra, aunque haya quedado .open al redimensionar */
@media(min-width:921px){.nav-mobile{display:none!important}}

/* ---------- botones ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--grotesk);font-weight:500;font-size:14px;
  letter-spacing:.03em;padding:16px 30px;border-radius:2px;transition:.26s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:linear-gradient(160deg,var(--gold),var(--honey-deep));color:#1a1206}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 44px -14px rgba(231,164,44,.6)}
.btn-ghost{border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:30px}

/* ---------- sección genérica ---------- */
section{position:relative;padding:140px 0}
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.eyebrow .pip{position:relative;width:11px;height:13px;flex:none;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);border:1px solid var(--honey)}
.eyebrow .pip::after{content:"";position:absolute;inset:32%;background:var(--gold);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.title{font-size:clamp(34px,5.4vw,68px);max-width:18ch;margin-bottom:30px;text-wrap:balance;font-weight:500;line-height:1.02}
.lede{font-size:clamp(18px,2.1vw,22px);color:var(--muted);max-width:60ch;line-height:1.62;font-family:var(--sans)}

.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ============================================================
   HERO · EL UMBRAL — descenso a la cripta
   ============================================================ */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:130px 0 80px;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:2px;
  padding:8px 16px;margin-bottom:24px}
.hero-tag .dot{width:6px;height:7px;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:var(--gold);box-shadow:0 0 10px var(--gold);animation:breathe 3.4s ease-in-out infinite}
.hero-tag span{font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
@keyframes breathe{50%{opacity:.35}}
.hero h1{font-size:clamp(36px,5.4vw,76px);max-width:17ch;font-weight:500;line-height:1.0;letter-spacing:-.005em}
.hero .lede{margin:26px auto 0;max-width:56ch;font-size:clamp(16px,1.7vw,19px)}
.hero-foot{margin-top:32px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--muted-2);
  max-width:64ch;line-height:1.8;text-transform:uppercase}

/* la cripta: hexágono profundo con UNA celda encendida por dentro */
.crypt{position:relative;width:min(190px,40vw);aspect-ratio:1/1.1;margin:0 auto 30px}
.crypt .ring{position:absolute;inset:0;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  border:1px solid var(--line-2)}
.crypt .ring.r2{inset:11%;border-color:rgba(231,164,44,.20)}
.crypt .ring.r3{inset:23%;border-color:rgba(231,164,44,.32);animation:turn 64s linear infinite}
@keyframes turn{to{transform:rotate(360deg)}}
.crypt .vault{position:absolute;inset:35%;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:radial-gradient(circle at 50% 42%, rgba(243,198,89,.55), rgba(196,126,28,.18) 55%, rgba(10,8,9,.9));
  box-shadow:0 0 60px rgba(231,164,44,.25),inset 0 0 30px rgba(243,198,89,.25);
  display:flex;align-items:center;justify-content:center;animation:vault-breathe 6s ease-in-out infinite}
@keyframes vault-breathe{50%{box-shadow:0 0 90px rgba(231,164,44,.42),inset 0 0 40px rgba(243,198,89,.4)}}
/* la Palabra sellada — un trazo que casi forma una letra, jamás explicado */
.crypt .word{width:36%;height:46%;opacity:.92}
.crypt .word path,.crypt .word line{stroke:#1c1408;stroke-width:2.4;fill:none;stroke-linecap:round}
.scroll-cue{font-family:var(--mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-2);
  display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px}
.scroll-cue .ln{width:1px;height:46px;background:linear-gradient(var(--gold-soft),transparent);animation:drip 2.6s ease-in-out infinite}
@keyframes drip{0%{opacity:.2;transform:scaleY(.5);transform-origin:top}50%{opacity:1}100%{opacity:.2;transform:scaleY(1);transform-origin:top}}

@media(max-width:900px){.wrap{padding:0 26px}.wrap-narrow{padding:0 26px}section{padding:96px 0}}

/* ============================================================
   CUSTODIOS · motes en lemniscata + estela + sello
   ============================================================ */
.keeper{position:absolute;top:0;left:0;will-change:transform}
.kmote{position:absolute;top:0;left:0;width:26px;height:18px;will-change:transform}
.kcore{position:absolute;left:7px;top:5px;width:11px;height:8px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%, var(--gold), var(--honey-deep));
  box-shadow:0 0 12px rgba(243,198,89,.8),0 0 22px rgba(231,164,44,.35)}
.kwing{position:absolute;top:1px;width:13px;height:9px;border-radius:60% 60% 50% 50%;
  background:radial-gradient(circle at 40% 30%, rgba(255,255,255,.6), rgba(180,210,230,.12));
  mix-blend-mode:screen;opacity:.55}
.kwing-l{left:3px;transform-origin:bottom right;animation:fl .22s linear infinite}
.kwing-r{left:10px;transform:scaleX(-1);transform-origin:bottom left;animation:flR .23s linear infinite}
@keyframes fl{50%{transform:rotate(-26deg)}}
@keyframes flR{50%{transform:scaleX(-1) rotate(-26deg)}}
.kt{position:absolute;top:0;left:0;width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle, rgba(243,198,89,.9), transparent 70%);will-change:transform,opacity}

.seal-flash{position:absolute;top:0;left:0;width:120px;height:120px;border-radius:50%;
  transform:translate(-50%,-50%) scale(.3);opacity:0;mix-blend-mode:screen;will-change:transform,opacity;
  background:radial-gradient(circle,
    rgba(63,220,198,calc(.55*var(--q-intensity))),
    rgba(138,108,255,calc(.28*var(--q-intensity))) 40%, transparent 70%)}
.seal-flash.go{animation:seal .9s cubic-bezier(.2,.7,.2,1)}
@keyframes seal{0%{opacity:0;transform:translate(-50%,-50%) scale(.25)}
  28%{opacity:1}100%{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}

/* ============================================================
   CELDAS SELLADAS · abundancia que llena y no se vacía
   ============================================================ */
.comb-strip{display:flex;justify-content:center;gap:7px;margin-top:80px;flex-wrap:wrap;max-width:760px;margin-left:auto;margin-right:auto}
.comb-strip .cell{position:relative;width:66px;height:74px;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:var(--panel-solid);overflow:hidden;transition:1s cubic-bezier(.2,.7,.2,1)}
.comb-strip .cell .fill{position:absolute;inset:0;
  background:linear-gradient(0deg,var(--honey-deep),var(--gold));
  transform:translateY(101%);transition:transform 1.2s cubic-bezier(.3,.8,.3,1)}
.comb-strip .cell.sealed .fill{transform:translateY(0)}
.comb-strip .cell.sealed{box-shadow:0 0 22px rgba(231,164,44,.18)}
.comb-strip .cell:nth-child(even){margin-top:38px}
/* sello sugerido en la celda central */
.comb-strip .cell.keystone::after{content:"";position:absolute;inset:34%;z-index:2;
  border:1.5px solid rgba(28,20,8,.6);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}

/* ============================================================
   SÍNTOMAS · lo que no se guarda, se pierde
   ============================================================ */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:56px}
.loss-list{list-style:none;display:flex;flex-direction:column;gap:0}
.loss-list li{display:flex;gap:16px;padding:17px 0;border-bottom:1px solid var(--line);font-size:16px;color:var(--muted);align-items:flex-start}
.loss-list li::before{content:"";width:10px;height:11px;flex:none;margin-top:7px;background:transparent;border:1px solid var(--muted-2);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.kicker{font-family:var(--display);font-size:clamp(26px,3.4vw,40px);color:var(--ink);max-width:22ch;margin-top:40px;line-height:1.12;font-weight:500}
.kicker em{font-style:italic;color:var(--gold)}

/* ============================================================
   DECLARACIÓN (acto 2) · sellar
   ============================================================ */
.statement{text-align:center;padding:200px 0}
.statement h2{font-size:clamp(38px,6.4vw,92px);max-width:15ch;margin:0 auto;font-weight:500;line-height:1.0;text-wrap:balance}
.statement .lede{margin:38px auto 0}

/* ============================================================
   TRES GUARDIANAS (acto 3)
   ============================================================ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.pillar{background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:40px 34px;position:relative;overflow:hidden;
  backdrop-filter:blur(4px);transition:.3s}
.pillar:hover{border-color:var(--line-2)}
.pillar .cellicon{position:relative;width:66px;height:76px;margin-bottom:30px;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(160deg, rgba(231,164,44,.18), rgba(231,164,44,.02));border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center}
.pillar .cellicon .core{width:20px;height:23px;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:var(--gold);box-shadow:0 0 18px var(--gold)}
.pillar h3{font-size:27px;margin-bottom:14px;font-weight:500}
.pillar p{color:var(--muted);font-size:15px;line-height:1.6}
.pillar .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.pillar .tags span{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--comb);border:1px solid var(--line-2);border-radius:2px;padding:6px 11px}
@media(max-width:900px){.pillars{grid-template-columns:1fr}.two-col{grid-template-columns:1fr;gap:8px}}

/* ============================================================
   LA SINCRONÍA / lo que permanece vivo (acto 4)
   ============================================================ */
.quantum{padding:170px 0}
.quantum .title em{font-style:italic;color:var(--q-teal)}
.qstage{position:relative;height:380px;margin-top:70px;border:1px solid var(--line);border-radius:4px;overflow:hidden;
  background:radial-gradient(720px 380px at 50% 50%, rgba(63,220,198,.05), transparent 70%)}
.qnode{position:absolute;width:92px;height:104px;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:var(--panel-solid);display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--comb);text-align:center;padding:6px;
  box-shadow:inset 0 0 22px rgba(231,164,44,.06)}
.qnode .lab{opacity:.82;line-height:1.5}
.qline{position:absolute;height:1px;background:linear-gradient(90deg,transparent,var(--q-teal),transparent);opacity:.3}
.q-readout{display:flex;gap:36px;justify-content:center;margin-top:46px;flex-wrap:wrap}
.q-readout div{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.q-readout b{color:var(--q-teal)}

/* ============================================================
   EL PANAL FUERTE · prueba (acto 5)
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:64px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:38px 28px;text-align:center}
.stat .n{font-family:var(--display);font-size:clamp(46px,5.6vw,68px);font-weight:500;color:var(--gold);line-height:1}
.stat .l{font-size:13.5px;color:var(--muted);margin-top:16px;line-height:1.45}
.cases{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:28px}
.case{background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:36px;position:relative;overflow:hidden}
.case .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--honey);margin-bottom:18px}
.case h3{font-size:24px;margin-bottom:12px;font-weight:500}
.case .metric{display:flex;align-items:baseline;gap:11px;margin:16px 0}
.case .metric b{font-family:var(--display);font-size:42px;color:var(--gold);font-weight:500}
.case .metric span{font-size:13px;color:var(--muted)}
.case p{font-size:14.5px;color:var(--muted);line-height:1.6}
.case .quote{font-style:italic;font-family:var(--display);color:var(--comb);font-size:17px;margin-top:18px;padding-left:16px;border-left:2px solid var(--honey)}
@media(max-width:900px){.stats{grid-template-columns:1fr 1fr}.cases{grid-template-columns:1fr}}

/* módulos */
.mods{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.mod{background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:28px;transition:.28s}
.mod:hover{border-color:var(--line-2);transform:translateY(-3px)}
.mod h4{font-size:18px;margin-bottom:9px;font-weight:500}
.mod p{font-size:13.5px;color:var(--muted);line-height:1.6}
.mod .hx{position:relative;width:18px;height:21px;margin-bottom:18px;border:1px solid var(--honey);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.mod .hx::after{content:"";position:absolute;inset:30%;background:var(--gold);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
@media(max-width:900px){.mods{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.mods{grid-template-columns:1fr}.stats{grid-template-columns:1fr}}

/* proceso */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:60px}
.step{position:relative;padding-top:30px}
.step .num{font-family:var(--mono);font-size:11px;color:var(--honey);letter-spacing:.14em}
.step h4{font-size:20px;margin:16px 0 10px;font-weight:500}
.step p{font-size:13.5px;color:var(--muted);line-height:1.55}
.step::before{content:"";position:absolute;top:0;left:0;width:30px;height:34px;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);border:1px solid var(--line-2)}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr}}

/* ============================================================
   LO QUE PERMANECE · manifiesto + CTA (acto 6)
   ============================================================ */
.manifesto{text-align:center;padding:200px 0 150px;position:relative}
.manifesto .crypt{width:min(220px,52vw);margin-bottom:54px}
.manifesto h2{font-size:clamp(36px,5.8vw,80px);max-width:17ch;margin:0 auto 32px;font-weight:500;line-height:1.0;text-wrap:balance}
.manifesto h2 em{font-style:italic;color:var(--gold)}
.manifesto .lede{margin:0 auto}
.final-strip{font-family:var(--display);font-size:clamp(24px,3vw,38px);color:var(--ink);margin:46px auto 0;max-width:26ch;font-weight:500;font-style:italic}

/* ============================================================
   FOOTER
   ============================================================ */
footer{border-top:1px solid var(--line);padding:80px 0 64px;position:relative;z-index:3;background:var(--black-2)}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:32px}
.foot-grid h5{font-family:var(--grotesk);font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;color:var(--ink)}
.foot-grid ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-grid a{font-size:14px;color:var(--muted)}
.foot-grid a:hover{color:var(--gold)}
.foot-brand p{font-size:14px;color:var(--muted);max-width:36ch;margin-top:16px;line-height:1.65}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:54px;padding-top:28px;
  border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--muted-2);
  text-transform:uppercase;flex-wrap:wrap;gap:14px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ============================================================
   COSTO INVISIBLE · parches
   ============================================================ */
.cost-list{list-style:none;display:flex;flex-direction:column;gap:0}
.cost-list li{display:flex;gap:15px;padding:16px 0;border-bottom:1px solid var(--line);font-size:15.5px;color:var(--muted);align-items:flex-start}
.cost-list li::before{content:"";width:9px;height:10px;flex:none;margin-top:7px;background:var(--honey-deep);opacity:.6;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}

/* ============================================================
   CALCULADORA · el costo del caos sale de lo oculto
   ============================================================ */
.calc{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:64px}
.calc-panel{background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:40px}
.calc-panel h3{font-size:23px;margin-bottom:28px;font-weight:500}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--grotesk);font-size:13px;letter-spacing:.01em;color:var(--ink);margin-bottom:9px}
.field label small{color:var(--muted-2);font-size:11.5px;letter-spacing:0}
.field input{width:100%;background:var(--crypt);border:1px solid var(--line-2);border-radius:3px;padding:14px 16px;
  color:var(--ink);font-family:var(--mono);font-size:15px;transition:.2s}
.field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px rgba(231,164,44,.3)}
.calc-note{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--muted-2);margin-top:6px;line-height:1.6}

.calc-out{position:relative;background:
  radial-gradient(120% 100% at 50% 0%, rgba(231,164,44,.12), transparent 60%), var(--crypt);
  border:1px solid var(--line-2);border-radius:4px;padding:44px 40px;overflow:hidden}
.calc-out .ribbon{font-family:var(--mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--honey)}
.calc-out .big{font-family:var(--display);font-size:clamp(54px,8vw,84px);font-weight:500;color:var(--gold);line-height:1;margin:14px 0 8px;
  text-shadow:0 0 40px rgba(231,164,44,.35)}
.calc-out .sub{font-size:15px;color:var(--muted);margin-bottom:34px}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding-top:28px;border-top:1px solid var(--line)}
.calc-grid .c .k{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.calc-grid .c .v{font-family:var(--display);font-size:28px;color:var(--comb);font-weight:500;margin-top:6px}
.calc-seal{margin-top:32px;padding:20px 22px;border:1px solid var(--line-2);border-radius:3px;background:rgba(231,164,44,.05)}
.calc-seal b{color:var(--gold);font-weight:500;font-family:var(--display);font-size:17px}
.calc-seal p{font-size:13px;color:var(--muted);margin-top:8px;line-height:1.6}
.calc-ctas{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.calc-ctas a{text-align:center}
@media(max-width:900px){.calc{grid-template-columns:1fr}}

/* ============================================================
   ECOSISTEMA ODOO · 30+ módulos
   ============================================================ */
.odoo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:60px}
.app{background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:24px;transition:.26s}
.app:hover{border-color:var(--line-2);transform:translateY(-2px)}
.app .ah{display:flex;align-items:center;gap:11px;margin-bottom:11px}
.app .glyph{position:relative;width:16px;height:18px;flex:none;border:1px solid var(--honey);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.app .glyph::after{content:"";position:absolute;inset:32%;background:var(--gold);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.app h4{font-size:16px;font-weight:500}
.app p{font-size:13px;color:var(--muted);line-height:1.55}
@media(max-width:900px){.odoo-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.odoo-grid{grid-template-columns:1fr}}

/* ============================================================
   OTAs · canales sincronizados
   ============================================================ */
.ota-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:56px}
.ota{height:96px;border:1px solid var(--line);border-radius:3px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:7px;background:var(--panel);transition:.26s;text-align:center;padding:10px}
.ota:hover{border-color:var(--line-2)}
.ota .name{font-family:var(--display);font-size:19px;font-weight:500;color:var(--ink)}
.ota .meta{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.split-notes{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:48px}
.split-notes h4{font-family:var(--grotesk);font-size:14px;letter-spacing:.04em;color:var(--gold);margin-bottom:18px;text-transform:uppercase}
.split-notes ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.split-notes li{font-size:14.5px;color:var(--muted);line-height:1.55;padding-left:18px;position:relative}
.split-notes li::before{content:"";position:absolute;left:0;top:7px;width:8px;height:9px;background:var(--honey);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.split-notes b{color:var(--comb);font-weight:500}
@media(max-width:900px){.ota-grid{grid-template-columns:1fr 1fr}.split-notes{grid-template-columns:1fr;gap:8px}}

/* ============================================================
   CANALES DIGITALES
   ============================================================ */
.chan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:56px}
.chan{border:1px solid var(--line);border-radius:3px;padding:26px 20px;text-align:center;background:var(--panel);transition:.26s}
.chan:hover{border-color:var(--line-2)}
.chan .ico{width:30px;height:30px;margin:0 auto 16px;border:1px solid var(--line-2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:15px;color:var(--gold)}
.chan h4{font-size:15px;font-weight:500;margin-bottom:7px}
.chan p{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;color:var(--muted-2);line-height:1.6}
@media(max-width:900px){.chan-grid{grid-template-columns:1fr 1fr}}

/* ============================================================
   BÁSCULA · split con imagen
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-top:20px}
.split .media{position:relative;border-radius:4px;overflow:hidden;border:1px solid var(--line-2);aspect-ratio:4/3}
.split .media image-slot{width:100%;height:100%}
.split h2{font-size:clamp(28px,3.6vw,44px);margin-bottom:20px;font-weight:500}
.split p{color:var(--muted);font-size:16px;line-height:1.62;margin-bottom:14px}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:30px}}

/* ============================================================
   INDUSTRIAS
   ============================================================ */
.verticals{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:60px}
.vert .vtag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--honey);margin-bottom:16px;display:inline-block}
.vert.foco .vtag{color:var(--q-teal)}
.vert h3{font-size:26px;font-weight:500;margin-bottom:14px;line-height:1.1}
.vert p{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:18px}
.vert ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.vert li{font-size:14px;color:var(--comb);padding-left:18px;position:relative}
.vert li::before{content:"";position:absolute;left:0;top:6px;width:8px;height:9px;background:var(--honey);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.vert .vlink{font-family:var(--grotesk);font-size:13px;color:var(--gold);border-bottom:1px solid var(--line-2);padding-bottom:3px}
.vert .vlink:hover{border-color:var(--gold)}
.verts-foot{font-size:14px;color:var(--muted);text-align:center;margin-top:48px;max-width:70ch;margin-left:auto;margin-right:auto}
@media(max-width:900px){.verticals{grid-template-columns:1fr;gap:40px}}

/* ============================================================
   PRICING · cómo trabajamos
   ============================================================ */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:60px}
.tier{background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:32px 26px;display:flex;flex-direction:column;position:relative}
.tier.feat{border-color:var(--gold);box-shadow:0 0 40px -16px rgba(231,164,44,.5)}
.tier .band{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:6px}
.tier .when{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--honey);margin-bottom:18px}
.tier h3{font-size:21px;font-weight:500;margin-bottom:14px;line-height:1.12}
.tier .price{font-family:var(--display);font-size:34px;color:var(--gold);font-weight:500;line-height:1}
.tier .price small{font-size:14px;color:var(--muted);font-family:var(--grotesk)}
.tier .term{font-size:12.5px;color:var(--muted);margin:8px 0 22px}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px;flex:1}
.tier li{font-size:13.5px;color:var(--muted);padding-left:18px;position:relative;line-height:1.5}
.tier li::before{content:"→";position:absolute;left:0;top:0;color:var(--honey);font-size:12px}
.tier .tier-cta{text-align:center;font-family:var(--grotesk);font-size:13px;font-weight:500;letter-spacing:.03em;
  padding:13px;border:1px solid var(--line-2);border-radius:2px;color:var(--ink);transition:.24s}
.tier .tier-cta:hover{border-color:var(--gold);color:var(--gold)}
.tier.feat .tier-cta{background:linear-gradient(160deg,var(--gold),var(--honey-deep));color:#1a1206;border-color:transparent}
.tiers-foot{font-size:13px;color:var(--muted-2);text-align:center;margin-top:36px;font-family:var(--mono);letter-spacing:.04em}
@media(max-width:980px){.tiers{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tiers{grid-template-columns:1fr}}

/* ============================================================
   RECURSOS
   ============================================================ */
.res-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:56px}
.res{background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:38px}
.res .rtag{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--honey);margin-bottom:18px}
.res h3{font-size:24px;font-weight:500;margin-bottom:14px;line-height:1.15}
.res p{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:24px}
.res .rlink{font-family:var(--grotesk);font-size:14px;font-weight:500;color:var(--gold);border-bottom:1px solid var(--line-2);padding-bottom:3px}
.res .rlink:hover{border-color:var(--gold)}
@media(max-width:900px){.res-grid{grid-template-columns:1fr}}

/* ============================================================
   NEWSLETTER + CTA FINAL
   ============================================================ */
.news{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:radial-gradient(120% 120% at 50% 0%, rgba(231,164,44,.06), transparent 60%);padding:90px 0}
.news-row{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.news-row .nt h3{font-family:var(--display);font-size:30px;font-weight:500}
.news-row .nt p{font-size:14.5px;color:var(--muted);margin-top:8px;max-width:46ch}
.news-form{display:flex;gap:12px}
.news-form input{background:var(--crypt);border:1px solid var(--line-2);border-radius:3px;padding:15px 18px;
  color:var(--ink);font-family:var(--mono);font-size:14px;min-width:240px}
.news-form input:focus{outline:none;border-color:var(--gold)}

.finale{text-align:center;padding:150px 0}
.finale h2{font-size:clamp(34px,5.2vw,68px);max-width:18ch;margin:0 auto 26px;font-weight:500;line-height:1.02;text-wrap:balance}
.finale h2 em{font-style:italic;color:var(--gold)}
.finale .lede{margin:0 auto 14px}
.finale .contact{font-family:var(--mono);font-size:13px;letter-spacing:.08em;color:var(--gold);margin:34px 0;display:flex;gap:28px;justify-content:center;flex-wrap:wrap}
.finale .contact a:hover{color:var(--comb)}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important}
  html{scroll-behavior:auto}
}

/* ============================================================
   LISTOBOT · widget de chat del sitio (handoff a WhatsApp)
   ============================================================ */
.lb-fab{position:fixed;right:22px;bottom:22px;z-index:90;width:60px;height:66px;cursor:pointer;border:0;background:transparent;
  filter:drop-shadow(0 10px 26px rgba(0,0,0,.5))}
.lb-fab .hexb{position:absolute;inset:0;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(160deg,var(--gold,#fbc94a),var(--honey-deep,#e8821e));transition:.25s}
.lb-fab:hover .hexb{transform:translateY(-3px)}
.lb-fab .ic{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#1a1206;font-size:24px}
.lb-fab .pulse{position:absolute;right:-2px;top:-2px;width:14px;height:14px;border-radius:50%;background:var(--q-teal,#36e0c8);
  box-shadow:0 0 0 0 rgba(54,224,200,.6);animation:lbpulse 2.2s infinite}
@keyframes lbpulse{70%{box-shadow:0 0 0 10px rgba(54,224,200,0)}100%{box-shadow:0 0 0 0 rgba(54,224,200,0)}}
.lb-panel{position:fixed;right:22px;bottom:98px;z-index:91;width:min(360px,calc(100vw - 32px));max-height:min(560px,72vh);
  display:none;flex-direction:column;background:var(--panel-solid,#1a160e);border:1px solid var(--line-2,#3a3220);
  border-radius:18px;overflow:hidden;box-shadow:0 24px 70px -20px rgba(0,0,0,.8)}
.lb-panel.open{display:flex;animation:lbup .26s cubic-bezier(.2,.7,.2,1)}
@keyframes lbup{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.lb-head{display:flex;align-items:center;gap:12px;padding:16px 18px;background:linear-gradient(160deg,rgba(245,166,35,.18),transparent);
  border-bottom:1px solid var(--line,#2a2418)}
.lb-head .av{width:34px;height:38px;flex:none;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(160deg,var(--gold,#fbc94a),var(--honey-deep,#e8821e));display:flex;align-items:center;justify-content:center;color:#1a1206}
.lb-head .ti{font-family:var(--display,sans-serif);font-weight:600;font-size:15px;color:var(--ink,#f4ede0)}
.lb-head .st{font-family:var(--mono,monospace);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--q-teal,#36e0c8)}
.lb-head .x{margin-left:auto;background:0;border:0;color:var(--muted,#a89a82);font-size:20px;cursor:pointer;line-height:1}
.lb-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.lb-msg{max-width:84%;padding:10px 13px;border-radius:14px;font-size:14px;line-height:1.45}
.lb-msg.bot{align-self:flex-start;background:var(--panel,rgba(26,22,14,.72));border:1px solid var(--line,#2a2418);color:var(--ink,#f4ede0);border-bottom-left-radius:4px}
.lb-msg.me{align-self:flex-end;background:linear-gradient(160deg,var(--gold,#fbc94a),var(--honey-deep,#e8821e));color:#1a1206;border-bottom-right-radius:4px}
.lb-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px}
.lb-chip{font-family:var(--display,sans-serif);font-size:12.5px;color:var(--comb,#fbe6b8);background:rgba(245,166,35,.06);
  border:1px solid var(--line-2,#3a3220);border-radius:100px;padding:7px 12px;cursor:pointer;transition:.18s}
.lb-chip:hover{border-color:var(--honey,#f5a623);color:var(--honey,#f5a623)}
.lb-wa{display:flex;align-items:center;justify-content:center;gap:9px;margin:0 16px 12px;padding:11px;border-radius:12px;
  background:#25d366;color:#072b14;font-family:var(--display,sans-serif);font-weight:600;font-size:14px;text-decoration:none}
.lb-wa:hover{filter:brightness(1.06)}
.lb-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line,#2a2418);background:var(--black-2,#13100a)}
.lb-input input{flex:1;background:#0d0b08;border:1px solid var(--line-2,#3a3220);border-radius:100px;padding:10px 15px;color:var(--ink,#f4ede0);font-size:14px;outline:none}
.lb-input input:focus{border-color:var(--honey,#f5a623)}
.lb-input button{flex:none;width:40px;height:40px;border:0;border-radius:50%;cursor:pointer;color:#1a1206;
  background:linear-gradient(160deg,var(--gold,#fbc94a),var(--honey-deep,#e8821e));font-size:16px}
@media(max-width:560px){.lb-panel{right:8px;left:8px;width:auto;bottom:88px}}

/* ---------- BÁSCULA · etiqueta EAN-13 rica (estilo Hobart, tema oscuro) ---------- */
.bc-label{background:#fbfbf7;color:#0c0c0c;padding:22px 24px 18px;border-radius:10px;
  font-family:var(--mono),"Courier New",monospace;
  box-shadow:0 30px 70px -28px rgba(0,0,0,.7),0 0 0 1px rgba(243,198,89,.18);max-width:360px;margin:0 auto}
.bc-head{display:flex;flex-direction:column;padding-bottom:8px;border-bottom:2px solid #0c0c0c;margin-bottom:10px}
.bc-head strong{font-size:14px;letter-spacing:1px}
.bc-head span{font-size:9.5px;color:#555;margin-top:2px}
.bc-product{font-size:16px;font-weight:700;letter-spacing:.3px;margin:6px 0 14px;line-height:1.2}
.bc-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px;padding:8px 0;
  border-top:1px dashed #999;border-bottom:1px dashed #999}
.bc-grid>div{display:flex;flex-direction:column}
.bc-grid span{font-size:9px;color:#555;letter-spacing:.8px}
.bc-grid b{font-size:14px;font-weight:700}.bc-grid .bc-total{font-size:18px}
.bc-meta{display:flex;flex-direction:column;gap:2px;font-size:9px;color:#555;margin-bottom:12px}
.bc-svg{display:block;width:100%;max-width:300px;margin:6px auto 10px;height:auto}
.bc-digits{display:flex;gap:4px;font-size:16px;font-weight:700;justify-content:center}
.bc-digits .bc-d{padding:3px 8px;border-radius:4px}
.bc-prefix{background:#3fdcc6;color:#003027}
.bc-plu{background:#8a6cff;color:#fff}
.bc-weight{background:#f3c659;color:#4a3700}
.bc-check{background:#ef6a4f;color:#fff}
.bc-foot{display:flex;justify-content:space-between;font-size:8.5px;color:#777;padding-top:8px;margin-top:6px;border-top:1px dashed #999}
.bc-key{margin-top:20px;display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.bc-key .bc-k{padding:12px 10px;border-radius:10px;background:var(--panel);border:1px solid var(--line-2);font-size:11.5px;color:var(--muted)}
.bc-key .bc-k b{display:block;font-size:14px;margin-bottom:4px;font-family:var(--mono);color:var(--gold)}
@media(max-width:560px){.bc-grid{grid-template-columns:1fr 1fr}.bc-key{grid-template-columns:1fr 1fr}}

/* ---------- Compatibilidad con website.layout (F2) ---------- */
#wrapwrap{background:transparent !important;min-height:0}
#wrapwrap>main,#wrap,.o_cc,.o_cc1{background:transparent !important}
body{background:var(--black) !important}
#wrapwrap>header,#wrapwrap>.o_footer,header.o_header_standard,.o_footer{display:none !important}

/* =====================================================================
   F5 · Tema oscuro para el CONTENIDO de paginas internas (skin al-*).
   Se carga SOLO en paginas que usan colmena_layout (via <link> del layout),
   asi que NO afecta patchmybyte ni paginas aun en tema viejo.
   asistentelisto.scss es token-driven -> redefinir --al-* voltea casi todo.
   ===================================================================== */
:root{
  --al-bg:#08070a; --al-text:#efe7d6; --al-muted:#9c8f78;
  --al-primary:#e7a42c; --al-primary-dark:#f3c659; --al-primary-soft:rgba(231,164,44,.12);
  --al-primary-deep:#14110d; --al-accent:#f3c659; --al-accent-ink:#1a1206;
  --al-card-bg:#14110d; --al-card-border:#332b1d;
  --al-resource-bg:#0d0b0e; --al-resource-border:#231e16;
  --al-hospitality-tint:#f3c659; --al-hospitality-soft:#0d0b0e;
  --al-odoo-tint:#b9a3ff; --al-odoo-soft:rgba(138,108,255,.12);
  --al-free:#3fdcc6; --al-free-soft:rgba(63,220,198,.10);
  --al-paid:#f3c659; --al-paid-soft:rgba(243,198,89,.10);
  --al-pain:#ef6a4f; --al-pain-soft:rgba(176,52,27,.16);
  --al-danger:#ef6a4f; --al-success:#3fdcc6;
}
/* superficies hardcodeadas claras del skin -> oscuro */
.al-calc-embed,.al-apps-odoo,.al-cases,.al-hero{background:transparent !important}
.al-calc-result{background:linear-gradient(180deg,#1a130a,#0d0b0e) !important;color:var(--ink) !important}
.al-calc-result__total,.al-calc-result__metric,.al-calc-result__eyebrow,.al-calc-result__label{color:var(--gold) !important}
.al-calc-result__sub,.al-calc-result__caveat{color:var(--muted) !important}
.al-calc-result .btn-light-on-dark{background:linear-gradient(160deg,var(--gold),var(--honey-deep)) !important;color:#1a1206 !important;border:0 !important}
.al-calc-embed__eyebrow,.al-hospitality-hero__eyebrow{background:var(--panel) !important;color:var(--gold) !important;border-color:var(--line-2) !important}
.al-hospitality-hero{background:var(--black-2) !important}
.al-sticky-bar{background:rgba(8,7,10,.97) !important;border-top-color:var(--line) !important}
.al-section-deep{background:var(--panel-solid) !important}
.al-calc-band{background:rgba(243,198,89,.06) !important}
/* Bootstrap / Odoo surfaces dentro de paginas Colmena */
.card,.bg-white,.bg-light,.bg-body,.bg-body-tertiary,.bg-secondary{background:var(--panel) !important;color:var(--ink) !important;border-color:var(--line) !important}
.o_cc1,.o_cc2,.o_cc3,.o_cc4,.o_cc5{background-color:transparent !important;color:var(--ink) !important}
.text-muted,.small.text-muted{color:var(--muted) !important}
.text-dark,.text-body,.text-black,.text-secondary{color:var(--ink) !important}
.btn-primary{background:linear-gradient(160deg,var(--gold),var(--honey-deep)) !important;border:0 !important;color:#1a1206 !important}
.btn-secondary,.btn-outline-primary,.btn-outline-secondary,.btn-light,.btn-outline-light,.btn-outline-dark{background:transparent !important;color:var(--ink) !important;border:1px solid var(--line-2) !important}
.btn-secondary:hover,.btn-outline-primary:hover,.btn-outline-secondary:hover,.btn-light:hover{border-color:var(--honey) !important;color:var(--honey) !important;background:transparent !important}
.form-control,.form-select,textarea,input[type=text],input[type=email],input[type=tel],input[type=number]{background:var(--black-2) !important;color:var(--ink) !important;border:1px solid var(--line-2) !important}
.form-control::placeholder{color:var(--muted-2)}
.form-label,.form-check-label,label,legend{color:var(--ink) !important}
.table{color:var(--ink);border-color:var(--line)}
.table th,.table td,.table tr{border-color:var(--line) !important;color:var(--ink) !important;background:transparent !important}
.table thead th{color:var(--gold) !important}
hr{border-color:var(--line) !important;opacity:.6}
.accordion,.accordion-item,.accordion-button,.accordion-body{background:var(--panel) !important;color:var(--ink) !important;border-color:var(--line) !important}
.accordion-button:not(.collapsed){color:var(--gold) !important;background:var(--panel-solid) !important}
blockquote,.blockquote{color:var(--comb) !important;border-color:var(--honey) !important}

/* F3.fix · una sola burbuja de chat (ListoBot). Oculta livechat nativo de Odoo. */
.o-livechat-root,.o_livechat_button,#livechatButton,.o-livechat-LivechatButton{display:none !important}

/* F-fix · el card del barcode no debe recortarse por .media (diseñado para imagen 4:3) */
.split .media:has(.bc-label){aspect-ratio:auto !important;overflow:visible !important;border:0 !important;border-radius:0 !important;background:transparent !important}

/* ---------- COLMENAS QUE PASAN (drift + se disipan, 5×6 = 30 abejas) ---------- */
.hive-drift{position:fixed;top:var(--top,20%);left:0;width:124px;height:108px;pointer-events:none;
  opacity:0;will-change:transform,opacity;animation:hd-pass var(--dur,40s) linear var(--delay,0s) infinite}
@keyframes hd-pass{
  0%{opacity:0;transform:translateX(calc(var(--dir,1) * -24vw)) scale(var(--sc,.8))}
  10%{opacity:.5}
  90%{opacity:.5}
  100%{opacity:0;transform:translateX(calc(var(--dir,1) * 124vw)) scale(var(--sc,.8))}
}
.hd-comb{position:absolute;inset:0;display:grid;grid-template-columns:repeat(3,36px);grid-auto-rows:32px;gap:3px;
  filter:drop-shadow(0 0 10px rgba(231,164,44,.12))}
.hd-cell{width:36px;height:40px;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(160deg,rgba(243,198,89,.10),rgba(231,164,44,.02));border:1px solid rgba(243,198,89,.20)}
.hd-cell:nth-child(2),.hd-cell:nth-child(4),.hd-cell:nth-child(6){margin-top:16px}
.hd-bee{position:absolute;left:50%;top:50%;width:26px;height:18px;will-change:transform;
  animation:hd-orbit calc(7s + (var(--b,0) * 1s)) ease-in-out infinite;animation-delay:calc(var(--b,0) * -0.8s)}
@keyframes hd-orbit{
  0%,100%{transform:translate(30px,-50%)}
  25%{transform:translate(6px,calc(-50% - 26px))}
  50%{transform:translate(-42px,-50%)}
  75%{transform:translate(4px,calc(-50% + 26px))}
}
.hd-bee .kmote{position:absolute;top:0;left:0}
@media(prefers-reduced-motion:reduce){.hive-drift{display:none}}

/* ---------- nav: menú de inicio de sesión (nativo Odoo portal) ---------- */
.nav-right{display:flex;align-items:center;gap:18px}
.nav-auth{list-style:none;display:flex;align-items:center;gap:14px;margin:0;padding:0}
.nav-auth .nav-login{font-family:var(--grotesk);font-size:13px;letter-spacing:.02em;color:var(--muted);
  text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;gap:7px;background:transparent;border:0}
.nav-auth .nav-login:hover{color:var(--gold)}
.nav-auth .dropdown-menu{background:var(--panel-solid);border:1px solid var(--line-2);border-radius:8px;
  box-shadow:0 18px 50px -20px rgba(0,0,0,.8);padding:6px}
.nav-auth .dropdown-item{color:var(--ink);border-radius:6px;font-size:14px}
.nav-auth .dropdown-item:hover,.nav-auth .dropdown-item:focus{background:rgba(243,198,89,.10);color:var(--gold)}
.nav-auth .dropdown-divider{border-color:var(--line)}
.nav-auth .fa-user{color:var(--gold)}
@media(max-width:900px){.nav-auth .nav-login span:not(.fa){display:none}}

/* ---------- Tutoriales (página /tutoriales) ---------- */
.tut-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.tut-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:12px}
.tut-h{display:flex;align-items:center;gap:10px}
.tut-h .hx{width:14px;height:16px;flex:none;background:var(--honey);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.tut-h h3{font-size:19px;margin:0}
.tut-video{width:100%;border-radius:10px;background:#000;aspect-ratio:16/9;border:1px solid var(--line-2)}
.tut-card p{color:var(--muted);font-size:13.5px;line-height:1.5;margin:0}
.tut-ph{aspect-ratio:16/9;border:1px dashed var(--line-2);border-radius:10px;display:flex;align-items:center;justify-content:center;
  color:var(--muted-2);font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;background:rgba(243,198,89,.03)}
@media(max-width:900px){.tut-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tut-grid{grid-template-columns:1fr}.news-form{flex-wrap:wrap}.news-form input{width:100%}}
@media(max-width:560px){.tut-grid{grid-template-columns:1fr}}
