:root {
    --bg: #070707;
    --bg-soft: #101010;
    --surface: rgba(255, 255, 255, 0.05);
    --surface-strong: rgba(255, 255, 255, 0.08);
    --border: rgba(255, 214, 92, 0.18);
    --text: #f4efe2;
    --muted: rgba(244, 239, 226, 0.75);
    --accent: #d4af37;
    --accent-dark: #9b7b1d;
    --secondary: #59b84c;
    --success: #79d26b;
    --shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
    --radius: 22px;
}

html { scroll-behavior: smooth; }
body {
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: radial-gradient(circle at top left, rgba(212, 175, 55, 0.14), transparent 28%), radial-gradient(circle at top right, rgba(89, 184, 76, 0.12), transparent 30%), linear-gradient(180deg, #050505 0%, #0a0a0a 100%);
    color: var(--text);
    min-height: 100vh;
}

p,
li,
small,
label,
.form-label,
.table,
.accordion-body,
.dropdown-item,
.page-link,
.nav-tabs .nav-link,
.breadcrumb-item,
.modal-content,
.modal-title {
    color: var(--text);
}

.text-muted {
    color: rgba(238, 243, 255, 0.82) !important;
}

.card-glass,
.form-card,
.info-card,
.coverage-panel,
.pricing-card,
.blog-card,
.stat-card,
.service-banner,
.map-placeholder,
.feature-card,
.testimonial-card {
    color: var(--text);
}

.card-glass p,
.form-card p,
.info-card p,
.pricing-card p,
.blog-card p,
.feature-card p,
.testimonial-card p,
.service-card p,
.service-card li,
.blog-article p,
.blog-article li,
.breadcrumb-section p,
.content-section p {
    color: rgba(238, 243, 255, 0.9);
}
a { text-decoration: none; }
img { object-fit: cover; }
.site-navbar { background: rgba(5, 5, 5, 0.94); backdrop-filter: blur(18px); border-bottom: 1px solid var(--border); }
.navbar-brand { color: var(--text) !important; }
.navbar-brand small { display: block; color: var(--muted); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; }
.navbar-collapse {
    gap: 1rem;
}
.navbar-nav {
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.2rem;
}
.brand-mark { width: 54px; height: 54px; display: inline-flex; align-items: center; justify-content: center; border-radius: 18px; background: linear-gradient(135deg, #d4af37 0%, #6bcf63 100%); color: #111; box-shadow: 0 12px 30px rgba(212, 175, 55, 0.28); border: 1px solid rgba(255, 255, 255, 0.12); flex-shrink: 0; }
.brand-mark-text { display: inline-flex; align-items: center; justify-content: center; width: 100%; height: 100%; color: #111; font-weight: 900; font-size: 0.95rem; letter-spacing: 0.08em; text-shadow: 0 1px 0 rgba(255, 255, 255, 0.28); }
.brand-logo { height: 48px; width: auto; max-width: 100px; border-radius: 12px; flex-shrink: 0; object-fit: contain; }
.nav-link { color: rgba(244, 239, 226, 0.84) !important; font-weight: 500; margin-inline: 0.1rem; padding-inline: 0.5rem !important; white-space: nowrap; }
.nav-link.active, .nav-link:hover, .nav-link:focus { color: #fff !important; }
.btn-accent { background: linear-gradient(135deg, var(--accent), var(--secondary)); border: none; color: #111; box-shadow: 0 14px 30px rgba(212, 175, 55, 0.24); }
.btn-accent:hover, .btn-accent:focus { color: #111; transform: translateY(-1px); }
.btn-outline-accent { border: 1px solid rgba(212, 175, 55, 0.5); color: #f0d98a; background: rgba(212, 175, 55, 0.08); }
.btn-outline-accent:hover, .btn-outline-accent:focus { background: rgba(89, 184, 76, 0.16); color: #fff; }
.hero-section, .breadcrumb-section, .content-section { padding: 3rem 0; }
.hero-section { padding-top: 4rem; }
.hero-section .row {
    align-items: center;
}
.hero-section .col-lg-6:first-child {
    max-width: 580px;
}
.hero-section .lead {
    max-width: 54ch;
}
.section-title {
    max-width: 760px;
}
.content-section .container > .row,
.content-section .container > .accordion,
.content-section .container > .card-glass {
    position: relative;
}
.content-section .container > .row,
.content-section .container > .accordion,
.content-section .container > .card-glass,
.content-section .container > .section-title {
    margin-left: auto;
    margin-right: auto;
}
.content-section .container > .row {
    max-width: 1180px;
}
.content-section .container > .accordion,
.content-section .container > .card-glass {
    max-width: 1120px;
}
.content-section .container > .section-title {
    text-align: center;
}
.hero-kicker { color: #f0d98a; text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.78rem; font-weight: 700; }
.hero-points span, .service-meta span, .pricing-tag, .blog-meta span, .coverage-badge { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.9rem; color: var(--muted); }
.hero-points i, .service-highlights i { color: var(--success); }
.hero-media, .card-glass, .form-card, .info-card, .coverage-panel, .pricing-card, .blog-card, .stat-card, .service-banner, .map-placeholder { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); backdrop-filter: blur(18px); }
.hero-media { position: relative; }
.hero-shape { position: absolute; border-radius: 999px; filter: blur(12px); opacity: 0.85; }
.hero-shape-1 { width: 260px; height: 260px; right: -120px; top: 20px; background: rgba(89, 184, 76, 0.15); }
.hero-shape-2 { width: 220px; height: 220px; left: -80px; bottom: 20px; background: rgba(212, 175, 55, 0.16); }
.stat-card { padding: 1rem; text-align: center; }
.stat-card strong { display: block; font-size: 1.4rem; }
.stat-card span { color: var(--muted); font-size: 0.85rem; }
.section-title { margin-bottom: 1.75rem; }
.section-title .eyebrow, .eyebrow { color: #f0d98a; text-transform: uppercase; letter-spacing: 0.15em; font-size: 0.75rem; font-weight: 700; }
.service-card, .testimonial-card, .pricing-card, .blog-card, .info-card, .faq-item, .feature-card { overflow: hidden; }
.service-card-image { position: relative; aspect-ratio: 16 / 10; }
.service-card-image img { width: 100%; height: 100%; }
.service-icon { position: absolute; right: 1rem; top: 1rem; width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border-radius: 16px; background: rgba(5, 5, 5, 0.86); border: 1px solid var(--border); color: #f0d98a; }
.service-price { font-size: 1.35rem; font-weight: 800; }
.service-highlights { display: grid; gap: 0.55rem; }
.service-highlights li { display: flex; align-items: flex-start; gap: 0.55rem; color: var(--text); }
.service-highlights i { margin-top: 0.25rem; }
.featured-services-section .section-title {
    margin-bottom: 2.15rem;
}

.featured-services-grid {
    row-gap: 1.75rem;
}

.featured-services-grid > [class*="col-"] {
    display: flex;
}

.featured-services-grid .service-card {
    width: 100%;
}

.featured-services-grid .service-card .p-4 {
    padding: 1.35rem !important;
}

.featured-services-grid .service-meta {
    margin-bottom: 0.9rem !important;
}
.testimonial-card {
    display: flex;
    flex-direction: column;
}

.testimonial-rating {
    color: #f0d98a;
    letter-spacing: 0.18em;
    font-size: 0.92rem;
    line-height: 1;
    margin-bottom: 1rem;
}

.testimonial-text {
    color: var(--text);
    font-size: 1.02rem;
    line-height: 1.75;
    font-style: normal;
}

.testimonial-author {
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid rgba(212, 175, 55, 0.28);
}

.testimonial-author-meta strong {
    display: block;
    font-size: 1rem;
    line-height: 1.2;
    color: #fff;
}

.testimonial-author-meta span {
    display: block;
    margin-top: 0.2rem;
    color: var(--muted);
    font-size: 0.9rem;
}

.avatar-circle { width: 52px; height: 52px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(135deg, rgba(89, 184, 76, 0.36), rgba(212, 175, 55, 0.5)); font-weight: 700; }
.pricing-card.highlight { border-color: rgba(212, 175, 55, 0.55); transform: translateY(-8px); }
.pricing-price { font-size: 2.4rem; font-weight: 800; line-height: 1; }
.pricing-card ul, .check-list, .feature-list, .footer-links, .footer-contact, .blog-categories, .area-list { display: grid; gap: 0.65rem; }
.check-list li, .feature-list li { display: flex; gap: 0.55rem; align-items: flex-start; }
.check-list i, .feature-list i { color: var(--success); margin-top: 0.2rem; }
.breadcrumb { --bs-breadcrumb-divider-color: rgba(244, 239, 226, 0.55); }
.breadcrumb a, .breadcrumb-item.active { color: var(--muted); }
.breadcrumb-item + .breadcrumb-item::before { color: rgba(244, 239, 226, 0.45); }
.breadcrumb-item a {
    color: #f0d98a;
}
.breadcrumb-item a:hover {
    color: #fff;
}
.map-placeholder { min-height: 320px; display: grid; place-items: center; text-align: center; border-style: dashed; }
.map-embed-wrap {
    padding: 0 !important;
    overflow: hidden;
    border-style: solid;
}

.map-embed {
    display: block;
    width: 100%;
    min-height: 320px;
    height: 100%;
    border: 0;
}
.map-pin { width: 74px; height: 74px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: rgba(212, 175, 55, 0.18); color: #f0d98a; margin-bottom: 1rem; }
.blog-card-image, .blog-hero-image { aspect-ratio: 16 / 10; }
.blog-card-image img, .blog-hero-image img { width: 100%; height: 100%; }
.blog-meta { display: flex; flex-wrap: wrap; gap: 0.8rem; }
.blog-categories a { padding: 0.6rem 0.9rem; border-radius: 999px; border: 1px solid var(--border); color: var(--text); background: rgba(255, 255, 255, 0.03); }
.blog-categories a.active, .blog-categories a:hover { background: rgba(89, 184, 76, 0.16); border-color: rgba(89, 184, 76, 0.42); }
.search-box .form-control, .form-control, .form-select, .input-group-text { background: rgba(255, 255, 255, 0.05); border-color: var(--border); color: var(--text); }
.form-control::placeholder { color: rgba(244, 239, 226, 0.45); }
.form-control:focus, .form-select:focus { background: rgba(255, 255, 255, 0.06); border-color: rgba(89, 184, 76, 0.6); box-shadow: 0 0 0 0.2rem rgba(89, 184, 76, 0.14); color: var(--text); }
.form-select option,
.form-control option {
    background: #101010;
    color: #f4efe2;
}
.input-group-text { color: var(--muted); }
.accordion { --bs-accordion-bg: rgba(255, 255, 255, 0.04); --bs-accordion-border-color: var(--border); --bs-accordion-btn-color: var(--text); --bs-accordion-btn-bg: rgba(255, 255, 255, 0.02); --bs-accordion-active-color: #fff; --bs-accordion-active-bg: rgba(212, 175, 55, 0.12); --bs-accordion-btn-focus-box-shadow: none; --bs-accordion-inner-border-radius: 16px; }
.accordion-button:not(.collapsed) { box-shadow: none; }
.accordion-button::after { filter: invert(1) saturate(0) brightness(2); }
.accordion-button,
.accordion-button:not(.collapsed) {
    color: var(--text);
}
.accordion-button:hover,
.accordion-button:focus {
    color: #fff;
}
.accordion-body {
    background: rgba(255, 255, 255, 0.02);
}
.table td,
.table th {
    color: var(--text);
}
.table > :not(caption) > * > * {
    background-color: transparent;
}
.page-link {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--border);
}
.page-link:hover,
.page-link:focus {
    background: rgba(212, 175, 55, 0.16);
    color: #fff;
    border-color: rgba(212, 175, 55, 0.35);
}
.page-item.active .page-link {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border-color: transparent;
    color: #fff;
}
.page-item.disabled .page-link {
    background: rgba(255, 255, 255, 0.02);
    color: rgba(238, 243, 255, 0.45);
}
.footer-links a, .footer-contact li, .footer-bottom, .social-links a { color: var(--muted); }
.footer-links a:hover, .social-links a:hover { color: #fff; }
.social-links a { width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: rgba(255, 255, 255, 0.06); border: 1px solid var(--border); }
.site-footer { background: #050505; border-top: 1px solid var(--border); margin-top: 4rem; }
.footer-bottom { border-top: 1px solid var(--border); font-size: 0.92rem; }
.site-footer h6,
.site-footer strong {
    color: #fff;
}

@media (min-width: 992px) and (max-width: 1299.98px) {
    .site-navbar .container {
        max-width: 100%;
    }

    .site-navbar .navbar-brand {
        flex-shrink: 0;
    }

    .site-navbar .navbar-collapse {
        min-width: 0;
    }

    .site-navbar .navbar-nav {
        overflow-x: auto;
        scrollbar-width: none;
    }

    .site-navbar .navbar-nav::-webkit-scrollbar {
        display: none;
    }
}

.reveal { opacity: 0; transform: translateY(16px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.service-banner { overflow: hidden; }
.service-banner .banner-image { min-height: 100%; width: 100%; height: 100%; }
.service-banner .banner-copy { padding: 2rem; }
.service-pill { display: inline-flex; align-items: center; gap: 0.45rem; padding: 0.55rem 0.8rem; border-radius: 999px; background: rgba(255, 255, 255, 0.06); border: 1px solid var(--border); color: var(--text); }
.comparison-table { overflow-x: auto; }
.comparison-table table { color: var(--text); }
.comparison-table .table { --bs-table-bg: transparent; --bs-table-border-color: var(--border); --bs-table-color: var(--text); }
.table thead th { color: #fff; }
.badge-soft { display: inline-flex; align-items: center; padding: 0.45rem 0.8rem; border-radius: 999px; background: rgba(212, 175, 55, 0.12); border: 1px solid rgba(89, 184, 76, 0.25); color: #f0d98a; }
.blog-article p, .blog-article li, .content-copy, .about-copy, .lead { color: var(--muted); }
.progress-divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent); }
.faq-category-title { font-size: 1.05rem; margin-bottom: 1rem; }
.form-note { color: var(--muted); font-size: 0.9rem; }
.toast-alert { background: rgba(71, 209, 140, 0.12); border: 1px solid rgba(71, 209, 140, 0.22); color: #d8ffec; border-radius: 16px; }
