:root {
    --color-primary: #3d6ab4; --color-primary-container: #d8e2ff; --color-on-primary: #ffffff;
    --color-secondary: #006d77; --color-tertiary: #b99d00; --color-background: #fdfcff;
    --color-surface: #f7f9ff; --color-on-background: #1a1c1e; --color-on-surface-variant: #44474f;
    --color-outline: #e1e2ec; --color-shadow: rgba(0, 0, 0, 0.08); --font-family-body: 'Roboto', sans-serif;
    --font-family-headline: 'Geist', sans-serif; --shadow-sm: 0 1px 2px 0 var(--color-shadow);
    --shadow-md: 0 4px 6px -1px var(--color-shadow), 0 2px 4px -2px var(--color-shadow);
    --radius-md: 8px; --radius-lg: 16px; --transition-speed: 0.3s;
}
body.dark-mode {
    --color-primary: #adc6ff; --color-primary-container: #24519a; --color-on-primary: #002d6d;
    --color-secondary: #4ed8e5; --color-tertiary: #d8c63d; --color-background: #1a1c1e;
    --color-surface: #242629; --color-on-background: #e2e2e6; --color-on-surface-variant: #c4c6d0;
    --color-outline: #3a3c40; --color-shadow: rgba(0, 0, 0, 0.25);
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-family-body); background-color: var(--color-background);
    color: var(--color-on-background); margin: 0; -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; transition: background-color var(--transition-speed), color var(--transition-speed);
}
body.modal-open { position: fixed; width: 100%; overflow-y: hidden; }
:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 2px; border-radius: var(--radius-md); }

.skip-links {
    list-style: none;
    margin: 0;
    padding: 0;
    position: absolute;
    z-index: 9999;
}
.skip-link {
    position: absolute;
    top: 0;
    left: 0;
    background: var(--color-primary);
    color: var(--color-on-primary);
    padding: 8px 16px;
    transform: translateY(-120%);
    transition: transform 0.3s ease-out;
    text-decoration: none;
    font-weight: 500;
}
.skip-link:focus {
    transform: translateY(0);
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.loading {
    position: relative;
    pointer-events: none;
}
.loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--color-background);
    opacity: 0.7;
    backdrop-filter: blur(2px);
}
.loading .spinner {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

@media print {
    body {
        background: white;
        color: black;
        font-size: 12pt;
    }
    .header, .skip-links, .theme-toggle-btn, .header-menu-toggle, .floating-cta, .back-to-top-btn, .filter-buttons, .search-wrapper, .pagination-container, .newsletter-signup, .footer-social-links, .hero-buttons, .contact-form-container {
        display: none !important;
    }
    a {
        text-decoration: none;
        color: black;
    }
    a[href^="http"]::after {
        content: " (" attr(href) ")";
        font-size: 90%;
    }
    .app-card, .article-card {
        break-inside: avoid;
        page-break-inside: avoid;
        border: 1px solid #ddd;
    }
    img {
        max-width: 100% !important;
        page-break-inside: avoid;
    }
}
.container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }
.header { background-color: rgba(253, 252, 255, 0.85); backdrop-filter: blur(10px); position: fixed; top: 0; left: 0; right: 0; z-index: 1000; border-bottom: 1px solid var(--color-outline); transition: background-color var(--transition-speed), border-color var(--transition-speed); }
body.dark-mode .header { background-color: rgba(26, 28, 30, 0.85); }
.header .container { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.header-logo { font-family: var(--font-family-headline); font-weight: 600; font-size: 1.5rem; text-decoration: none; color: var(--color-on-background); }
.header-logo span { color: var(--color-primary); }
.header-controls { display: flex; align-items: center; gap: 8px; }
.header-nav { display: flex; gap: 8px; }
.header-nav a { color: var(--color-on-surface-variant); text-decoration: none; font-weight: 500; padding: 8px 16px; border-radius: var(--radius-md); transition: all var(--transition-speed) ease; }
.header-nav a:hover, .header-nav a:focus-visible { color: var(--color-primary); background-color: var(--color-primary-container); outline: none; }
.header-nav a.active { background-color: var(--color-primary); color: var(--color-on-primary); font-weight: bold; }
body.dark-mode .header-nav a.active { color: #002d6d; }
.theme-toggle-btn { background: none; border: none; cursor: pointer; color: var(--color-on-surface-variant); font-size: 1.25rem; padding: 8px; line-height: 1; transition: color var(--transition-speed) ease, transform 0.1s ease; }
.theme-toggle-btn:hover { color: var(--color-primary); }
.header-menu-toggle { display: none; font-size: 2rem; background: none; border: none; color: var(--color-on-surface-variant); cursor: pointer; z-index: 1002; }
main { padding-top: 64px; }
.view { display: none; animation: fadeIn 0.5s ease-in-out; }
.view.active { display: block; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.section { padding: 80px 0; }
.section-soft { background-color: var(--color-surface); }
h1, h2, h3, h4, h5 { font-family: var(--font-family-headline); font-weight: 800; letter-spacing: -0.02em; color: var(--color-on-background); text-align: center; }
h1 { font-size: clamp(2.5rem, 5.5vw, 4rem); line-height: 1.15; margin: 0 0 24px 0; }
h2 { font-size: clamp(2rem, 4.5vw, 3rem); margin: 0 0 16px 0; }
.section-subtitle { font-size: 1.25rem; color: var(--color-on-surface-variant); max-width: 700px; margin: 0 auto 48px auto; line-height: 1.6; text-align: center; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 500; font-size: 1rem; padding: 12px 28px; border-radius: 24px; border: 1px solid transparent; text-decoration: none; cursor: pointer; transition: all var(--transition-speed) ease; }
.btn-filled { background-color: var(--color-primary); color: var(--color-on-primary); }
.btn-filled:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.btn-outlined { color: var(--color-primary); border-color: var(--color-outline); }
.btn-outlined:hover { background-color: var(--color-primary-container); border-color: var(--color-primary); }
.btn:active { transform: scale(0.97) translateY(-1px); }
.hero { text-align: center; }
.hero-typing-container { font-size: clamp(1.8rem, 4vw, 2.5rem); color: var(--color-primary); font-family: var(--font-family-headline); font-weight: 800; height: 4rem; display: flex; justify-content: center; align-items: center; margin-bottom: 24px; }
.typing-cursor { width: 3px; height: 3rem; background-color: var(--color-tertiary); animation: blink 1s infinite; }
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } }
.hero-buttons { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.manifesto-section .container { max-width: 960px; }
.manifesto-content { display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: center; }
.manifesto-text h2 { text-align: left; font-size: clamp(2rem, 4vw, 2.8rem); margin-bottom: 1rem; }
.manifesto-image { text-align: center; display: flex; align-items: center; justify-content: center; }
.manifesto-image i { font-size: clamp(8rem, 20vw, 12rem); color: var(--color-primary-container); line-height: 1; }
body.dark-mode .manifesto-image i { opacity: 0.6; }
@media (min-width: 768px) { .manifesto-content { grid-template-columns: 2fr 1fr; gap: 4rem; } }
.centered-button-container { text-align: center; margin-top: 3rem; }
.pathway-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; max-width: 1100px; margin: 48px auto 0 auto; }
.pathway-card { display: block; background-color: var(--color-surface); border: 1px solid var(--color-outline); border-radius: var(--radius-lg); padding: 2rem; text-decoration: none; color: var(--color-on-background); text-align: left; transition: all var(--transition-speed) ease; }
.pathway-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--color-primary); }
.pathway-card i { font-size: 2.5rem; color: var(--color-primary); margin-bottom: 1rem; display: block; }
.pathway-card h3 { font-size: 1.5rem; margin: 0 0 0.5rem 0; text-align: left; }
.pathway-card p { color: var(--color-on-surface-variant); margin: 0 0 1.5rem 0; line-height: 1.6; }
.pathway-card span { font-weight: 500; color: var(--color-primary); }
.search-wrapper { max-width: 600px; margin: 0 auto 2.5rem auto; position: relative; }
.search-input { width: 100%; padding: 0.75rem 1.25rem; border-radius: var(--radius-md); border: 1px solid var(--color-outline); background-color: var(--color-background); color: var(--color-on-background); font-size: 1rem; box-shadow: var(--shadow-sm); transition: var(--transition-speed); }
.search-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-container); outline: none; }
.filter-buttons { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem; margin-bottom: 3rem; }
.filter-btn { color: var(--color-on-surface-variant); font-weight: 500; background-color: transparent; border: 1px solid var(--color-outline); box-shadow: var(--shadow-sm); padding: 8px 16px; border-radius: 16px; cursor: pointer; transition: all var(--transition-speed) ease; }
.filter-btn.active, .filter-btn:hover { background-color: var(--color-primary); color: var(--color-on-primary); border-color: var(--color-primary); }
.filter-btn:active { transform: scale(0.96); }
body.dark-mode .filter-btn.active { color: #002d6d; }
.portfolio-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 24px; }
.app-card-wrapper { position: relative; }
.app-card { display: flex; flex-direction: column; height: 100%; background-color: var(--color-surface); border: 1px solid var(--color-outline); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease; text-align: left; }
.app-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--color-primary); }
.app-card-main-content { padding: 24px; flex-grow: 1; }
.app-card-header { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 12px; }
.app-card-icon { font-size: 1.75rem; color: var(--color-primary); margin-top: 4px; }
.app-card h5 { font-family: var(--font-family-headline); font-weight: 700; font-size: 1.2rem; color: var(--color-on-background); margin:0; text-align: left; }
.app-card-category { font-size: 0.8rem; font-weight: 500; color: var(--color-secondary); }
.app-card-desc { font-size: 0.95rem; line-height: 1.5; color: var(--color-on-surface-variant); margin-bottom: 16px; }
.app-card-features { list-style: none; padding: 0; margin: 0; }
.app-card-features li { display: flex; align-items: center; gap: 8px; font-size: 0.9rem; color: var(--color-on-surface-variant); margin-bottom: 8px; }
.app-card-features i { color: var(--color-secondary); font-size: 1rem; }
.favorite-btn { position: absolute; top: 12px; right: 12px; z-index: 2; background: none; border: none; font-size: 1.5rem; color: var(--color-on-surface-variant); cursor: pointer; transition: color 0.2s, transform 0.2s; padding: 4px; }
.favorite-btn:hover { transform: scale(1.2); background-color: rgba(0,0,0,0.05); border-radius: 50%; }
body.dark-mode .favorite-btn:hover { background-color: rgba(255,255,255,0.1); }
.favorite-btn.favorited { color: var(--color-tertiary); }
.app-card-footer { display: flex; align-items: center; justify-content: space-between; padding: 12px 24px; background-color: var(--color-background); border-top: 1px solid var(--color-outline); border-bottom-left-radius: var(--radius-lg); border-bottom-right-radius: var(--radius-lg); }
.footer-learn-more { font-size: 0.9rem; color: var(--color-primary); font-weight: 500; display: flex; align-items: center; gap: 4px; }
.footer-learn-more i { transition: transform 0.3s ease-out; }
.app-card:hover .footer-learn-more i { transform: translateX(5px); }
.app-card-footer-actions { display: flex; gap: 8px; }
.footer-action-btn { background: none; border: none; font-size: 1.2rem; color: var(--color-on-surface-variant); cursor: pointer; padding: 8px; border-radius: 50%; line-height: 1; transition: background-color 0.2s, color 0.2s; }
.footer-action-btn:hover { background-color: var(--color-primary-container); color: var(--color-primary); }
.footer-action-btn.saved i { color: var(--color-tertiary); }
[data-tooltip] { position: relative; }
[data-tooltip]::after { content: attr(data-tooltip); position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%); background-color: var(--color-on-background); color: var(--color-background); padding: 4px 8px; border-radius: var(--radius-md); font-size: 0.8rem; white-space: nowrap; opacity: 0; visibility: hidden; transition: opacity 0.2s, visibility 0.2s; margin-bottom: 8px; pointer-events: none; }
[data-tooltip]:hover::after { opacity: 1; visibility: visible; }
.no-results { text-align: center; display: none; margin-top: 2rem; }
.pagination-container { display: flex; justify-content: center; gap: 8px; margin-top: 2rem; }
.pagination-btn { padding: 8px 16px; border: 1px solid var(--color-outline); background-color: var(--color-surface); color: var(--color-primary); cursor: pointer; border-radius: var(--radius-md); transition: all 0.2s ease; }
.pagination-btn.active { background-color: var(--color-primary); color: var(--color-on-primary); }
.pagination-btn:active { transform: scale(0.96); }
.pagination-btn:disabled { cursor: not-allowed; opacity: 0.5; }
.timeline-container { position: relative; max-width: 800px; margin: 2rem auto 0 auto; padding: 0; }
.timeline-container::before { content: ''; position: absolute; top: 20px; bottom: 20px; left: 28px; width: 4px; background: var(--color-primary-container); border-radius: 2px; }
.timeline-item { position: relative; margin-bottom: 2.5rem; padding-left: 80px; }
.timeline-badge { position: absolute; left: 0; top: 0; width: 60px; height: 60px; border-radius: 50%; background: var(--color-primary); color: var(--color-on-primary); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: bold; font-family: var(--font-family-headline); border: 4px solid var(--color-surface); }
body.dark-mode .timeline-badge { border-color: var(--color-surface); color: #002d6d; }
.timeline-content { text-align: left; }
.timeline-content h4 { color: var(--color-primary); font-size: 1.5rem; margin-bottom: 8px; text-align: left;}
.timeline-content p { color: var(--color-on-surface-variant); margin: 0; }
.philosophy-grid { display: grid; gap: 2rem; max-width: 1100px; margin: 48px auto 0 auto; }
.philosophy-item { text-align: center; padding: 2rem; background-color: var(--color-background); border: 1px solid var(--color-outline); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.philosophy-icon { font-size: 3rem; color: var(--color-primary); margin-bottom: 1rem; }
.philosophy-item h3 { font-size: 1.5rem; margin-bottom: 1rem; }
.philosophy-item p { text-align: left; line-height: 1.7; color: var(--color-on-surface-variant); margin: 0; }
.wall-of-love-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 24px; align-items: start; }
.testimonial-card { background-color: var(--color-surface); border: 1px solid var(--color-outline); border-radius: var(--radius-lg); padding: 2rem; display: flex; flex-direction: column; box-shadow: var(--shadow-sm); height: 100%; }
@media(min-width: 920px) {
    .wall-of-love-grid { grid-template-columns: repeat(3, 1fr); }
    .testimonial-card:nth-child(1) { grid-column: span 2; }
    .testimonial-card:nth-child(5) { grid-column: span 2; }
}
.testimonial-body { position: relative; padding-left: 3rem; font-style: italic; color: var(--color-on-surface-variant); flex-grow: 1; margin: 0 0 1.5rem 0; }
.testimonial-body .quote-icon { position: absolute; left: 0; top: -0.5rem; font-size: 2.5rem; color: var(--color-primary-container); line-height: 1; }
.testimonial-body p { margin: 0; font-size: 1.05rem; text-align: left; }
.testimonial-footer { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; padding-top: 1.5rem; border-top: 1px solid var(--color-outline); }
.testimonial-author { font-weight: 700; color: var(--color-on-background); margin: 0; text-align: left; }
.testimonial-author span { display: block; font-weight: 400; color: var(--color-on-surface-variant); font-size: 0.9rem; }
.testimonial-tool { font-size: 0.9rem; color: var(--color-secondary); font-weight: 500; display: flex; align-items: center; gap: 8px; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 24px; }
.blog-card { background-color: var(--color-background); border: 1px solid var(--color-outline); border-radius: var(--radius-lg); padding: 24px; text-decoration: none; color: var(--color-on-background); transition: all var(--transition-speed) ease; cursor: pointer; display: flex; flex-direction: column; text-align: left; }
.blog-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--color-primary); }
.blog-card-header { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 12px; }
.blog-card-icon { font-size: 1.75rem; color: var(--color-primary); margin-top: 4px; }
.blog-card-header h4 { margin: 0; color: var(--color-primary); text-align: left; font-size: 1.2rem; }
.blog-card p { margin: 0 0 1rem 0; color: var(--color-on-surface-variant); font-size: 0.95rem; flex-grow: 1; }
.blog-card-footer { display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; color: var(--color-on-surface-variant); }
.blog-card-tags { display: flex; gap: 6px; }
.blog-card-tags span { background-color: var(--color-primary-container); padding: 2px 8px; border-radius: 10px; font-size: 0.75rem; }
.blog-card-read-time { flex-shrink: 0; white-space: nowrap; display: flex; align-items: center; gap: 4px; }
.faq-list-container { max-width: 800px; margin: 0 auto; }
.faq-list-item { padding: 1.5rem 0; border-bottom: 1px solid var(--color-outline); }
.faq-list-item:first-child { padding-top: 0; }
.faq-list-item:last-child { border-bottom: none; }
.faq-list-item h3 { font-size: 1.2rem; font-weight: 700; font-family: var(--font-family-body); text-align: left; margin: 0 0 0.75rem 0; color: var(--color-primary); }
.faq-list-item p { text-align: left; line-height: 1.7; margin: 0; color: var(--color-on-surface-variant); }
.contact-layout { display: grid; grid-template-columns: 1fr; gap: 48px; max-width: 960px; margin: 48px auto 0 auto; }
@media(min-width: 920px) { .contact-layout { grid-template-columns: 1fr 1.2fr; } .philosophy-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 920px) { .philosophy-grid { grid-template-columns: 1fr; } }
.contact-hub { display: flex; flex-direction: column; gap: 24px; }
.contact-card { background-color: var(--color-surface); border: 1px solid var(--color-outline); border-radius: var(--radius-lg); padding: 32px; text-align: center; box-shadow: var(--shadow-sm); transition: all var(--transition-speed) ease; flex-grow: 1; text-decoration: none; }
.contact-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--color-primary); }
.contact-card i { font-size: 32px; color: var(--color-primary); margin-bottom: 16px; }
.contact-card h3 { margin: 0 0 8px 0; color: var(--color-on-background); }
.contact-card p { color: var(--color-on-surface-variant); margin: 0; }
.contact-form-container { background-color: var(--color-surface); border-radius: var(--radius-lg); padding: 32px; border: 1px solid var(--color-outline); }
.form-group { margin-bottom: 1.25rem; }
#contact-form label, #newsletter-form label { display: block; font-weight: 500; margin-bottom: 8px; color: var(--color-on-surface-variant); }
#contact-form input, #contact-form textarea, #newsletter-form input { width: 100%; padding: 0.75rem 1rem; border-radius: var(--radius-md); border: 1px solid var(--color-outline); background-color: var(--color-background); color: var(--color-on-background); font-size: 1rem; font-family: var(--font-family-body); transition: all var(--transition-speed) ease; }
#contact-form input:focus, #contact-form textarea:focus, #newsletter-form input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-container); outline: none; }
.modal-container { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(26, 28, 30, 0.7); backdrop-filter: blur(8px); z-index: 2000; display: none; align-items: center; justify-content: center; opacity: 0; transition: opacity var(--transition-speed) ease; }
.modal-container.open { display: flex; opacity: 1; }
.modal-content { background-color: var(--color-background); width: clamp(320px, 95vw, 900px); height: 90vh; border-radius: var(--radius-lg); display: flex; flex-direction: column; box-shadow: var(--shadow-md); transform: scale(0.95); transition: transform var(--transition-speed) ease; }
.modal-container.open .modal-content { transform: scale(1); }
.modal-header { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.5rem; border-bottom: 1px solid var(--color-outline); flex-shrink: 0; }
.modal-title { font-size: 1.5rem; text-align: left; margin: 0; }
.modal-close-btn { background: none; border: none; font-size: 1.75rem; color: var(--color-on-surface-variant); cursor: pointer; line-height: 1; }
.modal-close-btn:hover { color: var(--color-primary); }
.modal-body { overflow-y: auto; padding: 2rem; }
.landing-page-content h2 { text-align: left; font-size: 2rem; }
.landing-page-content h3 { text-align: left; margin: 2rem 0 1rem 0; color: var(--color-primary); }
.landing-page-content .subtitle { text-align: left; max-width: 100%; margin: 0 0 2rem 0; }
.landing-page-content ul { list-style: none; padding-left: 0; }
.landing-page-content ul li { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 1rem; text-align: left; }
.landing-page-content ul li i { margin-top: 5px; color: var(--color-secondary); }
.landing-page-content p {text-align: left; line-height: 1.7;}
.landing-page-content .privacy-box { background-color: var(--color-primary-container); border-radius: var(--radius-md); padding: 1rem 1.5rem; margin-top: 2rem; text-align: left; }
body.dark-mode .landing-page-content .privacy-box { background-color: var(--color-primary-container); }
.landing-page-content .privacy-box h4 { color: var(--color-on-primary); font-size: 1.1rem; text-align: left; margin: 0 0 0.5rem 0; display: flex; align-items: center; gap: 8px;}
body.dark-mode .landing-page-content .privacy-box h4 { color: white; }
.landing-page-content .privacy-box p { margin: 0; font-size: 0.95rem; }
.article-share { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--color-outline); text-align: left; }
.article-share h4 { text-align: left; margin: 0 0 1rem 0; font-size: 1.1rem; }
.article-share a { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; padding: 8px 16px; border-radius: var(--radius-md); color: white; margin-right: 10px; transition: opacity 0.2s ease; }
.article-share a:hover { opacity: 0.85; }
.share-whatsapp { background-color: #25D366; }
.share-linkedin { background-color: #0A66C2; }
.share-twitter { background-color: #1DA1F2; }
@keyframes fadeInSlideUp { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } }
.modal-container.open .modal-body > div > * { animation: fadeInSlideUp 0.5s ease-out forwards; opacity: 0; }
.modal-container.open .modal-body > div > *:nth-child(1) { animation-delay: 0.05s; }
.modal-container.open .modal-body > div > *:nth-child(2) { animation-delay: 0.1s; }
.modal-container.open .modal-body > div > *:nth-child(3) { animation-delay: 0.15s; }
.modal-container.open .modal-body > div > *:nth-child(4) { animation-delay: 0.2s; }
.modal-container.open .modal-body > div > *:nth-child(5) { animation-delay: 0.25s; }
.modal-container.open .modal-body > div > *:nth-child(6) { animation-delay: 0.3s; }
@media (max-width: 920px) {
    .header-menu-toggle { display: block; }
    .header-nav { position: fixed; top: 64px; right: 0; bottom: 0; width: min(75vw, 300px); background-color: var(--color-surface); flex-direction: column; padding: 24px; gap: 16px; transform: translateX(100%); transition: transform 0.3s ease-in-out; border-left: 1px solid var(--color-outline); box-shadow: -5px 0 15px rgba(0,0,0,0.1); }
    .header-nav.active { transform: translateX(0); }
    .header-nav a { width: 100%; padding: 12px 16px; text-align: left; }
    .section { padding: 60px 0; }
}
.floating-cta { position: fixed; bottom: 24px; right: 24px; width: 60px; height: 60px; background-color: var(--color-secondary); color: var(--color-on-primary); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2); z-index: 999; text-decoration: none; transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out; }
.floating-cta:hover { transform: scale(1.1); box-shadow: 0 8px 16px rgba(0, 0, 0, 0.25); }
.floating-cta i { font-size: 32px; line-height: 1; }
.animate-on-scroll { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease-out, transform 0.6s ease-out; }
.animate-on-scroll.is-visible { opacity: 1; transform: translateY(0); }
.back-to-top-btn { position: fixed; bottom: 24px; left: 24px; width: 50px; height: 50px; background-color: var(--color-on-surface-variant); color: var(--color-surface); border: none; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md); z-index: 999; cursor: pointer; transition: opacity 0.3s ease, transform 0.3s ease; opacity: 0; transform: translateY(20px); }
.back-to-top-btn.visible { opacity: 1; transform: translateY(0); }
.back-to-top-btn:hover { background-color: var(--color-primary); }
.back-to-top-btn i { font-size: 24px; }
.loader-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: var(--color-background); z-index: 9999; display: flex; align-items: center; justify-content: center; transition: opacity 0.5s ease; }
.loader-overlay.hidden { opacity: 0; pointer-events: none; }
.spinner { width: 50px; height: 50px; border: 5px solid var(--color-primary-container); border-top-color: var(--color-primary); border-radius: 50%; animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.footer-reboot { background-color: #1a1c1e; color: var(--color-on-surface-variant); padding: 80px 0 30px 0; text-align: left; }
body.dark-mode .footer-reboot { background-color: #111315; }
.footer-reboot-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 48px; padding-bottom: 48px; }
.footer-column .footer-logo { font-family: var(--font-family-headline); font-weight: 600; font-size: 1.8rem; text-decoration: none; color: #ffffff; display: block; margin-bottom: 1rem; }
.footer-column .footer-logo span { color: var(--color-primary); }
.footer-column p { line-height: 1.7; margin-bottom: 2rem; }
.footer-column h4 { font-family: var(--font-family-headline); font-weight: 700; font-size: 1.2rem; color: #ffffff; margin: 0 0 1.5rem 0; text-align: left; }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 1rem; }
.footer-links a { color: var(--color-on-surface-variant); text-decoration: none; transition: color 0.2s, padding-left 0.2s; }
.footer-links a:hover { color: #ffffff; padding-left: 4px; }
.footer-social-links { display: flex; gap: 16px; margin-bottom: 2rem; }
.footer-social-links a { color: var(--color-on-surface-variant); font-size: 1.8rem; transition: color 0.2s, transform 0.2s; }
.footer-social-links a:hover { color: #ffffff; transform: scale(1.1); }
.footer-reboot .newsletter-signup { margin: 0; }
.footer-reboot .newsletter-signup h4 { margin-top: 2rem; }
.footer-reboot .newsletter-signup form { display: flex; flex-direction: column; gap: 12px; }
.footer-reboot .newsletter-signup input { width: 100%; padding: 0.75rem 1rem; border-radius: var(--radius-md); border: 1px solid #3a3c40; background-color: #242629; color: white; }
.footer-reboot .newsletter-signup button { width: 100%; }
.footer-reboot-bottom { border-top: 1px solid #3a3c40; padding-top: 30px; text-align: center; font-size: 0.9rem; }
.footer-reboot-bottom p { margin: 0.5rem 0; }
@media (max-width: 768px) {
    .footer-reboot-grid, .footer-column, .footer-column h4, .footer-column .footer-logo { text-align: center; }
    .footer-social-links { justify-content: center; }
    #footer-brand { grid-column: 1 / -1; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
  .typing-cursor { animation: none; }
  .animate-on-scroll { opacity: 1; transform: translateY(0); }
}
.toast-container { position: fixed; top: 88px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 12px; }
.toast { display: flex; align-items: center; gap: 12px; padding: 14px 20px; border-radius: var(--radius-md); background-color: var(--color-surface); color: var(--color-on-background); box-shadow: var(--shadow-md); border-left: 5px solid; min-width: 320px; max-width: 360px; opacity: 0; transform: translateX(120%); transition: all 0.4s cubic-bezier(0.68, -0.55, 0.27, 1.55); }
.toast.show { opacity: 1; transform: translateX(0); }
.toast.hide { opacity: 0; }
.toast--success { border-color: #28a745; }
.toast--error { border-color: #dc3545; }
.toast--info { border-color: var(--color-primary); }
.toast i { font-size: 1.5rem; line-height: 1; }
.toast--success i { color: #28a745; }
.toast--error i { color: #dc3545; }
.toast--info i { color: var(--color-primary); }
.toast-message { font-size: 0.95rem; font-weight: 500; line-height: 1.4; }
@media (max-width: 480px) {
    .toast-container { right: 16px; left: 16px; width: auto; min-width: unset; }
    .toast { width: 100%; }
}
.ai-feedback-modal { position: fixed; inset: 0; z-index: 9999; background-color: rgba(26, 28, 30, 0.7); backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: opacity 0.3s ease, visibility 0.3s ease; }
.ai-feedback-modal.show { opacity: 1; visibility: visible; }
.ai-feedback-content { background-color: var(--color-surface); color: var(--color-on-background); border-radius: var(--radius-lg); padding: 2.5rem; width: clamp(320px, 90vw, 500px); text-align: center; box-shadow: var(--shadow-md); transform: scale(0.95); transition: transform 0.3s ease; }
.ai-feedback-modal.show .ai-feedback-content { transform: scale(1); }
.ai-feedback-content .modal-icon { font-size: 4rem; line-height: 1; margin-bottom: 1.5rem; }
.ai-feedback-content .modal-icon .spinner { margin: 0 auto; width: 60px; height: 60px; border-width: 6px; }
.ai-feedback-content .modal-icon .bi { animation: popIn 0.4s ease-out; }
@keyframes popIn { from { transform: scale(0.5); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.ai-feedback-content .modal-title { font-size: 1.75rem; margin: 0 0 1rem 0; }
.ai-feedback-content .modal-steps { list-style: none; padding: 0; margin: 0 auto 1.5rem auto; max-width: 350px; text-align: left; }
.modal-step { display: flex; align-items: center; gap: 12px; padding: 8px 0; color: var(--color-on-surface-variant); opacity: 0; transform: translateY(10px); animation: fadeInUp 0.5s ease-out forwards; }
@keyframes fadeInUp { to { opacity: 1; transform: translateY(0); } }
.modal-step::before { content: '\f28a'; font-family: 'bootstrap-icons'; font-size: 1rem; color: var(--color-outline); transition: all 0.3s ease; }
.modal-step.completed { color: var(--color-on-background); font-weight: 500; }
.modal-step.completed::before { content: '\f26a'; font-family: 'bootstrap-icons'; color: var(--color-secondary); transform: scale(1.1); }
.ai-feedback-content .modal-message { font-size: 1rem; line-height: 1.6; color: var(--color-on-surface-variant); margin: 0 0 2rem 0; min-height: 48px; }
.ai-feedback-content .btn { opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s; }
.ai-feedback-content .btn.show { opacity: 1; visibility: visible; }