:root {
    --color-bg-dark-primary: #111827;
    --color-bg-dark-secondary: #1F2937;
    --color-bg-dark-tertiary: #374151;
    --color-text-light-primary: #F3F4F6;
    --color-text-light-secondary: #D1D5DB;
    --color-accent-vibrant: #06B6D4;
    --color-accent-vibrant-hover: #0891B2;
    --color-accent-warm: #F59E0B;
    --font-heading: 'Lexend Deca', sans-serif;
    --font-body: 'Inter', sans-serif;
    --shadow-glow-accent: 0 0 15px rgba(6, 182, 212, 0.3), 0 0 25px rgba(6, 182, 212, 0.2);
    --shadow-card: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --border-radius-std: 8px;
    --border-radius-lg: 12px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 100%; }
body {
    font-family: var(--font-body);
    color: var(--color-text-light-primary);
    background-color: var(--color-bg-dark-primary);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.container { width: 90%; max-width: 1200px; margin-left: auto; margin-right: auto; }
h1, h2, h3, h4 { font-family: var(--font-heading); font-weight: 700; line-height: 1.3; color: var(--color-text-light-primary); }
h1 { font-size: clamp(2.8rem, 6vw, 4.5rem); margin-bottom: 0.5em; font-weight: 700; }
h2 { font-size: clamp(2.2rem, 4.5vw, 3.5rem); margin-bottom: 1em; text-align: center; }
h3 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); margin-bottom: 0.75em; }
p { margin-bottom: 1.5em; font-size: 1.05rem; color: var(--color-text-light-secondary); }
a { color: var(--color-accent-vibrant); text-decoration: none; transition: color 0.25s ease-in-out; }
a:hover { color: var(--color-accent-vibrant-hover); }
img { max-width: 100%; height: auto; display: block; }
.section { padding: clamp(70px, 12vh, 120px) 0; position: relative; overflow: hidden; }
.section-accent-text { color: var(--color-accent-vibrant); }
.section-warm-accent-text { color: var(--color-accent-warm); }

.site-header { 
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
.site-header.scrolled {
    background-color: rgba(17, 24, 39, 0.98) !important; 
    border-color: var(--color-bg-dark-tertiary) !important;
}
.btn-header { 
    display: inline-block; background-color: var(--color-accent-vibrant); color: var(--color-bg-dark-primary) !important;
    padding: 6px 14px; font-family: var(--font-heading); font-weight: 700; font-size: 0.75rem; text-transform: uppercase;
    letter-spacing: 0.5px; border-radius: var(--border-radius-std); transition: all 0.3s ease; margin-left: 1rem;
    box-shadow: var(--shadow-glow-accent);
}
.btn-header:hover {
    background-color: var(--color-accent-vibrant-hover); transform: translateY(-2px); color: var(--color-bg-dark-primary);
    box-shadow: 0 0 20px rgba(6, 182, 212, 0.5);
}
.hero-section {
    min-height: 90vh; padding-top: 140px; display: flex; align-items: center; text-align: center;
    position: relative; overflow: hidden; color: white;
}
.hero-section::before {
    content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background-image: url('images/portada.webp');
    background-size: cover; background-position: center; pointer-events: none; user-select: none;
    z-index: -2;
    animation: kenburns-effect 20s ease-in-out infinite alternate;
}
.hero-section::after {
    content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(17, 24, 39, 0.6); z-index: -1;
}
.hero-content { max-width: 900px; margin: 0 auto; position: relative; z-index: 1; }
.hero-content h1 { text-shadow: 0 2px 15px rgba(0,0,0,0.5); }
.hero-content .subtitle {
    font-size: clamp(1.15rem, 2.5vw, 1.5rem); color: var(--color-text-light-primary);
    margin-bottom: 2.5em; max-width: 750px; margin-left: auto; margin-right: auto; line-height: 1.8;
    text-shadow: 0 1px 8px rgba(0,0,0,0.6);
}
@keyframes kenburns-effect {
    0% { transform: scale(1); }
    100% { transform: scale(1.1); }
}
.fade-in-up {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.fade-in-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.essence-item, .solution-card {
    transition-delay: var(--delay, 0s);
}
.btn {
    display: inline-block; padding: 16px 40px; font-family: var(--font-heading); font-weight: 700;
    font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.8px; border-radius: var(--border-radius-std);
    transition: all 0.3s ease; border: 2px solid transparent; cursor: pointer;
}
.btn-primary-accent {
    background-color: var(--color-accent-vibrant); color: var(--color-bg-dark-primary); border-color: var(--color-accent-vibrant);
    box-shadow: var(--shadow-glow-accent);
}
.btn-primary-accent:hover {
    background-color: var(--color-accent-vibrant-hover); border-color: var(--color-accent-vibrant-hover);
    transform: translateY(-3px) scale(1.02); box-shadow: 0 0 20px rgba(6, 182, 212, 0.4), 0 0 30px rgba(6, 182, 212, 0.3);
}
.btn-outline-light {
    background-color: transparent; color: var(--color-text-light-primary); border-color: var(--color-text-light-secondary);
    margin-left: 20px;
}
.btn-outline-light:hover {
    border-color: var(--color-accent-vibrant); color: var(--color-accent-vibrant);
    box-shadow: 0 0 10px rgba(6, 182, 212, 0.2);
}
.essence-section { background-color: var(--color-bg-dark-secondary); }
.essence-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 40px; margin-top: 50px; }
.essence-item {
    background-color: var(--color-bg-dark-primary); padding: 35px; border-radius: var(--border-radius-lg);
    border: 1px solid var(--color-bg-dark-tertiary); transition: transform 0.3s ease, border-color 0.3s ease;
}
.essence-item:hover { transform: translateY(-8px); border-color: var(--color-accent-vibrant); }
.essence-item-icon {
    font-size: 2.8rem; color: var(--color-accent-vibrant); margin-bottom: 20px; line-height: 1;
}
.essence-item h3 { font-size: 1.8rem; margin-bottom: 0.5em; }
.solutions-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 35px; margin-top: 50px; }
.solution-card {
    background-color: var(--color-bg-dark-secondary); border-radius: var(--border-radius-lg); overflow: hidden;
    box-shadow: var(--shadow-card); display: flex; flex-direction: column; border: 1px solid transparent;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.solution-card:hover { transform: translateY(-5px) scale(1.01); box-shadow: 0 10px 20px rgba(0,0,0,0.25); border-color: var(--color-accent-vibrant); }
.solution-card-image { 
    height: 200px; background-size: cover; background-position: center;
}
.solution-card-content { padding: 30px; flex-grow: 1; display: flex; flex-direction: column; justify-content: space-between; }
.solution-card h3 { color: var(--color-accent-vibrant); font-size: 1.7rem; }
.solution-card p { font-size: 0.95rem; color: var(--color-text-light-secondary); }
.solution-card .btn-details { 
    background-color: var(--color-accent-vibrant-hover); color: var(--color-text-light-primary);
    padding: 12px 28px; font-size: 0.9rem; align-self: flex-start; border-radius: var(--border-radius-std);
}
.solution-card .btn-details:hover { background-color: var(--color-accent-vibrant); box-shadow: var(--shadow-glow-accent); }

.knowledge-focus-section { background-color: var(--color-bg-dark-secondary); }
.knowledge-intro { text-align: center; max-width: 750px; margin: 0 auto 3em auto; }
.btn-view-all-knowledge {
    display: block; width: fit-content; margin: 3em auto 0 auto; background-color: transparent;
    color: var(--color-accent-vibrant); border: 2px solid var(--color-accent-vibrant);
}
.btn-view-all-knowledge:hover { background-color: var(--color-accent-vibrant); color: var(--color-bg-dark-primary); box-shadow: var(--shadow-glow-accent); }
.final-cta-section {
    background-image: linear-gradient(to right, var(--color-accent-vibrant), var(--color-accent-vibrant-hover));
    color: var(--color-bg-dark-primary); text-align: center;
}
.final-cta-section h2 { color: var(--color-bg-dark-primary); font-size: clamp(2rem, 4vw, 3rem); }
.final-cta-section p { max-width: 700px; margin-left: auto; margin-right: auto; color: rgba(17, 24, 39, 0.85); font-size: 1.1rem; }
.final-cta-section .btn-dark {
    background-color: var(--color-bg-dark-primary); color: var(--color-accent-vibrant); border-color: var(--color-bg-dark-primary);
    margin-top: 1.5em; padding: 18px 45px; font-size: 1.1rem;
}
.final-cta-section .btn-dark:hover { background-color: var(--color-bg-dark-secondary); transform: translateY(-3px) scale(1.02); box-shadow: 0 6px 20px rgba(0,0,0,0.3); }

.site-footer {
    background-color: var(--color-bg-dark-secondary); border-top: 1px solid var(--color-bg-dark-tertiary);
    color: var(--color-text-light-secondary); padding: 60px 0 30px; font-size: 0.9rem;
}
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 40px; margin-bottom: 40px; }
.footer-column h4 { color: var(--color-text-light-primary); font-size: 1.15rem; margin-bottom: 1.2em; text-transform: uppercase; letter-spacing: 0.8px; }
.footer-column ul { list-style: none; }
.footer-column li { margin-bottom: 0.8em; }
.footer-column a { color: var(--color-text-light-secondary); }
.footer-column a:hover { color: var(--color-accent-vibrant); }
.footer-column p { color: var(--color-text-light-secondary); line-height: 1.8; }
.footer-bottom-text { text-align: center; padding-top: 30px; border-top: 1px solid var(--color-bg-dark-tertiary); font-size: 0.85rem; }
@media (max-width: 850px) { 
  .main-nav { display: none; }
  .hero-section { min-height: 75vh; text-align: center; }
  .btn-outline-light { margin-left: 0; margin-top: 15px; }
}
.whatsapp-float {
    position: fixed; bottom: 20px; right: 20px; background-color: #25D366; border-radius: 50%; padding: 12px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.2); z-index: 9999; transition: transform 0.3s ease;
    display: flex; align-items: center; justify-content: center;
}
.whatsapp-float:hover { transform: scale(1.1); }
.whatsapp-float img { filter: invert(1); width: 40px; height: 40px; }
@keyframes shake-animation {
    0% { transform: rotate(0deg); }
    25% { transform: rotate(-15deg); } 
    50% { transform: rotate(15deg); } 
    75% { transform: rotate(-15deg); } 
    100% { transform: rotate(0deg); }
}
.shake {
    animation: shake-animation 0.8s; 
}
:root {
    --color-bg-dark-primary: #111827;
    --color-bg-dark-secondary: #1F2937;
    --color-bg-dark-tertiary: #374151;
    --color-text-light-primary: #F3F4F6;
    --color-text-light-secondary: #D1D5DB;
    --color-accent-vibrant: #06B6D4;
    --color-accent-vibrant-hover: #0891B2;
    --color-accent-warm: #F59E0B; 
    --font-heading: 'Lexend Deca', sans-serif;
    --font-body: 'Inter', sans-serif;
    --shadow-glow-accent: 0 0 15px rgba(6, 182, 212, 0.3), 0 0 25px rgba(6, 182, 212, 0.2);
    --shadow-card: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --border-radius-std: 8px;
    --border-radius-lg: 12px;
    --color-bg-light-primary: #FFFFFF;      
    --color-bg-light-secondary: #F8F9FA;     
    --color-bg-light-tertiary: #E9ECEF;    
    --color-text-dark-primary: #212529;       
    --color-text-dark-secondary: #495057;     
    --shadow-card-light: 0 4px 12px rgba(0, 0, 0, 0.07); 
    --border-color-light: #DEE2E6;           
}
.light-theme h1,
.light-theme h2,
.light-theme h3,
.light-theme h4 {
    color: var(--color-text-dark-primary); 
}
.light-theme p {
    color: var(--color-text-dark-secondary); 
}
.light-theme .section-accent-text { color: var(--color-accent-vibrant); }
.light-theme .section-warm-accent-text { color: var(--color-accent-warm); }

.essence-section.light-theme {
    background-color: var(--color-bg-light-secondary);
}
.essence-section.light-theme h2 {
    color: var(--color-text-dark-primary);
}
.essence-section.light-theme .essence-item {
    background-color: var(--color-bg-light-primary); 
    border: 1px solid var(--border-color-light); 
    box-shadow: var(--shadow-card-light);
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}
.essence-section.light-theme .essence-item:hover {
    transform: translateY(-8px);
    border-color: var(--color-accent-vibrant);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
}
.essence-section.light-theme .essence-item-icon {
    color: var(--color-accent-vibrant); 
}
.essence-section.light-theme .essence-item h3 {
    color: var(--color-text-dark-primary);
}
.essence-section.light-theme .essence-item p {
    color: var(--color-text-dark-secondary);
}
.featured-solutions-section.light-theme {
    background-color: var(--color-bg-light-primary); 
}
.featured-solutions-section.light-theme h2 {
    color: var(--color-text-dark-primary);
}
.featured-solutions-section.light-theme .solution-card {
    background-color: var(--color-bg-light-secondary);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-card-light);
    border: 1px solid var(--border-color-light);
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.featured-solutions-section.light-theme .solution-card:hover {
    transform: translateY(-5px) scale(1.01);
    box-shadow: 0 10px 20px rgba(0,0,0,0.08);
    border-color: var(--color-accent-vibrant);
}
.featured-solutions-section.light-theme .solution-card-content {
    padding: 30px;
}
.featured-solutions-section.light-theme .solution-card h3 {
    color: var(--color-accent-vibrant); 
}
.featured-solutions-section.light-theme .solution-card p {
    color: var(--color-text-dark-secondary);
}
.featured-solutions-section.light-theme .solution-card .btn-details {
    background-color: var(--color-accent-vibrant);
    color: var(--color-bg-light-primary); 
    border: 2px solid var(--color-accent-vibrant);
}
.featured-solutions-section.light-theme .solution-card .btn-details:hover {
    background-color: var(--color-accent-vibrant-hover);
    border-color: var(--color-accent-vibrant-hover);
    color: var(--color-bg-light-primary);
    box-shadow: 0 2px 8px rgba(6, 182, 212, 0.3);
}
.knowledge-focus-section.light-theme {
    background-color: var(--color-bg-light-secondary);
}
.knowledge-focus-section.light-theme h2 {
    color: var(--color-text-dark-primary);
}
.knowledge-focus-section.light-theme .knowledge-intro {
    color: var(--color-text-dark-secondary);
}
.knowledge-focus-section.light-theme .btn-view-all-knowledge {
    background-color: transparent; 
    color: var(--color-accent-vibrant);
    border: 2px solid var(--color-accent-vibrant);
}
.knowledge-focus-section.light-theme .btn-view-all-knowledge:hover {
    background-color: var(--color-accent-vibrant);
    color: var(--color-bg-light-primary); 
    border-color: var(--color-accent-vibrant);
    box-shadow: 0 2px 8px rgba(6, 182, 212, 0.3);
}
.final-cta-section.light-theme {
    background-image: linear-gradient(to right, var(--color-accent-vibrant) 0%, var(--color-accent-vibrant-hover) 100%); 
    color: var(--color-text-light-primary); 
}
.final-cta-section.light-theme h2 {
    color: var(--color-text-light-primary);
}
.final-cta-section.light-theme p {
    color: rgba(243, 244, 246, 0.9);

}
.final-cta-section.light-theme .btn-dark { 
    background-color: var(--color-bg-light-primary);
    color: var(--color-accent-vibrant); 
    border-color: var(--color-bg-light-primary); 
}
.final-cta-section.light-theme .btn-dark:hover {
    background-color: var(--color-text-light-secondary); 
    border-color: var(--color-text-light-secondary);
    color: var(--color-accent-vibrant-hover);
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 6px 20px rgba(0,0,0,0.1);
}
.close-button {
      font-size: 2.5rem;
      line-height: 1;
      color: #333;
      background: white;
      border-radius: 50%;
      width: 40px;
      height: 40px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      border: 2px solid #ddd;
      box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}
.close-button:hover {
      background: #f0f0f0;
      color: #000;
}
#leaflet-map {
    height: 400px !important;
    width: 100% !important;
    min-height: 400px;
}
#map-modal .bg-white {
    min-height: 500px;
}
.why-us-section {
    background-color: var(--color-bg-light-secondary);
}
.why-us-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 2rem;
    margin-top: 4rem;
}
.why-us-item {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    background-color: var(--color-bg-light-primary);
    padding: 2rem;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--border-color-light);
    box-shadow: var(--shadow-card-light);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.why-us-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
}
.why-us-icon {
    font-size: 2rem;
    color: var(--color-accent-vibrant);
    margin-top: 0.1em;
}
.why-us-item h3 {
    font-size: 1.25rem;
    color: var(--color-text-dark-primary);
    margin-bottom: 0.5rem;
}
.why-us-item p {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 0;
    color: var(--color-text-dark-secondary);
}
.process-section {
    background-color: var(--color-accent-vibrant);
    overflow-x: hidden;
}

.process-section h2 {
    color: var(--color-bg-dark-primary);
}
.process-section .timeline-container {
    margin-top: 5rem;
    display: flex;
    justify-content: space-between;
    position: relative;
}

.process-section .timeline-line {
    position: absolute;
    top: 44px;
    left: 5%;
    width: 90%;
    height: 4px;
    background-color: rgba(17, 24, 39, 0.2);
}

.process-section .timeline-step {
    text-align: center;
    width: 12%;
    opacity: 1; 
    transform: translateY(0);
}

.timeline-icon {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background-color: var(--color-bg-dark-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.5rem auto;
    font-size: 1.8rem;
    border: 3px solid var(--color-bg-dark-secondary);
}
.timeline-step h4 {
    color: var(--color-bg-dark-primary);
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}
.timeline-step p {
    font-size: 0.85rem;
    color: var(--color-bg-dark-secondary);
    line-height: 1.5;
    margin-bottom: 0;
}

@media (max-width: 768px) {
    .process-section .timeline-container {
        flex-direction: column;
        align-items: center;    
        gap: 2rem;              
    }

    .process-section .timeline-line {
        left: 50%;
        top: 0;
        width: 3px;         
        height: 100%;     
        transform: translateX(-50%); 
    }

    .process-section .timeline-step {
        width: 100%;
        max-width: 350px;   
        position: relative; 
        padding: 0 1rem;   
        background-color: var(--color-accent-vibrant); 
    }

    .main-nav { 
      display: none; 
    }
    .hero-section { 
      min-height: 75vh; 
      text-align: center; 
    }
    .btn-outline-light { 
      margin-left: 0; 
      margin-top: 15px; 
    }
    .why-us-grid {
        grid-template-columns: 1fr;
    }
}

.coverage-payment-section { background-color: var(--color-bg-light-primary); }
.coverage-container { text-align: center; margin-bottom: 5rem; }
.coverage-map {
    width: 100%;
    max-width: 800px;
    margin: 2rem auto;
}
.payment-container { text-align: center; }
.payment-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
    text-align: left;
}
.payment-option {
    background: var(--color-bg-light-secondary);
    padding: 2rem;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--border-color-light);
}
.payment-icon {
    font-size: 2.5rem;
    color: var(--color-accent-vibrant);
    margin-bottom: 1rem;
}
.payment-option h3 {
    font-size: 1.3rem;
    color: var(--color-text-dark-primary);
    margin-bottom: 1rem;
}
.payment-option ul {
    list-style-type: none;
    padding-left: 0;
}
.payment-option li {
    font-size: 0.9rem;
    color: var(--color-text-dark-secondary);
    padding-left: 1.5em;
    position: relative;
    margin-bottom: 0.5rem;
}
.payment-option li::before {
    content: '✔';
    position: absolute;
    left: 0;
    color: var(--color-accent-vibrant);
}

@media (max-width: 768px) {
    .timeline-container {
        flex-direction: column;
        align-items: center;
        gap: 2rem;
    }
    .timeline-line {
        left: 50%;
        top: 5%;
        width: 3px;
        height: 90%;
        transform: scaleY(0);
        transform-origin: top;
    }
    .process-section.is-visible .timeline-line::after {
        transform: scaleY(1);
    }
    .timeline-step {
        width: 100%;
        max-width: 350px;
    }
    .why-us-grid {
        grid-template-columns: 1fr;
    }
}

.coverage-map {
    width: 100%;
    max-width: 800px;
    margin: 2rem auto;
    user-select: none;    
    pointer-events: none; 
}

.regularizacion-section {
    background-color: #f8f9fa; 
    padding: 4rem 1rem;
    font-family: 'Inter', sans-serif;
}

.regularizacion-section h2 {
    color: var(--color-text-dark-primary);
    font-family: var(--font-heading);
}

.regularizacion-section .section-subtitle {
    color: var(--color-text-dark-secondary);
    margin-top: 0.5rem;
}

.plan-card {
    background-color: var(--color-bg-light-primary);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-card-light);
    border: 1px solid var(--border-color-light);
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.plan-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.plan-card h3 {
    font-family: var(--font-heading);
    font-size: 1.5rem; 
    font-weight: 700;
    color: var(--color-text-dark-primary);
    margin-bottom: 0.5rem;
}

.plan-card .plan-description {
    color: var(--color-text-dark-secondary);
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 1.5rem;
}

.plan-card ul {
    list-style: none;
    padding: 0;
    margin-bottom: 2rem;
}

.plan-card li {
    color: var(--color-text-dark-secondary);
    padding-left: 2em;
    position: relative;
    margin-bottom: 0.8rem;
}

.plan-card li::before {
    content: '✔';
    position: absolute;
    left: 0;
    top: 2px;
    color: var(--color-accent-vibrant);
    font-weight: 600;
}

.price-section {
    text-align: center;
    margin-top: auto; 
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color-light);
}

.price {
    font-family: var(--font-heading);
    font-size: 2.75rem;
    font-weight: 700;
    color: var(--color-accent-warm);
    line-height: 1.2;
}

.price-details {
    font-size: 0.875rem; 
    color: #6c757d; 
    margin-bottom: 1.5rem;
}

.plan-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
    background-color: var(--color-accent-vibrant);
    color: white;
    font-family: var(--font-heading);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1rem;
    padding: 1rem;
    border-radius: var(--border-radius-std);
    transition: all 0.3s ease;
}

.plan-button:hover {
    background-color: var(--color-accent-vibrant-hover);
    transform: translateY(-3px);
    box-shadow: var(--shadow-glow-accent);
}

.plan-button i {
    font-size: 1.25rem;
}