@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;800;900&family=Inter:wght@300;400;500;600&display=swap');

/* --- Scope: solo dentro de .am-ficha --- */
.am-ficha {
  --am-bg: #0a0a0c;
  --am-card: #111116;
  --am-card2: #15161a;
  --am-border: #1f2937;
  --am-orange: #f97316;
  --am-wa: #25d366;
  --am-wa-hover: #20bd5a;
  --am-text: #ffffff;
  --am-muted: #9ca3af;
  --am-inner-max: 80rem;
  box-sizing: border-box;
  background: var(--am-bg);
  color: var(--am-text);
  font-family: Inter, system-ui, sans-serif;
  padding: clamp(4rem, 12vw, 8rem) 0 clamp(3rem, 8vw, 5rem);
}

.am-ficha *,
.am-ficha *::before,
.am-ficha *::after {
  box-sizing: border-box;
}

.am-ficha__inner {
  max-width: var(--am-inner-max);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
  width: 100%;
}

.am-ficha__crumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.875rem;
  color: var(--am-muted);
  margin-bottom: 1.5rem;
}

.am-ficha__crumbs a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}

.am-ficha__crumbs a:hover {
  color: var(--am-orange);
}

.am-ficha__crumb-sep {
  opacity: 0.6;
}

.am-ficha__crumb-current {
  color: #d1d5db;
}

.am-ficha__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 4vw, 2.5rem);
  align-items: start;
}

@media (min-width: 1024px) {
  .am-ficha__grid {
    grid-template-columns: 2fr 1fr;
    gap: 2.5rem;
  }
}

.am-ficha__col--main {
  display: flex;
  flex-direction: column;
  gap: clamp(1.5rem, 4vw, 2rem);
}

.am-ficha__badges-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.am-ficha__badge {
  background: var(--am-orange);
  color: #fff;
  font-family: Montserrat, sans-serif;
  font-size: 10px;
  font-weight: 700;
  padding: 0.2rem 0.5rem;
  border-radius: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.am-ficha__cod {
  color: var(--am-muted);
  font-size: 0.875rem;
}

.am-ficha__title {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(1.75rem, 5vw, 3rem);
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  margin: 0 0 0.35rem;
}

.am-ficha__subtitle {
  margin: 0;
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  color: var(--am-muted);
}

/* Galería */
.am-ficha__gallery {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

#am-ficha-gallery-fb {
  display: none !important;
}

.am-ficha__gallery-main {
  background: #1c1d24;
  border-radius: 0.75rem;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border: 1px solid #374151;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(0.5rem, 2vw, 2rem);
}

.am-ficha__gallery-main--zoomable {
  cursor: zoom-in;
}

.am-ficha__gallery-main--zoomable:focus-visible {
  outline: 2px solid var(--am-orange);
  outline-offset: 3px;
}

.am-ficha-fancybox {
  --fancybox-bg: rgba(10, 10, 12, 0.96);
  /* Zona mínima táctil accesible (44px) */
  --am-fb-close-size: 3rem;
  --am-fb-close-bg: rgba(17, 17, 22, 0.95);
  --am-fb-close-border: rgba(249, 115, 22, 0.55);
}

/* Botón cerrar flotante (encima de la imagen) + barra: mismo look, bien visible en móvil */
.am-ficha-fancybox [data-fancybox-close] {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: var(--am-fb-close-size) !important;
  min-height: var(--am-fb-close-size) !important;
  width: var(--am-fb-close-size) !important;
  height: var(--am-fb-close-size) !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0.5rem !important;
  background: var(--am-fb-close-bg) !important;
  background-image: none !important;
  border: 1px solid var(--am-fb-close-border) !important;
  color: #fff !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.45) !important;
  opacity: 1 !important;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box !important;
  z-index: 3;
}

.am-ficha-fancybox [data-fancybox-close] svg {
  width: 1.5rem !important;
  height: 1.5rem !important;
  flex-shrink: 0;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.5;
  pointer-events: none;
}

/* Flotante: esquina segura (notch) */
.am-ficha-fancybox .f-button.is-close-btn {
  position: fixed !important;
  top: max(0.75rem, env(safe-area-inset-top, 0px)) !important;
  right: max(0.75rem, env(safe-area-inset-right, 0px)) !important;
  left: auto !important;
}

.am-ficha-fancybox .fancybox__toolbar {
  padding: 0.5rem max(0.5rem, env(safe-area-inset-right, 0px)) 0.5rem
    max(0.5rem, env(safe-area-inset-left, 0px)) !important;
  background: linear-gradient(
    to bottom,
    rgba(10, 10, 12, 0.98) 0%,
    rgba(10, 10, 12, 0.75) 70%,
    transparent 100%
  ) !important;
}

.am-ficha__gallery-main--empty {
  background: #1c1d24;
  border-radius: 0.75rem;
  border: 1px solid #374151;
  min-height: 12rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}

.am-ficha__empty-msg {
  color: var(--am-muted);
  margin: 0;
}

.am-ficha__main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0.25rem;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

/* Miniaturas: rejilla 4 (como demo) o fila con scroll si hay más de 4; flechas solo en esta franja */
.am-ficha__thumbs-wrap {
  display: flex;
  align-items: stretch;
  gap: 0.5rem;
}

.am-ficha__thumbs-wrap--grid .am-ficha__thumbs-scroll {
  display: none;
}

.am-ficha__thumbs-scroll {
  flex-shrink: 0;
  align-self: center;
  width: 2rem;
  min-height: 3rem;
  border: 1px solid var(--am-border);
  border-radius: 0.375rem;
  background-color: var(--am-card2) !important;
  background-image: none !important;
  color: #e5e7eb;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: border-color 0.2s, color 0.2s;
  -webkit-tap-highlight-color: transparent;
  box-shadow: none !important;
  filter: none !important;
}

.am-ficha__thumbs-scroll:hover,
.am-ficha__thumbs-scroll:focus,
.am-ficha__thumbs-scroll:active {
  background-color: var(--am-card2) !important;
  background-image: none !important;
  border-color: rgba(249, 115, 22, 0.45);
  color: var(--am-orange) !important;
  box-shadow: none !important;
  filter: none !important;
  opacity: 1 !important;
}

.am-ficha__thumbs-scroll:focus {
  outline: none !important;
}

.am-ficha__thumbs-scroll:focus-visible {
  outline: 2px solid var(--am-orange) !important;
  outline-offset: 2px;
}

@media (min-width: 768px) {
  .am-ficha__thumbs-scroll {
    width: 2.25rem;
    min-height: 3.5rem;
  }
}

.am-ficha__thumbs-viewport {
  flex: 1;
  min-width: 0;
  container-type: inline-size;
  container-name: amth;
}

/* Hasta 4 fotos: rejilla fija de 4 columnas (como ficha-card) */
.am-ficha__thumbs-wrap--grid .am-ficha__thumbs-viewport {
  overflow: visible;
}

.am-ficha__thumbs-wrap--grid .am-ficha__thumbs-track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(0.5rem, 2vw, 1rem);
  width: 100%;
}

.am-ficha__thumbs-wrap--grid .am-ficha__thumb {
  width: 100%;
  min-width: 0;
}

/* Más de 4: misma anchura por celda (~4 visibles), scroll horizontal + flechas */
.am-ficha__thumbs-wrap--scrollable .am-ficha__thumbs-viewport {
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.am-ficha__thumbs-wrap--scrollable .am-ficha__thumbs-viewport::-webkit-scrollbar {
  display: none;
}

.am-ficha__thumbs-wrap--scrollable .am-ficha__thumbs-track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: clamp(0.5rem, 2vw, 1rem);
  width: max-content;
  min-height: 0;
}

.am-ficha__thumbs-wrap--scrollable .am-ficha__thumb {
  flex: 0 0 auto;
  width: calc((100cqw - 3 * clamp(0.5rem, 2vw, 1rem)) / 4);
  max-width: 12rem;
}

@supports not (width: 1cqw) {
  .am-ficha__thumbs-wrap--scrollable .am-ficha__thumb {
    width: min(22vw, 8.5rem);
  }
}

.am-ficha__thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  cursor: zoom-in;
  border: 2px solid transparent;
  border-radius: 0.5rem;
  overflow: hidden;
  background: #1c1d24;
  padding: 0;
  opacity: 0.55;
  transition: opacity 0.2s, border-color 0.2s;
}

.am-ficha__thumb:hover,
.am-ficha__thumb.is-active {
  opacity: 1;
  border-color: var(--am-orange);
}

.am-ficha__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Paneles */
.am-ficha__panel {
  background: var(--am-card);
  padding: clamp(1.25rem, 4vw, 2rem);
  border-radius: 0.75rem;
  border: 1px solid var(--am-border);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.25);
}

.am-ficha__panel-title {
  font-family: Montserrat, sans-serif;
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--am-border);
}

.am-ficha__spec-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(1.25rem, 3vw, 2rem) clamp(1rem, 3vw, 1.5rem);
}

@media (min-width: 768px) {
  .am-ficha__spec-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.am-ficha__spec-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.am-ficha__spec-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: #6b7280;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.am-ficha__spec-ico {
  flex-shrink: 0;
  color: var(--am-orange);
}

.am-ficha__spec-value {
  font-size: clamp(1rem, 2.5vw, 1.125rem);
  font-weight: 500;
  color: #fff;
}

.am-ficha__eq-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .am-ficha__eq-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

.am-ficha__eq-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  background: var(--am-card2);
  border: 1px solid rgba(55, 65, 81, 0.5);
  border-radius: 0.375rem;
  color: #d1d5db;
}

.am-ficha__eq-ico--yes {
  flex-shrink: 0;
  color: var(--am-orange);
}

.am-ficha__eq-item--green .am-ficha__eq-ico--yes {
  color: var(--am-wa);
}

.am-ficha__eq-item--off .am-ficha__eq-ico--no {
  flex-shrink: 0;
  color: #ef4444;
}

.am-ficha__eq-label {
  min-width: 0;
}

.am-ficha__content {
  color: #d1d5db;
  line-height: 1.7;
  font-size: clamp(0.875rem, 2vw, 1rem);
}

.am-ficha__content p {
  margin: 0 0 1rem;
}

.am-ficha__content ul {
  margin: 0.5rem 0 0;
  padding-left: 1.25rem;
  color: #9ca3af;
}

/* Sidebar */
.am-ficha__sticky {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  .am-ficha__sticky {
    position: sticky;
    top: clamp(5rem, 12vh, 7rem);
  }
}

.am-ficha__price-card {
  position: relative;
  overflow: hidden;
  padding: clamp(1.5rem, 4vw, 2rem);
  border-radius: 0.75rem;
  border: 1px solid var(--am-border);
  background: linear-gradient(135deg, #1a1c23 0%, #111216 100%);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.45);
}

/* Móvil: precio bajo la galería; desktop: solo en sidebar */
.am-ficha__price-card--after-gallery {
  display: block;
}

.am-ficha__price-card--sidebar {
  display: block;
}

@media (min-width: 1024px) {
  .am-ficha__price-card--after-gallery {
    display: none !important;
  }
}

@media (max-width: 1023px) {
  .am-ficha__price-card--sidebar {
    display: none !important;
  }
}

.am-ficha__price-deco {
  position: absolute;
  right: -1.5rem;
  bottom: -1.5rem;
  color: var(--am-orange);
  pointer-events: none;
}

.am-ficha__price-label {
  margin: 0 0 0.35rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--am-muted);
}

.am-ficha__price-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.35rem 0.5rem;
  margin-bottom: 1rem;
}

.am-ficha__price-num {
  font-family: Montserrat, sans-serif;
  font-size: clamp(2rem, 6vw, 2.5rem);
  font-weight: 800;
  line-height: 1;
  color: #fff;
}

.am-ficha__price-currency {
  font-size: 1.25rem;
  color: var(--am-muted);
  margin-bottom: 0.15rem;
}

.am-ficha__price-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.am-ficha__pill {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.2rem 0.45rem;
  border-radius: 0.25rem;
}

.am-ficha__pill--orange {
  background: rgba(249, 115, 22, 0.1);
  color: var(--am-orange);
  border: 1px solid rgba(249, 115, 22, 0.2);
}

.am-ficha__pill--green {
  background: rgba(34, 197, 94, 0.1);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.am-ficha__wa {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  min-height: 48px;
  padding: 1rem;
  border-radius: 0.375rem;
  background: var(--am-wa);
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: clamp(0.75rem, 2vw, 0.875rem);
  box-shadow: 0 4px 14px rgba(37, 211, 102, 0.35);
  transition: background 0.2s, box-shadow 0.2s;
}

.am-ficha__wa:hover {
  background: var(--am-wa-hover);
  box-shadow: 0 6px 18px rgba(37, 211, 102, 0.45);
}

.am-ficha__wa-ico {
  flex-shrink: 0;
}

/* Formulario + WPForms */
.am-ficha__form-panel {
  background: var(--am-card2);
  padding: clamp(1rem, 3vw, 1.5rem);
  border-radius: 0.75rem;
  border: 1px solid var(--am-border);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.2);
}

.am-ficha__form-title {
  font-family: Montserrat, sans-serif;
  font-size: 1.125rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--am-border);
  color: #fff;
}

.am-ficha__wpforms .wpforms-container {
  margin: 0 !important;
}

.am-ficha__wpforms .wpforms-field,
.am-ficha__wpforms .wpforms-field-container {
  padding: 0 !important;
}

.am-ficha__wpforms .wpforms-field-label,
.am-ficha__wpforms label.wpforms-field-label {
  display: block;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: #9ca3af !important;
  margin: 0 0 0.35rem !important;
}

.am-ficha__wpforms .wpforms-field {
  margin-bottom: 1rem !important;
}

.am-ficha__wpforms input[type='text'],
.am-ficha__wpforms input[type='email'],
.am-ficha__wpforms input[type='tel'],
.am-ficha__wpforms input[type='number'],
.am-ficha__wpforms textarea,
.am-ficha__wpforms select {
  width: 100% !important;
  max-width: 100% !important;
  background: var(--am-bg) !important;
  border: 1px solid #374151 !important;
  color: #fff !important;
  border-radius: 0.375rem !important;
  padding: 0.75rem !important;
  font-size: 0.875rem !important;
  transition: border-color 0.2s !important;
}

.am-ficha__wpforms input:focus,
.am-ficha__wpforms textarea:focus,
.am-ficha__wpforms select:focus {
  outline: none !important;
  border-color: var(--am-orange) !important;
}

.am-ficha__wpforms textarea {
  min-height: 5rem !important;
  resize: vertical !important;
}

.am-ficha__wpforms .wpforms-submit-container {
  margin-top: 0.5rem !important;
  padding: 0 !important;
}

.am-ficha__wpforms button[type='submit'],
.am-ficha__wpforms .wpforms-submit {
  width: 100% !important;
  background: var(--am-orange) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0.375rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  padding: 0.75rem 1rem !important;
  font-size: 0.875rem !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
}

.am-ficha__wpforms button[type='submit']:hover,
.am-ficha__wpforms .wpforms-submit:hover {
  background: #ea580c !important;
}

.am-ficha__wpforms .wpforms-error-container,
.am-ficha__wpforms .wpforms-field-description {
  color: #fca5a5 !important;
  font-size: 0.75rem !important;
}

/* Compra segura */
.am-ficha__trust {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: clamp(1rem, 3vw, 1.5rem);
  background: var(--am-card);
  border-radius: 0.75rem;
  border: 1px solid var(--am-border);
}

.am-ficha__trust-icon {
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  border-radius: 9999px;
  background: rgba(249, 115, 22, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--am-orange);
}

.am-ficha__trust-title {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 700;
  color: #fff;
}

.am-ficha__trust-text {
  margin: 0.25rem 0 0;
  font-size: 0.75rem;
  color: var(--am-muted);
  line-height: 1.45;
}
