/* Fotomaton Navarra — Premium 2026 */
:root {
  --fn-bg: #0a0e17;
  --fn-bg-soft: #111827;
  --fn-card: #151d2e;
  --fn-gold: #c9a962;
  --fn-gold-light: #e8d5a3;
  --fn-white: #f8f6f1;
  --fn-muted: #94a3b8;
  --fn-wa: #25d366;
  --fn-radius: 16px;
  --fn-font: 'DM Sans', system-ui, sans-serif;
  --fn-display: 'Playfair Display', Georgia, serif;
  --fn-shadow: 0 24px 64px rgba(0,0,0,.45);
  --fn-header: 76px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--fn-font);
  background: var(--fn-bg);
  color: var(--fn-white);
  line-height: 1.65;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--fn-gold-light); text-decoration: none; transition: color .2s; }
a:hover { color: var(--fn-gold); }
.fn-container { width: min(1180px, 92vw); margin: 0 auto; }

/* Header */
.fn-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: var(--fn-header);
  background: rgba(10,14,23,.85);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(201,169,98,.12);
}
.fn-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: var(--fn-header);
}
.fn-logo {
  font-family: var(--fn-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--fn-white) !important;
  letter-spacing: .02em;
}
.fn-logo span { color: var(--fn-gold); }
.fn-nav { display: flex; align-items: center; gap: 1.75rem; list-style: none; margin: 0; padding: 0; }
.fn-nav a { color: var(--fn-white); font-size: .9rem; font-weight: 500; opacity: .9; }
.fn-nav a:hover { opacity: 1; color: var(--fn-gold); }
.fn-nav a.fn-active { color: var(--fn-gold); opacity: 1; }
.fn-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .75rem 1.5rem; border-radius: 999px; font-weight: 600; font-size: .9rem;
  border: none; cursor: pointer; transition: transform .2s, box-shadow .2s;
}
.fn-btn--gold {
  background: linear-gradient(135deg, var(--fn-gold), #a88b4a);
  color: #0a0e17 !important;
  box-shadow: 0 8px 24px rgba(201,169,98,.35);
}
.fn-btn--gold:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(201,169,98,.45); }
.fn-btn--outline {
  background: transparent; border: 1.5px solid rgba(255,255,255,.35);
  color: var(--fn-white) !important;
}
.fn-btn--outline:hover { border-color: var(--fn-gold); color: var(--fn-gold) !important; }
.fn-menu-toggle { display: none; background: none; border: none; color: #fff; font-size: 1.5rem; cursor: pointer; }

/* Hero */
.fn-hero {
  position: relative; min-height: 100vh; min-height: 100dvh;
  display: flex; align-items: flex-end; padding-bottom: 5rem;
  margin-top: 0;
}
.fn-hero__bg {
  position: absolute; inset: 0; z-index: 0;
}
.fn-hero__bg img {
  width: 100%; height: 100%; object-fit: cover;
}
.fn-hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(10,14,23,.55) 0%, rgba(10,14,23,.75) 45%, rgba(10,14,23,.95) 100%);
}
.fn-hero__overlay--light {
  background: linear-gradient(180deg, transparent 40%, rgba(10,14,23,.55) 75%, rgba(10,14,23,.85) 100%);
}
.fn-hero-slide .fn-hero__bg img { filter: none; }
.fn-hero__content { position: relative; z-index: 2; padding-top: calc(var(--fn-header) + 3rem); }
.fn-hero__tag {
  display: inline-block; padding: .4rem 1rem; border-radius: 999px;
  background: rgba(201,169,98,.15); border: 1px solid rgba(201,169,98,.35);
  color: var(--fn-gold-light); font-size: .8rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .12em; margin-bottom: 1.25rem;
}
.fn-hero h1 {
  font-family: var(--fn-display);
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  line-height: 1.1; margin: 0 0 1.25rem; font-weight: 700;
  max-width: 14ch;
}
.fn-hero h1 em { font-style: italic; color: var(--fn-gold); }
.fn-hero__lead {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: var(--fn-muted); max-width: 540px; margin-bottom: 2rem;
}
.fn-hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 2.5rem; }
.fn-hero__stats {
  display: flex; flex-wrap: wrap; gap: 2rem;
  padding-top: 2rem; border-top: 1px solid rgba(255,255,255,.1);
}
.fn-hero__stat strong {
  display: block; font-family: var(--fn-display);
  font-size: 1.75rem; color: var(--fn-gold);
}
.fn-hero__stat span { font-size: .85rem; color: var(--fn-muted); }

/* Showcase hero — split layout, fotos limpias */
.fn-showcase {
  padding-top: var(--fn-header);
  background: linear-gradient(135deg, var(--fn-bg) 0%, var(--fn-bg-soft) 100%);
  border-bottom: 1px solid rgba(201,169,98,.1);
}
.fn-showcase__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: 2.5rem;
  align-items: center;
  min-height: calc(88vh - var(--fn-header));
  padding: 2rem 0 2.5rem;
}
.fn-showcase__copy { position: relative; padding: 1rem 0; }
.fn-showcase__copy-slide { display: none; }
.fn-showcase__copy-slide.is-active { display: block; animation: fn-fadeIn .45s ease; }
.fn-showcase__copy h1 {
  font-family: var(--fn-display);
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  line-height: 1.12; margin: 0 0 1rem; max-width: 16ch;
}
.fn-showcase__copy h1 em { font-style: italic; color: var(--fn-gold); }
.fn-showcase__tabs {
  display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 2rem;
}
.fn-showcase__tab {
  padding: .55rem 1rem; border-radius: 999px; cursor: pointer;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.12);
  color: var(--fn-muted); font-size: .82rem; font-weight: 600; font-family: inherit;
  transition: .2s;
}
.fn-showcase__tab.is-active, .fn-showcase__tab:hover {
  background: rgba(201,169,98,.15); border-color: rgba(201,169,98,.45); color: var(--fn-gold-light);
}
.fn-showcase__media {
  position: relative; border-radius: var(--fn-radius); overflow: hidden;
  border: 1px solid rgba(201,169,98,.25);
  box-shadow: 0 32px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(201,169,98,.08);
  background: var(--fn-card);
}
.fn-showcase__media-slide { display: none; aspect-ratio: 4/5; max-height: min(78vh, 720px); }
.fn-showcase__media-slide.is-active { display: block; animation: fn-fadeIn .5s ease; }
.fn-showcase__media-slide img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(1.1) contrast(1.04) saturate(1.06);
}
.fn-showcase__arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25);
  background: rgba(10,14,23,.75); color: #fff; font-size: 1.5rem; cursor: pointer;
  backdrop-filter: blur(8px); transition: .2s; z-index: 2;
}
.fn-showcase__arrow:hover { background: var(--fn-gold); color: #0a0e17; border-color: var(--fn-gold); }
.fn-showcase__prev { left: 1rem; }
.fn-showcase__next { right: 1rem; }

/* Trust bar */
.fn-trust {
  background: var(--fn-bg-soft);
  border-top: 1px solid rgba(201,169,98,.1);
  border-bottom: 1px solid rgba(201,169,98,.1);
  padding: 1rem 0;
}
.fn-trust__inner {
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: 1.5rem 2.5rem; font-size: .88rem; color: var(--fn-muted);
}
.fn-trust__inner strong { color: var(--fn-gold); }
.fn-trust__inner a.fn-google-badge { text-decoration: none; }

.fn-google-badge {
  display: inline-flex; align-items: center; gap: .5rem; flex-wrap: wrap;
  padding: .45rem .85rem; border-radius: 999px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(201,169,98,.25);
  color: var(--fn-white); font-size: .88rem; transition: border-color .2s, background .2s;
}
.fn-google-badge:hover { border-color: var(--fn-gold); background: rgba(201,169,98,.1); color: var(--fn-white); }
.fn-google-badge__stars { color: var(--fn-gold); letter-spacing: .05em; }
.fn-google-badge strong { font-family: var(--fn-display); font-size: 1.1rem; color: var(--fn-gold-light); }
.fn-google-badge__count { color: var(--fn-muted); font-size: .82rem; }

.fn-google-section { background: linear-gradient(180deg, rgba(201,169,98,.05), transparent); }
.fn-google-section__grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 2rem; align-items: center;
}
.fn-google-section__note { font-size: .85rem; color: var(--fn-muted); margin: 1rem 0 0; }
.fn-google-card {
  text-align: center; padding: 2rem; border-radius: var(--fn-radius);
  background: var(--fn-card); border: 1px solid rgba(201,169,98,.2);
  box-shadow: var(--fn-shadow);
}
.fn-google-card__score {
  font-family: var(--fn-display); font-size: 3.5rem; color: var(--fn-gold); line-height: 1;
}
.fn-google-card__stars { color: var(--fn-gold); font-size: 1.25rem; margin: .5rem 0 1rem; }
.fn-google-card .fn-btn { margin: .35rem; }

.fn-team-visual { position: relative; }
.fn-team-visual > picture, .fn-team-visual > img { border-radius: var(--fn-radius); overflow: hidden; }
.fn-team-visual__stack {
  display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: .75rem;
}
.fn-team-visual__stack picture, .fn-team-visual__stack img {
  border-radius: 12px; width: 100%; height: 100%; object-fit: cover;
}

.fn-video-section { overflow: hidden; }
.fn-split--video { align-items: center; }
.fn-video-wrap {
  position: relative; border-radius: var(--fn-radius); overflow: hidden;
  border: 1px solid rgba(201,169,98,.25); aspect-ratio: 16/10;
  background: #000; box-shadow: var(--fn-shadow);
}
.fn-video { width: 100%; height: 100%; object-fit: cover; display: block; }
.fn-video-wrap.is-playing .fn-video__play { opacity: 0; pointer-events: none; }
.fn-video__play {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .5rem;
  background: rgba(10,14,23,.45); border: none; cursor: pointer;
  color: var(--fn-white); font-weight: 600; font-size: .9rem;
  transition: opacity .3s, background .2s;
}
.fn-video__play:hover { background: rgba(10,14,23,.6); }
.fn-video__play-icon {
  width: 4rem; height: 4rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: rgba(201,169,98,.9); color: #0a0e17; font-size: 1.25rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
}

picture { display: block; }
picture img { width: 100%; height: auto; }

/* Logos */
.fn-logos { padding: 2rem 0; background: var(--fn-bg); border-bottom: 1px solid rgba(255,255,255,.04); }
.fn-logos__inner {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 2rem 2.5rem; opacity: .55; filter: grayscale(1) brightness(1.4);
}
.fn-logos__inner img { height: 36px; width: auto; max-width: 110px; object-fit: contain; }

/* Steps */
.fn-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 2rem; }
.fn-step {
  padding: 1.25rem; border-radius: 12px; background: var(--fn-card);
  border: 1px solid rgba(201,169,98,.15);
}
.fn-step strong {
  display: block; font-family: var(--fn-display); font-size: 1.5rem;
  color: var(--fn-gold); margin-bottom: .35rem;
}
.fn-step span { font-size: .88rem; color: var(--fn-muted); }

/* Section */
.fn-section { padding: 5rem 0; }
.fn-section--dark { background: var(--fn-bg-soft); }
.fn-section__head { text-align: center; max-width: 640px; margin: 0 auto 3rem; }
.fn-section__head h2 {
  font-family: var(--fn-display);
  font-size: clamp(1.85rem, 4vw, 2.75rem);
  margin: 0 0 1rem; line-height: 1.2;
}
.fn-section__head p { color: var(--fn-muted); margin: 0; font-size: 1.05rem; }
.fn-label {
  display: block; font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .15em;
  color: var(--fn-gold); margin-bottom: .75rem;
}

/* Service cards */
.fn-services {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}
.fn-service {
  position: relative; border-radius: var(--fn-radius); overflow: hidden;
  background: var(--fn-card); border: 1px solid rgba(255,255,255,.06);
  transition: transform .35s, box-shadow .35s;
}
.fn-service:hover {
  transform: translateY(-6px);
  box-shadow: var(--fn-shadow);
  border-color: rgba(201,169,98,.25);
}
.fn-service__img { aspect-ratio: 4/3; overflow: hidden; position: relative; }
.fn-service__img picture { display: block; width: 100%; height: 100%; }
.fn-service__img img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform .5s;
  filter: brightness(1.14) contrast(1.06) saturate(1.08); }
.fn-service:hover .fn-service__img img { transform: scale(1.06); }
.fn-service__body { padding: 1.5rem; }
.fn-service__body h3 {
  font-family: var(--fn-display); font-size: 1.35rem; margin: 0 0 .5rem;
}
.fn-service__body p { color: var(--fn-muted); font-size: .92rem; margin: 0 0 1rem; }
.fn-service__link { font-weight: 600; font-size: .88rem; color: var(--fn-gold) !important; }
.fn-service--click { cursor: pointer; text-align: left; width: 100%; border: none; background: none; font: inherit; color: inherit; }
.fn-service--click:focus-visible { outline: 2px solid var(--fn-gold); outline-offset: 3px; }
article.fn-service { display: block; text-decoration: none; color: inherit; }
.fn-service__badge {
  position: absolute; top: .85rem; left: .85rem; z-index: 1;
  padding: .35rem .75rem; border-radius: 999px; font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  background: rgba(10,14,23,.85); border: 1px solid rgba(201,169,98,.35); color: var(--fn-gold-light);
}
.fn-services--blog { grid-template-columns: repeat(3, 1fr); }

/* Gallery */
.fn-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
}
.fn-gallery__item {
  border: none; padding: 0; border-radius: 12px; overflow: hidden;
  position: relative; cursor: pointer; aspect-ratio: 4/3; background: var(--fn-card);
  display: block; width: 100%;
}
.fn-gallery__item picture { display: block; width: 100%; height: 100%; }
.fn-gallery__item img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; filter: brightness(1.08); transition: transform .4s; }
.fn-gallery__item:hover img { transform: scale(1.04); }

/* Lightbox */
.fn-lightbox {
  position: fixed; inset: 0; z-index: 10001;
  display: flex; align-items: center; justify-content: center;
  padding: clamp(1rem, 3vw, 2.5rem);
  opacity: 0; visibility: hidden; transition: opacity .25s, visibility .25s;
}
.fn-lightbox.is-open { opacity: 1; visibility: visible; }
.fn-lightbox__overlay {
  position: absolute; inset: 0; z-index: 0;
  background: rgba(0,0,0,.94); cursor: zoom-out;
}
.fn-lightbox__frame {
  position: relative; z-index: 1;
  width: min(1400px, 94vw);
  height: min(88vh, calc(100vh - 4rem));
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.fn-lightbox__img {
  display: block;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 40px 100px rgba(0,0,0,.65);
  pointer-events: auto;
  cursor: zoom-out;
}
.fn-lightbox__close {
  position: fixed; top: 1.25rem; right: 1.25rem; z-index: 10002;
  width: 48px; height: 48px; border-radius: 50%; border: none;
  background: var(--fn-card); color: #fff; font-size: 1.6rem; cursor: pointer;
}
.fn-zoomable,
.fn-showcase__media-slide img,
.fn-modal__body img,
.fn-map-detail__hero img { cursor: zoom-in; }

/* Cities */
.fn-cities { display: flex; flex-wrap: wrap; gap: .65rem; justify-content: center; }
.fn-city {
  padding: .55rem 1.15rem; border-radius: 999px;
  background: rgba(201,169,98,.1); border: 1px solid rgba(201,169,98,.25);
  color: var(--fn-white) !important; font-size: .88rem; font-weight: 500;
}
.fn-city:hover { background: var(--fn-gold); color: #0a0e17 !important; }

/* Reviews */
.fn-reviews { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; }
.fn-review {
  background: var(--fn-card); border-radius: var(--fn-radius);
  padding: 1.75rem; border: 1px solid rgba(255,255,255,.06);
}
.fn-review__stars { color: var(--fn-gold); margin-bottom: .75rem; letter-spacing: .1em; }
.fn-review blockquote { margin: 0 0 1rem; font-style: italic; color: var(--fn-muted); }
.fn-review footer { font-size: .85rem; }
.fn-review footer strong { color: var(--fn-white); }

/* FAQ */
.fn-faq details {
  background: var(--fn-card); border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px; margin-bottom: .75rem; padding: 1rem 1.25rem;
}
.fn-faq summary { font-weight: 600; cursor: pointer; list-style: none; }
.fn-faq summary::-webkit-details-marker { display: none; }
.fn-faq p { color: var(--fn-muted); margin: .75rem 0 0; font-size: .95rem; }

/* CTA band */
.fn-cta {
  text-align: center; padding: 4rem 2rem;
  background: linear-gradient(135deg, rgba(201,169,98,.15), rgba(201,169,98,.05));
  border: 1px solid rgba(201,169,98,.2); border-radius: var(--fn-radius);
}
.fn-cta h2 { font-family: var(--fn-display); font-size: 2rem; margin: 0 0 .75rem; }

/* Form */
.fn-form { max-width: 640px; margin: 0 auto; }
.fn-form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.fn-form label { display: block; font-size: .82rem; font-weight: 600; margin-bottom: .35rem; color: var(--fn-muted); }
.fn-form input, .fn-form select, .fn-form textarea {
  width: 100%; padding: .85rem 1rem; border-radius: 10px;
  border: 1px solid rgba(255,255,255,.12); background: var(--fn-card);
  color: var(--fn-white); font-family: inherit; font-size: 1rem;
}
.fn-form input:focus, .fn-form select:focus, .fn-form textarea:focus {
  outline: none; border-color: var(--fn-gold);
}
.fn-form__full { grid-column: 1 / -1; }
.fn-form textarea { min-height: 120px; resize: vertical; }

/* Footer */
.fn-footer {
  background: #060810; padding: 3rem 0 1.5rem;
  border-top: 1px solid rgba(201,169,98,.1);
}
.fn-footer__grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2rem; margin-bottom: 2rem;
}
.fn-footer h4 { font-size: .85rem; text-transform: uppercase; letter-spacing: .1em; color: var(--fn-gold); margin: 0 0 1rem; }
.fn-footer ul { list-style: none; padding: 0; margin: 0; }
.fn-footer li { margin-bottom: .5rem; }
.fn-footer a { color: var(--fn-muted); font-size: .9rem; }
.fn-footer a:hover { color: var(--fn-gold); }
.fn-footer__bottom {
  text-align: center; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.06);
  font-size: .85rem; color: var(--fn-muted);
}

/* WhatsApp float */
.fn-wa {
  position: fixed; right: 22px; bottom: 130px; z-index: 9999;
  display: inline-flex; align-items: center; gap: .75rem;
  padding: 1.15rem 1.6rem; border-radius: 999px;
  background: linear-gradient(135deg, #25d366, #1ebe57);
  color: #fff !important;
  font-weight: 700; font-size: 1.12rem;
  box-shadow: 0 16px 48px rgba(37,211,102,.55);
  transition: transform .2s, box-shadow .2s;
  border: 2px solid rgba(255,255,255,.25);
}
.fn-wa:hover { transform: scale(1.06); box-shadow: 0 20px 56px rgba(37,211,102,.65); color: #fff !important; }
.fn-wa__icon { display:flex; line-height: 1; }
.fn-wa__pulse {
  position: absolute; inset: -4px; border-radius: 999px;
  border: 2px solid rgba(37,211,102,.6);
  animation: fn-pulse 2s infinite;
}
@keyframes fn-pulse {
  0% { transform: scale(1); opacity: 1; }
  100% { transform: scale(1.35); opacity: 0; }
}

/* Hero slider */
.fn-hero-slider { position: relative; min-height: 88vh; min-height: 88dvh; overflow: hidden; }
.fn-hero-slide {
  position: absolute; inset: 0; opacity: 0; visibility: hidden;
  transition: opacity .8s ease, visibility .8s;
  display: flex; align-items: flex-end; padding-bottom: 2rem;
}
.fn-hero-slide.is-active { opacity: 1; visibility: visible; z-index: 1; }
.fn-hero-bar {
  background: var(--fn-bg-soft);
  border-bottom: 1px solid rgba(201,169,98,.12);
  padding: 1.5rem 0;
}
.fn-hero-bar__inner {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1.5rem;
}
.fn-hero-bar .fn-hero__stats {
  border: none; padding: 0; margin: 0; gap: 2.5rem;
}
.fn-hero__content { padding-bottom: 1rem; }
.fn-hero__lead { text-shadow: 0 2px 12px rgba(0,0,0,.5); }
.fn-hero h1 { text-shadow: 0 2px 16px rgba(0,0,0,.6); max-width: 18ch; }
.fn-hero-nav {
  position: absolute; bottom: 2.5rem; right: 4vw; z-index: 5;
  display: flex; gap: .5rem; align-items: center;
}
.fn-hero-dot {
  width: 10px; height: 10px; border-radius: 50%; border: none; padding: 0;
  background: rgba(255,255,255,.35); cursor: pointer; transition: .2s;
}
.fn-hero-dot.is-active { background: var(--fn-gold); transform: scale(1.25); }
.fn-hero-arrow {
  width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(255,255,255,.3);
  background: rgba(10,14,23,.5); color: #fff; cursor: pointer; font-size: 1.2rem;
  backdrop-filter: blur(8px);
}
.fn-hero-arrow:hover { border-color: var(--fn-gold); color: var(--fn-gold); }

/* Reviews carousel */
.fn-reviews-carousel { overflow: hidden; position: relative; }
.fn-reviews-carousel--triple .fn-reviews-track { display: flex; transition: transform .7s ease; }
.fn-reviews-page {
  flex: 0 0 100%; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem;
}
.fn-reviews-page .fn-review { margin: 0; }
@media (max-width: 900px) {
  .fn-reviews-page { grid-template-columns: 1fr; }
}

/* Blog 3-col */
.fn-blog-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.75rem;
}
.fn-post {
  background: var(--fn-card); border-radius: var(--fn-radius);
  overflow: hidden; border: 1px solid rgba(255,255,255,.06);
  transition: transform .3s, box-shadow .3s; cursor: pointer;
}
.fn-post:hover { transform: translateY(-6px); box-shadow: var(--fn-shadow); border-color: rgba(201,169,98,.25); }
.fn-post__img { aspect-ratio: 16/10; overflow: hidden; position: relative; }
.fn-post__img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(1.1); transition: transform .5s; }
.fn-post:hover .fn-post__img img { transform: scale(1.05); }
.fn-post__date {
  position: absolute; top: 1rem; left: 1rem;
  background: var(--fn-gold); color: #0a0e17; font-weight: 700;
  padding: .35rem .75rem; border-radius: 8px; font-size: .75rem;
}
.fn-post__body { padding: 1.35rem; }
.fn-post__cat { font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: var(--fn-gold); }
.fn-post__title { font-family: var(--fn-display); font-size: 1.15rem; margin: .5rem 0; line-height: 1.35; color: var(--fn-white); }
.fn-post__excerpt { color: var(--fn-muted); font-size: .9rem; margin: 0 0 1rem; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.fn-post__more { font-weight: 600; font-size: .85rem; color: var(--fn-gold) !important; }

/* Modal */
.fn-modal {
  position: fixed; inset: 0; z-index: 10000; display: flex; align-items: center; justify-content: center;
  padding: 1rem; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .3s, visibility .3s;
}
.fn-modal.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
body.fn-modal-open { overflow: hidden; }
.fn-modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.75); backdrop-filter: blur(6px); }
.fn-modal__box {
  position: relative; width: min(820px, 96vw); max-height: 90vh; overflow-y: auto;
  background: var(--fn-bg-soft); border-radius: var(--fn-radius);
  border: 1px solid rgba(201,169,98,.2); padding: 2rem;
  box-shadow: var(--fn-shadow);
}
.fn-modal__close {
  position: sticky; top: 0; float: right;
  width: 40px; height: 40px; border-radius: 50%; border: none;
  background: var(--fn-card); color: #fff; font-size: 1.4rem; cursor: pointer; z-index: 2;
}
.fn-modal__title { font-family: var(--fn-display); font-size: 1.75rem; margin: 0 0 1.5rem; clear: both; }
.fn-modal__body { color: var(--fn-muted); line-height: 1.7; }
.fn-modal__body h2 { font-family: var(--fn-display); color: var(--fn-white); font-size: 1.25rem; margin: 1.5rem 0 .75rem; }
.fn-modal__loading { text-align: center; padding: 3rem; color: var(--fn-muted); }
.fn-modal--reader .fn-modal__box--wide { max-width: 820px; padding: 0; overflow: hidden; }
.fn-modal__hero {
  height: 220px; background: var(--fn-card) center/cover no-repeat;
  border-bottom: 1px solid rgba(201,169,98,.2);
}
.fn-modal--reader .fn-modal__close {
  position: absolute; top: 1rem; right: 1rem; z-index: 3;
  width: 44px; height: 44px; padding: 0; border-radius: 50%;
  background: rgba(10,14,23,.92); border: 1px solid rgba(201,169,98,.45);
  color: var(--fn-gold); font-size: 1.65rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(0,0,0,.45);
  transition: transform .2s, background .2s;
}
.fn-modal--reader .fn-modal__close:hover {
  transform: scale(1.06); background: rgba(10,14,23,.98); color: var(--fn-white);
}
.fn-modal--reader .fn-modal__body { padding: 2rem; max-height: 55vh; overflow-y: auto; }
.fn-modal__error { text-align: center; padding: 2rem; color: var(--fn-muted); }
.fn-modal__body .ftn-article-faq details { margin-bottom: .65rem; border-bottom: 1px solid rgba(255,255,255,.08); padding-bottom: .65rem; }
.fn-modal__body .ftn-article-cta { margin-top: 1.5rem; padding: 1.25rem; border-radius: var(--fn-radius); background: rgba(201,169,98,.08); border: 1px solid rgba(201,169,98,.2); }
.fn-modal__body .ftn-article-cta .btn { display: inline-block; margin: .35rem .35rem 0 0; }
.fn-modal__foot { padding: 1.25rem 2rem 2rem; text-align: center; border-top: 1px solid rgba(255,255,255,.06); }
.fn-modal__title { font-family: var(--fn-display); font-size: 1.75rem; margin: 0 0 1.5rem; clear: both; color: var(--fn-white); }

/* Map premium stage */
.fn-map-stage {
  display: grid; grid-template-columns: 1.25fr 1fr; gap: 1.5rem;
  margin-top: 2rem; align-items: stretch;
}
.fn-map-stage__map, .fn-map-stage__panel { min-height: 520px; }
.fn-map--premium {
  position: relative; height: 100%; min-height: 520px;
  border-radius: var(--fn-radius); overflow: hidden;
  background: radial-gradient(ellipse at 50% 40%, rgba(201,169,98,.12), transparent 60%),
    linear-gradient(160deg, #121a2a 0%, #0a0e17 100%);
  border: 1px solid rgba(201,169,98,.25);
  box-shadow: var(--fn-shadow), inset 0 0 80px rgba(201,169,98,.06);
}
.fn-map__glow {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(circle at 50% 45%, rgba(201,169,98,.08), transparent 55%);
}
.fn-map--premium svg {
  width: 100%; height: 100%; display: block; padding: 2rem;
  pointer-events: none; position: relative; z-index: 1;
}
.fn-map-shape { transition: fill .3s; }
.fn-map-legend {
  position: absolute; bottom: 1rem; left: 1rem; right: 1rem;
  display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center;
  font-size: .75rem; color: var(--fn-muted);
  pointer-events: none; z-index: 2;
}
.fn-map-legend__dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--fn-gold); margin-right: .35rem; vertical-align: middle;
}
.fn-map-legend__dot--mid { background: #7eb8da; }
.fn-map-legend__dot--south { background: #c97a62; }
.fn-map-pin--pulse .fn-map-pin__dot {
  width: 14px; height: 14px; border-radius: 50%; background: var(--fn-gold);
  box-shadow: 0 0 0 0 rgba(201,169,98,.6); animation: fn-pinPulse 2s infinite;
}
@keyframes fn-pinPulse {
  0% { box-shadow: 0 0 0 0 rgba(201,169,98,.55); }
  70% { box-shadow: 0 0 0 12px rgba(201,169,98,0); }
  100% { box-shadow: 0 0 0 0 rgba(201,169,98,0); }
}
.fn-map-pin__label {
  display: block; font-size: .72rem; font-weight: 700; margin-top: 2px;
  white-space: nowrap; text-shadow: 0 1px 4px rgba(0,0,0,.8);
}
.fn-map-stage__panel {
  background: var(--fn-card); border-radius: var(--fn-radius);
  border: 1px solid rgba(201,169,98,.2); overflow: hidden;
  box-shadow: var(--fn-shadow);
}
.fn-map-detail { height: 100%; display: flex; flex-direction: column; position: relative; }
.fn-map-detail__placeholder {
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  text-align: center; padding: 2.5rem; height: 100%; color: var(--fn-muted);
  position: absolute; inset: 0; z-index: 0;
}
.fn-map-detail__icon { font-size: 3rem; margin-bottom: 1rem; }
.fn-map-detail__placeholder h3 { font-family: var(--fn-display); color: var(--fn-white); margin: 0 0 .75rem; }
.fn-map-stats {
  display: flex; gap: 2rem; margin-top: 2rem;
}
.fn-map-stats div strong {
  display: block; font-family: var(--fn-display); font-size: 1.5rem; color: var(--fn-gold);
}
.fn-map-stats div span { font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; }
.fn-map-panel {
  display: none; padding: 1.75rem; flex: 1; overflow-y: auto;
  animation: fn-fadeIn .4s ease; position: relative; z-index: 1;
}
.fn-map-panel.is-open { display: flex; flex-direction: column; }
.fn-map-detail__hero {
  margin: -1.75rem -1.75rem 1.25rem; aspect-ratio: 16/9; overflow: hidden;
}
.fn-map-detail__hero img { width: 100%; height: 100%; object-fit: cover; filter: brightness(1.1); }
.fn-map-detail__title { font-family: var(--fn-display); margin: 0 0 .75rem; font-size: 1.5rem; }
.fn-map-detail__text { color: var(--fn-muted); margin: 0 0 1rem; line-height: 1.65; }
.fn-map-detail__services { color: var(--fn-muted); padding-left: 1.1rem; margin: 0 0 1.5rem; }
.fn-map--detail .fn-map-pin:not(.is-active) { opacity: .4; }
.fn-map-pin.is-discovered .fn-map-pin__dot { background: #7eb8da; box-shadow: 0 0 12px rgba(126,184,218,.5); }

/* Navarra quest game */
.fn-quest-hud {
  display: grid; grid-template-columns: 1fr auto; gap: 1.5rem; align-items: center;
  margin-bottom: 1.5rem; padding: 1.25rem 1.5rem;
  background: rgba(201,169,98,.06); border: 1px solid rgba(201,169,98,.2);
  border-radius: var(--fn-radius);
}
.fn-quest-progress__label {
  font-size: .9rem; font-weight: 600; color: var(--fn-white); margin-bottom: .5rem;
}
.fn-quest-progress__label span { color: var(--fn-gold); font-family: var(--fn-display); font-size: 1.25rem; }
.fn-quest-progress {
  height: 8px; background: rgba(255,255,255,.08); border-radius: 999px; overflow: hidden;
}
.fn-quest-progress__fill {
  height: 100%; width: 0; background: linear-gradient(90deg, var(--fn-gold), #e8d5a8);
  border-radius: 999px; transition: width .5s cubic-bezier(.4,0,.2,1);
}
.fn-quest-progress__msg { font-size: .82rem; color: var(--fn-muted); margin: .5rem 0 0; }
.fn-quest-badges {
  display: flex; flex-wrap: wrap; gap: .45rem; max-width: 220px; justify-content: flex-end;
}
.fn-quest-badge {
  width: 2.25rem; height: 2.25rem; display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; border-radius: 50%; background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1); opacity: .25; filter: grayscale(1);
  transition: opacity .3s, transform .3s, filter .3s;
  cursor: pointer;
}
.fn-quest-badge.is-unlocked {
  opacity: 1; filter: none; transform: scale(1.05);
  border-color: rgba(201,169,98,.45); box-shadow: 0 0 12px rgba(201,169,98,.25);
}
.fn-quest-unlock {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .78rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em;
  color: var(--fn-gold); margin-bottom: .75rem;
}
.fn-quest-unlock__badge { font-size: 1.25rem; }
.fn-quest-cards {
  display: grid; gap: .75rem; margin: 0 0 1.25rem;
}
.fn-quest-card {
  padding: 1rem 1.1rem; border-radius: 12px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  animation: fn-questIn .45s ease backwards;
}
.fn-quest-card:nth-child(1) { animation-delay: .05s; }
.fn-quest-card:nth-child(2) { animation-delay: .12s; }
.fn-quest-card:nth-child(3) { animation-delay: .19s; }
@keyframes fn-questIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.fn-quest-card__icon { font-size: 1.1rem; margin-right: .35rem; }
.fn-quest-card h4 {
  display: inline; font-size: .85rem; font-weight: 700; color: var(--fn-white);
  margin: 0 0 .35rem;
}
.fn-quest-card p { font-size: .88rem; color: var(--fn-muted); margin: .35rem 0 0; line-height: 1.55; }
.fn-quest-card--tip { border-color: rgba(201,169,98,.25); background: rgba(201,169,98,.06); }
.fn-map-detail__sell { font-size: .9rem; color: var(--fn-white); margin: 0 0 1rem; line-height: 1.55; }

.fn-quest-section { background: linear-gradient(180deg, transparent, rgba(201,169,98,.04)); }
.fn-quest-deck {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem;
  perspective: 1200px;
}
.fn-flip-card {
  background: none; border: none; padding: 0; cursor: pointer; min-height: 180px;
  font-family: inherit; color: inherit;
}
.fn-flip-card__inner {
  position: relative; width: 100%; height: 100%; min-height: 180px;
  transition: transform .6s cubic-bezier(.4,0,.2,1); transform-style: preserve-3d;
}
.fn-flip-card.is-flipped .fn-flip-card__inner { transform: rotateY(180deg); }
.fn-flip-card__face {
  position: absolute; inset: 0; backface-visibility: hidden; border-radius: var(--fn-radius);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 1.25rem;
  border: 1px solid rgba(201,169,98,.25);
  background: var(--fn-card);
  box-shadow: var(--fn-shadow);
}
.fn-flip-card__front { gap: .5rem; }
.fn-flip-card__front strong { font-family: var(--fn-display); color: var(--fn-white); font-size: 1.05rem; }
.fn-flip-card__front small { color: var(--fn-muted); font-size: .85rem; }
.fn-flip-card__hint { font-size: .72rem; color: var(--fn-gold); opacity: .7; margin-top: .5rem; }
.fn-flip-card__back {
  transform: rotateY(180deg); background: linear-gradient(145deg, #1a2235, #121820);
}
.fn-flip-card__back p { font-size: .88rem; color: var(--fn-muted); line-height: 1.6; margin: 0; }
.fn-flip-card__back a { color: var(--fn-gold); }
.fn-flip-card__icon { font-size: 2rem; margin-bottom: .25rem; }
.fn-flip-card:focus-visible { outline: 2px solid var(--fn-gold); outline-offset: 4px; border-radius: var(--fn-radius); }

/* Contact split — mapa y formulario nivelados */
.fn-page-intro { max-width: 760px; margin: 0 auto 2.5rem; text-align: center; }
.fn-page-intro h2 { font-family: var(--fn-display); margin: 0 0 1rem; font-size: clamp(1.5rem, 3vw, 2rem); }
.fn-page-intro p { color: var(--fn-muted); margin: 0 0 1rem; line-height: 1.7; }
.fn-page-intro .fn-sell-list { display: inline-block; text-align: left; margin: 1rem auto 0; max-width: 420px; }
.fn-contact-split {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; align-items: stretch;
}
.fn-panel {
  height: 100%; display: flex; flex-direction: column;
  background: var(--fn-card); border-radius: var(--fn-radius);
  border: 1px solid rgba(201,169,98,.15); padding: 1.75rem;
  box-shadow: var(--fn-shadow);
}
.fn-panel__title { font-family: var(--fn-display); margin: 0 0 1rem; font-size: 1.2rem; }
.fn-panel__text { color: var(--fn-muted); font-size: .9rem; margin: 1rem 0; line-height: 1.6; flex: 1; }
.fn-panel--form { padding: 0; border: none; background: transparent; box-shadow: none; }
.fn-panel--form .fn-form-pro { height: 100%; margin: 0; display: flex; flex-direction: column; }
.fn-panel--map .fn-map-embed { flex: 1; min-height: 200px; aspect-ratio: auto; }
.fn-contact-channels { display: flex; flex-direction: column; gap: .65rem; margin-top: auto; }
.fn-channel {
  display: flex; gap: .85rem; align-items: center; padding: .85rem 1rem;
  border-radius: 12px; background: rgba(201,169,98,.08);
  border: 1px solid rgba(201,169,98,.2); color: inherit !important; transition: .2s;
}
.fn-channel:hover { background: rgba(201,169,98,.16); border-color: var(--fn-gold); }
.fn-channel span:first-child { font-size: 1.25rem; }
.fn-channel strong { display: block; color: var(--fn-white); font-size: .95rem; }
.fn-channel small { color: var(--fn-muted); font-size: .78rem; }

/* Map (legacy pins) */
.fn-map-wrap { position: relative; max-width: 900px; margin: 0 auto; }
.fn-map {
  position: relative; border-radius: var(--fn-radius); overflow: hidden;
  background: var(--fn-card); border: 1px solid rgba(201,169,98,.15);
  aspect-ratio: 4/3;
}
.fn-map svg { width: 100%; height: 100%; display: block; }
.fn-map-pin {
  position: absolute; transform: translate(-50%, -100%);
  background: var(--fn-gold); color: #0a0e17; border: none; cursor: pointer;
  padding: .4rem .85rem; border-radius: 999px; font-weight: 700; font-size: .78rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.4); transition: transform .2s, background .2s;
  white-space: nowrap;
}
.fn-map-pin::after {
  content: ''; position: absolute; left: 50%; bottom: -6px; transform: translateX(-50%);
  border: 6px solid transparent; border-top-color: var(--fn-gold);
}
.fn-map-pin:hover, .fn-map-pin.is-active { transform: translate(-50%, -100%) scale(1.08); background: var(--fn-gold-light); }
.fn-map--premium .fn-map-pin {
  background: transparent; color: var(--fn-white); padding: .35rem;
  display: flex; flex-direction: column; align-items: center;
  transform: translate(-50%, -50%); box-shadow: none;
  z-index: 10; pointer-events: auto; cursor: pointer;
  min-width: 44px; min-height: 44px; justify-content: center;
}
.fn-map--premium .fn-map-pin::after { display: none; }
.fn-map--premium .fn-map-pin.is-active .fn-map-pin__label { color: var(--fn-gold-light); }
.fn-map-wrap .fn-map-panel {
  display: none; margin-top: 1.5rem; padding: 2rem;
  background: var(--fn-card); border-radius: var(--fn-radius);
  border: 1px solid rgba(201,169,98,.2);
}
.fn-map-wrap .fn-map-panel.is-open { display: block; animation: fn-fadeIn .4s ease; }
.fn-map-back {
  display: inline-flex; align-items: center; gap: .5rem;
  background: none; border: 1px solid rgba(201,169,98,.35); color: var(--fn-gold);
  padding: .5rem 1rem; border-radius: 999px; cursor: pointer; margin-bottom: 1.5rem; font-weight: 600;
}
.fn-map--detail .fn-map-pin:not(.is-active) { opacity: .35; }
@keyframes fn-fadeIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* Casos */
.fn-casos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1.75rem; }
.fn-caso {
  border-radius: var(--fn-radius); overflow: hidden;
  background: var(--fn-card); border: 1px solid rgba(255,255,255,.06);
  transition: transform .35s, box-shadow .35s;
}
.fn-caso:hover { transform: translateY(-4px); box-shadow: var(--fn-shadow); }
.fn-caso__img { aspect-ratio: 16/10; overflow: hidden; }
.fn-caso__img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(1.12); }
.fn-caso__body { padding: 1.75rem; }
.fn-caso__tag { font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; color: var(--fn-gold); }
.fn-caso__stats { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1rem 0; }
.fn-caso__stat {
  padding: .35rem .75rem; border-radius: 999px; font-size: .78rem;
  background: rgba(201,169,98,.12); border: 1px solid rgba(201,169,98,.25);
}
.fn-caso__quote { font-style: italic; color: var(--fn-muted); border-left: 3px solid var(--fn-gold); padding-left: 1rem; margin-top: 1rem; }

/* Contact premium */
.fn-contact-hero { padding: calc(var(--fn-header) + 3rem) 0 2rem; text-align: center; }
.fn-contact-cards {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.25rem; margin-bottom: 3rem;
}
.fn-contact-card {
  padding: 1.75rem; border-radius: var(--fn-radius);
  background: var(--fn-card); border: 1px solid rgba(201,169,98,.15); text-align: center;
}
.fn-contact-card__icon { font-size: 2rem; margin-bottom: .75rem; }
.fn-contact-card h3 { font-family: var(--fn-display); margin: 0 0 .5rem; font-size: 1.1rem; }
.fn-contact-card p { color: var(--fn-muted); font-size: .9rem; margin: 0; }
.fn-contact-layout { display: grid; grid-template-columns: 1fr 1.1fr; gap: 2.5rem; align-items: start; }
.fn-map-embed { border-radius: var(--fn-radius); overflow: hidden; aspect-ratio: 16/10; border: 1px solid rgba(201,169,98,.15); }
.fn-map-embed iframe { width: 100%; height: 100%; border: 0; filter: grayscale(.3) contrast(1.1); }

/* Form premium */
/* Form premium */
.fn-form-pro {
  background: var(--fn-card); border-radius: var(--fn-radius);
  padding: 2rem; border: 1px solid rgba(201,169,98,.15);
  box-shadow: var(--fn-shadow);
}
.fn-form-pro__title { font-family: var(--fn-display); margin: 0 0 .35rem; font-size: 1.35rem; }
.fn-form-pro__sub { color: var(--fn-muted); font-size: .9rem; margin: 0 0 1.5rem; }
.fn-form-pro__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.fn-field--full { grid-column: 1 / -1; }
.fn-form-pro__submit { width: 100%; margin-top: .5rem; padding: 1rem; font-size: 1rem; }
.fn-captcha {
  margin: 1.25rem 0; padding: 1rem; border-radius: 10px;
  background: rgba(201,169,98,.08); border: 1px solid rgba(201,169,98,.2);
}
.fn-captcha label { display: block; margin-bottom: .5rem; font-size: .9rem; color: var(--fn-muted); }
.fn-captcha input[type="number"] {
  width: 100%; padding: .85rem 1rem; border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.12); background: var(--fn-bg);
  color: var(--fn-white); font-size: 1rem;
}
.fn-field--privacy { margin: 1rem 0 .25rem; }
.fn-field label.fn-check {
  display: inline-flex; align-items: flex-start; gap: .65rem;
  position: static; transform: none; left: auto; top: auto;
  pointer-events: auto; cursor: pointer;
  font-size: .88rem; line-height: 1.45; color: var(--fn-muted);
  width: auto; max-width: 100%;
}
.fn-field label.fn-check input[type="checkbox"] {
  width: 1.15rem !important; height: 1.15rem; min-width: 1.15rem;
  margin: .12rem 0 0; padding: 0; flex-shrink: 0;
  accent-color: var(--fn-gold); border-radius: 4px; cursor: pointer;
}
.fn-check__text { display: inline; }
.fn-check__text a { color: var(--fn-gold); text-decoration: underline; }
.fn-check__text a:hover { color: var(--fn-gold-light); }
.fn-sell { color: var(--fn-muted); font-size: 1.05rem; line-height: 1.7; max-width: 800px; }
.fn-sell strong { color: var(--fn-white); }
.fn-sell-list { color: var(--fn-muted); padding-left: 0; list-style: none; margin: 1rem 0; }
.fn-sell-list li { padding: .5rem 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.fn-contact-sell { margin-bottom: 2rem; max-width: 720px; }
.fn-why { display: flex; flex-wrap: wrap; gap: 1rem; }
.fn-why__item { padding: .65rem 1rem; border-radius: 999px; background: rgba(201,169,98,.1); border: 1px solid rgba(201,169,98,.2); font-size: .88rem; }
.fn-services--nine { grid-template-columns: repeat(3, 1fr); }
.fn-back-link {
  display: inline-flex; margin-bottom: 1rem; font-weight: 600; font-size: .9rem;
  color: var(--fn-gold) !important;
}
@media (max-width: 900px) {
  .fn-services--nine { grid-template-columns: 1fr; }
  .fn-services--blog { grid-template-columns: 1fr; }
  .fn-showcase__grid { grid-template-columns: 1fr; min-height: auto; padding: 1.5rem 0; }
  .fn-showcase__media-slide { aspect-ratio: 16/11; max-height: none; }
  .fn-showcase__copy { order: 2; }
  .fn-showcase__media { order: 1; margin: 0; }
  .fn-map-stage { grid-template-columns: 1fr; }
  .fn-map-stage__map, .fn-map--premium { min-height: 380px; }
  .fn-map-stage__panel { min-height: 320px; }
  .fn-quest-hud { grid-template-columns: 1fr; }
  .fn-quest-badges { max-width: none; justify-content: flex-start; }
  .fn-quest-deck { grid-template-columns: repeat(2, 1fr); }
  .fn-google-section__grid { grid-template-columns: 1fr; }
  .fn-team-visual__stack { grid-template-columns: 1fr 1fr; }
  .fn-contact-split { grid-template-columns: 1fr; }
  .fn-form-pro__grid { grid-template-columns: 1fr; }
  .fn-gallery { grid-template-columns: repeat(2, 1fr); }
}
.fn-form-progress { display: flex; gap: .5rem; margin-bottom: 1.5rem; justify-content: center; }
.fn-form-progress__dot {
  width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.15);
}
.fn-form-progress__dot.is-active { background: var(--fn-gold); }
.fn-form-progress__dot.is-done { background: var(--fn-gold-light); }
.fn-form-step { display: none; }
.fn-form-step.is-active { display: block; }
.fn-field { position: relative; margin-bottom: 1.25rem; min-width: 0; }
.fn-field input:not([type="checkbox"]), .fn-field select, .fn-field textarea {
  width: 100%; padding: 1.1rem 1rem .65rem; border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.12); background: var(--fn-bg);
  color: var(--fn-white); font-family: inherit; font-size: 1rem; transition: border-color .2s;
}
.fn-field input + label,
.fn-field select + label,
.fn-field textarea + label {
  position: absolute; left: 1rem; top: 50%; transform: translateY(-50%);
  color: var(--fn-muted); font-size: .9rem; pointer-events: none; transition: .2s;
}
/* Select y fecha: etiqueta fija arriba (evita solapamiento con placeholder nativo) */
.fn-field--labeled {
  display: flex; flex-direction: column; gap: .45rem;
  margin-bottom: 1rem;
}
.fn-field.fn-field--labeled > label {
  position: static !important; transform: none !important; left: auto !important; top: auto !important;
  pointer-events: auto; display: block;
  font-size: .82rem; font-weight: 600; line-height: 1.35; margin: 0;
  color: var(--fn-muted);
}
.fn-field--labeled:focus-within > label { color: var(--fn-gold); }
.fn-field--labeled input,
.fn-field--labeled select {
  padding: .85rem 1rem;
}
.fn-field--labeled select {
  padding-right: 2.5rem;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a8a8b3' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .85rem center;
}
.fn-field--labeled input[type="date"] { color-scheme: dark; }
.fn-field textarea + label { top: 1.1rem; transform: none; }
.fn-field input:focus, .fn-field select:focus, .fn-field textarea:focus {
  outline: none; border-color: var(--fn-gold);
}
.fn-field.is-filled input + label,
.fn-field.is-filled select + label,
.fn-field.is-filled textarea + label,
.fn-field input:focus + label, .fn-field select:focus + label, .fn-field textarea:focus + label {
  top: .45rem; transform: none; font-size: .7rem; color: var(--fn-gold);
}
.fn-field textarea { min-height: 110px; resize: vertical; }
.fn-form-actions { display: flex; gap: 1rem; margin-top: 1rem; flex-wrap: wrap; }
.fn-secure-badge {
  display: flex; align-items: center; gap: .5rem; margin-top: 1rem;
  font-size: .8rem; color: var(--fn-muted);
}
.fn-flash-err { color: #f87171; }
.ftn-flash { padding: 1rem 1.25rem; border-radius: 12px; margin: 1rem 0; }
.ftn-flash--ok { background: rgba(37,211,102,.12); border: 1px solid rgba(37,211,102,.35); color: #86efac; }
.ftn-flash--err { background: rgba(248,113,113,.12); border: 1px solid rgba(248,113,113,.35); color: #fca5a5; }

/* FAQ visual */
.fn-faq-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 3rem; align-items: start; }
.fn-faq-visual { border-radius: var(--fn-radius); overflow: hidden; position: sticky; top: calc(var(--fn-header) + 1rem); }
.fn-faq-visual img { width: 100%; filter: brightness(1.1); }
.fn-faq-cat { margin-bottom: 2rem; }
.fn-faq-cat h3 { font-family: var(--fn-display); font-size: 1.25rem; margin: 0 0 1rem; color: var(--fn-gold); }

/* Page hero (inner) */
.fn-page-hero {
  padding: calc(var(--fn-header) + 3rem) 0 3rem;
  background: var(--fn-bg-soft);
  border-bottom: 1px solid rgba(201,169,98,.1);
}
.fn-page-hero h1 { font-family: var(--fn-display); font-size: clamp(2rem, 4vw, 3rem); margin: 0 0 1rem; }
.fn-breadcrumb { font-size: .85rem; color: var(--fn-muted); margin-bottom: 1rem; }
.fn-breadcrumb a { color: var(--fn-gold); }

/* Content prose */
.fn-prose h2 { font-family: var(--fn-display); font-size: 1.5rem; margin: 2rem 0 1rem; }
.fn-prose p { color: var(--fn-muted); }
.fn-prose ul { color: var(--fn-muted); padding-left: 1.25rem; }
.fn-prose li { margin-bottom: .4rem; }

/* Split layout */
.fn-split { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.fn-split img { border-radius: var(--fn-radius); box-shadow: var(--fn-shadow); }

@media (max-width: 900px) {
  .fn-nav { display: none; position: fixed; top: var(--fn-header); left: 0; right: 0;
    background: var(--fn-bg); flex-direction: column; padding: 1.5rem; gap: 1rem;
    border-bottom: 1px solid rgba(201,169,98,.15); }
  .fn-nav.is-open { display: flex; }
  .fn-menu-toggle { display: block; }
  .fn-gallery { grid-template-columns: repeat(2, 1fr); }
  .fn-split { grid-template-columns: 1fr; }
  .fn-form__grid { grid-template-columns: 1fr; }
  .fn-steps { grid-template-columns: 1fr; }
  .fn-contact-layout { grid-template-columns: 1fr; }
  .fn-faq-layout { grid-template-columns: 1fr; }
  .fn-faq-visual { position: static; }
  .fn-wa { bottom: 100px; right: 16px; padding: 1rem 1.25rem; }
}
@media (max-width: 480px) {
  .fn-wa span:not(.fn-wa__icon) { display: none; }
  .fn-wa { width: 60px; height: 60px; padding: 0; justify-content: center; border-radius: 50%; }
  .fn-quest-deck { grid-template-columns: 1fr; }
}
