/* ============================================================
   CANALDOCENTE · ESTILO GLOBAL
   Una sola hoja para todas las páginas. v1.0
   ============================================================ */

:root{
  --ink:#0B0A1F;
  --ink-2:#1A1733;
  --violet:#6E3AFF;
  --violet-deep:#4A1FC4;
  --coral:#FF5C5C;
  --mint:#00E5A8;
  --yellow:#FFE15C;
  --cream:#FAF6F0;
  --paper:#FFFDF8;
  --line:rgba(11,10,31,.10);
  --muted:#5C5878;
  --display:'Bricolage Grotesque',system-ui,sans-serif;
  --body:'Plus Jakarta Sans',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --container:min(1440px,92vw);
  --gutter:clamp(20px,4vw,40px);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:clamp(15.5px,.95rem + .15vw,17px);line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;color:var(--ink);letter-spacing:-.025em;text-wrap:balance}
p,li{text-wrap:pretty}
::selection{background:var(--ink);color:var(--coral)}
*:focus-visible{outline:3px solid var(--violet);outline-offset:2px;border-radius:4px}

.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:var(--ink);color:#fff;padding:10px 16px;border-radius:10px;z-index:99999}

/* ===== CORTINA ===== */
.cd-curtain{position:fixed;inset:0;z-index:99999;pointer-events:none;display:grid;grid-template-columns:1fr 1fr}
.cd-curtain__panel{background:var(--ink);position:relative;overflow:hidden;transform:translateZ(0);transition:transform 1100ms cubic-bezier(.86,0,.07,1)}
.cd-curtain__mark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--display);font-weight:800;font-size:clamp(64px,12vw,180px);letter-spacing:-.04em;line-height:.9;color:#fff;white-space:nowrap;opacity:0;transition:opacity 600ms ease 250ms}
.cd-curtain__panel--l .cd-curtain__mark{transform:translate(-2%,-50%);color:transparent;-webkit-text-stroke:1.5px var(--coral)}
.cd-curtain__panel--r .cd-curtain__mark{transform:translate(-98%,-50%);background:linear-gradient(120deg,var(--coral),var(--yellow) 50%,var(--mint));-webkit-background-clip:text;background-clip:text;color:transparent}
.cd-curtain__sub{position:absolute;left:50%;top:calc(50% + clamp(60px,8vw,110px));color:rgba(255,255,255,.6);font-size:13px;letter-spacing:.3em;text-transform:uppercase;font-weight:500;white-space:nowrap;opacity:0;transition:opacity 600ms ease 400ms}
.cd-curtain__panel--l .cd-curtain__sub{transform:translateX(0%)}
.cd-curtain__panel--r .cd-curtain__sub{transform:translateX(-100%)}
.cd-curtain__dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);background-size:24px 24px;opacity:0;transition:opacity 500ms ease}
.cd-curtain.is-ready .cd-curtain__mark,.cd-curtain.is-ready .cd-curtain__sub,.cd-curtain.is-ready .cd-curtain__dots{opacity:1}
.cd-curtain.is-ready .cd-curtain__sub{opacity:.8}
.cd-curtain.is-open .cd-curtain__panel--l{transform:translateX(-101%)}
.cd-curtain.is-open .cd-curtain__panel--r{transform:translateX(101%)}
.cd-curtain.is-done{display:none}
@media (prefers-reduced-motion:reduce){.cd-curtain{display:none!important}}

/* ===== NAV ===== */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,246,240,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav__inner{max-width:var(--container);margin:0 auto;padding:14px var(--gutter);display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-.02em;color:var(--ink);flex-shrink:0}
.brand__mark{width:34px;height:34px;border-radius:10px;background:var(--ink);color:var(--coral);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:-.05em;position:relative;overflow:hidden;flex-shrink:0}
.brand__mark::after{content:"";position:absolute;inset:auto 0 0 0;height:35%;background:linear-gradient(180deg,transparent,rgba(110,58,255,.4))}
.nav__links{display:flex;gap:4px;margin-left:14px;flex-wrap:wrap}
.nav__link{padding:9px 14px;border-radius:999px;font-size:14.5px;font-weight:500;color:var(--ink-2);transition:all .18s ease}
.nav__link:hover,.nav__link.is-active{background:var(--ink);color:var(--paper)}
.nav__cta{margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:999px;font-weight:600;font-size:14.5px;transition:all .2s ease;border:1.5px solid transparent;white-space:nowrap;cursor:pointer;min-height:44px}
.btn--ghost{border-color:var(--ink);color:var(--ink);background:transparent}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}
.btn--coral{background:var(--coral);color:#fff}
.btn--coral:hover{background:#ff4040;transform:translateY(-1px)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ink:hover{background:var(--violet)}

/* mobile nav */
.nav__burger{display:none;width:44px;height:44px;border-radius:50%;background:var(--ink);color:#fff;align-items:center;justify-content:center}
.nav__burger span,.nav__burger span::before,.nav__burger span::after{content:"";display:block;width:18px;height:2px;background:#fff;border-radius:2px;position:relative}
.nav__burger span::before{position:absolute;top:-6px}
.nav__burger span::after{position:absolute;top:6px}

/* Mobile drawer — oculto siempre por defecto, activado en móvil al abrir */
.nav__mobile{display:none;position:fixed;inset:0;background:var(--ink);z-index:200;padding:80px 32px 32px;flex-direction:column;gap:8px}
.nav__mobile.is-open{display:flex}
.nav__mobile a{color:#fff;padding:14px 18px;border-radius:14px;font-size:18px;font-weight:600;border:1px solid rgba(255,255,255,.08)}
.nav__mobile a:hover{background:rgba(255,255,255,.08)}
.nav__mobile .btn--coral{background:var(--coral);margin-top:16px;justify-content:center;border:0}
.nav__close{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:24px;display:grid;place-items:center}

@media (max-width:980px){
  .nav__links,.nav__cta .btn--ghost{display:none}
  .nav__burger{display:inline-flex}
}

/* ===== PAGE HEADER (no-home) ===== */
.page-hero{padding:80px var(--gutter) 64px;background:var(--paper);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-hero__inner{max-width:var(--container);margin:0 auto;position:relative;z-index:2}
.page-hero__tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--violet);margin-bottom:20px}
.page-hero__tag::before{content:"";width:32px;height:1px;background:var(--violet)}
.page-hero__title{font-size:clamp(40px,5.5vw,80px);font-weight:600;line-height:1;letter-spacing:-.03em;margin-bottom:24px}
.page-hero__title em{font-style:italic;font-weight:400;color:var(--violet)}
.page-hero__lede{font-size:clamp(17px,1.4vw,21px);line-height:1.55;color:var(--muted);max-width:680px}
.page-hero__deco{position:absolute;right:-40px;top:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(110,58,255,.18),transparent 70%);pointer-events:none}

/* ===== SECTIONS ===== */
section{padding:96px var(--gutter);position:relative}
.container{max-width:var(--container);margin:0 auto}
.section__head{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-bottom:64px;align-items:end}
.section__tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--violet);margin-bottom:20px}
.section__tag::before{content:"";width:32px;height:1px;background:var(--violet)}
.section__title{font-size:clamp(32px,4.5vw,60px);font-weight:600;line-height:1;letter-spacing:-.03em}
.section__title em{font-style:italic;font-weight:400;color:var(--violet)}
.section__lede{font-size:17px;line-height:1.55;color:var(--muted);max-width:460px;justify-self:end}

/* ===== FOOTER ===== */
.ftr{background:var(--ink);color:rgba(255,253,248,.7);padding:64px var(--gutter) 32px}
.ftr__inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.ftr__col h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px;font-weight:600}
.ftr__col ul{list-style:none;display:grid;gap:10px}
.ftr__col a{color:rgba(255,253,248,.7);font-size:14.5px;transition:color .15s}
.ftr__col a:hover{color:var(--mint)}
.ftr__brand{font-family:var(--display);font-weight:700;font-size:22px;color:#fff;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.ftr__brand .brand__mark{background:rgba(255,255,255,.08);color:var(--coral)}
.ftr__about{font-size:14.5px;line-height:1.6;max-width:340px;margin-bottom:18px}
.ftr__bottom{max-width:var(--container);margin:0 auto;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;font-size:13px;color:rgba(255,253,248,.5)}
.ftr__bottom a{color:rgba(255,253,248,.5)}
.ftr__bottom a:hover{color:var(--mint)}

@media (max-width:980px){
  .ftr__inner{grid-template-columns:1fr 1fr;gap:32px}
  .ftr__col--brand{grid-column:span 2}
  .section__head{grid-template-columns:1fr;gap:24px;margin-bottom:40px}
  .section__lede{justify-self:start}
  section{padding:64px var(--gutter)}
  .page-hero{padding:48px var(--gutter) 40px}
}
@media (max-width:560px){
  .ftr__inner{grid-template-columns:1fr}
  .ftr__col--brand{grid-column:span 1}
}

/* ===== UTIL ===== */
.tag{display:inline-flex;align-items:center;padding:5px 11px;border-radius:999px;font-size:11.5px;font-weight:600;background:var(--cream);color:var(--ink);text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--line)}
.tag--violet{background:rgba(110,58,255,.1);color:var(--violet);border-color:transparent}
.tag--coral{background:var(--coral);color:#fff;border-color:transparent}
.tag--mint{background:rgba(0,229,168,.15);color:#008f6a;border-color:transparent}
.tag--yellow{background:var(--yellow);color:var(--ink);border-color:transparent}

.card{background:var(--paper);border-radius:24px;padding:28px;border:1px solid var(--line);transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-3px);box-shadow:0 20px 50px -20px rgba(11,10,31,.18)}
.card__title{font-size:22px;font-weight:600;letter-spacing:-.02em;margin-bottom:8px}
.card__desc{color:var(--muted);font-size:15px;line-height:1.55}

input,textarea,select{font-family:inherit;font-size:15px;padding:12px 16px;border:1.5px solid var(--line);border-radius:12px;background:#fff;width:100%;transition:border-color .15s,box-shadow .15s}
input:focus,textarea:focus,select:focus{border-color:var(--violet);box-shadow:0 0 0 4px rgba(110,58,255,.12);outline:0}
label{font-size:13px;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:8px}
