/* Ebike Tour Lanzarote - Estilos compartidos páginas de ruta */
:root{
  --orange:#E8911A;--orange2:#f5a020;--brown:#8B5E2A;--brown2:#6b4520;
  --black:#090909;--dark:#111;--dark2:#181818;--dark3:#222;
  --gray:#777;--light:#f5f0e8;--cream:#f7efe1;--white:#fff;--r:5px;
  --ff:'Inter',sans-serif;--fd:'Bebas Neue',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff);background:var(--black);color:var(--light);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* Topbar + Nav */
#topbar{background:var(--orange);padding:7px 48px;display:flex;justify-content:space-between;align-items:center}
#topbar a{color:white;font-size:.75rem;font-weight:600;letter-spacing:.04em;display:flex;align-items:center;gap:6px}
.tb-right{display:flex;gap:24px;align-items:center}
.tb-social{display:flex;gap:14px}
.tb-social a{color:white;opacity:.8;font-size:.85rem;transition:opacity .2s}
.tb-social a:hover{opacity:1}
#nav{position:fixed;top:33px;left:0;right:0;z-index:300}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:14px 48px;background:rgba(9,9,9,.97);border-bottom:1px solid rgba(255,255,255,.07);backdrop-filter:blur(12px)}
.nav-logo img{height:50px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none}
.nav-links a{color:rgba(245,240,232,.6);font-size:.78rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;transition:color .2s;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.nav-links a:hover,.nav-links a.active{color:var(--orange2)}
.nav-drop{position:relative}
.nav-sub{position:absolute;top:100%;left:-14px;min-width:240px;background:rgba(9,9,9,.98);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:8px 0;margin-top:14px;list-style:none;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s ease;backdrop-filter:blur(12px);box-shadow:0 20px 40px rgba(0,0,0,.4)}
.nav-drop:hover .nav-sub{opacity:1;visibility:visible;transform:translateY(0)}
.nav-sub li{display:block}
.nav-sub a{display:block;padding:10px 18px;font-size:.72rem;letter-spacing:.08em;color:rgba(245,240,232,.7)}
.nav-sub a:hover{background:rgba(232,145,26,.1);color:var(--orange2)}
.nav-cta{background:var(--orange)!important;color:white!important;padding:9px 20px;border-radius:var(--r)!important}

/* Hero */
.r-hero{min-height:88vh;display:flex;align-items:flex-end;padding:200px 48px 80px;background:#0a0a0a;position:relative;overflow:hidden}
.r-hero-bg{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;z-index:0;animation:slowZoom 20s ease-in-out infinite alternate}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.r-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,transparent 30%,rgba(10,10,10,.4) 60%,rgba(10,10,10,.92) 100%);z-index:1;pointer-events:none}
.r-hero-in{position:relative;z-index:2;max-width:1300px;margin:0 auto;width:100%}
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.18em;color:var(--orange2);text-transform:uppercase;margin-bottom:18px}
.r-h1{font-family:var(--fd);font-size:clamp(3.2rem,8vw,6.5rem);line-height:.9;letter-spacing:.01em;text-shadow:0 4px 20px rgba(0,0,0,.4)}
.r-h1 .accent{color:var(--orange)}
.r-sub{max-width:680px;font-size:1.1rem;line-height:1.6;color:rgba(245,240,232,.85);margin-top:20px;font-weight:300}
.r-meta{display:flex;flex-wrap:wrap;gap:20px;margin-top:32px;align-items:center}
.r-pill{background:rgba(0,0,0,.55);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);padding:10px 18px;border-radius:50px;font-size:.78rem;font-weight:500;display:flex;align-items:center;gap:8px;color:var(--light)}
.r-pill strong{color:var(--orange2);font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.72rem}
.r-cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.btn-orange{display:inline-flex;align-items:center;gap:10px;background:var(--orange);color:white;padding:16px 32px;border-radius:var(--r);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;transition:transform .2s,background .2s;border:none;cursor:pointer}
.btn-orange:hover{transform:translateY(-2px);background:var(--orange2)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;background:transparent;color:white;padding:16px 28px;border-radius:var(--r);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;border:1px solid rgba(255,255,255,.3);transition:all .2s}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:white}
.r-price{display:inline-flex;align-items:baseline;gap:8px}
.r-price .lbl{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange2);font-weight:600}
.r-price .num{font-family:var(--fd);font-size:2.4rem;color:white;line-height:1}

/* Section */
.sec{padding:90px 48px;max-width:1300px;margin:0 auto}
.sec h2{font-family:var(--fd);font-size:clamp(2rem,4.5vw,3.5rem);line-height:.95;letter-spacing:.01em;margin-bottom:24px}
.sec h2 .accent{color:var(--orange)}
.sec-sub{color:rgba(245,240,232,.7);font-size:1rem;line-height:1.75;max-width:760px;margin-bottom:48px;font-weight:300}

/* Resumen 2-col */
.resumen{background:linear-gradient(180deg,#0a0a0a 0%,#141210 100%);padding:90px 48px;border-bottom:1px solid rgba(255,255,255,.05)}
.resumen-in{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.resumen-tx p{font-size:1.05rem;line-height:1.8;color:rgba(245,240,232,.8);margin-bottom:18px;font-weight:300}
.resumen-tx p strong{color:var(--orange2);font-weight:600}
.resumen-img{aspect-ratio:4/3;border-radius:8px;overflow:hidden;background:#222 center/cover;box-shadow:0 30px 60px rgba(0,0,0,.5)}

/* Galería */
.gallery{padding:90px 48px;background:var(--black)}
.gallery-in{max-width:1400px;margin:0 auto}
.gal-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:10px;margin-top:36px}
.gal-cell{position:relative;overflow:hidden;border-radius:6px;background:#1a1a1a center/cover;cursor:pointer;transition:transform .3s}
.gal-cell:hover{transform:scale(1.02)}
.gal-cell::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.3));opacity:0;transition:opacity .3s}
.gal-cell:hover::after{opacity:1}
.gal-cell.placeholder{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.25);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;background:repeating-linear-gradient(45deg,#1a1a1a,#1a1a1a 10px,#1f1f1f 10px,#1f1f1f 20px)}
/* Layout grande/destacado: 1 grande + 5 pequeñas */
.gal-cell:nth-child(1){grid-column:span 3;grid-row:span 2}
.gal-cell:nth-child(2){grid-column:span 3;grid-row:span 1}
.gal-cell:nth-child(3){grid-column:span 1;grid-row:span 1}
.gal-cell:nth-child(4){grid-column:span 1;grid-row:span 1}
.gal-cell:nth-child(5){grid-column:span 1;grid-row:span 1}
.gal-cell:nth-child(6){grid-column:span 1;grid-row:span 1}
.gal-cell:nth-child(7){grid-column:span 2;grid-row:span 1}
@media(max-width:900px){
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gal-cell:nth-child(n){grid-column:span 1;grid-row:span 1}
  .gal-cell:nth-child(1){grid-column:span 2;grid-row:span 1}
}

/* Highlights */
.high{background:#0c0c0c;padding:90px 48px;border-top:1px solid rgba(255,255,255,.05)}
.high-in{max-width:1300px;margin:0 auto}
.high-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;margin-top:50px}
.hi{background:var(--dark2);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:30px 26px;transition:transform .2s,border-color .2s,background .2s;position:relative;overflow:hidden}
.hi:hover{transform:translateY(-4px);border-color:rgba(232,145,26,.4)}
.hi-num{font-family:var(--fd);color:var(--orange);font-size:1.4rem;letter-spacing:.05em;margin-bottom:14px;opacity:.7}
.hi h3{font-family:var(--fd);font-size:1.3rem;letter-spacing:.04em;margin-bottom:12px;color:var(--light);line-height:1.05}
.hi p{font-size:.88rem;line-height:1.65;color:var(--gray)}

/* Datos prácticos */
.facts{background:var(--orange);color:white;padding:60px 48px}
.facts-in{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:30px;text-align:center}
.fct-lb{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;opacity:.85;margin-bottom:8px}
.fct-val{font-family:var(--fd);font-size:1.8rem;line-height:1;letter-spacing:.02em}

/* Mapa */
.mapa{background:linear-gradient(180deg,#141210 0%,#0a0a0a 100%);padding:90px 48px;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}
.mapa-in{max-width:1300px;margin:0 auto;text-align:center}
.mapa-svg{margin-top:40px;background:#000;border-radius:10px;padding:36px 30px;box-shadow:0 30px 80px rgba(0,0,0,.5);overflow:hidden;border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center}
.mapa-svg svg{width:100%;height:auto;display:block;max-height:520px}
.mapa-img{max-width:260px;width:100%;height:auto;display:block;margin:0 auto}
.mapa-leg{display:flex;justify-content:center;flex-wrap:wrap;gap:24px;margin-top:24px;font-size:.78rem;color:rgba(245,240,232,.7)}
.mapa-leg span{display:flex;align-items:center;gap:8px}
.mapa-leg .dot{width:10px;height:10px;border-radius:50%}

/* Incluye */
.incluye{background:var(--black);padding:90px 48px}
.incluye-in{max-width:1300px;margin:0 auto}
.inc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:40px}
.inc-card{background:var(--dark2);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:24px 22px;transition:border-color .2s}
.inc-card:hover{border-color:rgba(232,145,26,.3)}
.inc-ic{font-size:1.6rem;margin-bottom:10px}
.inc-card h4{font-family:var(--fd);font-size:1.05rem;letter-spacing:.04em;margin-bottom:8px;color:var(--light)}
.inc-card p{font-size:.82rem;line-height:1.6;color:var(--gray)}

/* Mission band */
.band{background:var(--brown);color:white;padding:60px 48px;text-align:center}
.band h3{font-family:var(--fd);font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.1;letter-spacing:.02em;max-width:900px;margin:0 auto}
.band em{color:var(--orange2);font-style:normal}

/* CTA grande */
.r-cta{padding:100px 48px;background:linear-gradient(180deg,#0a0a0a,#141210);text-align:center}
.r-cta h2{font-family:var(--fd);font-size:clamp(2.4rem,5vw,4rem);line-height:.95;margin-bottom:20px}
.r-cta p{color:rgba(245,240,232,.7);font-size:1rem;line-height:1.7;max-width:600px;margin:0 auto 32px;font-weight:300}

/* FareHarbor calendar */
.r-fh{padding:90px 48px 70px;background:linear-gradient(180deg,#0a0a0a,#141210);position:relative}
.r-fh-head{max-width:900px;margin:0 auto 36px;text-align:center}
.r-fh-head h2{font-family:var(--fd);font-size:clamp(2.4rem,5vw,3.8rem);line-height:.95;margin-bottom:18px;letter-spacing:.02em}
.r-fh-head p{color:rgba(245,240,232,.62);font-size:.92rem;line-height:1.7;max-width:560px;margin:0 auto;font-weight:300}
.r-fh-meta{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap;margin-top:22px;font-size:.82rem;color:rgba(245,240,232,.75);letter-spacing:.02em}
.r-fh-meta b{color:var(--orange2);font-weight:700;font-size:1rem}
.r-fh-meta .dot{width:4px;height:4px;border-radius:50%;background:rgba(245,240,232,.25)}
.r-fh-frame{max-width:1100px;margin:0 auto;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(232,145,26,.18);position:relative}
.r-fh-frame::before{content:'';position:absolute;inset:-2px;border-radius:12px;background:linear-gradient(135deg,var(--orange) 0%,transparent 35%,transparent 65%,var(--orange) 100%);z-index:-1;opacity:.4}
.r-fh-frame iframe{width:100%;min-height:920px;border:0;display:block;background:#fff}
.r-fh-foot{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap;margin-top:26px;font-size:.82rem;color:rgba(245,240,232,.55)}
.btn-ghost-sm{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid rgba(245,240,232,.18);border-radius:5px;font-size:.78rem;font-weight:600;letter-spacing:.06em;color:var(--light);transition:all .2s}
.btn-ghost-sm:hover{border-color:var(--orange);color:var(--orange2)}
.r-fh-trust{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;max-width:1100px;margin:48px auto 0}
.r-fh-trust .tr{display:flex;align-items:flex-start;gap:12px;padding:18px 20px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:6px}
.r-fh-trust .tr .i{font-size:1.5rem;flex-shrink:0;line-height:1}
.r-fh-trust .tr b{display:block;font-size:.84rem;color:var(--light);margin-bottom:3px;font-weight:600}
.r-fh-trust .tr small{display:block;font-size:.72rem;color:rgba(245,240,232,.5);line-height:1.4}

/* Otras rutas */
.others{background:var(--black);padding:90px 48px;border-top:1px solid rgba(255,255,255,.05)}
.others-in{max-width:1300px;margin:0 auto}
.others-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:40px}
.oc{position:relative;aspect-ratio:4/3;border-radius:8px;overflow:hidden;cursor:pointer;background:#1a1a1a center/cover;transition:transform .25s}
.oc:hover{transform:translateY(-4px)}
.oc::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85));pointer-events:none}
.oc-cap{position:absolute;bottom:0;left:0;right:0;padding:22px;z-index:2;color:white}
.oc-cap .lbl{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--orange2);font-weight:700;margin-bottom:6px}
.oc-cap h4{font-family:var(--fd);font-size:1.4rem;letter-spacing:.04em;line-height:1}
.oc-cap .arr{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:white;opacity:.85;transition:opacity .2s}
.oc:hover .oc-cap .arr{opacity:1;color:var(--orange2)}

/* Footer */
footer{background:#070707;padding:48px 48px 28px;border-top:1px solid rgba(255,255,255,.06);text-align:center}
footer .ft-logo img{height:100px;margin-bottom:18px}
footer p{color:var(--gray);font-size:.78rem;line-height:1.65;max-width:460px;margin:0 auto 18px}
.ft-social{display:flex;justify-content:center;gap:18px;margin-bottom:18px}
.ft-social a{color:var(--orange2);font-size:.78rem;letter-spacing:.06em}
.ft-bot{color:#444;font-size:.7rem;margin-top:18px}

/* Responsive */
@media(max-width:980px){
  .nav-links{display:none}
  #topbar{padding:7px 18px;font-size:.7rem}
  .r-hero{padding:160px 22px 60px;min-height:75vh}
  .sec,.resumen,.gallery,.high,.facts,.mapa,.incluye,.r-cta,.others,.r-fh{padding-left:22px;padding-right:22px}
  .r-fh-frame iframe{min-height:1100px}
  .resumen-in{grid-template-columns:1fr;gap:36px}
  footer{padding:48px 22px 24px}
}
