/* ============================================================
   SENDARO — Sistema de diseño
   Tu ruta. Tu historia.
   ============================================================ */

@import url("https://api.fontshare.com/v2/css?f[]=satoshi@400,500,700,900&display=swap");

:root{
  --graphite:   #1E1E1E;
  --graphite-2: #2B2B2B;
  --graphite-3: #242424;
  --panel:      #232323;
  --line:       rgba(240,239,237,.10);
  --line-2:     rgba(240,239,237,.06);
  --orange:     #DC5B00;
  --orange-soft:#F2691A;
  --light:      #F0EFED;
  --gray:       #8A8A8A;
  --gray-2:     #626262;
  --gray-3:     #A7A7A7;

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 64px);

  --f: "Satoshi", system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  font-family:var(--f);
  background:var(--graphite);
  color:var(--light);
  font-weight:400;
  line-height:1.5;
  letter-spacing:.01em;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--orange); color:#1a1a1a; }

/* ---------- Typographic helpers ---------- */
.eyebrow{
  font-size:12px; font-weight:700; letter-spacing:.34em;
  text-transform:uppercase; color:var(--gray-3);
}
.eyebrow .dot{ color:var(--orange); }
.display{
  font-weight:900; line-height:.98; letter-spacing:-.02em;
  font-size:clamp(44px, 7.2vw, 104px);
  text-wrap:balance;
}
h2.section-title{
  font-weight:900; line-height:1.0; letter-spacing:-.015em;
  font-size:clamp(32px,4.6vw,60px); text-wrap:balance;
}
.lead{ font-size:clamp(16px,1.4vw,20px); color:var(--gray-3); max-width:46ch; }
.mono{
  font-family:ui-monospace, "SF Mono", "JetBrains Mono", Menlo, monospace;
  font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gray);
}

.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 26px; border-radius:0;
  font-weight:700; font-size:14px; letter-spacing:.06em; text-transform:uppercase;
  transition:transform .4s var(--ease), background .3s, color .3s, border-color .3s;
  white-space:nowrap;
}
.dash{ width:46px; height:3px; background:var(--orange); border:none; display:block; }
.btn--primary{ background:var(--orange); color:#1a1a1a; }
.btn--primary:hover{ background:var(--orange-soft); transform:translateY(-2px); }
.btn--ghost{ border:1px solid var(--line); color:var(--light); }
.btn--ghost:hover{ border-color:var(--light); transform:translateY(-2px); }
.btn .arrow{ transition:transform .4s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

/* ---------- Logo ---------- */
.iso{ display:block; }
.iso .peak{ fill:var(--orange); }

/* ---------- Nav ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px var(--pad);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(20,20,20,.78); backdrop-filter:blur(16px);
  padding-top:14px; padding-bottom:14px; border-bottom:1px solid var(--line-2);
}
.nav__brand{ display:flex; align-items:center; gap:12px; }
.nav__brand img{ height:21px; width:auto; display:block; }
.nav__brand .name{ font-weight:700; letter-spacing:.42em; font-size:17px; padding-left:.42em;}
.nav__links{ display:flex; align-items:center; gap:36px; }
.nav__links a{
  font-size:13px; font-weight:500; letter-spacing:.08em; text-transform:uppercase;
  color:var(--gray-3); transition:color .25s; position:relative;
}
.nav__links a:hover{ color:var(--light); }
.nav__cta{ display:flex; align-items:center; gap:18px; }

/* language switcher (globe icon + dropdown) */
.langsel{ position:relative; display:inline-flex; }
.langsel__toggle{ display:inline-flex; align-items:center; gap:7px; padding:7px 11px;
  border:1px solid var(--line); border-radius:999px; background:rgba(20,20,20,.3); color:var(--gray-3);
  cursor:pointer; transition:color .22s, border-color .22s, background .22s; }
.langsel__toggle:hover{ color:var(--light); border-color:var(--gray-2); }
.langsel__toggle svg{ width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:1.6;
  stroke-linecap:round; stroke-linejoin:round; flex:none; }
.langsel__toggle .chev{ width:13px; height:13px; opacity:.7; transition:transform .25s var(--ease); }
.langsel__code{ font-size:11px; font-weight:700; letter-spacing:.1em; line-height:1; }
.langsel.open .langsel__toggle{ color:var(--light); border-color:var(--orange); }
.langsel.open .langsel__toggle .chev{ transform:rotate(180deg); }
.langsel__menu{ position:absolute; top:calc(100% + 9px); right:0; z-index:200; min-width:158px;
  background:rgba(26,26,26,.98); backdrop-filter:blur(14px); border:1px solid var(--line); border-radius:11px;
  padding:6px; display:flex; flex-direction:column; gap:2px; box-shadow:0 24px 52px -22px rgba(0,0,0,.85);
  opacity:0; transform:translateY(-7px); pointer-events:none; transition:opacity .18s var(--ease), transform .18s var(--ease); }
.langsel.open .langsel__menu{ opacity:1; transform:translateY(0); pointer-events:auto; }
.langsel__menu button{ display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:10px 13px; border-radius:7px; color:var(--gray-3); font-size:14px; font-weight:500;
  text-align:left; cursor:pointer; transition:color .16s, background .16s; }
.langsel__menu button:hover{ color:var(--light); background:rgba(255,255,255,.05); }
.langsel__menu button .lc{ font-size:10.5px; font-weight:700; letter-spacing:.1em; color:var(--gray-2); }
.langsel__menu button.active{ color:var(--orange); }
.langsel__menu button.active .lc{ color:var(--orange); }
.cfg-nav .langsel{ margin-left:auto; margin-right:16px; }

/* ---------- Mobile nav (burger) ---------- */
.nav__burger{ display:none; width:42px; height:42px; border:1px solid var(--line); border-radius:6px;
  flex-direction:column; align-items:center; justify-content:center; gap:5px; background:rgba(20,20,20,.3); }
.nav__burger span{ display:block; width:20px; height:2px; background:var(--light); transition:transform .3s var(--ease), 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{ position:fixed; inset:0 0 auto 0; top:0; z-index:99; transform:translateY(-100%);
  transition:transform .42s var(--ease); background:rgba(18,18,18,.97); backdrop-filter:blur(18px);
  padding:96px var(--pad) 36px; border-bottom:1px solid var(--line); display:flex; flex-direction:column; gap:6px; }
.nav__mobile.open{ transform:translateY(0); }
.nav__mobile a{ font-size:20px; font-weight:700; letter-spacing:.02em; color:var(--light); padding:15px 0;
  border-bottom:1px solid var(--line-2); }
.nav__mobile a.mcta{ margin-top:18px; border:none; background:var(--orange); color:#1a1a1a; text-align:center;
  border-radius:2px; padding:16px; text-transform:uppercase; font-size:14px; letter-spacing:.06em; }
.nav__mobile .mlang{ display:flex; gap:8px; margin-top:22px; }
.nav__mobile .mlang button{ flex:1; padding:12px; border:1px solid var(--line); border-radius:4px;
  color:var(--gray-3); font-weight:700; letter-spacing:.08em; font-size:13px; }
.nav__mobile .mlang button.active{ background:var(--orange); color:#1a1a1a; border-color:var(--orange); }
body.nav-open{ overflow:hidden; }

@media(max-width:900px){
  .nav__links{ display:none; }
  .nav__cta .langsel, .nav__cta .btn{ display:none; }
  .nav__burger{ display:flex; }
  .nav{ padding-top:16px; padding-bottom:16px; }
}
@media(min-width:901px){ .nav__mobile, .nav__burger{ display:none !important; } }

/* ---------- Footer ---------- */
.footer{ border-top:1px solid var(--line-2); padding:72px 0 40px; margin-top:40px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.footer h4{ font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); margin-bottom:18px; font-weight:700;}
.footer a{ display:block; color:var(--gray-3); font-size:14px; padding:5px 0; transition:color .2s; }
.footer a:hover{ color:var(--light); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; margin-top:56px; padding-top:24px; border-top:1px solid var(--line-2); color:var(--gray-2); font-size:12px; letter-spacing:.04em;}
@media(max-width:760px){ .footer__grid{ grid-template-columns:1fr 1fr; gap:32px; } }

/* ---------- Image placeholder (elegant, labeled) ---------- */
.ph{
  position:relative; overflow:hidden; background:var(--graphite-2);
  background-image:
    repeating-linear-gradient(135deg, rgba(240,239,237,.035) 0 2px, transparent 2px 11px);
  border:1px solid var(--line-2);
  display:flex; align-items:center; justify-content:center;
}
.ph::after{
  content:attr(data-label);
  font-family:ui-monospace,"SF Mono",Menlo,monospace;
  font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray-2);
  text-align:center; padding:0 16px; line-height:1.7;
}

/* full-bleed cinematic band */
.band{ position:relative; height:min(78vh,720px); overflow:hidden; display:flex; align-items:center; }
.band img{ position:absolute; top:-240px; left:0; width:100%; height:calc(100% + 480px); object-fit:cover; will-change:transform; }
.band__scrim{ position:absolute; inset:0; background:linear-gradient(90deg, rgba(20,20,20,.82) 0%, rgba(20,20,20,.45) 42%, rgba(20,20,20,.15) 100%), linear-gradient(0deg, rgba(20,20,20,.6), transparent 55%); }
.band__scrim--right{ background:linear-gradient(270deg, rgba(20,20,20,.85) 0%, rgba(20,20,20,.45) 45%, rgba(20,20,20,.1) 100%), linear-gradient(0deg, rgba(20,20,20,.55), transparent 55%); }
.band--detail{ height:min(72vh,640px); }
.band .wrap{ position:relative; z-index:2; }

/* reveal — transform-only entrance; content is NEVER hidden (no opacity gating) */
.reveal{ transform:translateY(26px); transition:transform .9s var(--ease); will-change:transform; }
.reveal.in{ transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ transform:none; transition:none; } }

/* ===== Shared components (relief plate, gallery, cta) ===== */
.relief{ position:relative; aspect-ratio:4/5; }
.relief__plate{ position:relative; width:100%; height:100%; background:linear-gradient(155deg,#303030,#1e1e1e 62%,#161616);
  border:1px solid rgba(255,255,255,.06); overflow:hidden;
  box-shadow:0 60px 100px -50px rgba(0,0,0,.95), inset 0 1px 0 rgba(255,255,255,.04);
  transition:transform .25s var(--ease); transform-style:preserve-3d; }
.relief__svg{ position:absolute; inset:0; width:100%; height:100%; }
.relief__light{ position:absolute; inset:0; pointer-events:none; mix-blend-mode:soft-light;
  background:radial-gradient(440px circle at var(--lx,50%) var(--ly,38%), rgba(255,255,255,.5), transparent 60%); }
.relief__sheen{ position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(680px circle at var(--lx,50%) var(--ly,38%), rgba(220,91,0,.08), transparent 55%); }
.relief__brand{ position:absolute; left:0; right:0; bottom:18px; text-align:center; z-index:3;
  font-weight:700; letter-spacing:.46em; font-size:11px; color:rgba(240,239,237,.4); padding-left:.46em; }
.contour{ fill:none; stroke:rgba(240,239,237,.06); stroke-width:1; }
.contour.b{ stroke:rgba(240,239,237,.035); }
.route-line{ fill:none; stroke:var(--orange); stroke-width:5; stroke-linecap:round; stroke-linejoin:round;
  filter:drop-shadow(0 2px 7px rgba(220,91,0,.4)); }
.node, .node-sq{ fill:var(--orange); }

.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.6vw,44px); }
.frame{ background:linear-gradient(160deg,#1e1e1e,#161616); border:1px solid var(--line-2); padding:18px;
  box-shadow:0 50px 80px -50px rgba(0,0,0,.9); transition:transform .5s var(--ease); }
.piece:hover .frame{ transform:translateY(-6px); }
.frame__inner{ aspect-ratio:1/1; position:relative; }
.plate{ display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-top:18px; }
.plate__l{ display:flex; flex-direction:column; flex:1 1 auto; min-width:0; }
.plate .nm{ font-weight:700; font-size:15px; }
.plate .loc{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); margin-top:5px; }
.plate .dist{ flex:0 0 auto; white-space:nowrap; font-family:ui-monospace,Menlo,monospace; font-size:12px; color:var(--orange); }
@media(max-width:860px){ .gallery{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .gallery{ grid-template-columns:1fr; } }

.cta{ position:relative; overflow:hidden; text-align:center; padding:clamp(70px,11vw,150px) var(--pad); border:1px solid var(--line-2);
  background:linear-gradient(rgba(26,26,26,.82), rgba(26,26,26,.9)), url('tex-slate.jpg') center/cover; }
.cta > *{ position:relative; z-index:2; }
.cta h2{ font-size:clamp(36px,5.6vw,82px); font-weight:900; letter-spacing:-.025em; line-height:.98; margin:22px 0 18px; }
.cta p{ color:var(--gray-3); max-width:48ch; margin:0 auto 36px; font-size:18px; }
.cta .o{ color:var(--orange); }

/* Shared section scaffold for inner pages */
.block{ padding:clamp(80px,11vh,150px) 0; position:relative; }
.page-head{ max-width:820px; margin-bottom:60px; }
.page-head .eyebrow{ display:flex; align-items:center; gap:14px; }
.page-head h1{ margin-top:22px; font-weight:900; line-height:.98; letter-spacing:-.02em; font-size:clamp(44px,7vw,92px); text-wrap:balance; }
.page-head .lead{ margin-top:22px; }

/* ===================== RESPONSIVE (tablet / móvil) ===================== */
@media(max-width:760px){
  :root{ --pad: 22px; }
  .lead{ font-size:16px; }
  .cta{ padding:clamp(48px,12vw,90px) 22px; }
  .cta p{ font-size:16px; }
  .footer{ padding:56px 0 32px; }
  .footer__bottom{ flex-direction:column; gap:10px; align-items:flex-start; }
  /* Sin parallax en móvil: las imágenes vuelven a encuadrarse centradas */
  .hero__media img, .band img, .shero__media img, .aud__media img{
    top:0 !important; left:0 !important; width:100% !important; height:100% !important;
    object-position:center center !important; transform:none !important;
  }
}
@media(max-width:560px){
  .footer__grid{ grid-template-columns:1fr; gap:26px; }
  .btn{ padding:14px 22px; font-size:13px; }
}
/* hit targets táctiles */
@media(hover:none){
  .nav__links a{ padding:8px 0; }
}

/* ===== Sendaro custom cursor (isotipo A naranja) ===== */
:root{ --sendaro-cursor: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%22533%20230%20300%20300%22%20width%3D%2232%22%20height%3D%2232%22%3E%3Cg%20transform%3D%22rotate(-30%20683%20380)%22%3E%3Cpath%20fill%3D%22%23DC5B00%22%20d%3D%22M574.28%2C466c12.58%2C0%2C25.16%2C0%2C37.74%2C0c23.36-41.52%2C46.72-83.05%2C70.08-124.57c23.36%2C41.52%2C46.72%2C83.05%2C70.08%2C124.57c13.48%2C0%2C26.96%2C0%2C40.43%2C0c-36.84-62.62-73.68-125.25-110.52-187.87C646.17%2C340.75%2C610.22%2C403.38%2C574.28%2C466z%22%2F%3E%3Ccircle%20fill%3D%22%23DC5B00%22%20cx%3D%22683.45%22%20cy%3D%22439.34%22%20r%3D%2226.66%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") 11 7, auto; }
*{ cursor: var(--sendaro-cursor) !important; }
input:not([type=button]):not([type=submit]):not([type=range]), textarea, [contenteditable="true"]{ cursor: text !important; }
