/* ============================================
   MUDANZAS LA SEDA SORIA — CSS 2026 EDITION
   Diseño premium con scroll-animations,
   glassmorphism 2.0, bento grids y gradient mesh
   ============================================ */
/* Google Font: cargar via link en el HTML, NO aqui */
/* ============================================
   CUSTOM PROPERTIES — DESIGN TOKENS 2026
   ============================================ */
:root {
    /* Primary palette - warm amber tones */
    --ms-amber-50: #fffbeb;
    --ms-amber-100: #fef3c7;
    --ms-amber-200: #fde68a;
    --ms-amber-300: #fcd34d;
    --ms-amber-400: #f4a460;
    --ms-amber-500: #e69350;
    --ms-amber-600: #d97706;
    --ms-amber-700: #b45309;
    /* Neutral palette - refined warm grays */
    --ms-stone-50: #fafaf9;
    --ms-stone-100: #f5f5f4;
    --ms-stone-200: #e7e5e4;
    --ms-stone-300: #d6d3d1;
    --ms-stone-400: #a8a29e;
    --ms-stone-500: #78716c;
    --ms-stone-600: #57534e;
    --ms-stone-700: #44403c;
    --ms-stone-800: #292524;
    --ms-stone-900: #1c1917;
    --ms-stone-950: #0f0e0d;
    /* Accent */
    --ms-accent: #f4a460;
    --ms-accent-hover: #e69350;
    --ms-accent-glow: rgba(244, 164, 96, 0.35);
    --ms-brown: #7c6e64;
    --ms-brown-dark: #5c4f46;
    --ms-white: #ffffff;
    /* Shadows — layered depth system */
    --ms-shadow-xs: 0 1px 2px rgba(28, 25, 23, 0.04);
    --ms-shadow-sm: 0 2px 8px rgba(28, 25, 23, 0.06);
    --ms-shadow-md: 0 8px 24px rgba(28, 25, 23, 0.08);
    --ms-shadow-lg: 0 16px 48px rgba(28, 25, 23, 0.10);
    --ms-shadow-xl: 0 24px 64px rgba(28, 25, 23, 0.14);
    --ms-shadow-accent: 0 12px 40px rgba(244, 164, 96, 0.25);
    --ms-shadow-accent-lg: 0 20px 60px rgba(244, 164, 96, 0.35);
    /* Radius — organic system */
    --ms-radius-sm: 12px;
    --ms-radius-md: 20px;
    --ms-radius-lg: 28px;
    --ms-radius-xl: 40px;
    --ms-radius-2xl: 48px;
    --ms-radius-pill: 100px;
    /* Transitions */
    --ms-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --ms-ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
    --ms-duration: 0.4s;
    --ms-duration-slow: 0.6s;
}
/* ============================================
   SCROLL-DRIVEN ANIMATION KEYFRAMES
   ============================================ */
@keyframes ms-fade-up {
    from {
        opacity: 0;
        transform: translateY(40px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes ms-fade-scale {
    from {
        opacity: 0;
        transform: scale(0.92);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}
@keyframes ms-slide-left {
    from {
        opacity: 0;
        transform: translateX(-60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
@keyframes ms-slide-right {
    from {
        opacity: 0;
        transform: translateX(60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
@keyframes ms-hero-float {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-12px);
    }
}
@keyframes ms-pulse-ring {
    0% {
        transform: scale(1);
        opacity: 1;
    }
    100% {
        transform: scale(1.8);
        opacity: 0;
    }
}
@keyframes ms-shimmer {
    from {
        background-position: -200% center;
    }
    to {
        background-position: 200% center;
    }
}
@keyframes ms-gradient-rotate {
    to {
        --gradient-angle: 360deg;
    }
}
@keyframes ms-glow-pulse {
    0%,
    100% {
        --glow-opacity: 0.3;
    }
    50% {
        --glow-opacity: 0.7;
    }
}
/* ============================================
   ASTRA RESET — MÍNIMO
   ============================================ */
body,
.ast-separate-container,
.ast-page-builder-template .site-content>.ast-container {
    background-color: var(--ms-white) !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
}
.entry-content {
    font-family: 'Inter', sans-serif !important;
    color: var(--ms-stone-700) !important;
    line-height: 1.7 !important;
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
}
.page .entry-header,
.ast-archive-description {
    display: none !important;
}
.ast-page-builder-template .site-content>.ast-container,
.ast-plain-container,
.entry-content>* {
    max-width: 100% !important;
}
.ast-separate-container .ast-article-single,
.ast-separate-container .entry-content,
.ast-separate-container .ast-article-post,
.ast-plain-container .site-content .ast-container,
.ast-page-builder-template .entry-content,
.site-content .ast-container {
    padding: 0 !important;
    margin: 0 auto !important;
    max-width: 100% !important;
}
.entry-content>.wp-block-html,
.entry-content>div,
.entry-content>section,
.entry-content>footer {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.entry-content>*:first-child {
    margin-top: 0 !important;
}
.entry-content>*:last-child {
    margin-bottom: 0 !important;
}
article.page,
article.post {
    padding: 0 !important;
    margin: 0 !important;
}
#primary,
#content,
.site-main,
.content-area {
    padding: 0 !important;
    max-width: 100% !important;
}
.ast-separate-container .ast-article-single .entry-content {
    padding: 0 !important;
}
.ast-separate-container .ast-article-single {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
}
.site-content,
#content.site-content,
.ast-separate-container #primary,
.ast-plain-container #primary {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
.site-footer,
.ast-footer-overlay,
footer.site-footer,
#colophon {
    display: none !important;
}
.ast-separate-container .ast-article-single,
.ast-separate-container #primary,
.site-main {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}
/* ============================================
   MS-PAGE WRAPPER
   ============================================ */
.ms-page {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--ms-stone-700);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.ms-page *,
.ms-page *::before,
.ms-page *::after {
    box-sizing: border-box;
}
/* ============================================
   WPAUTOP PROTECTION
   ============================================ */
.ms-page .ms-barrios-grid>p,
.ms-page .ms-municipios-grid>p,
.ms-page .ms-logistics-grid>p,
.ms-page .ms-travel-times-grid>p,
.ms-page .ms-location-stats-grid>p,
.ms-page .ms-location-services-grid>p,
.ms-page .ms-services-grid>p,
.ms-page .ms-areas-grid>p,
.ms-page .ms-areas-grid>br,
.ms-page .ms-stats-grid>p,
.ms-page .ms-check-grid>p,
.ms-page .ms-testimonials-grid>p,
.ms-page .ms-footer-grid>p,
.ms-page .ms-trust-grid>p,
.ms-page .ms-detail-stats>p,
.ms-page .ms-detail-content>p,
.ms-page .ms-detail-sidebar>p,
.ms-page .ms-detail-pricing-row>p,
.ms-page .ms-hero-actions>p,
.ms-page .ms-detail-actions>p,
.ms-page .ms-detail-banner-actions>p,
.ms-page .ms-footer-social>p,
.ms-page .ms-footer-legal>p,
.ms-page .ms-todo-incluido-grid>p,
.ms-page .ms-features-grid>p,
.ms-page .ms-intro-grid>p,
.ms-page .ms-servicios-4col-grid>p,
.ms-page .ms-presupuesto-features-grid>p,
.ms-page .ms-presupuesto-contact-grid>p,
.ms-page .ms-bento-grid>p,
.ms-page .ms-muni-hero-grid>p,
.ms-page .ms-muni-hero-actions>p,
.ms-page .ms-muni-content>p,
.ms-page .ms-muni-ficha-grid>p,
.ms-page .ms-muni-garantias-grid>p,
.ms-page .ms-muni-banner-actions>p {
    display: contents !important;
    margin: 0 !important;
    padding: 0 !important;
}
.ms-page p:empty,
.ms-page .ms-container>p:empty,
.ms-page .ms-brown-box>p:empty,
.ms-page .ms-travel-box>p,
.ms-page .ms-travel-content>p:empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    line-height: 0 !important;
}
.ms-page .ms-barrios-grid br,
.ms-page .ms-municipios-grid br,
.ms-page .ms-logistics-grid br,
.ms-page .ms-travel-times-grid br,
.ms-page .ms-location-stats-grid br,
.ms-page .ms-location-services-grid br,
.ms-page .ms-services-grid br,
.ms-page .ms-areas-grid br,
.ms-page .ms-areas-grid>p:empty,
.ms-page .ms-stats-grid br,
.ms-page .ms-check-grid br,
.ms-page .ms-testimonials-grid br,
.ms-page .ms-footer-grid br,
.ms-page .ms-trust-grid br,
.ms-page .ms-detail-stats br,
.ms-page .ms-detail-content br,
.ms-page .ms-detail-sidebar br,
.ms-page .ms-hero-actions br,
.ms-page .ms-detail-actions br,
.ms-page .ms-pricing-table br,
.ms-page .ms-detail-pricing-row br,
.ms-page .ms-todo-incluido-grid br,
.ms-page .ms-features-grid br,
.ms-page .ms-intro-grid br,
.ms-page .ms-servicios-4col-grid br,
.ms-page .ms-presupuesto-features-grid br,
.ms-page .ms-presupuesto-contact-grid br,
.ms-page .ms-bento-grid br,
.ms-page .ms-muni-hero-grid br,
.ms-page .ms-muni-hero-actions br,
.ms-page .ms-muni-content br,
.ms-page .ms-muni-ficha-grid br,
.ms-page .ms-muni-garantias-grid br,
.ms-page .ms-muni-banner-actions br {
    display: none !important;
}
.ms-page .ms-area-card>p,
.ms-page .ms-guard-card>p {
    display: contents !important;
    margin: 0 !important;
    padding: 0 !important;
}
.ms-page .ms-area-card br,
.ms-page .ms-guard-card br {
    display: none !important;
}
.ms-page [class*="ms-"] p {
    margin-top: 0;
}
/* ============================================
   SCROLL-TRIGGERED ANIMATIONS (CSS only)
   ============================================ */
.ms-animate {
    animation: ms-fade-up var(--ms-duration-slow) var(--ms-ease) both;
    animation-timeline: view();
    animation-range: entry 0% entry 35%;
}
.ms-animate-scale {
    animation: ms-fade-scale var(--ms-duration-slow) var(--ms-ease) both;
    animation-timeline: view();
    animation-range: entry 0% entry 35%;
}
.ms-animate-left {
    animation: ms-slide-left var(--ms-duration-slow) var(--ms-ease) both;
    animation-timeline: view();
    animation-range: entry 0% entry 35%;
}
.ms-animate-right {
    animation: ms-slide-right var(--ms-duration-slow) var(--ms-ease) both;
    animation-timeline: view();
    animation-range: entry 0% entry 35%;
}
/* Staggered children */
.ms-stagger>*:nth-child(1) {
    animation-delay: 0s;
}
.ms-stagger>*:nth-child(2) {
    animation-delay: 0.08s;
}
.ms-stagger>*:nth-child(3) {
    animation-delay: 0.16s;
}
.ms-stagger>*:nth-child(4) {
    animation-delay: 0.24s;
}
.ms-stagger>*:nth-child(5) {
    animation-delay: 0.32s;
}
.ms-stagger>*:nth-child(6) {
    animation-delay: 0.40s;
}
.ms-stagger>*:nth-child(7) {
    animation-delay: 0.48s;
}
.ms-stagger>*:nth-child(8) {
    animation-delay: 0.56s;
}
.ms-stagger>*:nth-child(9) {
    animation-delay: 0.64s;
}
/* ============================================
   LAYOUT — SECTIONS & CONTAINER
   ============================================ */
.ms-page .ms-section {
    padding: 120px 24px;
    position: relative;
}
.ms-page .ms-section-light {
    background: var(--ms-white);
}
.ms-page .ms-section-gray {
    background: var(--ms-stone-50);
    border-top: 1px solid rgba(0, 0, 0, 0.03);
    border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}
.ms-page .ms-container {
    max-width: 1280px;
    margin: 0 auto;
}
.ms-page .ms-section-label {
    color: var(--ms-accent) !important;
    font-weight: 800 !important;
    letter-spacing: 5px !important;
    text-transform: uppercase !important;
    font-size: 11px !important;
    margin-bottom: 16px !important;
    text-align: center !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 12px;
}
.ms-page .ms-section-label::before,
.ms-page .ms-section-label::after {
    content: '';
    width: 24px;
    height: 1px;
    background: var(--ms-accent);
    opacity: 0.5;
}
.ms-page .ms-section-title {
    font-size: clamp(2.2rem, 5vw, 3.5rem) !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    text-align: center !important;
    margin-bottom: 24px !important;
    letter-spacing: -1.5px !important;
    line-height: 1.08 !important;
}
.ms-page .ms-section-divider {
    width: 64px;
    height: 3px;
    background: linear-gradient(90deg, var(--ms-accent), var(--ms-amber-300));
    margin: 0 auto 60px;
    border-radius: 4px;
}
/* ============================================
   HERO — Immersive 2026
   ============================================ */
.ms-page .ms-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding-top: 80px;
    overflow: hidden;
}
.ms-page .ms-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.ms-page .ms-hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.05);
    animation: ms-hero-zoom 20s ease-in-out infinite alternate;
}
@keyframes ms-hero-zoom {
    from {
        transform: scale(1.05);
    }
    to {
        transform: scale(1.12);
    }
}
.ms-page .ms-hero-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(15, 14, 13, 0.95) 0%, rgba(28, 25, 23, 0.85) 40%, rgba(41, 37, 36, 0.6) 70%, transparent 100%),
        linear-gradient(to bottom, transparent 60%, rgba(15, 14, 13, 0.4) 100%);
}
.ms-page .ms-hero-content {
    position: relative;
    z-index: 10;
    max-width: 800px;
    padding: 0 24px;
    margin: 0 auto;
    color: white;
}
.ms-page .ms-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(244, 164, 96, 0.12);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(244, 164, 96, 0.2);
    padding: 10px 22px;
    border-radius: var(--ms-radius-pill);
    margin-bottom: 32px;
}
.ms-page .ms-badge-dot {
    width: 10px;
    height: 10px;
    background: var(--ms-accent);
    border-radius: 50%;
    position: relative;
}
.ms-page .ms-badge-dot::after {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    border: 2px solid var(--ms-accent);
    animation: ms-pulse-ring 2s var(--ms-ease) infinite;
}
.ms-page .ms-badge-text {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--ms-accent);
}
.ms-page .ms-hero h1 {
    font-size: clamp(3.2rem, 8vw, 6.5rem) !important;
    font-weight: 900 !important;
    line-height: 0.95 !important;
    margin-bottom: 32px !important;
    letter-spacing: -3px;
    color: white !important;
}
.ms-page .ms-hero h1 span {
    color: var(--ms-accent) !important;
    display: inline-block;
}
.ms-page .ms-hero-subtitle {
    font-size: 1.2rem;
    color: var(--ms-stone-300);
    margin-bottom: 48px;
    line-height: 1.8;
    font-weight: 400;
    max-width: 560px;
}
.ms-page .ms-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center;
}
/* ============================================
   BUTTONS — Refined 2026
   ============================================ */
.ms-page .ms-btn-primary,
.ms-page .wp-block-button__link {
    background: linear-gradient(135deg, var(--ms-accent), var(--ms-amber-500)) !important;
    color: white !important;
    padding: 18px 44px !important;
    border-radius: var(--ms-radius-sm) !important;
    font-weight: 800 !important;
    font-size: 0.875rem !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    border: none !important;
    cursor: pointer;
    transition: all var(--ms-duration) var(--ms-ease) !important;
    box-shadow: var(--ms-shadow-accent) !important;
    display: inline-block;
    text-decoration: none !important;
    position: relative;
    overflow: hidden;
}
.ms-page .ms-btn-primary::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.2) 50%, transparent 60%);
    background-size: 200% 100%;
    animation: ms-shimmer 3s linear infinite;
    pointer-events: none;
}
.ms-page .ms-btn-primary:hover,
.ms-page .wp-block-button__link:hover {
    transform: translateY(-3px) scale(1.02) !important;
    box-shadow: var(--ms-shadow-accent-lg) !important;
    filter: brightness(1.1);
}
.ms-page .ms-btn-secondary {
    background: var(--ms-brown) !important;
    color: white !important;
    padding: 16px 40px !important;
    border-radius: var(--ms-radius-sm) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    font-size: 0.8rem !important;
    border: none !important;
    transition: all var(--ms-duration) var(--ms-ease) !important;
    text-decoration: none !important;
    display: inline-block;
}
.ms-page .ms-btn-secondary:hover {
    background: var(--ms-stone-800) !important;
    transform: translateY(-2px) !important;
}
/* Phone box — glassmorphism */
.ms-page .ms-phone-box {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 18px 28px;
    background: rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: var(--ms-radius-md);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-phone-box:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(244, 164, 96, 0.3);
}
.ms-page .ms-phone-icon {
    width: 44px;
    height: 44px;
    background: var(--ms-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}
.ms-page .ms-phone-label {
    font-size: 9px;
    color: var(--ms-accent);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 3px;
    margin-bottom: 2px;
}
.ms-page .ms-phone-number {
    font-size: 1.6rem;
    font-weight: 900;
    color: white;
    letter-spacing: -1px;
    text-decoration: none;
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-phone-number:hover {
    color: var(--ms-accent);
}
/* ============================================
   TRUST BAR — Refined glassmorphism
   ============================================ */
.ms-page .ms-trust {
    background: linear-gradient(180deg, var(--ms-stone-50), var(--ms-white));
    border-top: 1px solid rgba(0, 0, 0, 0.04);
    border-bottom: 1px solid rgba(0, 0, 0, 0.04);
    padding: 48px 24px;
}
.ms-page .ms-trust-label {
    text-align: center;
    font-size: 9px;
    font-weight: 800;
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 6px;
    margin-bottom: 40px;
}
.ms-page .ms-trust-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 48px;
    opacity: 0.5;
    transition: all 0.6s var(--ms-ease);
    filter: grayscale(100%);
}
.ms-page .ms-trust-grid:hover {
    opacity: 1;
    filter: grayscale(0%);
}
.ms-page .ms-trust-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    transition: transform var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-trust-item:hover {
    transform: translateY(-4px);
}
.ms-page .ms-trust-icon {
    font-size: 2.5rem;
}
.ms-page .ms-trust-name {
    font-size: 9px;
    font-weight: 900;
    color: var(--ms-stone-800);
    text-transform: uppercase;
    letter-spacing: 3px;
}
/* ============================================
   STATS — Bento-inspired cards
   ============================================ */
.ms-page .ms-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}
.ms-page .ms-stat-card {
    background: var(--ms-stone-50);
    padding: 36px;
    border-radius: var(--ms-radius-lg);
    border: 1px solid var(--ms-stone-100);
    text-align: center;
    transition: all var(--ms-duration) var(--ms-ease);
    position: relative;
    overflow: hidden;
}
.ms-page .ms-stat-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(244, 164, 96, 0.08) 0%, transparent 60%);
    opacity: 0;
    transition: opacity var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-stat-card:hover {
    border-color: var(--ms-accent);
    transform: translateY(-4px);
}
.ms-page .ms-stat-card:hover::before {
    opacity: 1;
}
.ms-page .ms-stat-icon {
    font-size: 2rem;
    margin-bottom: 12px;
    display: block;
    transition: transform var(--ms-duration) var(--ms-ease-bounce);
}
.ms-page .ms-stat-card:hover .ms-stat-icon {
    transform: scale(1.2) rotate(5deg);
}
.ms-page .ms-stat-value {
    font-size: 2.2rem;
    font-weight: 900;
    color: var(--ms-stone-900);
    letter-spacing: -2px;
    margin-bottom: 4px;
}
.ms-page .ms-stat-label {
    font-size: 9px;
    font-weight: 800;
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 3px;
}
/* ============================================
   BROWN BOX — Gradient mesh 2026
   ============================================ */
.ms-page .ms-brown-box {
    background: linear-gradient(135deg, var(--ms-brown) 0%, var(--ms-brown-dark) 100%) !important;
    color: white !important;
    padding: 56px 72px !important;
    border-radius: var(--ms-radius-2xl) !important;
    position: relative;
    overflow: hidden;
}
.ms-page .ms-brown-box::before {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(244, 164, 96, 0.12) 0%, transparent 70%);
    pointer-events: none;
}
.ms-page .ms-brown-box::after {
    content: '';
    position: absolute;
    bottom: -80px;
    left: -60px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.04) 0%, transparent 70%);
    pointer-events: none;
}
.ms-page .ms-brown-box h3,
.ms-page .ms-brown-box h4 {
    color: white !important;
    font-size: 1.8rem !important;
    font-weight: 900 !important;
    margin-bottom: 32px !important;
    position: relative;
}
.ms-page .ms-check-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 48px;
}
.ms-page .ms-check-item {
    display: flex;
    align-items: center;
    gap: 14px;
}
.ms-page .ms-check-icon {
    width: 28px;
    height: 28px;
    background: var(--ms-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
    flex-shrink: 0;
}
.ms-page .ms-check-text {
    font-size: 1rem;
    font-weight: 600;
    color: var(--ms-stone-100);
}
/* ============================================
   SERVICE CARDS — 3D hover with depth
   ============================================ */
.ms-page .ms-services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.ms-page .ms-service-card {
    background: white;
    border: 1px solid var(--ms-stone-200);
    border-radius: var(--ms-radius-xl);
    padding: 40px;
    transition: all var(--ms-duration-slow) var(--ms-ease);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.ms-page .ms-service-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--ms-accent), var(--ms-amber-300));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--ms-duration-slow) var(--ms-ease);
}
.ms-page .ms-service-card:hover {
    border-color: transparent;
    box-shadow: var(--ms-shadow-lg);
    transform: translateY(-8px);
}
.ms-page .ms-service-card:hover::before {
    transform: scaleX(1);
}
.ms-page .ms-service-icon {
    width: 72px;
    height: 72px;
    background: linear-gradient(135deg, var(--ms-stone-50), var(--ms-stone-100));
    border-radius: var(--ms-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    margin-bottom: 28px;
    transition: all var(--ms-duration-slow) var(--ms-ease);
}
.ms-page .ms-service-card:hover .ms-service-icon {
    background: linear-gradient(135deg, var(--ms-accent), var(--ms-amber-500));
    transform: scale(1.08);
    box-shadow: var(--ms-shadow-accent);
}
.ms-page .ms-service-title {
    font-size: 1.35rem !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    margin-bottom: 12px !important;
    letter-spacing: -0.5px;
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-service-card:hover .ms-service-title {
    color: var(--ms-brown) !important;
}
.ms-page .ms-service-desc {
    color: var(--ms-stone-500);
    line-height: 1.7;
    margin-bottom: 28px;
    flex-grow: 1;
    font-size: 0.95rem;
}
.ms-page .ms-service-bullets {
    border-top: 1px solid var(--ms-stone-100);
    padding-top: 20px;
    list-style: none !important;
    margin: 0 !important;
    padding-left: 0 !important;
}
.ms-page .ms-service-bullets li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--ms-stone-400);
    padding: 6px 0;
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-service-bullets li::before {
    content: '';
    width: 6px;
    height: 6px;
    background: var(--ms-accent);
    border-radius: 50%;
    flex-shrink: 0;
}
.ms-page .ms-service-card:hover .ms-service-bullets li {
    color: var(--ms-stone-600);
}
.ms-page a.ms-service-card {
    display: flex !important;
    flex-direction: column !important;
    color: inherit !important;
    text-decoration: none !important;
}
/* ============================================
   PRICING TABLE — Elegant 2026
   ============================================ */
.ms-page .ms-pricing-table {
    background: white;
    border-radius: var(--ms-radius-xl);
    box-shadow: var(--ms-shadow-xl);
    overflow: hidden;
    border: 1px solid var(--ms-stone-100);
    max-width: 900px;
    margin: 0 auto;
}
.ms-page .ms-pricing-header {
    background: linear-gradient(135deg, var(--ms-brown), var(--ms-brown-dark));
    padding: 24px 36px;
    display: grid;
    grid-template-columns: 1fr auto;
    color: white;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 3px;
    font-size: 0.8rem;
}
.ms-page .ms-pricing-row {
    display: grid;
    grid-template-columns: 1fr auto;
    padding: 22px 36px;
    border-bottom: 1px solid var(--ms-stone-100);
    align-items: center;
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-pricing-row:hover {
    background: var(--ms-stone-50);
    padding-left: 44px;
}
.ms-page .ms-pricing-item {
    font-weight: 700;
    color: var(--ms-stone-700);
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-pricing-row:hover .ms-pricing-item {
    color: var(--ms-stone-900);
}
.ms-page .ms-pricing-price {
    font-weight: 900;
    font-size: 1.2rem;
    color: var(--ms-accent);
    letter-spacing: -0.5px;
}
.ms-page .ms-pricing-footer {
    padding: 28px 36px;
    background: var(--ms-stone-50);
    text-align: center;
    color: var(--ms-stone-400);
    font-size: 0.72rem;
    font-style: italic;
}
/* ============================================
   FAQ — Smooth accordion
   ============================================ */
.ms-page .ms-faq-list {
    max-width: 900px;
    margin: 0 auto;
}
.ms-page .ms-faq-item {
    background: var(--ms-stone-50);
    border-radius: var(--ms-radius-md);
    overflow: hidden;
    margin-bottom: 16px;
    border: 1px solid var(--ms-stone-100);
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-faq-item:hover {
    border-color: rgba(244, 164, 96, 0.25);
}
.ms-page .ms-faq-question {
    width: 100%;
    text-align: left;
    padding: 28px 32px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 800;
    font-size: 1.1rem;
    color: var(--ms-stone-800);
    background: none;
    border: none;
    cursor: pointer;
    transition: color var(--ms-duration) var(--ms-ease);
    gap: 16px;
}
.ms-page .ms-faq-question:hover {
    color: var(--ms-accent);
}
.ms-page .ms-faq-toggle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--ms-stone-200);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ms-stone-300);
    font-size: 1rem;
    flex-shrink: 0;
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-faq-item.active .ms-faq-toggle {
    background: var(--ms-accent);
    border-color: var(--ms-accent);
    color: white;
    transform: rotate(180deg);
}
.ms-page .ms-faq-item.active .ms-faq-question {
    color: var(--ms-accent);
}
.ms-page .ms-faq-answer {
    padding: 0 32px 28px;
    background: white;
    border-top: 1px solid var(--ms-stone-100);
    color: var(--ms-stone-500);
    font-size: 1rem;
    line-height: 1.8;
    font-weight: 500;
}
/* ============================================
   TESTIMONIALS — Premium glass cards
   ============================================ */
.ms-page .ms-testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.ms-page .ms-testimonial-card {
    background: white;
    padding: 44px;
    border-radius: var(--ms-radius-xl);
    border: 1px solid var(--ms-stone-100);
    box-shadow: var(--ms-shadow-sm);
    transition: all var(--ms-duration) var(--ms-ease);
    position: relative;
    text-align: center;
}
.ms-page .ms-testimonial-card:hover {
    box-shadow: var(--ms-shadow-lg);
    transform: translateY(-6px);
}
.ms-page .ms-testimonial-quote {
    position: absolute;
    top: 28px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 2.5rem;
    color: var(--ms-accent);
    opacity: 0.15;
}
.ms-page .ms-testimonial-stars {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-bottom: 20px;
    color: #facc15;
    font-size: 1.1rem;
}
.ms-page .ms-testimonial-text {
    color: var(--ms-stone-700);
    font-size: 1rem;
    line-height: 1.8;
    font-style: italic;
    margin-bottom: 28px;
}
.ms-page .ms-testimonial-author {
    padding-top: 20px;
    border-top: 1px solid var(--ms-stone-100);
}
.ms-page .ms-testimonial-name {
    font-weight: 900;
    color: var(--ms-stone-900);
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.8rem;
    margin-bottom: 4px;
}
.ms-page .ms-testimonial-location {
    font-size: 9px;
    font-weight: 700;
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 3px;
}
/* ============================================
   FORM SECTION — Immersive CTA
   ============================================ */
.ms-page .ms-form-section {
    background: linear-gradient(135deg, var(--ms-brown-dark) 0%, var(--ms-brown) 50%, var(--ms-stone-700) 100%);
    padding: 120px 24px;
    position: relative;
    overflow: hidden;
}
.ms-page .ms-form-section::before {
    content: '';
    position: absolute;
    top: -200px;
    right: -200px;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(244, 164, 96, 0.15) 0%, transparent 70%);
    pointer-events: none;
}
.ms-page .ms-form-title {
    text-align: center;
    color: white !important;
    font-size: clamp(2rem, 5vw, 3.5rem) !important;
    font-weight: 900 !important;
    margin-bottom: 20px !important;
    letter-spacing: -1px;
}
.ms-page .ms-form-subtitle {
    text-align: center;
    color: rgba(255, 200, 150, 0.85);
    font-size: 1.15rem;
    font-weight: 400;
    margin-bottom: 56px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}
.ms-page .ms-form-box {
    max-width: 900px;
    margin: 0 auto;
    background: white;
    border-radius: var(--ms-radius-xl);
    padding: 56px 72px;
    box-shadow: var(--ms-shadow-xl);
    border-top: 4px solid var(--ms-accent);
    position: relative;
}
/* Form inputs */
.ms-page .wpcf7-form,
.ms-page .wpforms-form {
    display: grid;
    gap: 20px;
}
.ms-page .wpcf7-form input[type="text"],
.ms-page .wpcf7-form input[type="email"],
.ms-page .wpcf7-form input[type="tel"],
.ms-page .wpcf7-form input[type="number"],
.ms-page .wpcf7-form textarea,
.ms-page .wpcf7-form select,
.ms-page .wpforms-form input,
.ms-page .wpforms-form textarea,
.ms-page .wpforms-form select {
    width: 100% !important;
    padding: 16px 22px !important;
    border: 2px solid var(--ms-stone-200) !important;
    border-radius: var(--ms-radius-sm) !important;
    font-size: 0.95rem !important;
    font-family: 'Inter', sans-serif !important;
    background: white !important;
    transition: all var(--ms-duration) var(--ms-ease) !important;
}
.ms-page .wpcf7-form input:focus,
.ms-page .wpcf7-form textarea:focus,
.ms-page .wpcf7-form select:focus {
    border-color: var(--ms-accent) !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(244, 164, 96, 0.12) !important;
}
.ms-page .wpcf7-form input[type="submit"],
.ms-page .wpforms-form button[type="submit"] {
    background: linear-gradient(135deg, var(--ms-accent), var(--ms-amber-500)) !important;
    color: white !important;
    padding: 18px 44px !important;
    border: none !important;
    border-radius: var(--ms-radius-sm) !important;
    font-size: 0.875rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    cursor: pointer !important;
    transition: all var(--ms-duration) var(--ms-ease) !important;
    width: auto !important;
}
.ms-page .wpcf7-form input[type="submit"]:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--ms-shadow-accent) !important;
}
/* ============================================
   LOGISTICS GRID
   ============================================ */
.ms-page .ms-logistics-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
}
.ms-page .ms-logistics-card {
    background: var(--ms-stone-50);
    padding: 44px;
    border-radius: var(--ms-radius-xl);
    border: 1px solid var(--ms-stone-100);
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-logistics-card:hover {
    border-color: var(--ms-accent);
    box-shadow: var(--ms-shadow-md);
}
/* ============================================
   INTRO GRID
   ============================================ */
.ms-page .ms-intro-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 64px !important;
    align-items: center;
}
/* ============================================
   TODO INCLUIDO GRID
   ============================================ */
.ms-page .ms-todo-incluido-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 72px !important;
    align-items: center;
}
.ms-page .ms-features-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
}
/* ============================================
   BARRIOS & MUNICIPIOS TAGS
   ============================================ */
.ms-page .ms-barrios-grid {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 14px !important;
    margin-bottom: 56px;
}
.ms-page .ms-municipios-grid {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 14px !important;
    margin-bottom: 72px;
}
.ms-page .ms-area-tag {
    background: white;
    padding: 18px;
    border-radius: var(--ms-radius-sm);
    border: 1px solid var(--ms-stone-100);
    text-align: center;
    font-weight: 800;
    text-transform: uppercase;
    font-size: 0.55rem;
    letter-spacing: 3px;
    color: var(--ms-stone-600);
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-area-tag:hover {
    border-color: var(--ms-accent);
    color: var(--ms-accent);
    transform: translateY(-2px);
}
.ms-page .ms-municipality-tag {
    background: var(--ms-stone-100);
    padding: 18px;
    border-radius: var(--ms-radius-sm);
    text-align: center;
    font-weight: 800;
    text-transform: uppercase;
    font-size: 0.55rem;
    letter-spacing: 3px;
    color: var(--ms-stone-600);
    text-decoration: none;
    display: block;
    transition: all var(--ms-duration) var(--ms-ease);
    border: 1px solid transparent;
}
.ms-page .ms-municipality-tag:hover {
    background: var(--ms-brown);
    color: white;
    transform: translateY(-2px);
    box-shadow: var(--ms-shadow-sm);
}
.ms-page a.ms-municipality-tag {
    cursor: pointer;
}
.ms-page .ms-zones-section-title {
    font-size: 1.1rem;
    font-weight: 900;
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 5px;
    margin-bottom: 36px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--ms-stone-200);
}
/* ============================================
   TRAVEL BOX — Gradient depth
   ============================================ */
.ms-page .ms-travel-box {
    background: linear-gradient(135deg, var(--ms-brown), var(--ms-brown-dark));
    border-radius: var(--ms-radius-2xl);
    padding: 48px 60px;
    color: white;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    box-shadow: var(--ms-shadow-lg);
    position: relative;
    overflow: hidden;
}
.ms-page .ms-travel-box::before {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(244, 164, 96, 0.1), transparent 70%);
    pointer-events: none;
}
.ms-page .ms-travel-content {
    flex: 1;
    position: relative;
}
.ms-page .ms-travel-times-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 14px !important;
    font-size: 0.85rem;
    font-weight: 700;
    color: rgba(255, 237, 213, 0.85);
}
/* ============================================
   AREA CARDS (Municipios page)
   ============================================ */
.ms-page .ms-areas-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
    margin-bottom: 60px;
}
.ms-page .ms-area-card {
    display: block !important;
    background: white !important;
    padding: 32px !important;
    border-radius: var(--ms-radius-lg) !important;
    border: 1px solid var(--ms-stone-100) !important;
    text-decoration: none !important;
    transition: all var(--ms-duration) var(--ms-ease) !important;
    color: inherit !important;
    position: relative;
    overflow: hidden;
}
.ms-page .ms-area-card::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--ms-accent), var(--ms-amber-300));
    transform: scaleX(0);
    transition: transform var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-area-card:hover {
    box-shadow: var(--ms-shadow-lg) !important;
    transform: translateY(-6px) !important;
    border-color: transparent !important;
}
.ms-page .ms-area-card:hover::before {
    transform: scaleX(1);
}
.ms-page .ms-area-card:hover h4 {
    color: var(--ms-brown) !important;
}
.ms-page .ms-area-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
}
.ms-page .ms-area-card-icon {
    font-size: 1.5rem;
}
.ms-page .ms-area-card-data {
    text-align: right;
}
.ms-page .ms-area-card-alt {
    font-size: 9px;
    font-weight: 900;
    color: var(--ms-accent);
    text-transform: uppercase;
    letter-spacing: 2px;
}
.ms-page .ms-area-card-pop {
    font-size: 9px;
    font-weight: 700;
    color: var(--ms-stone-300);
    text-transform: uppercase;
    letter-spacing: 2px;
}
.ms-page .ms-area-card-title {
    font-size: 1.15rem;
    font-weight: 900;
    color: var(--ms-stone-900);
    margin-bottom: 8px;
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-area-card-title-sm {
    font-size: 1rem;
}
.ms-page .ms-area-card-desc {
    font-size: 0.85rem;
    color: var(--ms-stone-500);
    line-height: 1.6;
    margin-bottom: 20px;
}
.ms-page .ms-area-card-desc-sm {
    font-size: 0.78rem;
    margin-bottom: 16px;
}
.ms-page .ms-area-card-link {
    color: var(--ms-accent);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: gap var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-area-card:hover .ms-area-card-link {
    gap: 10px;
}
.ms-page .ms-area-card-link::after {
    content: '\2192';
    font-size: 14px;
}
/* ============================================
   GUARDAMUEBLES CARDS
   ============================================ */
.ms-page .ms-servicios-4col-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 24px !important;
}
.ms-page .ms-guard-card {
    background: var(--ms-stone-50);
    padding: 32px;
    border-radius: var(--ms-radius-lg);
    text-align: center;
    border: 1px solid var(--ms-stone-100);
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-guard-card:hover {
    border-color: var(--ms-accent);
    transform: translateY(-4px);
    box-shadow: var(--ms-shadow-md);
}
.ms-page .ms-guard-card-icon {
    font-size: 2rem;
    display: block;
    margin-bottom: 16px;
}
.ms-page .ms-guard-card-title {
    font-weight: 900;
    color: var(--ms-stone-900);
    margin-bottom: 8px;
    font-size: 1rem;
}
.ms-page .ms-guard-card-desc {
    font-size: 10px;
    color: var(--ms-stone-400);
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 20px;
    letter-spacing: 1px;
}
.ms-page .ms-guard-card-btn {
    background: white;
    padding: 8px 24px;
    border-radius: var(--ms-radius-sm);
    font-size: 9px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--ms-accent);
    text-decoration: none;
    display: inline-block;
    transition: all var(--ms-duration) var(--ms-ease);
    border: 1px solid var(--ms-stone-200);
}
.ms-page .ms-guard-card-btn:hover {
    background: var(--ms-accent);
    color: white;
    border-color: var(--ms-accent);
}
/* ============================================
   FOOTER — Dark premium 2026
   ============================================ */
.ms-page .ms-footer {
    background: var(--ms-stone-950);
    color: white;
    padding: 100px 24px 48px;
    position: relative;
}
.ms-page .ms-footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--ms-accent), transparent);
    opacity: 0.4;
}
.ms-page .ms-footer-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 56px;
    max-width: 1280px;
    margin: 0 auto;
}
.ms-page .ms-footer-logo {
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: -2px;
    margin-bottom: 6px;
}
.ms-page .ms-footer-tagline {
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--ms-accent);
    margin-bottom: 28px;
}
.ms-page .ms-footer-desc {
    color: var(--ms-stone-500);
    line-height: 1.8;
    font-weight: 400;
    margin-bottom: 28px;
    font-size: 0.9rem;
}
.ms-page .ms-footer-social {
    display: flex;
    gap: 10px;
}
.ms-page .ms-footer-social-item {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--ms-stone-800);
    border: 1px solid var(--ms-stone-700);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    color: var(--ms-stone-400);
    text-decoration: none;
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-footer-social-item:hover {
    background: var(--ms-accent);
    border-color: var(--ms-accent);
    color: white;
    transform: translateY(-2px);
}
.ms-page .ms-footer-title {
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 4px;
    color: var(--ms-accent);
    margin-bottom: 28px;
}
.ms-page .ms-footer-links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.ms-page .ms-footer-links li {
    margin-bottom: 16px;
}
.ms-page .ms-footer-links a {
    color: var(--ms-stone-400);
    font-weight: 600;
    font-size: 0.85rem;
    text-decoration: none;
    transition: all var(--ms-duration) var(--ms-ease);
    display: inline-flex;
    align-items: center;
    gap: 0;
}
.ms-page .ms-footer-links a:hover {
    color: white;
    gap: 6px;
}
.ms-page .ms-footer-links a::before {
    content: '';
    width: 0;
    height: 1px;
    background: var(--ms-accent);
    transition: width var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-footer-links a:hover::before {
    width: 12px;
}
.ms-page .ms-footer-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 20px;
}
.ms-page .ms-footer-contact-icon {
    font-size: 1.1rem;
    color: var(--ms-accent);
}
.ms-page .ms-footer-contact-label {
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--ms-stone-500);
    margin-bottom: 4px;
    letter-spacing: 2px;
}
.ms-page .ms-footer-contact-value {
    font-size: 1.15rem;
    font-weight: 900;
    letter-spacing: -0.5px;
}
.ms-page .ms-footer-contact-value a {
    color: white;
    text-decoration: none;
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-footer-contact-value a:hover {
    color: var(--ms-accent);
}
.ms-page .ms-footer-bottom {
    max-width: 1280px;
    margin: 80px auto 0;
    padding-top: 40px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}
.ms-page .ms-footer-copyright {
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 4px;
    color: var(--ms-stone-600);
}
.ms-page .ms-footer-legal {
    display: flex;
    gap: 24px;
}
.ms-page .ms-footer-legal a {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--ms-stone-600);
    text-decoration: none;
    transition: color var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-footer-legal a:hover {
    color: var(--ms-accent);
}
/* ============================================
   SERVICE DETAIL PAGE
   ============================================ */
.ms-page .ms-detail-hero {
    background: var(--ms-stone-900);
    color: white;
    padding: 160px 24px 100px;
    position: relative;
    overflow: hidden;
}
.ms-page .ms-detail-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(244, 164, 96, 0.1), transparent 70%);
}
.ms-page .ms-detail-hero h1 {
    font-size: clamp(2.5rem, 8vw, 5rem) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -2px;
    text-transform: uppercase;
    margin-bottom: 32px !important;
    color: white !important;
    max-width: 900px;
}
.ms-page .ms-detail-hero p {
    font-size: 1.25rem;
    color: var(--ms-stone-400);
    font-weight: 300;
    line-height: 1.8;
    max-width: 800px;
    margin-bottom: 48px;
}
.ms-page .ms-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}
.ms-page .ms-detail-phone-btn {
    display: flex;
    align-items: center;
    gap: 16px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    padding: 18px 28px;
    border-radius: var(--ms-radius-md);
    color: white;
    text-decoration: none;
    font-weight: 900;
    font-size: 1.15rem;
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-detail-phone-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(244, 164, 96, 0.3);
}
.ms-page .ms-detail-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    max-width: 1280px;
    margin: -60px auto 0;
    padding: 0 24px;
    position: relative;
    z-index: 10;
}
.ms-page .ms-detail-stat-card {
    background: white;
    padding: 28px;
    border-radius: var(--ms-radius-lg);
    box-shadow: var(--ms-shadow-lg);
    border: 1px solid var(--ms-stone-100);
    text-align: center;
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-detail-stat-card:hover {
    border-color: var(--ms-accent);
    transform: translateY(-4px);
}
.ms-page .ms-detail-stat-icon {
    font-size: 2rem;
    margin-bottom: 12px;
    display: block;
    transition: transform var(--ms-duration) var(--ms-ease-bounce);
}
.ms-page .ms-detail-stat-card:hover .ms-detail-stat-icon {
    transform: scale(1.2);
}
.ms-page .ms-detail-stat-title {
    font-weight: 900;
    color: var(--ms-stone-900);
    margin-bottom: 4px;
}
.ms-page .ms-detail-stat-desc {
    font-size: 10px;
    font-weight: 700;
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 1px;
}
.ms-page .ms-detail-content {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 64px;
    max-width: 1280px;
    margin: 0 auto;
    padding: 80px 24px;
}
.ms-page .ms-detail-main h2 {
    font-size: 1.6rem !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    text-transform: uppercase;
    margin-bottom: 28px !important;
}
.ms-page .ms-detail-main p {
    color: var(--ms-stone-600);
    font-size: 1.05rem;
    line-height: 1.8;
    margin-bottom: 24px;
}
.ms-page .ms-detail-commitment {
    background: var(--ms-stone-50);
    padding: 36px;
    border-radius: var(--ms-radius-lg);
    border: 1px solid var(--ms-stone-100);
    margin-top: 44px;
}
.ms-page .ms-detail-commitment h4 {
    font-weight: 900;
    color: var(--ms-stone-900);
    margin-bottom: 20px;
    font-size: 1.15rem;
}
.ms-page .ms-detail-commitment ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.ms-page .ms-detail-commitment li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 700;
    color: var(--ms-stone-700);
    padding: 6px 0;
}
.ms-page .ms-detail-commitment li::before {
    content: '';
    width: 6px;
    height: 6px;
    background: var(--ms-accent);
    border-radius: 50%;
}
.ms-page .ms-detail-sidebar {
    display: flex;
    flex-direction: column;
    gap: 28px;
}
.ms-page .ms-detail-cta-box {
    background: linear-gradient(135deg, var(--ms-brown), var(--ms-brown-dark));
    padding: 44px;
    border-radius: var(--ms-radius-xl);
    color: white;
    text-align: center;
}
.ms-page .ms-detail-cta-box h4 {
    font-size: 1.6rem !important;
    font-weight: 900 !important;
    color: white !important;
    margin-bottom: 14px !important;
}
.ms-page .ms-detail-cta-box p {
    color: rgba(255, 200, 150, 0.8);
    margin-bottom: 28px;
    font-weight: 500;
}
.ms-page .ms-detail-cta-btn {
    background: linear-gradient(135deg, var(--ms-accent), var(--ms-amber-500)) !important;
    color: white !important;
    padding: 18px 40px !important;
    border-radius: var(--ms-radius-sm) !important;
    font-weight: 800 !important;
    font-size: 0.875rem !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    border: none !important;
    transition: all var(--ms-duration) var(--ms-ease) !important;
    box-shadow: var(--ms-shadow-accent) !important;
    display: inline-block;
    text-decoration: none !important;
}
.ms-page .ms-detail-cta-btn:hover {
    transform: translateY(-3px) !important;
}
.ms-page .ms-detail-cta-phone {
    padding-top: 28px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    margin-top: 28px;
}
.ms-page .ms-detail-cta-phone span {
    display: block;
    font-size: 9px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--ms-accent);
    margin-bottom: 6px;
}
.ms-page .ms-detail-cta-phone a {
    font-size: 1.8rem;
    font-weight: 900;
    color: white;
    text-decoration: none;
    letter-spacing: -1px;
}
.ms-page .ms-detail-faq-box {
    background: var(--ms-stone-50);
    padding: 36px;
    border-radius: var(--ms-radius-xl);
    border: 1px solid var(--ms-stone-200);
}
.ms-page .ms-detail-faq-box h4 {
    font-size: 1.1rem !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    padding-bottom: 14px !important;
    border-bottom: 1px solid var(--ms-stone-200);
    margin-bottom: 20px !important;
}
.ms-page .ms-detail-faq-item {
    margin-bottom: 20px;
}
.ms-page .ms-detail-faq-item:last-child {
    margin-bottom: 0;
}
.ms-page .ms-detail-faq-q {
    font-weight: 900;
    color: var(--ms-stone-800);
    font-size: 0.85rem;
    margin-bottom: 6px;
}
.ms-page .ms-detail-faq-a {
    color: var(--ms-stone-500);
    font-size: 0.78rem;
    line-height: 1.7;
}
.ms-page .ms-detail-banner {
    background: var(--ms-stone-100);
    padding: 100px 24px;
    text-align: center;
}
.ms-page .ms-detail-banner h3 {
    font-size: clamp(2rem, 5vw, 3.5rem) !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    margin-bottom: 24px !important;
    letter-spacing: -1px;
    max-width: 800px;
    margin-left: auto !important;
    margin-right: auto !important;
}
.ms-page .ms-detail-banner p {
    font-size: 1.15rem;
    color: var(--ms-stone-500);
    font-weight: 300;
    margin-bottom: 48px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}
.ms-page .ms-detail-banner-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
}
.ms-page .ms-detail-hero-dark {
    background: var(--ms-stone-950) !important;
    color: white !important;
    padding: 140px 24px 100px !important;
}
.ms-page .ms-detail-hero-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 64px !important;
    align-items: center !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
}
.ms-page .ms-detail-hero-content {
    max-width: 600px;
}
.ms-page .ms-detail-hero-content .ms-section-label {
    text-align: left !important;
    color: var(--ms-accent) !important;
}
.ms-page .ms-detail-map {
    position: relative;
    border-radius: var(--ms-radius-lg);
    overflow: hidden;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
    border: 6px solid rgba(255, 255, 255, 0.08);
}
.ms-page .ms-detail-map iframe {
    display: block;
    width: 100%;
    min-height: 400px;
    border-radius: 22px;
    filter: grayscale(1) contrast(1.1) brightness(1.1);
    transition: filter 0.7s var(--ms-ease);
}
.ms-page .ms-detail-map:hover iframe {
    filter: grayscale(0);
}
.ms-page .ms-location-datasheet {
    background: var(--ms-stone-50);
    padding: 44px;
    border-radius: var(--ms-radius-xl);
    border: 1px solid var(--ms-stone-200);
    position: relative;
    overflow: hidden;
}
.ms-page .ms-location-stats-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 28px !important;
}
.ms-page .ms-location-services-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
}
.ms-page .ms-detail-pricing {
    background: white;
    border-radius: var(--ms-radius-xl);
    box-shadow: var(--ms-shadow-lg);
    overflow: hidden;
    border: 1px solid var(--ms-stone-100);
    margin-top: 44px;
}
.ms-page .ms-detail-pricing-header {
    background: linear-gradient(135deg, var(--ms-brown), var(--ms-brown-dark));
    padding: 28px 32px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.ms-page .ms-detail-pricing-header h3 {
    font-size: 1.35rem !important;
    font-weight: 900 !important;
    color: white !important;
    margin: 0 !important;
}
.ms-page .ms-detail-pricing-header span {
    font-size: 9px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: rgba(255, 200, 150, 0.8);
}
.ms-page .ms-detail-pricing-row {
    padding: 28px 32px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 16px;
    align-items: center;
    border-bottom: 1px solid var(--ms-stone-100);
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-detail-pricing-row:hover {
    background: var(--ms-stone-50);
}
.ms-page .ms-detail-pricing-service {
    font-weight: 900;
    color: var(--ms-stone-900);
    margin-bottom: 4px;
}
.ms-page .ms-detail-pricing-info {
    font-size: 10px;
    font-weight: 700;
    color: var(--ms-stone-400);
    text-transform: uppercase;
}
.ms-page .ms-detail-pricing-price {
    font-size: 1.5rem;
    font-weight: 900;
    color: var(--ms-accent);
}
.ms-page .ms-detail-pricing-footer {
    padding: 22px;
    background: var(--ms-stone-50);
    text-align: center;
    font-size: 9px;
    font-weight: 700;
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 2px;
}
.ms-page .ms-presupuesto-features-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 28px !important;
    max-width: 900px;
    margin: 0 auto;
}
.ms-page .ms-presupuesto-contact-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
    margin-bottom: 44px;
}
.ms-page .ms-btn-dark {
    background: var(--ms-stone-900) !important;
    color: white !important;
    padding: 18px 44px !important;
    border-radius: var(--ms-radius-sm) !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    font-size: 0.85rem !important;
    text-decoration: none !important;
    display: inline-block;
    transition: all var(--ms-duration) var(--ms-ease) !important;
}
.ms-page .ms-btn-dark:hover {
    background: var(--ms-stone-800) !important;
    transform: translateY(-2px) !important;
}
/* ============================================
   MUNICIPALITY PAGES — ms-muni-*
   ============================================ */
/* --- Hero --- */
.ms-page .ms-muni-hero {
    background: var(--ms-stone-900);
    color: white;
    padding: 140px 24px 80px;
    position: relative;
    overflow: hidden;
}
.ms-page .ms-muni-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(244, 164, 96, 0.1), transparent 70%);
}
.ms-page .ms-muni-hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
}
.ms-page .ms-muni-label {
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 4px !important;
    color: var(--ms-accent) !important;
    margin-bottom: 16px !important;
}
.ms-page .ms-muni-hero-text h1 {
    font-size: clamp(2.5rem, 7vw, 4.5rem) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -2px;
    text-transform: uppercase;
    margin-bottom: 24px !important;
    color: white !important;
}
.ms-page .ms-muni-hero-text > p {
    font-size: 1.1rem;
    color: var(--ms-stone-400);
    font-weight: 300;
    line-height: 1.8;
    margin-bottom: 36px;
}
.ms-page .ms-muni-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center;
}
.ms-page .ms-muni-phone-btn {
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    padding: 16px 24px;
    border-radius: var(--ms-radius-md);
    color: white;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
    transition: all var(--ms-duration) var(--ms-ease);
}
.ms-page .ms-muni-phone-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(244, 164, 96, 0.3);
}
.ms-page .ms-muni-hero-map {
    position: relative;
}
.ms-page .ms-muni-hero-map iframe {
    border-radius: var(--ms-radius-sm) !important;
    width: 100%;
    min-height: 350px;
    display: block;
}
.ms-page .ms-muni-coords {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--ms-stone-800);
    padding: 10px 18px;
    border-radius: var(--ms-radius-sm);
    position: absolute;
    bottom: 16px;
    right: 16px;
    font-size: 0.8rem;
    border: 1px solid rgba(244, 164, 96, 0.3);
}
.ms-page .ms-muni-coords span {
    color: var(--ms-stone-400);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 0.65rem;
    font-weight: 600;
}
.ms-page .ms-muni-coords strong {
    color: var(--ms-accent);
    font-size: 0.8rem;
}
/* --- Content Layout --- */
.ms-page .ms-muni-content {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 48px;
    max-width: 1280px;
    margin: 0 auto;
    padding: 64px 24px;
}
.ms-page .ms-muni-main h2 {
    font-size: clamp(1.75rem, 4vw, 2.25rem) !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    text-transform: uppercase !important;
    letter-spacing: -0.5px;
    margin-bottom: 24px !important;
    margin-top: 48px !important;
}
.ms-page .ms-muni-main > p {
    font-size: 1.05rem;
    color: var(--ms-stone-600);
    line-height: 1.8;
    margin-bottom: 16px;
}
/* --- Ficha Tecnica --- */
.ms-page .ms-muni-ficha {
    background: var(--ms-stone-50);
    border: 1px solid var(--ms-stone-200);
    border-radius: var(--ms-radius-md);
    padding: 36px 40px;
}
.ms-page .ms-muni-ficha-label {
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 3px !important;
    color: var(--ms-accent) !important;
    margin-bottom: 28px !important;
}
.ms-page .ms-muni-ficha-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.ms-page .ms-muni-ficha-subtitle {
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 1.5px !important;
    color: var(--ms-stone-500) !important;
    font-weight: 600 !important;
    margin-bottom: 4px !important;
}
.ms-page .ms-muni-ficha-value {
    font-size: 2rem !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    line-height: 1.2 !important;
    margin-bottom: 4px !important;
}
.ms-page .ms-muni-ficha-note {
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: var(--ms-stone-400) !important;
    font-weight: 500 !important;
}
/* --- Garantias --- */
.ms-page .ms-muni-garantias {
    background: var(--ms-stone-50);
    border: 1px solid var(--ms-stone-200);
    border-radius: var(--ms-radius-md);
    padding: 36px 40px;
    margin-top: 48px;
}
.ms-page .ms-muni-garantias h3 {
    font-size: 1.25rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    color: var(--ms-stone-900) !important;
    margin-bottom: 28px !important;
}
.ms-page .ms-muni-garantias-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.ms-page .ms-muni-garantia-item {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}
.ms-page .ms-muni-garantia-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ms-stone-100);
    border-radius: 50%;
}
.ms-page .ms-muni-garantia-title {
    font-size: 0.95rem !important;
    font-weight: 800 !important;
    color: var(--ms-stone-900) !important;
    margin-bottom: 4px !important;
}
.ms-page .ms-muni-garantia-desc {
    font-size: 0.85rem !important;
    color: var(--ms-stone-500) !important;
    line-height: 1.5 !important;
}
/* --- Sidebar --- */
.ms-page .ms-muni-sidebar {
    display: flex;
    flex-direction: column;
    gap: 28px;
    align-self: start;
    position: sticky;
    top: 32px;
}
.ms-page .ms-muni-cta-box {
    background: var(--ms-stone-900);
    color: white;
    padding: 36px 32px;
    border-radius: var(--ms-radius-md);
}
.ms-page .ms-muni-cta-box h4 {
    font-size: 1.35rem !important;
    font-weight: 900 !important;
    color: white !important;
    margin-bottom: 12px !important;
}
.ms-page .ms-muni-cta-box > p {
    font-size: 0.9rem;
    color: var(--ms-stone-400);
    line-height: 1.6;
    margin-bottom: 20px;
}
.ms-page .ms-muni-cta-phone {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.ms-page .ms-muni-cta-phone span {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--ms-stone-400);
    font-weight: 600;
}
.ms-page .ms-muni-cta-phone a {
    font-size: 1.5rem;
    font-weight: 900;
    color: white;
    text-decoration: none;
    letter-spacing: -0.5px;
}
.ms-page .ms-muni-cta-phone a:hover {
    color: var(--ms-accent);
}
.ms-page .ms-muni-servicios-box {
    background: white;
    border: 1px solid var(--ms-stone-200);
    padding: 32px;
    border-radius: var(--ms-radius-md);
}
.ms-page .ms-muni-servicios-box h4 {
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 3px !important;
    color: var(--ms-stone-900) !important;
    margin-bottom: 20px !important;
}
.ms-page .ms-muni-servicios-box ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.ms-page .ms-muni-servicios-box li {
    padding: 10px 0;
    border-bottom: 1px solid var(--ms-stone-100);
    font-size: 0.9rem;
    color: var(--ms-stone-600);
    padding-left: 20px;
    position: relative;
}
.ms-page .ms-muni-servicios-box li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--ms-accent);
    transform: translateY(-50%);
}
.ms-page .ms-muni-servicios-box li:last-child {
    border-bottom: none;
}
/* --- Banner CTA --- */
.ms-page .ms-muni-banner {
    text-align: center;
    padding: 100px 24px;
    background: var(--ms-stone-100);
    max-width: 100%;
}
.ms-page .ms-muni-banner h3 {
    font-size: clamp(1.75rem, 5vw, 2.75rem) !important;
    font-weight: 900 !important;
    color: var(--ms-stone-900) !important;
    margin-bottom: 20px !important;
}
.ms-page .ms-muni-banner > p {
    font-size: 1.1rem;
    color: var(--ms-stone-500);
    max-width: 700px;
    margin: 0 auto 40px;
    line-height: 1.7;
}
.ms-page .ms-muni-banner-actions {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

/* ============================================
   RESPONSIVE 2026
   ============================================ */
@media (max-width: 992px) {
    .ms-page .ms-muni-hero-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .ms-page .ms-muni-content {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-muni-sidebar {
        position: static;
    }
    .ms-page .ms-muni-garantias-grid {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .ms-page .ms-testimonials-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .ms-page .ms-footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .ms-page .ms-todo-incluido-grid {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }
    .ms-page .ms-servicios-4col-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .ms-page .ms-detail-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    .ms-page .ms-detail-content {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-detail-hero-grid {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }
    .ms-page .ms-detail-hero-content {
        text-align: center;
        max-width: 100%;
    }
    .ms-page .ms-detail-hero-content .ms-section-label {
        text-align: center !important;
    }
    .ms-page .ms-areas-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .ms-page .ms-intro-grid {
        grid-template-columns: 1fr !important;
    }
}
@media (max-width: 768px) {
    .ms-page .ms-muni-hero {
        padding: 120px 16px 60px;
    }
    .ms-page .ms-muni-hero-text h1 {
        font-size: 2.5rem !important;
    }
    .ms-page .ms-muni-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .ms-page .ms-muni-ficha-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .ms-page .ms-muni-ficha {
        padding: 28px 24px;
    }
    .ms-page .ms-muni-garantias {
        padding: 28px 24px;
    }
    .ms-page .ms-muni-banner-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .ms-page .ms-hero h1 {
        font-size: 3rem !important;
        letter-spacing: -1px;
    }
    .ms-page .ms-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .ms-page .ms-phone-box {
        justify-content: center;
    }
    .ms-page .ms-section {
        padding: 72px 16px;
    }
    .ms-page .ms-stats-grid {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-brown-box {
        padding: 36px 24px !important;
    }
    .ms-page .ms-check-grid {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-form-box {
        padding: 36px 24px;
    }
    .ms-page .ms-pricing-header,
    .ms-page .ms-pricing-row {
        padding: 16px 20px;
    }
    .ms-page .ms-testimonials-grid {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-footer-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .ms-page .ms-footer-bottom {
        flex-direction: column;
        text-align: center;
    }
    .ms-page .ms-barrios-grid,
    .ms-page .ms-municipios-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .ms-page .ms-logistics-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-location-stats-grid,
    .ms-page .ms-areas-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-location-services-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-features-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-presupuesto-features-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-presupuesto-contact-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-servicios-4col-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-area-tag,
    .ms-page .ms-municipality-tag {
        font-size: 0.5rem;
    }
    .ms-page .ms-travel-box {
        flex-direction: column;
        text-align: center;
        padding: 36px 24px;
        border-radius: var(--ms-radius-lg);
    }
    .ms-page .ms-travel-times-grid {
        grid-template-columns: 1fr !important;
    }
}
@media (max-width: 640px) {
    .ms-page .ms-services-grid {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-detail-stats {
        grid-template-columns: 1fr;
    }
    .ms-page .ms-areas-grid {
        grid-template-columns: 1fr !important;
    }
    .ms-page .ms-detail-hero-dark {
        padding: 120px 16px 60px !important;
    }
    .ms-page .ms-location-datasheet {
        padding: 28px 20px;
    }
}

/* =============================================
   PRESUPUESTO — SureForms Overrides
   Añadir al final de mudanzas-soria-2026-final.css
   ============================================= */

/* Botón ENVIAR — naranja, pill, full-width */
.ms-presupuesto-form button[type="submit"],
.ms-presupuesto-form input[type="submit"],
.ms-presupuesto-form .srfm-submit-btn,
.ms-presupuesto-form .srfm-btn {
    background-color: #f4a460 !important;
    color: #fff !important;
    border: none !important;
    padding: 20px 48px !important;
    font-size: 0.9rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 3px !important;
    border-radius: 50px !important;
    cursor: pointer !important;
    width: 100% !important;
    display: block !important;
    margin-top: 16px !important;
    transition: all 0.3s ease !important;
}
.ms-presupuesto-form button[type="submit"]:hover,
.ms-presupuesto-form input[type="submit"]:hover,
.ms-presupuesto-form .srfm-submit-btn:hover {
    background-color: #e69350 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 40px rgba(244,164,96,0.35) !important;
}

/* Checkbox labels — texto normal, NO mayúsculas */
.ms-presupuesto-form label:has(input[type="checkbox"]),
.ms-presupuesto-form input[type="checkbox"] + label,
.ms-presupuesto-form input[type="checkbox"] ~ label,
.ms-presupuesto-form input[type="checkbox"] ~ span,
.ms-presupuesto-form .srfm-checkbox label,
.ms-presupuesto-form .srfm-checkbox span,
.ms-presupuesto-form [data-field-type="checkbox"] label,
.ms-presupuesto-form [data-field-type="checkbox"] span,
.ms-presupuesto-form [data-field-type="gdpr"] label,
.ms-presupuesto-form [data-field-type="gdpr"] span,
.ms-presupuesto-form [data-field-type="acceptance"] label,
.ms-presupuesto-form [data-field-type="acceptance"] span {
    font-size: 0.9rem !important;
    font-weight: 400 !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    color: #57534e !important;
}
		

.ms-related-zone a, .ms-related-zone a:visited{text-decoration:none !important}
.ms-related-zone__item, .ms-related-zone__item *{text-decoration:none !important}
.ms-related-zone__text strong{font-weight:600}
.ms-related-zone__arrow{font-size:1.05rem}

/* ===== ms-related-zone (bloque relacionados muni) ===== */
.ms-related-zone{display:block;margin:48px auto 0;max-width:1180px;padding:0 24px}
.ms-related-zone__inner{background:linear-gradient(180deg,#fff7ee 0%,#fff 100%);border:1px solid #f3d9b8;border-radius:18px;padding:48px 40px;box-shadow:0 8px 32px rgba(236,102,8,0.06)}
.ms-related-zone__header{text-align:center;margin-bottom:36px}
.ms-related-zone__eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ec6608;background:#ffeedb;padding:6px 14px;border-radius:999px;margin-bottom:14px}
.ms-related-zone__title{font-size:1.7rem;line-height:1.25;color:#1a2332;margin:0 0 12px;font-weight:700;border:none !important;padding:0 !important}
.ms-related-zone__lead{font-size:1rem;color:#4a5568;margin:0 auto;max-width:640px;line-height:1.55}
.ms-related-zone__cols{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;margin-bottom:32px}
.ms-related-zone__col-title{font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#1a2332;margin:0 0 18px;padding-bottom:10px;border-bottom:2px solid #ec6608}
.ms-related-zone__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ms-related-zone__list li{margin:0;padding:0}
.ms-related-zone__item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:10px;background:#fff;border:1px solid #ececec;color:#1a2332;text-decoration:none;transition:all .18s ease;line-height:1.45}
.ms-related-zone__item:hover{border-color:#ec6608;background:#fff8f0;transform:translateX(2px);text-decoration:none}
.ms-related-zone__item:hover .ms-related-zone__arrow{color:#ec6608;transform:translateX(2px)}
.ms-related-zone__arrow{flex:none;color:#bbb;font-weight:700;transition:all .18s ease;line-height:1.45}
.ms-related-zone__text{flex:1;font-size:.95rem}
.ms-related-zone__text strong{color:#1a2332;font-weight:600}
.ms-related-zone__text em{font-style:normal;color:#6b7280;font-size:.88rem;display:block;margin-top:2px}
.ms-related-zone__cta{display:flex;align-items:center;justify-content:center;gap:18px;padding-top:28px;border-top:1px solid #f3d9b8;flex-wrap:wrap}
.ms-related-zone__cta-btn{display:inline-flex;align-items:center;gap:8px;background:#ec6608;color:#fff !important;padding:14px 28px;border-radius:10px;font-weight:600;text-decoration:none;font-size:1rem;transition:all .18s ease;box-shadow:0 4px 14px rgba(236,102,8,0.25)}
.ms-related-zone__cta-btn:hover{background:#d65a07;transform:translateY(-1px);box-shadow:0 6px 18px rgba(236,102,8,0.35);color:#fff !important;text-decoration:none}
.ms-related-zone__cta-note{color:#6b7280;font-size:.92rem}
@media (max-width:900px){
.ms-related-zone{margin-top:32px}
.ms-related-zone__inner{padding:32px 22px;border-radius:14px}
.ms-related-zone__title{font-size:1.4rem}
.ms-related-zone__cols{grid-template-columns:1fr;gap:28px}
.ms-related-zone__cta{flex-direction:column;gap:10px}
}
</style>

<style id="ms-content-fragments-fix">
/* ============================================
   FIX: contenedor para fragmentos sueltos de Gutenberg
   en todas las paginas (basque section, silo block,
   barrios, servicios complementarios)
   ============================================ */
.ast-plain-container article .entry-content > .wp-block-heading,
.ast-plain-container article .entry-content > h1,
.ast-plain-container article .entry-content > h2,
.ast-plain-container article .entry-content > h3,
.ast-plain-container article .entry-content > h4,
.ast-plain-container article .entry-content > p,
.ast-plain-container article .entry-content > ul,
.ast-plain-container article .entry-content > ol,
.ast-plain-container article .entry-content > .wp-block-list,
.ast-plain-container article .entry-content > aside.ms-silo-block,
.ast-plain-container article .entry-content > aside.laseda-fmap,
.ast-plain-container article .entry-content > blockquote,
.ast-plain-container article .entry-content > figure {
  max-width: 1140px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box;
}
.ast-plain-container article .entry-content > .wp-block-heading {
  margin-top: 56px !important;
  margin-bottom: 16px !important;
  font-size: 1.6rem !important;
  line-height: 1.3 !important;
  color: #0e1a2b !important;
  font-weight: 700 !important;
  border-left: 4px solid #ec6608;
  padding-left: 16px !important;
}
.ast-plain-container article .entry-content > p {
  font-size: 1rem;
  line-height: 1.7;
  color: #475569;
  margin-bottom: 14px !important;
}
.ast-plain-container article .entry-content > p strong {
  color: #1e293b;
}
.ast-plain-container article .entry-content > p a {
  color: #ec6608;
}
.ast-plain-container article .entry-content > .wp-block-list,
.ast-plain-container article .entry-content > ul,
.ast-plain-container article .entry-content > ol {
  padding-left: 44px !important;
  margin-bottom: 24px !important;
}
.ast-plain-container article .entry-content > .wp-block-list li,
.ast-plain-container article .entry-content > ul li,
.ast-plain-container article .entry-content > ol li {
  margin-bottom: 8px;
  line-height: 1.65;
  color: #475569;
}
.ast-plain-container article .entry-content > .wp-block-list li a,
.ast-plain-container article .entry-content > ul li a {
  color: #ec6608;
  text-decoration: none;
}
.ast-plain-container article .entry-content > .wp-block-list li a:hover,
.ast-plain-container article .entry-content > ul li a:hover {
  text-decoration: underline;
}
/* ASIDE silo block: tarjeta */
.ast-plain-container article .entry-content > aside.ms-silo-block {
  background: linear-gradient(180deg, #fef7ed 0%, #fff 100%);
  border-radius: 16px;
  padding: 28px 32px;
  border-left: 4px solid #ec6608;
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}
.ms-silo-block .ms-rating-badge {
  font-size: 1.05rem;
  margin-bottom: 14px;
  color: #f5b300;
  font-weight: 600;
}
.ms-silo-block .ms-rating-badge::before {
  content: "";
}
/* Reset cuando .ms-page envuelve todo (hubs y page builder) */
.ast-plain-container article .entry-content > .ms-page {
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.ast-plain-container article .entry-content > .ms-page * {
  /* sin override - dejar que ms-section maneje su propio padding */
}
/* Padding superior/inferior para legibilidad cuando los bloques estan sueltos */
.ast-plain-container article .entry-content {
  padding-bottom: 60px;
}
/* Para paginas con mucho contenido suelto al inicio */
.ast-plain-container article .entry-content > .wp-block-heading:first-child,
.ast-plain-container article .entry-content > h1:first-child,
.ast-plain-container article .entry-content > h2:first-child {
  margin-top: 40px !important;
}
@media (max-width: 900px) {
  .ast-plain-container article .entry-content > .wp-block-heading {
    font-size: 1.35rem !important;
  }
}

/* === Fix: Unstyled fragments on legacy/muni pages (no .ms-page wrapper) === */
article > .entry-content > h2.wp-block-heading,
article > .entry-content > h3.wp-block-heading,
article > .entry-content > h4.wp-block-heading,
article > .entry-content > p,
article > .entry-content > ul,
article > .entry-content > ol,
article > .entry-content > .wp-block-list,
article > .entry-content > blockquote,
article > .entry-content > figure {
  max-width: 1140px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  box-sizing: border-box !important;
}
article > .entry-content > h2.wp-block-heading {
  border-left: 4px solid #ec6608 !important;
  padding-left: 16px !important;
  margin-top: 56px !important;
  margin-bottom: 18px !important;
  font-size: 1.55rem !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  color: #1a2332 !important;
}
article > .entry-content > h3.wp-block-heading {
  margin-top: 32px !important;
  margin-bottom: 14px !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: #1a2332 !important;
}
article > .entry-content > p {
  font-size: 1rem !important;
  line-height: 1.7 !important;
  color: #475569 !important;
  margin-bottom: 16px !important;
}
article > .entry-content > ul,
article > .entry-content > ol,
article > .entry-content > .wp-block-list {
  font-size: 1rem !important;
  line-height: 1.75 !important;
  color: #475569 !important;
  margin-bottom: 16px !important;
}
@media (max-width: 768px) {
  article > .entry-content > h2.wp-block-heading {
    font-size: 1.25rem !important;
    margin-top: 36px !important;
  }
}


/* === ms-related-zone v2 — UX premium (overrides v1) === */
.ms-related-zone__inner{
  background:linear-gradient(135deg,#fff7ee 0%,#fff 55%,#fff8f0 100%) !important;
  border:1px solid #f3d9b8 !important;
  border-radius:24px !important;
  padding:56px 48px !important;
  position:relative;
  overflow:hidden;
  box-shadow:0 10px 40px rgba(236,102,8,0.06) !important;
}
.ms-related-zone__inner::before{
  content:'';
  position:absolute;
  top:-80px;
  right:-80px;
  width:280px;
  height:280px;
  background:radial-gradient(circle,rgba(236,102,8,0.10) 0%,transparent 70%);
  pointer-events:none;
  z-index:0;
}
.ms-related-zone__inner > *{position:relative;z-index:1}
.ms-related-zone__header{margin-bottom:48px !important}
.ms-related-zone__eyebrow{
  background:#fff !important;
  border:1px solid #f3d9b8;
  box-shadow:0 2px 8px rgba(236,102,8,0.08);
  padding:7px 16px !important;
  font-size:.72rem !important;
  letter-spacing:.16em !important;
}
.ms-related-zone__title{
  font-size:2rem !important;
  letter-spacing:-.01em;
  margin-bottom:14px !important;
}
.ms-related-zone__lead{
  font-size:1.02rem !important;
  color:#475569 !important;
  max-width:680px !important;
}
.ms-related-zone__cols{gap:48px !important;margin-bottom:36px !important}
.ms-related-zone__col-title{
  font-size:.78rem !important;
  letter-spacing:.14em !important;
  border-bottom:none !important;
  padding-bottom:14px !important;
  position:relative;
  margin-bottom:20px !important;
}
.ms-related-zone__col-title::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:48px;
  height:3px;
  background:linear-gradient(90deg,#ec6608 0%,#ff8534 100%);
  border-radius:2px;
}
.ms-related-zone__list{gap:8px !important}
.ms-related-zone__item{
  align-items:center !important;
  gap:14px !important;
  padding:14px 18px !important;
  border-radius:12px !important;
  background:#fff !important;
  border:1px solid #ececec !important;
  transition:all .22s cubic-bezier(.4,0,.2,1) !important;
  position:relative;
  overflow:hidden;
}
.ms-related-zone__item::after{
  content:'';
  position:absolute;
  left:0;
  top:50%;
  height:0;
  width:3px;
  background:linear-gradient(180deg,#ec6608 0%,#ff8534 100%);
  border-radius:0 3px 3px 0;
  transform:translateY(-50%);
  transition:height .22s ease;
}
.ms-related-zone__item:hover{
  border-color:#ec6608 !important;
  background:linear-gradient(135deg,#fff8f0 0%,#fff 100%) !important;
  transform:translateX(4px) !important;
  box-shadow:0 8px 20px rgba(236,102,8,0.14) !important;
}
.ms-related-zone__item:hover::after{height:60%}
.ms-related-zone__arrow{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  width:34px !important;
  height:34px !important;
  min-width:34px;
  border-radius:50%;
  background:#fff8f0 !important;
  color:#ec6608 !important;
  font-size:1.05rem !important;
  font-weight:700 !important;
  transition:all .22s ease !important;
  line-height:1 !important;
}
.ms-related-zone__item:hover .ms-related-zone__arrow{
  background:#ec6608 !important;
  color:#fff !important;
  transform:translateX(2px) scale(1.06) !important;
  box-shadow:0 4px 10px rgba(236,102,8,0.3);
}
.ms-related-zone__text{
  font-size:.97rem !important;
  font-weight:600 !important;
  color:#1a2332 !important;
  line-height:1.4;
}
.ms-related-zone__text strong{font-weight:600}
.ms-related-zone__text em{
  font-size:.82rem !important;
  color:#6b7280 !important;
  margin-top:3px !important;
  font-weight:400;
  display:block;
}
.ms-related-zone__list li:first-child .ms-related-zone__item{
  background:linear-gradient(135deg,#fff8f0 0%,#ffeedb 100%) !important;
  border-color:#f3d9b8 !important;
  box-shadow:0 2px 8px rgba(236,102,8,0.08);
}
.ms-related-zone__list li:first-child .ms-related-zone__arrow{
  background:#ec6608 !important;
  color:#fff !important;
}
.ms-related-zone__cta{
  margin-top:8px;
  padding-top:36px !important;
  border-top:1px solid #f3d9b8 !important;
  gap:18px !important;
}
.ms-related-zone__cta-btn{
  background:linear-gradient(135deg,#ec6608 0%,#ff8534 100%) !important;
  padding:16px 36px !important;
  border-radius:12px !important;
  font-size:1.02rem !important;
  font-weight:600 !important;
  letter-spacing:.005em;
  box-shadow:0 6px 20px rgba(236,102,8,0.28) !important;
  transition:all .22s ease !important;
}
.ms-related-zone__cta-btn:hover{
  background:linear-gradient(135deg,#d65a07 0%,#ec6608 100%) !important;
  transform:translateY(-2px) !important;
  box-shadow:0 10px 26px rgba(236,102,8,0.42) !important;
}
.ms-related-zone__cta-note{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:#6b7280 !important;
  font-size:.9rem !important;
}
.ms-related-zone__cta-note::before{
  content:'⚡';
  color:#ec6608;
  font-size:1rem;
}
@media (max-width:900px){
  .ms-related-zone__inner{padding:36px 22px !important;border-radius:18px !important}
  .ms-related-zone__inner::before{width:180px;height:180px;top:-50px;right:-50px}
  .ms-related-zone__title{font-size:1.5rem !important}
  .ms-related-zone__cols{gap:28px !important}
  .ms-related-zone__item{padding:12px 14px !important}
  .ms-related-zone__arrow{width:30px !important;height:30px !important}
  .ms-related-zone__cta-btn{padding:14px 28px !important;font-size:.98rem !important}
}
