/*
Theme Name: Divi Child
Theme URI: http://www.elegantthemes.com/gallery/divi/
Template: Divi
Author: Elegant Themes
Author URI: http://www.elegantthemes.com
Description: Smart. Flexible. Beautiful. Divi is the most powerful theme in our collection.
Version: 5.1.1.1779782993
Updated: 2026-05-26 10:09:53

*/

.et_header_style_left .logo_container {
    width: 96%;
}

.logo_container {
    background: #FFFFFF;
    border-radius: 60px;
    padding: 10px;
}


.darkify_switch{  
	margin-right: 20px;
}




/estilos ia*/


@import url('https://fonts.bunny.net/css?family=manrope:400,500,600,700,800&family=outfit:500,600,700,800');


:root {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.18), transparent 38%),
    radial-gradient(circle at 85% 15%, rgba(246, 173, 85, 0.18), transparent 24%),
    linear-gradient(180deg, #f4f8f6 0%, #eef4f6 46%, #f9f3eb 100%);
  --rm-text: #16323d;
  --rm-muted: rgba(16, 37, 45, 0.8);
  --rm-soft: rgba(16, 37, 45, 0.68);
  --rm-line: rgba(22, 50, 61, 0.08);
  --rm-panel: rgba(255, 255, 255, 0.72);
  --rm-panel-strong: rgba(255, 255, 255, 0.86);
  --rm-accent: #0097a7;
  --rm-accent-2: #62d7e0;
  --rm-button: #16323d;
  --rm-button-hover: #0f232a;
  --rm-surface-end: #eef4f6;
  --rm-hero-overlay: linear-gradient(90deg, rgba(244, 248, 246, 0.95) 0%, rgba(244, 248, 246, 0.82) 46%, rgba(244, 248, 246, 0.22) 100%);
  background: var(--rm-bg);
  color: var(--rm-text);
  font-family: "Manrope", sans-serif;
  line-height: 1.5;
  position: relative;
  overflow: visible;
}

:root[data-theme="dark"] {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.16), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(98, 215, 224, 0.14), transparent 20%),
    linear-gradient(180deg, #07141b 0%, #0b1d27 48%, #112430 100%);
  --rm-text: #edf6f8;
  --rm-muted: rgba(237, 246, 248, 0.78);
  --rm-soft: rgba(237, 246, 248, 0.62);
  --rm-line: rgba(237, 246, 248, 0.1);
  --rm-panel: rgba(10, 25, 33, 0.68);
  --rm-panel-strong: rgba(15, 32, 42, 0.88);
  --rm-accent: #62d7e0;
  --rm-accent-2: #8fe3ea;
  --rm-button: #edf6f8;
  --rm-button-hover: #d6e8ec;
  --rm-surface-end: #0b1d27;
  --rm-hero-overlay: linear-gradient(90deg, rgba(7, 20, 27, 0.94) 0%, rgba(7, 20, 27, 0.8) 46%, rgba(7, 20, 27, 0.28) 100%);
}
.rm-section {
  --rm-text: #16323d;
  --rm-muted: rgba(16, 37, 45, 0.8);
  --rm-soft: rgba(16, 37, 45, 0.68);
  --rm-line: rgba(22, 50, 61, 0.08);
  --rm-panel: rgba(255, 255, 255, 0.72);
  --rm-panel-strong: rgba(255, 255, 255, 0.86);
  --rm-accent: #0097a7;
  --rm-accent-2: #62d7e0;
  --rm-button: #16323d;
  --rm-button-hover: #0f232a;
  --rm-surface-end: #eef4f6;

}

.rm-section[data-theme="dark"] {
	--rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.16), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(98, 215, 224, 0.14), transparent 20%),
    linear-gradient(180deg, #07141b 0%, #0b1d27 48%, #112430 100%);
  --rm-text: #edf6f8;
  --rm-muted: rgba(237, 246, 248, 0.78);
  --rm-soft: rgba(237, 246, 248, 0.62);
  --rm-line: rgba(237, 246, 248, 0.1);
  --rm-panel: rgba(10, 25, 33, 0.68);
  --rm-panel-strong: rgba(15, 32, 42, 0.88);
  --rm-accent: #62d7e0;
  --rm-accent-2: #8fe3ea;
  --rm-button: #edf6f8;
  --rm-button-hover: #d6e8ec;
  --rm-surface-end: #0b1d27;

}


.rm-landing-inicio {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.18), transparent 38%),
    radial-gradient(circle at 85% 15%, rgba(246, 173, 85, 0.18), transparent 24%),
    linear-gradient(180deg, #f4f8f6 0%, #eef4f6 46%, #f9f3eb 100%);
  --rm-text: #16323d;
  --rm-muted: rgba(16, 37, 45, 0.8);
  --rm-soft: rgba(16, 37, 45, 0.68);
  --rm-line: rgba(22, 50, 61, 0.08);
  --rm-panel: rgba(255, 255, 255, 0.72);
  --rm-panel-strong: rgba(255, 255, 255, 0.86);
  --rm-accent: #0097a7;
  --rm-accent-2: #62d7e0;
  --rm-button: #16323d;
  --rm-button-hover: #0f232a;
  --rm-surface-end: #eef4f6;
  --rm-hero-overlay: linear-gradient(90deg, rgba(244, 248, 246, 0.95) 0%, rgba(244, 248, 246, 0.82) 46%, rgba(244, 248, 246, 0.22) 100%);
  background: url('https://raccoonmetrics.com/wp-content/uploads/2026/03/bg3-min-scaled.jpg') center/cover no-repeat;
  color: var(--rm-text);
  font-family: "Manrope", sans-serif;
  line-height: 1.5;
  position: relative;
  overflow: visible;
}

.rm-landing-inicio[data-theme="dark"] {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.16), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(98, 215, 224, 0.14), transparent 20%),
    linear-gradient(180deg, #07141b 0%, #0b1d27 48%, #112430 100%);
  --rm-text: #edf6f8;
  --rm-muted: rgba(237, 246, 248, 0.78);
  --rm-soft: rgba(237, 246, 248, 0.62);
  --rm-line: rgba(237, 246, 248, 0.1);
  --rm-panel: rgba(10, 25, 33, 0.68);
  --rm-panel-strong: rgba(15, 32, 42, 0.88);
  --rm-accent: #62d7e0;
  --rm-accent-2: #8fe3ea;
  --rm-button: #edf6f8;
  --rm-button-hover: #d6e8ec;
  --rm-surface-end: #0b1d27;
  --rm-hero-overlay: linear-gradient(90deg, rgba(7, 20, 27, 0.94) 0%, rgba(7, 20, 27, 0.8) 46%, rgba(7, 20, 27, 0.28) 100%);
}



.rm-landing {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.18), transparent 38%),
    radial-gradient(circle at 85% 15%, rgba(246, 173, 85, 0.18), transparent 24%),
    linear-gradient(180deg, #f4f8f6 0%, #eef4f6 46%, #f9f3eb 100%);
  --rm-text: #16323d;
  --rm-muted: rgba(16, 37, 45, 0.8);
  --rm-soft: rgba(16, 37, 45, 0.68);
  --rm-line: rgba(22, 50, 61, 0.08);
  --rm-panel: rgba(255, 255, 255, 0.72);
  --rm-panel-strong: rgba(255, 255, 255, 0.86);
  --rm-accent: #0097a7;
  --rm-accent-2: #62d7e0;
  --rm-button: #16323d;
  --rm-button-hover: #0f232a;
  --rm-surface-end: #eef4f6;
  --rm-hero-overlay: linear-gradient(90deg, rgba(244, 248, 246, 0.95) 0%, rgba(244, 248, 246, 0.82) 46%, rgba(244, 248, 246, 0.22) 100%);
  background: var(--rm-bg), url('https://raccoonmetrics.com/wp-content/uploads/2026/03/bg3-min-scaled.jpg') center/cover no-repeat;
  color: var(--rm-text);
  font-family: "Manrope", sans-serif;
  line-height: 1.5;
  position: relative;
  overflow: visible;
}

.rm-landing[data-theme="dark"] {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.16), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(98, 215, 224, 0.14), transparent 20%),
    linear-gradient(180deg, #07141b 0%, #0b1d27 48%, #112430 100%);
  --rm-text: #edf6f8;
  --rm-muted: rgba(237, 246, 248, 0.78);
  --rm-soft: rgba(237, 246, 248, 0.62);
  --rm-line: rgba(237, 246, 248, 0.1);
  --rm-panel: rgba(10, 25, 33, 0.68);
  --rm-panel-strong: rgba(15, 32, 42, 0.88);
  --rm-accent: #62d7e0;
  --rm-accent-2: #8fe3ea;
  --rm-button: #edf6f8;
  --rm-button-hover: #d6e8ec;
  --rm-surface-end: #0b1d27;
  --rm-hero-overlay: linear-gradient(90deg, rgba(7, 20, 27, 0.94) 0%, rgba(7, 20, 27, 0.8) 46%, rgba(7, 20, 27, 0.28) 100%);
}

.rm-hero-media { position: relative; inset: -40px 0 0; background: linear-gradient(90deg, rgba(244, 248, 246, 0.95) 0%, rgba(244, 248, 246, 0.82) 46%, rgba(244, 248, 246, 0.22) 100%), url('/wp-content/uploads/2026/03/bg3-min-scaled.jpg') center/cover no-repeat; transform: translate3d(0, 0, 0); will-change: transform; pointer-events: none; }

.rm-landing *, .rm-landing *::before, .rm-landing *::after { box-sizing: border-box; }
.rm-wrap { max-width: 1200px; margin: 0 auto; padding-left: 24px; padding-right: 24px; }
.rm-hero[id], .rm-section[id] { scroll-margin-top: 108px; }
.rm-nav { position: sticky; top: 10px; z-index: 20; margin: 0 16px; border: 1px solid var(--rm-line); border-radius: 999px; background: color-mix(in srgb, var(--rm-panel-strong) 92%, transparent); box-shadow: 0 10px 26px rgba(22, 50, 61, 0.08); }
.rm-nav-inner { display: flex; align-items: center; gap: 24px; justify-content: space-between; padding: 12px 16px; flex-wrap: wrap; }
.rm-brand img { height: 44px; width: auto; display: block; }
.rm-menu { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.rm-menu a, .rm-brand { color: var(--rm-text); text-decoration: none; font-family: "Manrope", sans-serif; }
.rm-menu a:hover { color: var(--rm-accent); }
.rm-nav-controls { display: flex; align-items: center; gap: 12px; padding-left: 20px; padding-right: 20px;}
.rm-menu-toggle { display: none; align-items: center; justify-content: center; width: 46px; height: 46px; border: 1px solid var(--rm-line); border-radius: 999px; background: color-mix(in srgb, var(--rm-panel) 100%, transparent); color: var(--rm-text); cursor: pointer; padding: 0; }
.rm-menu-toggle-lines { display: inline-grid; gap: 4px; }
.rm-menu-toggle-lines span { width: 18px; height: 2px; border-radius: 999px; background: currentColor; display: block; transition: transform .2s ease, opacity .2s ease; }
.rm-menu-toggle[aria-expanded="true"] .rm-menu-toggle-lines span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.rm-menu-toggle[aria-expanded="true"] .rm-menu-toggle-lines span:nth-child(2) { opacity: 0; }
.rm-menu-toggle[aria-expanded="true"] .rm-menu-toggle-lines span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.rm-toggles { display: flex; align-items: center; }
.rm-theme-toggle { position: absolute; opacity: 0; pointer-events: none; }
.rm-theme-switch {top: -10px; position: relative; width: 74px; height: 40px; display: inline-flex; align-items: center; justify-content: space-between; padding: 0 11px; border: 1px solid var(--rm-line); border-radius: 999px; background: color-mix(in srgb, var(--rm-panel) 100%, transparent); cursor: pointer; box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.3); }
.rm-theme-switch::after { content: ""; position: absolute; top: 4px; left: 4px; width: 30px; height: 30px; border-radius: 999px; background: var(--rm-button); box-shadow: 0 8px 18px rgba(22, 50, 61, 0.18); transition: transform .22s ease, background .22s ease; }
.rm-theme-icon { position: relative; z-index: 1; width: 18px; text-align: center; font-size: 14px; line-height: 1; color: var(--rm-soft); transition: color .22s ease, opacity .22s ease; }
.rm-theme-icon-light { opacity: 1; }
.rm-theme-icon-dark { opacity: .58; }
.rm-theme-toggle:checked + .rm-theme-switch::after { transform: translateX(34px); background: var(--rm-button); }
.rm-theme-toggle:checked + .rm-theme-switch .rm-theme-icon-light { opacity: .58; }
.rm-theme-toggle:checked + .rm-theme-switch .rm-theme-icon-dark { opacity: 1; }
.rm-landing[data-theme="dark"] .rm-theme-switch { box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08); }
.rm-landing[data-theme="dark"] .rm-theme-switch::after { background: #edf6f8; }
.rm-landing[data-theme="dark"] .rm-theme-icon { color: var(--rm-soft); }
.rm-hero { padding: 72px 0 42px; position: relative; overflow: hidden; }

.rm-hero::before { content: ""; position: absolute; inset: 10% -10% auto auto; width: 28rem; height: 28rem; background: radial-gradient(circle, color-mix(in srgb, var(--rm-accent) 22%, transparent), transparent 66%); pointer-events: none; z-index: 0; }
.rm-hero::after { content: ""; position: absolute; inset: auto 0 0 0; height: 9rem; background: linear-gradient(180deg, transparent, var(--rm-surface-end)); pointer-events: none; z-index: 0; }
.rm-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 7fr 5fr; gap: 16px; align-items: start; }
.rm-chip { display: inline-block; background: color-mix(in srgb, var(--rm-accent) 12%, transparent); border: 1px solid color-mix(in srgb, var(--rm-accent) 30%, var(--rm-line)); border-radius: 999px; color: var(--rm-accent); font-size: 12px; font-weight: 700; letter-spacing: .12em; padding: 8px 14px; text-transform: uppercase; margin-bottom: 16px; }
.rm-title, .rm-section-title { font-family: "Outfit", "Manrope", sans-serif; color: var(--rm-text); }
.rm-title { font-size: clamp(2rem, 4.7vw, 3.7rem); line-height: 1.02; letter-spacing: -.02em; max-width: 12ch; margin: 0 0 16px; }
.rm-copy, .rm-lead, .rm-card p, .rm-panel p, .rm-step-copy, .rm-list li, .rm-gallery-copy p { color: var(--rm-muted); }
.rm-lead { max-width: 44rem; font-size: 1.02rem; line-height: 1.8; margin: 0 0 24px; }
.rm-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 24px; }
.rm-btn { display: inline-block; padding: 14px 22px; border-radius: 999px; text-decoration: none; font-weight: 700; border: 1px solid var(--rm-line); }
.rm-btn-primary { background: var(--rm-button); border-color: var(--rm-button); color: #fff; }
.rm-btn-primary:hover { background: var(--rm-button-hover); color: #fff; }
.rm-landing[data-theme="dark"] .rm-btn-primary, .rm-landing[data-theme="dark"] .rm-btn-primary:hover { color: #07141b; }
.rm-btn-secondary { background: color-mix(in srgb, var(--rm-panel) 100%, transparent); color: var(--rm-text); }
.rm-panel, .rm-card, .rm-gallery-card, .rm-flow { background: var(--rm-panel); border: 1px solid var(--rm-line); border-radius: 24px; box-shadow: 0 18px 50px rgba(22, 50, 61, 0.08); }
.rm-panel { padding: 24px; }
.rm-panel-side { margin-top: 16px; }
.rm-mini { color: var(--rm-soft); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.rm-panel h3, .rm-card h3, .rm-gallery-copy h3 { color: var(--rm-text); margin-top: 0; }
.rm-panel-split { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; border-top: 1px solid var(--rm-line); margin-top: 18px; padding-top: 18px; }
.rm-mini-card { padding: 16px; background: color-mix(in srgb, var(--rm-panel-strong) 76%, transparent); border: 1px solid var(--rm-line); border-radius: 18px; }
.rm-flow { padding: 20px; }
.rm-flow-track { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; position: relative; }
.rm-flow-track::before { content: ""; position: absolute; left: 12%; right: 12%; top: 18px; height: 2px; background: linear-gradient(90deg, color-mix(in srgb, var(--rm-accent) 50%, transparent), color-mix(in srgb, var(--rm-accent-2) 24%, transparent)); }
.rm-step { position: relative; z-index: 1; }
.rm-step-node { width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: color-mix(in srgb, var(--rm-panel-strong) 96%, transparent); border: 1px solid color-mix(in srgb, var(--rm-accent) 30%, var(--rm-line)); box-shadow: 0 12px 24px rgba(22, 50, 61, 0.12); color: var(--rm-accent); font-size: 12px; font-weight: 800; margin-bottom: 14px; }
.rm-step-title { color: var(--rm-text); font-size: 1rem; font-weight: 700; margin: 0 0 8px; }
.rm-step-copy { font-size: .94rem; line-height: 1.6; margin: 0; }
.rm-section { padding: 56px 0; }
.rm-section-header { display: grid; grid-template-columns: 5fr 7fr; gap: 24px; align-items: end; margin-bottom: 24px; }
.rm-eyebrow { color: var(--rm-accent); font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 12px; }
.rm-section-title { font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; margin: 0; }
.rm-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.rm-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.rm-card { padding: 24px; }
.rm-card-label { color: var(--rm-accent); font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.rm-gallery-track { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(18rem, 24rem); gap: 16px; overflow-x: auto; padding-bottom: 8px; }
.rm-gallery-card { overflow: hidden; }
.rm-gallery-frame { min-height: 240px; position: relative; display: flex; align-items: center; justify-content: center; background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0)), linear-gradient(135deg, color-mix(in srgb, var(--rm-accent) 14%, transparent), color-mix(in srgb, var(--rm-accent-2) 10%, transparent)); padding: 16px; }
.rm-gallery-trigger { appearance: none; border: 0; background: transparent; padding: 0; width: 100%; cursor: zoom-in; }
.rm-gallery-image { width: 100%; min-height: 240px; display: block; object-fit: cover; object-position: top center; border-radius: 18px; border: 1px solid var(--rm-line); box-shadow: 0 18px 40px rgba(22, 50, 61, 0.12); background: color-mix(in srgb, var(--rm-panel-strong) 86%, transparent); }
.rm-gallery-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; border: 0; border-radius: 999px; background: rgba(7, 20, 27, 0.68); color: #edf6f8; cursor: pointer; z-index: 2; font-size: 22px; line-height: 1; }
.rm-gallery-nav:hover { background: rgba(0, 151, 167, 0.92); color: #fff; }
.rm-gallery-nav[hidden] { display: none; }
.rm-gallery-prev { left: 26px; }
.rm-gallery-next { right: 26px; }
.rm-gallery-dots { position: absolute; left: 0; right: 0; bottom: 26px; display: flex; justify-content: center; gap: 8px; pointer-events: none; }
.rm-gallery-dot-btn { width: 10px; height: 10px; border: 0; border-radius: 999px; background: rgba(237, 246, 248, 0.45); box-shadow: 0 0 0 1px rgba(7, 20, 27, 0.12); padding: 0; pointer-events: auto; cursor: pointer; }
.rm-gallery-dot-btn.is-active { background: #0097a7; }
.rm-gallery-counter { position: absolute; top: 26px; right: 26px; z-index: 2; padding: 6px 10px; border-radius: 999px; background: rgba(7, 20, 27, 0.68); color: #edf6f8; font-size: 12px; font-weight: 700; letter-spacing: .04em; }
.rm-gallery-counter[hidden], .rm-gallery-dots[hidden] { display: none; }
.rm-gallery-copy { padding: 18px 20px 20px; }
.rm-contact-grid, .rm-offer-grid, .rm-detail-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 16px; }
.rm-contact-list { list-style: none; margin: 22px 0 0; padding: 0; display: grid; gap: 12px; }
.rm-contact-list li { padding: 14px 16px; border: 1px solid var(--rm-line); border-radius: 18px; background: color-mix(in srgb, var(--rm-panel-strong) 78%, transparent); color: var(--rm-muted); }
.rm-form { display: grid; gap: 14px; }
.rm-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.rm-field { display: grid; gap: 8px; }
.rm-field label { color: var(--rm-text); font-size: .94rem; font-weight: 700; }
.rm-field input, .rm-field select, .rm-field textarea { width: 100%; padding: 14px 16px; border: 1px solid var(--rm-line); border-radius: 16px; background: color-mix(in srgb, var(--rm-panel-strong) 88%, transparent); color: var(--rm-text); font: inherit; }
.rm-field textarea { min-height: 150px; resize: vertical; }
.rm-form-note { margin: 0; color: var(--rm-soft); font-size: .92rem; }
.rm-offer-card { padding: 24px; }
.rm-detail-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px; }
.rm-top-btn { position: fixed; right: 22px; bottom: 22px; z-index: 40; width: 52px; height: 52px; border: 0; border-radius: 999px; background: var(--rm-button); color: #fff; box-shadow: 0 18px 36px rgba(22, 50, 61, 0.22); cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(12px); transition: opacity .2s ease, transform .2s ease, background .2s ease; }
.rm-top-btn.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.rm-top-btn:hover { background: var(--rm-button-hover); }
.rm-landing[data-theme="dark"] .rm-top-btn { color: #07141b; }
.rm-lightbox[hidden] { display: none; }
.rm-lightbox { position: fixed; inset: 0; z-index: 60; background: rgba(7, 20, 27, 0.82); padding: 24px; }
.rm-lightbox-dialog { position: relative; width: min(1100px, 100%); margin: 0 auto; min-height: calc(100vh - 48px); display: flex; align-items: center; justify-content: center; }
.rm-lightbox-figure { margin: 0; width: 100%; }
.rm-lightbox-image-wrap { position: relative; width: 100%; height: min(72vh, 820px); display: flex; align-items: center; justify-content: center; border-radius: 24px; overflow: hidden; border: 1px solid rgba(255, 255, 255, 0.12); background: rgba(11, 29, 39, 0.9); box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35); cursor: grab; touch-action: none; }
.rm-lightbox-image-wrap.is-dragging { cursor: grabbing; }
.rm-lightbox-image { width: auto; max-width: none; max-height: none; display: block; flex: 0 0 auto; background: #07141b; transform-origin: center center; will-change: width, height, transform; user-select: none; -webkit-user-drag: none; }
.rm-lightbox-toolbar { position: absolute; left: 18px; bottom: 18px; display: flex; gap: 10px; z-index: 2; }
.rm-lightbox-tool { appearance: none; border: 0; min-width: 44px; height: 44px; border-radius: 999px; background: rgba(7, 20, 27, 0.76); color: #edf6f8; cursor: pointer; font-size: 18px; font-weight: 700; line-height: 1; padding: 0 14px; }
.rm-lightbox-tool:hover { background: rgba(0, 151, 167, 0.92); color: #fff; }
.rm-lightbox-zoom { position: absolute; right: 18px; bottom: 18px; z-index: 2; padding: 8px 12px; border-radius: 999px; background: rgba(7, 20, 27, 0.76); color: #edf6f8; font-size: 12px; font-weight: 700; letter-spacing: .04em; }
.rm-lightbox-caption { display: flex; align-items: center; justify-content: space-between; gap: 16px; color: #edf6f8; padding: 16px 4px 0; }
.rm-lightbox-title { font-family: "Outfit", "Manrope", sans-serif; font-size: 1.4rem; margin: 0; }
.rm-lightbox-meta { color: rgba(237, 246, 248, 0.75); font-size: 0.95rem; }
.rm-lightbox-close, .rm-lightbox-nav { appearance: none; border: 0; cursor: pointer; }
.rm-lightbox-close { position: absolute; top: 18px; right: 18px; width: 44px; height: 44px; border-radius: 999px; background: rgba(7, 20, 27, 0.7); color: #edf6f8; font-size: 24px; line-height: 1; z-index: 2; }
.rm-lightbox-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 999px; background: rgba(7, 20, 27, 0.76); color: #edf6f8; font-size: 28px; line-height: 1; z-index: 2; }
.rm-lightbox-prev { left: 18px; }
.rm-lightbox-next { right: 18px; }
.rm-lightbox-close:hover, .rm-lightbox-nav:hover { background: rgba(0, 151, 167, 0.92); color: #fff; }
.rm-highlight { background: linear-gradient(135deg, #14343f 0%, #1f5d6c 100%); color: #f8fbfb; }
.rm-landing[data-theme="dark"] .rm-highlight { background: linear-gradient(135deg, #0f2f39 0%, #175566 100%); }
.rm-highlight .rm-section-title, .rm-highlight p, .rm-highlight h3, .rm-highlight .rm-step-copy, .rm-highlight .rm-eyebrow { color: #f8fbfb; }
.rm-list { list-style: none; margin: 0; padding: 0; }
.rm-list li { border-bottom: 1px solid var(--rm-line); padding: 14px 0; }
.rm-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.rm-footer { border-top: 1px solid var(--rm-line); padding: 28px 0 36px; }
.rm-footer-inner { display: grid; grid-template-columns: 1.3fr .7fr; gap: 24px; align-items: center; }
.rm-footer-brand { display: inline-flex; gap: 16px; align-items: center; }
.rm-footer-brand img { height: 52px; width: auto; }
.rm-footer-meta { display: grid; gap: 10px; justify-items: end; }
.rm-footer-links { display: flex; gap: 16px; flex-wrap: wrap; justify-content: flex-end; }
.rm-footer-links a, .rm-footer-credit a { color: var(--rm-soft); text-decoration: none; }
.rm-footer-links a:hover, .rm-footer-credit a:hover { color: var(--rm-accent); }
.rm-footer-credit { margin: 0; color: var(--rm-soft); text-align: right; }
@media (max-width: 980px) {
  .rm-nav { margin: 0 10px; border-radius: 28px; }
  .rm-nav-inner { gap: 16px; align-items: flex-start; }
  .rm-nav-controls { margin-left: auto; }
  .rm-menu-toggle { display: inline-flex; }
  .rm-menu { display: none; width: 100%; order: 3; flex-direction: column; align-items: stretch; gap: 0; padding-top: 12px; margin-top: 4px; border-top: 1px solid var(--rm-line); }
  .rm-menu.is-open { display: flex; }
  .rm-menu a { padding: 12px 4px; }
  .rm-hero-grid, .rm-section-header, .rm-grid-3, .rm-grid-2, .rm-footer-inner, .rm-panel-split, .rm-contact-grid, .rm-offer-grid, .rm-detail-grid, .rm-form-grid { grid-template-columns: 1fr; }
  .rm-panel-side { margin-top: 0; }
  .rm-flow-track { grid-template-columns: 1fr; }
  .rm-flow-track::before { left: 18px; right: auto; top: 12%; bottom: 12%; width: 2px; height: auto; }
  .rm-lightbox { padding: 16px; }
  .rm-lightbox-dialog { min-height: calc(100vh - 32px); }
  .rm-lightbox-image-wrap { height: min(62vh, 560px); }
  .rm-lightbox-caption { align-items: flex-start; flex-direction: column; }
  .rm-lightbox-nav { width: 44px; height: 44px; }
  .rm-lightbox-prev { left: 10px; }
  .rm-lightbox-next { right: 10px; }
  .rm-lightbox-toolbar { left: 10px; bottom: 10px; }
  .rm-lightbox-zoom { right: 10px; bottom: 10px; }
  .rm-gallery-track { grid-auto-flow: row; grid-auto-columns: unset; grid-template-columns: 1fr; overflow-x: visible; }
  .rm-gallery-prev { left: 22px; }
  .rm-gallery-next { right: 22px; }
  .rm-top-btn { right: 16px; bottom: 16px; }
  .rm-footer-meta, .rm-footer-credit { justify-items: start; text-align: left; }
  .rm-footer-links { justify-content: flex-start; }
}
  
  
  /* Integración WP Form Forge dentro de la landing */
.rm-tcf.tcf-form-wrapper { margin: 0; }

.rm-tcf .tcf-form {
  display: grid;
  gap: 14px;
}

.rm-tcf .tcf-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 0;
}

.rm-tcf .tcf-col {
  max-width: 100%;
  flex-basis: auto;
  padding: 0;
}

.rm-tcf .tcf-field {
  display: grid;
  gap: 8px;
  margin: 0;
}

.rm-tcf .tcf-label {
  color: var(--rm-text);
  font-size: .94rem;
  font-weight: 700;
  margin: 0;
}

.rm-tcf input,
.rm-tcf select,
.rm-tcf textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--rm-line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--rm-panel-strong) 88%, transparent);
  color: var(--rm-text);
  font: inherit;
}

.rm-tcf textarea { min-height: 150px; resize: vertical; }

.rm-tcf .tcf-submit-button {
  display: inline-block;
  padding: 14px 22px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  border: 1px solid var(--rm-button);
  background: var(--rm-button);
  color: #fff;
  cursor: pointer;
}

.rm-tcf .tcf-submit-button:hover { background: var(--rm-button-hover); }

.rm-tcf .tcf-message { border-radius: 16px; }

@media (max-width: 980px) {
  .rm-tcf .tcf-row { grid-template-columns: 1fr; }
}







/* ─── Toggle wrapper ─────────────────────────────── */
.rm-theme-toggle-wrap {
  display: flex;
  align-items: center;
  margin-left: 1rem;
}

.rm-theme-toggle {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
}

.rm-theme-toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* ─── Track (fondo del switch) ───────────────────── */
.rm-toggle-track {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 56px;
  height: 28px;
  border-radius: 999px;
  background: rgba(0, 151, 167, 0.15);
  border: 1px solid rgba(0, 151, 167, 0.3);
  transition: background 0.3s ease, border-color 0.3s ease;
  padding: 0 4px;
  box-sizing: border-box;
}

/* ─── Iconos ☀️ 🌙 ───────────────────────────────── */
.rm-toggle-icon {
  position: absolute;
  font-size: 13px;
  line-height: 1;
  transition: opacity 0.3s ease;
  user-select: none;
}

.rm-icon-sun  { left: 5px;  opacity: 1; }
.rm-icon-moon { right: 5px; opacity: 0.4; }

/* ─── Thumb (bolita deslizante) ──────────────────── */
.rm-toggle-thumb {
  position: absolute;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #0097a7;
  box-shadow: 0 1px 4px rgba(0,0,0,0.18);
  transition: transform 0.3s cubic-bezier(.4,0,.2,1), background 0.3s ease;
}

/* ─── Estado OSCURO (checked) ────────────────────── */
.rm-theme-toggle input:checked ~ .rm-toggle-track {
  background: rgba(30, 30, 50, 0.5);
  border-color: rgba(98, 215, 224, 0.4);
}

.rm-theme-toggle input:checked ~ .rm-toggle-track .rm-toggle-thumb {
  transform: translateX(28px);
  background: #62d7e0;
}

.rm-theme-toggle input:checked ~ .rm-toggle-track .rm-icon-sun  { opacity: 0.4; }
.rm-theme-toggle input:checked ~ .rm-toggle-track .rm-icon-moon { opacity: 1; }

/* ─── Variables modo OSCURO ──────────────────────── */
:root.rm-dark,
:root.rm-dark .rm-landing {
  --rm-bg:
    radial-gradient(circle at top left, rgba(0, 177, 190, 0.10), transparent 38%),
    radial-gradient(circle at 85% 15%, rgba(246, 173, 85, 0.08), transparent 24%),
    linear-gradient(180deg, #0d1f26 0%, #112028 46%, #0f1a20 100%);
  --rm-text:          #e8f4f6;
  --rm-muted:         rgba(220, 240, 245, 0.75);
  --rm-soft:          rgba(220, 240, 245, 0.60);
  --rm-line:          rgba(98, 215, 224, 0.12);
  --rm-panel:         rgba(15, 35, 45, 0.75);
  --rm-panel-strong:  rgba(15, 35, 45, 0.90);
  --rm-accent:        #62d7e0;
  --rm-accent-2:      #0097a7;
  --rm-button:        #62d7e0;
  --rm-button-hover:  #7de0e8;
  --rm-surface-end:   #0d1f26;
  --rm-hero-overlay:  linear-gradient(
    90deg,
    rgba(13, 31, 38, 0.95) 0%,
    rgba(13, 31, 38, 0.82) 46%,
    rgba(13, 31, 38, 0.22) 100%
  );
}

/* Fondo del body en modo oscuro */
:root.rm-dark body {
  background: var(--rm-bg) !important;
  color: var(--rm-text) !important;
}