
:root {
  --navy: #062f4b;
  --navy-2: #0b4265;
  --blue: #0077b6;
  --aqua: #00b4d8;
  --aqua-soft: #dff8fc;
  --sand: #f4e1c1;
  --sun: #ffb703;
  --coral: #ef6a55;
  --green: #2aa779;
  --ink: #172a3a;
  --muted: #617487;
  --paper: #f7fbfd;
  --white: #fff;
  --shadow: 0 18px 55px rgba(6,47,75,.14);
  --shadow-soft: 0 10px 30px rgba(6,47,75,.10);
  --radius-xl: 30px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --max: 1240px;
  --header: 82px;
  --font-scale: 1;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;font-size:calc(16px * var(--font-scale))}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--paper);color:var(--ink);line-height:1.6;overflow-x:hidden}
body.reduced-motion *,body.reduced-motion *::before,body.reduced-motion *::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
body.high-contrast{--paper:#fff;--ink:#000;--muted:#222;--navy:#000;--blue:#004d80;--aqua:#006d83;--sun:#9d6500;--shadow:none;--shadow-soft:none}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.container{width:min(var(--max),calc(100% - 40px));margin-inline:auto}
.skip-link{position:fixed;left:16px;top:-60px;z-index:9999;background:#fff;color:#000;padding:12px 18px;border-radius:0 0 12px 12px;font-weight:800;transition:top .2s}
.skip-link:focus{top:0}
.site-header{position:fixed;inset:0 0 auto;z-index:1000;background:rgba(255,255,255,.84);backdrop-filter:blur(18px);border-bottom:1px solid rgba(6,47,75,.08)}
.header-inner{height:var(--header);display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;flex:0 0 auto}.brand img{width:205px;height:auto}
.main-nav{display:flex;align-items:center;gap:6px;margin-left:auto}
.main-nav a,.nav-button{border:0;background:transparent;padding:11px 12px;border-radius:999px;font-weight:700;font-size:.91rem;color:var(--navy);transition:.2s}
.main-nav a:hover,.main-nav a:focus-visible,.nav-button:hover,.nav-button:focus-visible{background:var(--aqua-soft);color:var(--blue)}
.main-nav a.active{background:var(--navy);color:#fff}
.header-actions{display:flex;align-items:center;gap:8px}
.icon-btn,.pill-btn,.primary-btn,.secondary-btn,.ghost-btn{border:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;transition:transform .2s,box-shadow .2s,background .2s}
.icon-btn{width:44px;height:44px;background:#fff;color:var(--navy);box-shadow:0 5px 18px rgba(6,47,75,.09)}
.pill-btn{padding:12px 17px;background:var(--sun);color:var(--navy)}
.primary-btn{padding:14px 22px;background:var(--navy);color:#fff;box-shadow:0 10px 24px rgba(6,47,75,.23)}
.secondary-btn{padding:14px 22px;background:#fff;color:var(--navy);box-shadow:0 10px 24px rgba(6,47,75,.12)}
.ghost-btn{padding:12px 18px;background:transparent;color:var(--navy);border:1px solid rgba(6,47,75,.16)}
.icon-btn:hover,.pill-btn:hover,.primary-btn:hover,.secondary-btn:hover,.ghost-btn:hover{transform:translateY(-2px)}
.mobile-toggle{display:none}
.lang-select{border:1px solid rgba(6,47,75,.12);background:#fff;border-radius:999px;padding:10px 12px;color:var(--navy);font-weight:700}
.hero{position:relative;min-height:760px;padding-top:var(--header);display:grid;place-items:center;overflow:hidden;background:#05324e}
.hero-media{position:absolute;inset:0}.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,32,52,.86) 0%,rgba(4,32,52,.55) 48%,rgba(4,32,52,.16) 100%)}
.hero-content{position:relative;z-index:2;color:#fff;padding:82px 0 110px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.7fr);gap:70px;align-items:end}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);font-size:.82rem;font-weight:900;letter-spacing:.09em;text-transform:uppercase}
.hero h1{font-size:clamp(3.4rem,7vw,6.8rem);line-height:.92;letter-spacing:-.055em;margin:22px 0 20px;max-width:860px}
.hero h1 span{display:block;color:var(--sun)}
.hero-copy{font-size:1.24rem;max-width:720px;color:rgba(255,255,255,.88);margin:0 0 32px}
.hero-buttons{display:flex;flex-wrap:wrap;gap:13px}
.hero-panel{background:rgba(255,255,255,.92);color:var(--ink);padding:22px;border-radius:var(--radius-xl);box-shadow:var(--shadow);backdrop-filter:blur(18px)}
.hero-panel h2{margin:0 0 14px;font-size:1.15rem}
.search-box{display:flex;gap:10px;background:#fff;border:1px solid rgba(6,47,75,.12);padding:8px;border-radius:18px}
.search-box input{min-width:0;flex:1;border:0;outline:0;padding:10px;background:transparent;color:var(--ink)}
.search-box button{border:0;background:var(--navy);color:#fff;border-radius:13px;width:46px}
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.quick-card{padding:14px;border-radius:16px;background:var(--paper);min-height:108px;display:flex;flex-direction:column;justify-content:space-between}
.quick-card b{font-size:.86rem}.quick-card small{color:var(--muted)}
.demo-label{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:900;letter-spacing:.05em;text-transform:uppercase;color:#805600;background:#fff3c5;border:1px solid #ffd664;border-radius:999px;padding:4px 8px}
.section{padding:96px 0}.section.compact{padding:70px 0}.section.white{background:#fff}.section.navy{background:var(--navy);color:#fff}.section.aqua{background:linear-gradient(180deg,#eafcff,#f7fbfd)}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:30px;margin-bottom:34px}
.section-kicker{color:var(--blue);text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-size:.78rem}
.section.navy .section-kicker{color:#78e0f1}
.section-title{font-size:clamp(2.25rem,4.3vw,4.15rem);line-height:1.02;letter-spacing:-.045em;margin:9px 0 0;max-width:820px}
.section-lead{max-width:620px;color:var(--muted);font-size:1.05rem}.section.navy .section-lead{color:rgba(255,255,255,.72)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:-50px;position:relative;z-index:3}
.stat{background:#fff;border-radius:22px;padding:24px;box-shadow:var(--shadow-soft);border:1px solid rgba(6,47,75,.07)}
.stat strong{display:block;font-size:2rem;line-height:1;color:var(--navy);margin-bottom:8px}.stat span{color:var(--muted);font-weight:700;font-size:.9rem}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card-grid.four{grid-template-columns:repeat(4,1fr)}
.media-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid rgba(6,47,75,.07);display:flex;flex-direction:column;min-height:100%;transition:transform .25s,box-shadow .25s}
.media-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.media-card .media{position:relative;aspect-ratio:16/10;overflow:hidden}.media-card .media img{width:100%;height:100%;object-fit:cover;transition:transform .45s}.media-card:hover .media img{transform:scale(1.04)}
.card-badge{position:absolute;left:16px;top:16px;background:rgba(255,255,255,.92);color:var(--navy);padding:7px 11px;border-radius:999px;font-size:.75rem;font-weight:900;backdrop-filter:blur(10px)}
.card-body{padding:22px;display:flex;flex-direction:column;gap:12px;flex:1}.card-body h3{font-size:1.42rem;line-height:1.15;margin:0;color:var(--navy)}.card-body p{margin:0;color:var(--muted)}
.tag-list{display:flex;flex-wrap:wrap;gap:7px}.tag{padding:6px 9px;border-radius:999px;background:var(--aqua-soft);color:var(--navy);font-size:.75rem;font-weight:800}
.card-actions{display:flex;flex-wrap:wrap;gap:9px;margin-top:auto;padding-top:8px}.card-actions button,.card-actions a{border:0;border-radius:999px;padding:10px 13px;font-weight:800;font-size:.84rem}.card-actions .details{background:var(--navy);color:#fff}.card-actions .plan-add{background:var(--sun);color:var(--navy)}
.feature-band{border-radius:38px;overflow:hidden;background:var(--navy);color:#fff;display:grid;grid-template-columns:1.1fr .9fr;box-shadow:var(--shadow)}
.feature-band .copy{padding:64px}.feature-band h2{font-size:clamp(2.4rem,4vw,4rem);line-height:1.02;margin:0 0 18px;letter-spacing:-.04em}.feature-band p{color:rgba(255,255,255,.72);font-size:1.08rem}.feature-band .visual img{width:100%;height:100%;object-fit:cover}
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}.filter-btn{border:1px solid rgba(6,47,75,.13);background:#fff;color:var(--navy);padding:10px 14px;border-radius:999px;font-weight:800}.filter-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}.split-media{border-radius:32px;overflow:hidden;box-shadow:var(--shadow)}
.timeline{display:grid;gap:16px}.timeline-item{display:grid;grid-template-columns:90px 1fr;gap:18px;background:#fff;padding:20px;border-radius:18px;border:1px solid rgba(6,47,75,.08)}.timeline-item time{font-weight:900;color:var(--blue);font-size:.9rem}.timeline-item h3{margin:0 0 5px;color:var(--navy)}.timeline-item p{margin:0;color:var(--muted)}
.map-shell{min-height:540px;border-radius:30px;overflow:hidden;background:#dcecf1;box-shadow:var(--shadow);position:relative}.map-toolbar{position:absolute;left:18px;top:18px;z-index:10;background:#fff;border-radius:18px;padding:14px;box-shadow:var(--shadow-soft);max-width:300px}.map-toolbar h3{margin:0 0 10px}.map-filters{display:flex;flex-wrap:wrap;gap:7px}.map-filters button{border:0;background:var(--paper);padding:7px 10px;border-radius:999px;font-weight:800;font-size:.75rem}.map-filters button.active{background:var(--navy);color:#fff}.map-canvas{position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,#fff 0 2px,transparent 3px),linear-gradient(130deg,#e6f4f2 0 42%,#9fd8e5 42% 62%,#f3dfbc 62%);background-size:60px 60px,100% 100%}.map-road{position:absolute;height:7px;background:rgba(255,255,255,.8);border-radius:999px;transform-origin:left center;box-shadow:0 0 0 2px rgba(6,47,75,.04)}.map-pin{position:absolute;width:38px;height:38px;border-radius:50% 50% 50% 0;background:var(--coral);transform:rotate(-45deg);display:grid;place-items:center;box-shadow:0 8px 20px rgba(6,47,75,.25)}.map-pin span{transform:rotate(45deg);color:#fff;font-size:16px}.map-popup{position:absolute;background:#fff;padding:14px 16px;border-radius:15px;box-shadow:var(--shadow-soft);width:210px;display:none}.map-popup.show{display:block}
.traveler-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.traveler{background:#fff;border-radius:18px;padding:20px;text-align:center;border:1px solid rgba(6,47,75,.08);box-shadow:var(--shadow-soft)}.traveler .emoji{font-size:2rem}.traveler h3{font-size:1rem;margin:10px 0 4px;color:var(--navy)}.traveler p{font-size:.82rem;color:var(--muted);margin:0}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:250px 250px;gap:14px}.gallery button{border:0;padding:0;border-radius:22px;overflow:hidden;position:relative}.gallery button:first-child{grid-row:1/3}.gallery img{width:100%;height:100%;object-fit:cover;transition:.35s}.gallery button:hover img{transform:scale(1.04)}.gallery span{position:absolute;left:16px;bottom:14px;color:#fff;font-weight:900;text-shadow:0 2px 12px rgba(0,0,0,.55)}
.newsletter{border-radius:34px;padding:48px;background:linear-gradient(135deg,var(--navy),#0a6d83);color:#fff;display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center}.newsletter h2{font-size:2.7rem;line-height:1.05;margin:0 0 12px}.newsletter p{color:rgba(255,255,255,.75)}.newsletter-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}.newsletter-form input,.newsletter-form select{border:0;border-radius:14px;padding:14px 15px}.newsletter-form label{grid-column:1/-1;font-size:.82rem}.newsletter-form button{grid-column:1/-1;border:0;border-radius:14px;padding:14px;background:var(--sun);color:var(--navy);font-weight:900}
.site-footer{background:#041f32;color:#fff;padding:72px 0 28px}.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:40px}.footer-brand img{width:210px;filter:brightness(0) invert(1)}.footer-brand p{color:rgba(255,255,255,.65);max-width:390px}.footer-col h3{font-size:1rem}.footer-col a{display:block;color:rgba(255,255,255,.68);padding:5px 0}.footer-col a:hover{color:#fff}.footer-bottom{margin-top:45px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:20px;color:rgba(255,255,255,.55);font-size:.84rem}
.page-hero{padding:150px 0 80px;background:linear-gradient(135deg,var(--navy),#0b6f88);color:#fff}.page-hero .breadcrumb{display:flex;gap:8px;font-size:.82rem;color:rgba(255,255,255,.7)}.page-hero h1{font-size:clamp(3rem,7vw,6rem);line-height:.95;letter-spacing:-.05em;margin:22px 0 18px}.page-hero p{max-width:760px;color:rgba(255,255,255,.78);font-size:1.14rem}
.content-panel{background:#fff;border-radius:26px;padding:34px;box-shadow:var(--shadow-soft);border:1px solid rgba(6,47,75,.07)}
.two-col{display:grid;grid-template-columns:280px 1fr;gap:28px}.side-nav{position:sticky;top:105px;align-self:start;background:#fff;padding:18px;border-radius:20px;box-shadow:var(--shadow-soft)}.side-nav a{display:block;padding:10px 12px;border-radius:12px;font-weight:800;color:var(--navy)}.side-nav a:hover{background:var(--aqua-soft)}
.detail-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.detail-item{padding:18px;border-radius:16px;background:var(--paper)}.detail-item b{display:block;color:var(--navy)}.detail-item span{color:var(--muted);font-size:.9rem}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.field{display:grid;gap:7px}.field.full{grid-column:1/-1}.field label{font-weight:800;color:var(--navy)}.field input,.field select,.field textarea{border:1px solid rgba(6,47,75,.14);border-radius:14px;padding:13px 14px;background:#fff}.field textarea{min-height:140px;resize:vertical}
.search-modal,.planner-drawer,.gallery-modal{position:fixed;z-index:2000;inset:0;display:none}.search-modal.open,.gallery-modal.open{display:grid;place-items:center;background:rgba(2,18,30,.72);backdrop-filter:blur(9px)}.modal-card{background:#fff;border-radius:28px;width:min(840px,calc(100% - 32px));max-height:85vh;overflow:auto;padding:28px;box-shadow:var(--shadow)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:20px}.modal-head h2{margin:0;color:var(--navy)}.close-btn{border:0;background:var(--paper);width:42px;height:42px;border-radius:50%;font-size:1.3rem}.global-search-input{width:100%;border:1px solid rgba(6,47,75,.15);border-radius:16px;padding:15px;margin:18px 0}.search-results{display:grid;gap:10px}.search-result{padding:15px;border-radius:15px;background:var(--paper)}.search-result b{display:block;color:var(--navy)}.search-result small{color:var(--muted)}
.planner-drawer{display:block;pointer-events:none}.planner-drawer::before{content:"";position:absolute;inset:0;background:rgba(2,18,30,.52);opacity:0;transition:.25s}.planner-panel{position:absolute;right:0;top:0;height:100%;width:min(430px,100%);background:#fff;transform:translateX(100%);transition:.3s;padding:26px;overflow:auto;box-shadow:-20px 0 55px rgba(6,47,75,.18)}.planner-drawer.open{pointer-events:auto}.planner-drawer.open::before{opacity:1}.planner-drawer.open .planner-panel{transform:none}.planner-list{display:grid;gap:10px;margin:20px 0}.planner-item{padding:14px;border-radius:14px;background:var(--paper);display:flex;justify-content:space-between;gap:12px}.planner-item button{border:0;background:transparent;color:#a02727;font-weight:900}.planner-empty{color:var(--muted);text-align:center;padding:30px}.planner-actions{display:grid;gap:10px}.planner-actions button{border:0;border-radius:14px;padding:13px;font-weight:900}.planner-actions .save{background:var(--navy);color:#fff}.planner-actions .clear{background:#ffe4e0;color:#852f24}
.toast{position:fixed;left:50%;bottom:26px;z-index:4000;transform:translate(-50%,30px);opacity:0;background:#082d47;color:#fff;border-radius:999px;padding:12px 18px;font-weight:800;box-shadow:var(--shadow);transition:.25s;pointer-events:none}.toast.show{transform:translate(-50%,0);opacity:1}
.accessibility-panel{position:fixed;right:18px;bottom:18px;z-index:1500;display:flex;flex-direction:column;gap:8px}.accessibility-panel button{width:46px;height:46px;border:0;border-radius:50%;background:#fff;color:var(--navy);box-shadow:var(--shadow-soft);font-weight:900}
.gallery-modal img{max-width:min(1100px,92vw);max-height:82vh;border-radius:20px;box-shadow:var(--shadow)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}.reveal.visible{opacity:1;transform:none}
.hidden{display:none!important}
:focus-visible{outline:3px solid var(--sun);outline-offset:3px}

.mt-20{margin-top:20px}.map-shell.tall{min-height:680px}
.map-road.road-a{left:8%;top:35%;width:72%;transform:rotate(8deg)}
.map-road.road-b{left:25%;top:14%;width:55%;transform:rotate(72deg)}
.map-road.road-c{left:6%;top:30%;width:78%;transform:rotate(10deg)}
.map-road.road-d{left:20%;top:12%;width:70%;transform:rotate(67deg)}
.map-pin.pin-poniente{left:24%;top:53%}.map-pin.pin-casco{left:54%;top:46%}.map-pin.pin-serra{left:72%;top:28%}.map-pin.pin-gastro{left:64%;top:64%}
.map-pin.pin-map-poniente{left:18%;top:57%}.map-pin.pin-map-casco{left:48%;top:48%}.map-pin.pin-map-serra{left:76%;top:22%}.map-pin.pin-map-gastro{left:61%;top:65%}

/* Vídeo hero fijo/parallax de la portada */
.home-page{background:#05324e}
.home-main{position:relative;z-index:1}
.video-hero{min-height:100svh;isolation:isolate;background:#05324e}
.video-hero .hero-media{
  position:fixed;
  top:var(--header);
  right:0;
  bottom:auto;
  left:0;
  height:calc(100svh - var(--header));
  z-index:-2;
  overflow:hidden;
  background:#05324e url('../img/fotos-reales/playa-levante.jpg') center/cover no-repeat;
}
.hero-video{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transform:scale(1.015)}
.hero-video-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,32,52,.90) 0%,rgba(4,32,52,.62) 48%,rgba(4,32,52,.26) 100%),linear-gradient(0deg,rgba(4,32,52,.28),transparent 45%)}
.video-hero .hero-media::after{display:none}
.home-main>section:not(.hero){position:relative;z-index:4}
.stats-section{background:linear-gradient(to bottom,transparent 0 50px,var(--paper) 50px 100%);padding-bottom:1px}
.hero-video-toggle{position:absolute;right:24px;bottom:24px;z-index:5;width:48px;height:48px;border:1px solid rgba(255,255,255,.35);border-radius:50%;background:rgba(3,31,49,.62);backdrop-filter:blur(12px);color:#fff;font-weight:900;box-shadow:0 8px 24px rgba(0,0,0,.22)}
.hero-video-toggle:hover,.hero-video-toggle:focus-visible{background:rgba(255,183,3,.95);color:var(--navy)}
body.reduced-motion .hero-video{display:none}
body.reduced-motion .video-hero .hero-media{background-image:url('../img/fotos-reales/playa-levante.jpg')}


/* Fotografías reales y créditos multimedia */
.media-card .media img,.feature-band .visual img,.gallery img{object-fit:cover;width:100%;height:100%}
.credit-note{font-size:.76rem;color:var(--muted);margin-top:8px}
.credits-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;margin:28px 0 40px}
.credit-card{overflow:hidden;border:1px solid rgba(2,48,71,.13);border-radius:20px;background:#fff;box-shadow:0 14px 35px rgba(2,48,71,.08)}
.credit-card img{width:100%;height:190px;object-fit:cover;display:block}
.credit-card-body{padding:18px}.credit-card-body h3{margin:0 0 10px}.credit-card-body p{margin:6px 0}.credit-card-body a{font-weight:800;color:var(--blue)}
@media(max-width:980px){.credits-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:620px){.credits-grid{grid-template-columns:1fr}.credit-card img{height:220px}}
