
			
			/* ============================================
   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;
}
		

        /* Breadcrumb */
        .ms-breadcrumb {
            padding: 12px 5%;
            font-size: 0.85rem;
        }
        .ms-breadcrumb-list {
            list-style: none;
            display: flex;
            flex-wrap: wrap;
            gap: 4px;
            margin: 0;
            padding: 0;
        }
        .ms-breadcrumb-list li:not(:last-child)::after {
            content: "\203A";
            margin-left: 6px;
            opacity: 0.5;
        }
        .ms-breadcrumb-list a {
            color: inherit;
            opacity: 0.7;
            text-decoration: none;
        }
        .ms-breadcrumb-list a:hover {
            opacity: 1;
            text-decoration: underline;
        }
        /* FAQ toggle animation (CSS-driven for CWV INP) */
        .ms-faq-question {
            display: flex;
            justify-content: space-between;
            align-items: center;
            width: 100%;
            background: none;
            border: none;
            cursor: pointer;
            font: inherit;
            color: inherit;
            padding: 20px 32px;
            text-align: left;
        }
        .ms-faq-question:focus-visible {
            outline: 2px solid #f4a460;
            outline-offset: -2px;
            border-radius: 4px;
        }
        .ms-faq-item .ms-faq-answer {
            max-height: 0;
            overflow: hidden;
            padding: 0 32px;
            transition: max-height 0.4s cubic-bezier(0.22, 1, 0.36, 1), padding 0.4s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s ease;
            opacity: 0;
        }
        .ms-faq-item.active .ms-faq-answer {
            max-height: 500px;
            padding: 0 32px 28px;
            opacity: 1;
        }
        .ms-faq-toggle {
            transition: transform 0.3s ease;
        }
        .ms-faq-item.active .ms-faq-toggle {
            transform: rotate(180deg);
        }
        /* Links de texto internos */
        .ms-text-link {
            color: #9a6c3b;
            text-decoration: underline;
        }
        .ms-text-link:hover {
            color: #7a5430;
        }
        /* Links de servicio */
        .ms-service-title a {
            color: inherit;
            text-decoration: none;
        }
        .ms-service-title a:hover {
            text-decoration: underline;
        }
        .ms-service-link {
            color: #9a6c3b;
            font-weight: 700;
            font-size: 0.9rem;
            text-decoration: underline;
        }
        /* CTA links */
        .ms-cta-link {
            color: #f4a460;
            font-weight: 900;
        }
        /* Hero links */
        .ms-hero-content a {
            color: #f4a460;
            text-decoration: underline;
        }
        /* Section subtitle shared */
        .ms-section-subtitle {
            text-align: center;
            color: #78716c;
            font-size: 1.05rem;
            max-width: 700px;
            margin: 0 auto 60px;
            font-weight: 500;
        }
        /* Zone headings */
        .ms-zone-heading {
            text-align: center;
            font-size: 0.65rem;
            font-weight: 900;
            color: #a8a29e;
            text-transform: uppercase;
            letter-spacing: 5px;
            margin-bottom: 36px;
        }
        /* Pricing note */
        .ms-pricing-note {
            text-align: center;
            color: #78716c;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 3px;
            font-size: 0.7rem;
            margin-bottom: 60px;
        }
        /* Logistics icons */
        .ms-logistics-icon {
            width: 56px;
            height: 56px;
            border-radius: 16px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.8rem;
            margin-bottom: 28px;
        }
        .ms-logistics-icon--warm {
            background: linear-gradient(135deg, #f4a460, #e69350);
            box-shadow: 0 8px 24px rgba(244, 164, 96, 0.2);
        }
        .ms-logistics-icon--cool {
            background: linear-gradient(135deg, #93c5fd, #60a5fa);
            box-shadow: 0 8px 24px rgba(96, 165, 250, 0.2);
        }
        .ms-logistics-title {
            font-size: 1.4rem;
            font-weight: 900;
            color: #1c1917;
            margin-bottom: 20px;
            letter-spacing: -0.5px;
        }
    

/* ── Reset & Contenedor ── */
.ms-footer-global-wrap{background:#1a1a1a;width:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
.ms-footer-global{max-width:1200px;margin:0 auto;padding:0 5%}
.ms-fg-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:50px;padding:55px 0 45px}

/* ── Columna 1 · Marca ── */
.ms-fg-logo{font-size:1.65rem;font-weight:800;color:#fff;margin:0 0 4px;line-height:1.1;letter-spacing:-.5px}
.ms-fg-tagline{font-size:.6rem;letter-spacing:2.5px;text-transform:uppercase;color:#d4a017;font-weight:700;margin:0 0 18px}
.ms-fg-desc{font-size:.82rem;color:#999;line-height:1.7;margin:0 0 22px}
.ms-fg-social{display:flex;gap:8px}
.ms-fg-social a{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#333;color:#fff;text-decoration:none;font-size:.65rem;font-weight:700;letter-spacing:.5px;transition:background .25s}
.ms-fg-social a:hover{background:#d4a017}

/* ── Columnas 2-3 · Navegación ── */
.ms-fg-heading{font-size:.6rem;letter-spacing:2.5px;text-transform:uppercase;color:#d4a017;font-weight:700;margin:0 0 22px}
.ms-fg-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.ms-fg-links a{color:#bbb;text-decoration:none;font-size:.88rem;transition:color .2s}
.ms-fg-links a:hover{color:#fff}

/* ── Columna 4 · Contacto ── */
.ms-fg-contact{display:flex;flex-direction:column;gap:28px}
.ms-fg-contact-item{display:flex;align-items:flex-start;gap:12px}
.ms-fg-contact-icon{flex-shrink:0;width:20px;height:20px;margin-top:2px}
.ms-fg-contact-icon svg{width:20px;height:20px}
.ms-fg-contact-icon--phone svg{fill:#999}
.ms-fg-contact-icon--pin svg{fill:#d4a017}
.ms-fg-contact-icon--email svg{fill:#999}
.ms-fg-contact-label{display:block;font-size:.55rem;letter-spacing:2px;text-transform:uppercase;color:#888;margin-bottom:4px;font-weight:600}
.ms-fg-contact-value{color:#fff;text-decoration:none;font-size:1.15rem;font-weight:700;transition:color .2s;display:block}
.ms-fg-contact-value:hover{color:#d4a017}
.ms-fg-contact-value--sm{font-size:.88rem;font-weight:600;line-height:1.5}

/* ── Barra inferior ── */
.ms-fg-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:22px 0;border-top:1px solid #2a2a2a}
.ms-fg-bottom p{margin:0;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:#555}
.ms-fg-legal{display:flex;gap:24px;flex-wrap:wrap}
.ms-fg-legal a{color:#555;text-decoration:none;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;transition:color .2s}
.ms-fg-legal a:hover{color:#999}

/* ── Responsive ── */
@media(max-width:900px){
  .ms-fg-grid{grid-template-columns:1fr 1fr;gap:35px}
}
@media(max-width:600px){
  .ms-fg-grid{grid-template-columns:1fr;gap:28px;padding:35px 0 28px}
  .ms-fg-bottom{flex-direction:column;text-align:center}
  .ms-fg-legal{justify-content:center}
}
		