/* Critical CSS - Above the fold optimizations */
/* Modern CSS Reset */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* Performance optimizations */
html {
    scroll-behavior: smooth;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* CSS Custom Properties */
:root {
    /* Colors */
    --primary-color: #2563eb;
    --primary-dark: #1e40af;
    --primary-light: #3b82f6;
    --secondary-color: #f59e0b;
    --accent-color: #10b981;
    --dark-color: #1f2937;
    --light-color: #f8fafc;
    --white: #ffffff;
    --gray-50: #f9fafb;
    --gray-100: #f3f4f6;
    --gray-200: #e5e7eb;
    --gray-300: #d1d5db;
    --gray-400: #9ca3af;
    --gray-500: #6b7280;
    --gray-600: #4b5563;
    --gray-700: #374151;
    --gray-800: #1f2937;
    --gray-900: #111827;
    
    /* Typography */
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 1.875rem;
    --font-size-4xl: 2.25rem;
    --font-size-5xl: 3rem;
    --font-size-6xl: 3.75rem;
    
    /* Spacing */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    
    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --glass-bg: rgba(255,255,255,0.65);
    --gradient-accent: linear-gradient(135deg,#2563eb 0%,#1e40af 50%,#0f172a 100%);
    --gradient-surface: linear-gradient(145deg,#ffffff 0%,#f1f5f9 60%,#e2e8f0 100%);
    
    /* Border Radius */
    --border-radius-sm: 0.375rem;
    --border-radius: 0.5rem;
    --border-radius-md: 0.75rem;
    --border-radius-lg: 1rem;
    --border-radius-xl: 1.5rem;
    
    /* Transitions */
    --transition-fast: 150ms ease-in-out;
    --transition-normal: 300ms ease-in-out;
    --transition-slow: 500ms ease-in-out;
}

/* Base Styles */
html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--gray-700);
    background-color: var(--white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    /* Prevent accidental horizontal scroll on mobile due to sub-pixel transforms */
    overflow-x: hidden;
}

/* Anchor scroll offset compensation for fixed header */
section[id] { scroll-margin-top: 90px; }
@media (max-width: 768px) { section[id] { scroll-margin-top: 72px; } }

.nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-6);
    display: grid;
    grid-template-columns: auto 1fr auto; /* brand | nav | lang */
    grid-template-areas: 'brand nav lang';
    align-items: center;
    height: 70px;
    column-gap: var(--space-8);
}
.nav-logo { grid-area: brand; }
.nav-menu { grid-area: nav; }
.lang-switcher { grid-area: lang; justify-self: end; }
.nav-toggle { display: none; }

/* Header & Navigation */
.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--gray-200);
    transition: var(--transition-normal);
}

.nav-logo {
    display: flex;
    flex-direction: column;
}

.nav-logo h1 {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--primary-color);
    line-height: 1;
}

/* Ensure logo link never shows underline */
.nav-home-link { text-decoration: none !important; }
.nav-home-link:hover { text-decoration: none !important; }

/* Hero sublead and link styling */
.hero-sublead { 
    margin-top: var(--space-4);
    color: rgba(255,255,255,0.9);
    font-size: 1rem;
}
.hero-sublead a {
    color: inherit;
    text-decoration: underline;
    text-decoration-color: rgba(255,255,255,0.5);
    text-underline-offset: 2px;
}
.hero-sublead a:hover {
    text-decoration-color: rgba(255,255,255,0.9);
}

/* Ensure hero description links match design */
.hero-description a,
.hero-description a:visited { 
    color: inherit !important; 
    text-decoration: none; 
}
.hero-description a:hover,
.hero-description a:focus-visible { 
    text-decoration: underline; 
    text-decoration-color: rgba(255,255,255,0.85);
    text-underline-offset: 2px; 
}

/* Calculator - removed old styles, using .calculator-* classes only */

.nav-tagline {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
    font-weight: 500;
}

.nav-menu {
    display: flex;
    list-style: none;
    align-items: center;
    gap: var(--space-8);
    padding-left: var(--space-8);
}

.nav-link {
    text-decoration: none;
    color: var(--gray-600);
    font-weight: 500;
    font-size: var(--font-size-sm);
    transition: var(--transition-fast);
    padding: 6px 2px;
    position: relative;
}

.nav-link:hover {
    color: var(--primary-color);
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--primary-color);
    transition: var(--transition-fast);
}

.nav-link:hover::after {
    width: 100%;
}

.nav-cta {
    background: var(--primary-color);
    color: var(--white) !important;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--border-radius);
    text-decoration: none;
    font-weight: 600;
    font-size: var(--font-size-sm);
    transition: var(--transition-fast);
}

.nav-cta:hover {
    background: var(--primary-dark);
    transform: translateY(-1px);
}

.nav-toggle {
    display: none;
    cursor: pointer;
    padding: var(--space-2);
}

/* Language Switcher (Desktop & Mobile) */
.lang-switcher { position: relative; display: inline-flex; align-items: center; gap: 0; background: var(--gray-100); border: 1px solid rgba(0,0,0,0.06); border-radius: 999px; padding: 4px; box-shadow: 0 6px 16px -8px rgba(0,0,0,0.25); overflow: hidden; margin-left: var(--space-4); }
.lang-btn { position: relative; z-index: 1; appearance: none; background: transparent; border: none; color: var(--gray-700); font-weight: 700; font-size: 12px; letter-spacing: 0.04em; padding: 6px 12px; border-radius: 999px; cursor: pointer; transition: color var(--transition-fast); }
.lang-btn:hover { color: var(--gray-900); }
.lang-btn.active { color: var(--white); }
.lang-switcher__thumb { position: absolute; z-index: 0; top: 4px; left: 4px; height: calc(100% - 8px); width: 0; border-radius: 999px; background: linear-gradient(135deg, var(--primary-color), var(--primary-light)); box-shadow: 0 6px 14px -6px rgba(37,99,235,0.7); transition: transform var(--transition-normal), width var(--transition-fast); will-change: transform, width; }

/* Mobile Navigation Controls */
.nav-mobile-controls {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    justify-self: end;
    grid-area: lang; /* occupy language column on desktop */
}

/* FAQ page layout container */
.page-faq .container {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-6);
    padding-right: var(--space-6);
}

/* Mobile Menu Toggle */
.mobile-menu-toggle {
    display: none;
    flex-direction: column;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: var(--space-2);
    gap: 4px;
}

.mobile-menu-toggle span {
    width: 20px;
    height: 2px;
    background: var(--gray-700);
    transition: var(--transition-fast);
    transform-origin: center;
}

.mobile-menu-toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.mobile-menu-toggle.active span:nth-child(2) {
    opacity: 0;
}

.mobile-menu-toggle.active span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -6px);
}

/* Mobile Navigation Menu */
.mobile-nav {
    position: fixed;
    top: 70px;
    left: 0;
    right: 0;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--gray-200);
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-normal);
    z-index: 999;
    box-shadow: var(--shadow-lg);
}

.mobile-nav.active {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
}

.mobile-nav-content {
    padding: var(--space-6) var(--space-4);
}

.mobile-nav-menu {
    list-style: none;
    margin-bottom: var(--space-6);
}

.mobile-nav-menu li {
    border-bottom: 1px solid var(--gray-100);
}

.mobile-nav-link {
    display: block;
    padding: var(--space-4) 0;
    text-decoration: none;
    color: var(--gray-700);
    font-weight: 500;
    font-size: var(--font-size-lg);
    transition: var(--transition-fast);
}

.mobile-nav-link:hover {
    color: var(--primary-color);
    transform: translateX(8px);
}

.mobile-nav-cta {
    text-align: center;
}

/* Pulse Animation for CTA */
.pulse-animation {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); }
    100% { transform: scale(1); }
}

/* Hero Urgency Badge */
.hero-urgency {
    margin-top: var(--space-4);
}

.urgency-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid var(--secondary-color);
    border-radius: var(--border-radius-lg);
    color: var(--secondary-color);
    font-weight: 600;
    font-size: var(--font-size-sm);
    animation: urgent-blink 3s infinite;
}

@keyframes urgent-blink {
    0%, 70% { opacity: 1; }
    85% { opacity: 0.6; }
    100% { opacity: 1; }
}

@media (max-width: 768px) {
    .nav-container {
        grid-template-columns: auto 1fr; /* brand | controls */
        grid-template-areas: 'brand controls';
        height: 64px;
        padding: 4px var(--space-5) 4px var(--space-5);
        column-gap: var(--space-4);
    }
    
    /* Ensure all containers have proper mobile padding */
    .container,
    .hero-content,
    .page-faq .container {
        padding-left: var(--space-5);
        padding-right: var(--space-5);
    }
    
    /* Apply mobile padding to sections */
    .services,
    .advantages,
    .location,
    .contact,
    .pricing,
    .footer {
        padding-left: var(--space-5);
        padding-right: var(--space-5);
    }
    
    .nav-menu { 
        display: none !important; 
    }
    
    .nav-mobile-controls { 
        grid-area: controls; 
    }
    
    .mobile-menu-toggle { 
        display: flex; 
    }
    
    .lang-switcher { 
        margin-left: 0; 
    }
    
    .mobile-nav {
        top: 64px;
    }
}

/* Engagement Prompt - Bounce Rate Reduction */
.engagement-prompt {
    position: fixed;
    bottom: var(--space-4);
    right: var(--space-4);
    background: var(--white);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-xl);
    border: 2px solid var(--secondary-color);
    max-width: 320px;
    z-index: 1001;
    animation: slideInUp 0.3s ease-out;
}

.engagement-content {
    padding: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.engagement-icon {
    font-size: var(--font-size-2xl);
    flex-shrink: 0;
}

.engagement-text strong {
    color: var(--gray-900);
    font-size: var(--font-size-sm);
    display: block;
    margin-bottom: var(--space-1);
}

.engagement-text p {
    color: var(--gray-600);
    font-size: var(--font-size-xs);
    margin: 0;
}

.engagement-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

.btn-small {
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-xs);
}

.engagement-close {
    background: transparent;
    border: none;
    color: var(--gray-400);
    cursor: pointer;
    font-size: var(--font-size-lg);
    padding: var(--space-1);
    border-radius: 50%;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition-fast);
}

.engagement-close:hover {
    background: var(--gray-100);
    color: var(--gray-600);
}

@keyframes slideInUp {
    from {
        transform: translateY(100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Responsive engagement prompt */
@media (max-width: 480px) {
    .engagement-prompt {
        bottom: var(--space-2);
        right: var(--space-2);
        left: var(--space-2);
        max-width: none;
    }
    
    .engagement-content {
        flex-direction: column;
        text-align: center;
    }
}

/* Enhanced CTA buttons */
.btn:hover {
    transform: translateY(-2px);
}

.btn-primary:hover {
    box-shadow: 0 8px 25px rgba(245, 158, 11, 0.3);
}

/* Progressive enhancement for better engagement */
.hero-stats {
    position: relative;
}

.hero-stats::after {
    content: '';
    position: absolute;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--secondary-color), transparent);
    border-radius: 2px;
}

/* Scroll indicator for better engagement */
.scroll-indicator {
    position: absolute;
    bottom: var(--space-8);
    left: 50%;
    transform: translateX(-50%);
    animation: bounce 2s infinite;
    color: rgba(255, 255, 255, 0.7);
}

.scroll-indicator { text-decoration: none; }
.scroll-indicator:hover { transform: translateY(2px); }
@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
        transform: translateX(-50%) translateY(0);
    }
    40% {
        transform: translateX(-50%) translateY(-10px);
    }
    60% {
        transform: translateX(-50%) translateY(-5px);
    }
}

/* Hero Section */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    background: var(--gradient-accent);
    overflow: hidden;
}
.hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 70% 30%, rgba(37,99,235,0.15), transparent 60%),
                radial-gradient(circle at 30% 70%, rgba(245,158,11,0.15), transparent 55%);
    pointer-events: none;
}

.hero-background {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(1200px 800px at 10% 20%, rgba(37,99,235,0.08), transparent 60%),
                radial-gradient(1000px 700px at 80% 60%, rgba(245,158,11,0.08), transparent 55%);
}

/* removed ether-blobs animations per request */

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(125deg,#0f172a 0%,#1e293b 55%, rgba(30,41,59,0.5) 100%);
    mix-blend-mode: multiply;
}

.hero-content {
    position: relative;
    z-index: 2;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-6);
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--space-16);
    align-items: center;
}

.hero-text { color: var(--white); backdrop-filter: blur(2px); }
.hero-title { background: linear-gradient(90deg,#fff 0%,#e2e8f0 40%,#fff 80%); -webkit-background-clip: text; background-clip: text; color: transparent; }

.hero-title {
    font-size: var(--font-size-6xl);
    font-weight: 700;
    line-height: 1.1;
    margin-bottom: var(--space-6);
}

.title-primary {
    display: block;
    color: var(--white);
}

.title-secondary {
    display: block;
    color: var(--secondary-color);
}

.hero-description {
    font-size: var(--font-size-lg);
    line-height: 1.7;
    margin-bottom: var(--space-8);
    color: rgba(255, 255, 255, 0.9);
}

.hero-actions {
    display: flex;
    gap: var(--space-4);
    margin-bottom: var(--space-16);
}

.hero-stats {
    display: flex;
    gap: var(--space-8);
}

.stat {
    text-align: center;
}

.stat-number {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    color: var(--secondary-color);
    line-height: 1;
}

.stat-label {
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.8);
    margin-top: var(--space-1);
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    border: none;
    border-radius: var(--border-radius);
    font-weight: 600;
    font-size: var(--font-size-sm);
    text-decoration: none;
    cursor: pointer;
    transition: var(--transition-fast);
    text-align: center;
}

.btn-primary {
    background: var(--secondary-color);
    color: var(--white);
    align-items: center;
    justify-content: center;
}

.btn-primary:hover {
    background: #d97706;
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.btn-secondary {
    background: transparent;
    color: var(--white);
    border: 2px solid rgba(255, 255, 255, 0.3);
    align-items: center;
    justify-content: center;
}

.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.5);
}

.btn-large {
    padding: var(--space-4) var(--space-8);
    font-size: var(--font-size-base);
}

/* Sections */
.section-header {
    text-align: center;
    margin-bottom: var(--space-16);
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

/* FAQ Page Styles */
.page-faq .header { position: sticky; }

.faq-hero {
    background: radial-gradient(1200px 800px at 10% 20%, rgba(37,99,235,0.08), transparent 60%),
                radial-gradient(1000px 700px at 80% 60%, rgba(245,158,11,0.08), transparent 55%),
                linear-gradient(125deg,#0f172a 0%,#1e293b 55%, rgba(30,41,59,0.85) 100%);
    color: var(--white);
    padding: calc(var(--space-24) + 70px) 0 var(--space-20);
}

.faq-hero .faq-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    margin-bottom: var(--space-3);
}

.faq-hero .faq-subtitle {
    color: rgba(255,255,255,0.85);
    font-size: var(--font-size-lg);
}

.faq-quick-cta { display: flex; gap: var(--space-3); margin-top: var(--space-6); flex-wrap: wrap; }

.faq-section { padding: var(--space-20) 0; background: var(--gray-50); }

.faq-grid { display: grid; grid-template-columns: 320px 1fr; gap: var(--space-8); align-items: start; }
/* Explicit aside target to improve cross-browser behavior */
.faq-aside { position: sticky; top: 90px; align-self: start; display: grid; gap: var(--space-6); max-height: calc(100vh - 90px); overflow: auto; -webkit-overflow-scrolling: touch; z-index: 1; }

@media (max-width: 1024px) {
    .faq-grid { grid-template-columns: 1fr; }
    /* Disable sticky when sidebar stacks to top */
    .faq-grid > *:first-child { position: static; top: auto; }
    .faq-aside { position: static; top: auto; max-height: none; overflow: visible; }
}

/* Adjust sticky offset for smaller header on mobile */
@media (max-width: 768px) {
    .faq-grid > *:first-child { top: 72px; }
    .faq-aside { top: 72px; max-height: calc(100vh - 72px); }
}

/* Fine tune FAQ typography on very small screens */
@media (max-width: 480px) {
    .accordion-trigger { font-size: var(--font-size-base); }
    .accordion-panel { font-size: var(--font-size-sm); }
}

.faq-card { background: var(--white); border: 1px solid var(--gray-200); border-radius: var(--border-radius-xl); box-shadow: var(--shadow-md); padding: var(--space-6); position: static; }
.faq-aside { z-index: 1; }

.faq-topics { list-style: none; margin-top: var(--space-3); }
.faq-topics li a { display: block; padding: var(--space-3) var(--space-4); color: var(--gray-700); text-decoration: none; border-radius: var(--border-radius); transition: var(--transition-fast); }
.faq-topics li a:hover { background: var(--gray-100); color: var(--primary-color); transform: translateX(4px); }
.faq-topics li a.active { background: var(--gray-100); color: var(--primary-color); font-weight: 700; }

/* Search empty helper (optional) */
.faq-search-empty .faq-content::before { content: 'Nicio potrivire pentru căutare'; display: block; color: var(--gray-500); font-size: 0.95rem; padding: var(--space-4); }

/* FAQ search */
.faq-search-card { margin-bottom: var(--space-6); }
.faq-search-card input[type="search"] { width: 100%; padding: 10px 12px; border: 1px solid var(--gray-300); border-radius: 10px; font-size: 0.95rem; outline: none; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); }
.faq-search-card input[type="search"]:focus { border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(37,99,235,0.15); }

/* A11y helper */
.visually-hidden { position: absolute !important; height: 1px; width: 1px; overflow: hidden; clip: rect(1px, 1px, 1px, 1px); white-space: nowrap; }

.faq-help { margin-top: var(--space-6); }
.faq-help-card { display: grid; grid-template-columns: 48px 1fr; gap: var(--space-3); align-items: center; background: linear-gradient(145deg,#ffffff 0%,#f8fafc 60%,#eef2f7 100%); border: 1px solid var(--gray-200); border-radius: var(--border-radius-xl); padding: var(--space-5); box-shadow: var(--shadow-md); }
.faq-help-icon { width: 48px; height: 48px; border-radius: 12px; display: grid; place-items: center; background: rgba(37,99,235,0.1); color: var(--primary-color); }

.faq-category + .faq-category { margin-top: var(--space-12); }
.faq-category h2 { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-2xl); color: var(--gray-900); margin-bottom: var(--space-4); }

.accordion { display: grid; gap: var(--space-3); }
.accordion-item { background: var(--white); border: 1px solid var(--gray-200); border-radius: var(--border-radius-lg); overflow: hidden; box-shadow: var(--shadow); }
.accordion-trigger { width: 100%; text-align: left; background: linear-gradient(180deg,#ffffff 0%,#fbfdff 100%); border: none; padding: var(--space-4) var(--space-5); font-weight: 700; color: var(--gray-800); display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); cursor: pointer; font-size: var(--font-size-lg); line-height: 1.45; }
.accordion-trigger span { flex: 1 1 auto; min-width: 0; white-space: normal; line-height: 1.4; overflow-wrap: anywhere; }
.accordion-trigger i { color: var(--gray-500); transition: transform var(--transition-fast); flex: 0 0 auto; margin-left: var(--space-3); }
.accordion-item.open .accordion-trigger i { transform: rotate(180deg); }
.accordion-panel { padding: 0 var(--space-5); max-height: 0; overflow: hidden; transition: max-height var(--transition-normal), padding var(--transition-fast); font-size: var(--font-size-base); color: var(--gray-700); }
.accordion-panel p { overflow-wrap: anywhere; }
.accordion-item.open .accordion-panel { padding: var(--space-4) var(--space-5); max-height: none; }

/* Subtle card hover */
.accordion-item:hover { box-shadow: var(--shadow-md); }

/* Service links for better internal navigation */
.service-link {
    display: inline-block;
    margin-top: var(--space-3);
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 600;
    transition: var(--transition-fast);
    position: relative;
    z-index: 1;
}

.service-link:hover {
    color: var(--primary-dark);
    transform: translateX(4px);
}

.service-link--cta {
    color: var(--secondary-color);
}

.service-link--cta:hover {
    color: #d97706;
}

/* General container for consistent padding */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-6);
}

.section-title {
    font-size: var(--font-size-4xl);
    font-weight: 700;
    color: var(--gray-900);
    margin-bottom: var(--space-4);
}

.section-description {
    font-size: var(--font-size-lg);
    color: var(--gray-600);
    max-width: 600px;
    margin: 0 auto;
}

/* Services Section */
.services {
    padding: var(--space-24) var(--space-6);
    background: var(--gray-50);
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-8);
    max-width: 1200px;
    margin: 0 auto;
}

.service-card {
    background: var(--glass-bg);
    backdrop-filter: blur(10px) saturate(1.2);
    padding: var(--space-8);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 8px 24px -6px rgba(0,0,0,0.15),0 4px 8px -2px rgba(0,0,0,0.08);
    transition: var(--transition-normal);
    text-align: center;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.4);
}
.service-card::before { content:""; position:absolute; inset:0; background:linear-gradient(140deg,rgba(37,99,235,0.15),rgba(245,158,11,0.12)); opacity:0; transition:var(--transition-normal); pointer-events:none; }
.service-card:hover::before { opacity:1; }
.service-card:hover { transform: translateY(-4px); box-shadow:0 12px 28px -6px rgba(0,0,0,0.25); }

.service-card:hover .service-icon {
    transform: scale(1.1);
    background: linear-gradient(135deg, var(--secondary-color), #d97706);
}

.service-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--primary-light));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-6);
    color: var(--white);
}

.service-icon i {
    width: 24px;
    height: 24px;
}

.service-title {
    font-size: var(--font-size-xl);
    font-weight: 600;
    color: var(--gray-900);
    margin-bottom: var(--space-4);
}

.service-description {
    color: var(--gray-600);
    line-height: 1.7;
}

/* Advantages Section */
.advantages { padding: var(--space-24) var(--space-6); background: linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%); }

.advantages-content {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--space-16);
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}

.advantages-text .section-title {
    text-align: left;
    margin-bottom: var(--space-12);
}

.advantages-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.advantage-item {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
}

.advantage-icon {
    width: 24px;
    height: 24px;
    color: var(--accent-color);
    flex-shrink: 0;
    margin-top: var(--space-1);
}

.advantage-content h3 {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--gray-900);
    margin-bottom: var(--space-2);
}

.advantage-content p {
    color: var(--gray-600);
    line-height: 1.7;
}

.advantages-visual {
    display: flex;
    justify-content: center;
}

.visual-card { background: var(--gradient-surface); padding: var(--space-12); border-radius: var(--border-radius-xl); text-align: center; color: var(--gray-900); box-shadow:0 8px 24px -6px rgba(0,0,0,0.15),0 4px 8px -2px rgba(0,0,0,0.08); position:relative; overflow:hidden; }
.visual-card::after { content:""; position:absolute; inset:0; background:linear-gradient(135deg,rgba(37,99,235,0.08),rgba(245,158,11,0.05)); pointer-events:none; }

.visual-content h3 {
    font-size: var(--font-size-lg);
    margin-bottom: var(--space-4);
    opacity: 0.9;
}

.visual-number {
    font-size: var(--font-size-6xl);
    font-weight: 700;
    line-height: 1;
    margin-bottom: var(--space-4);
    color: var(--secondary-color);
}

.visual-content p {
    opacity: 0.9;
}

/* Location Section */
.location {
    padding: var(--space-24) var(--space-6);
    background: var(--gray-50);
}

.location-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
    margin-top: var(--space-16);
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.location-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.location-card {
    background: var(--white);
    padding: var(--space-6);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow);
}

.location-map { position:relative; min-height:380px; border-radius: var(--border-radius-lg); overflow:hidden; box-shadow:0 10px 30px -10px rgba(0,0,0,0.3); }
.map-embed { position:relative; width:100%; height:100%; }
.map-overlay-note { position:absolute; left:0; right:0; bottom:0; padding:6px 12px; font-size:11px; background:rgba(15,23,42,0.55); color:#e2e8f0; backdrop-filter:blur(4px); }

.map-placeholder i {
    width: 48px;
    height: 48px;
    margin-bottom: var(--space-4);
}

/* Contact Section */
.contact {
    padding: var(--space-24) var(--space-6);
}

.contact-notice { display:flex; align-items:center; gap:10px; padding: var(--space-4) var(--space-5); border-radius:14px; background:linear-gradient(180deg,#fffaf4, #fff7ed); border:1px solid #fed7aa; color:#7c2d12; box-shadow: 0 12px 30px -18px rgba(124,45,18,0.4); margin-bottom: var(--space-10); }
.contact-notice i { width:20px; height:20px; color:#fb923c; flex-shrink: 0; }

/* Special Service Card - Match pricing card height */
.special-service-card {
    max-width: 100%;
    margin: 0 0 var(--space-4) 0;
    justify-content: flex-start;
    text-align: left;
    padding: var(--space-5) var(--space-4); /* Match pricing card padding */
    display: flex;
    align-items: center;
    min-height: auto; /* Let content dictate height */
}
.contact-link { color: var(--gray-700); text-decoration: none; border-bottom:1px solid transparent; transition: var(--transition-fast); }
.contact-link:hover { color: var(--primary-color); border-color: rgba(37,99,235,0.35); }

.contact-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-16);
    max-width: 1200px;
    margin: 0 auto;
}

.contact-info h2 { font-size: clamp(1.8rem, 1.2rem + 1.8vw, 2.25rem); font-weight: 800; letter-spacing:-0.015em; color: var(--gray-900); margin-bottom: var(--space-5); }

.contact-info > p { font-size: clamp(1rem, 0.9rem + 0.3vw, 1.125rem); color: var(--gray-600); margin-bottom: var(--space-12); line-height: 1.8; max-width: 52ch; }

.contact-methods { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-8); align-items: stretch; }

.contact-method { display: flex; align-items: center; gap: var(--space-5); }

.contact-icon { width: 56px; height: 56px; border-radius: 50%; background: radial-gradient(80% 80% at 30% 20%, #e8f0ff, #dbeafe); display:grid; place-items:center; border:1px solid rgba(37,99,235,0.18); box-shadow: inset 0 -6px 14px -10px rgba(37,99,235,0.8); flex-shrink:0; }
.contact-icon i { width: 24px; height: 24px; color: var(--primary-color); }

.contact-card-content h3 { font-size: 0.95rem; font-weight: 700; color: var(--gray-900); letter-spacing: 0.02em; margin-bottom: 6px; }

.contact-value { color: var(--gray-700); font-weight: 500; font-size: 1.05rem; }
.contact-value, .contact-value a { white-space: nowrap; }

/* Contact cards */
.contact-card { position: relative; background: #fff; border-radius: 16px; padding: 24px 26px; min-height: 140px; box-shadow: 0 18px 28px -18px rgba(0,0,0,0.25); border: 1px solid rgba(0,0,0,0.06); transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease; }
.contact-card::after { content:""; position:absolute; inset: 0; border-radius: 16px; pointer-events:none; background: linear-gradient(180deg, rgba(37,99,235,0.04), transparent 40%); opacity:0; transition: opacity 160ms ease; }
@media (max-width: 768px) {
    /* Ensure contact cards never overflow viewport width */
    .contact-card { width: 100%; max-width: 100%; }
    .contact-methods { grid-template-columns: 1fr; }
}
.contact-card:hover { transform: translateY(-3px); box-shadow: 0 26px 36px -20px rgba(0,0,0,0.28); border-color: rgba(37,99,235,0.22); }
.contact-card:hover::after { opacity:1; }

/* Slightly larger variant for the Email card */
.contact-card--wide { padding: 24px 44px 24px 30px; }
.contact-card--wide .contact-card-content h3 { font-size: 1.06rem; }
.contact-card--wide .contact-value { font-size: 1.12rem; }
.contact-card--wide .contact-value a { display: inline-block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; }
/* Keep same icon size to avoid extra height; inherit base 56px circle */

@media (max-width: 900px) {
    .contact-methods { grid-template-columns: 1fr; }
    .contact-icon { width: 48px; height: 48px; }
    .contact-card { padding: 20px; min-height: 0; }
    .contact-card--wide { grid-column: auto; padding: 20px; }
    .contact-value, .contact-value a { white-space: normal; }
}

/* On large screens, make the middle (Email) card wider without increasing height */
@media (min-width: 1100px) {
    .contact-methods {
        grid-template-columns: minmax(280px, 1fr) minmax(360px, 1.25fr) minmax(280px, 1fr);
    }
}

/* Contact form styles removed as the form no longer exists */

.price-summary { background: linear-gradient(135deg,#0f172a 0%,#1e293b 60%,#334155 100%); padding: var(--space-6); border-radius: var(--border-radius); height: fit-content; color: var(--white); position:relative; overflow:hidden; }
.price-summary::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 20%,rgba(255,255,255,0.08),transparent 60%); }

.price-summary h3 {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--gray-900);
    margin-bottom: var(--space-4);
}

.price-item {
    display: flex;
    justify-content: space-between;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--gray-200);
}

.price-item.total {
    font-weight: 600;
    color: var(--gray-900);
    border-bottom: none;
    padding-top: var(--space-4);
    font-size: var(--font-size-lg);
}

.price-note {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
    margin-top: var(--space-4);
    font-style: italic;
}

/* Footer */
.footer { background: radial-gradient(circle at 30% 30%,#1e293b,#0f172a 70%); color: var(--white); padding: var(--space-20) var(--space-6) var(--space-8) var(--space-6); }

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-8);
    margin-bottom: var(--space-8);
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.footer-section h3,
.footer-section h4 {
    margin-bottom: var(--space-4);
    color: var(--white);
}

.footer-section h3 {
    font-size: var(--font-size-xl);
    font-weight: 700;
}

.footer-section h4 {
    font-size: var(--font-size-base);
    font-weight: 600;
}

.footer-section p {
    color: var(--gray-400);
    line-height: 1.7;
}

.footer-section ul {
    list-style: none;
}

.footer-section ul li {
    margin-bottom: var(--space-2);
    color: var(--gray-400);
}

.social-links {
    display: flex;
    gap: var(--space-4);
}

.social-links a {
    width: 40px;
    height: 40px;
    background: var(--gray-800);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gray-400);
    transition: var(--transition-fast);
}

.social-links a:hover {
    background: var(--primary-color);
    color: var(--white);
}

.footer-bottom {
    text-align: center;
    padding-top: var(--space-8);
    border-top: 1px solid var(--gray-800);
    color: var(--gray-400);
}

/* Pricing + Calculator Section */
.pricing-calc-section { padding: var(--space-24) var(--space-6); background: linear-gradient(180deg,#f1f5f9 0%,#e2e8f0 100%); position:relative; }
.pricing-calc-section::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 20% 30%,rgba(37,99,235,0.08),transparent 60%),radial-gradient(circle at 80% 70%,rgba(245,158,11,0.08),transparent 55%); pointer-events:none; }

/* Two-column grid: Left (Special Service + Pricing) + Right (Calculator) */
.pricing-calc-grid { 
    display: grid; 
    grid-template-columns: 1.2fr 1fr; 
    grid-template-areas:
        'special special'
        'pricing calculator';
    gap: var(--space-8); 
    max-width: 1400px; 
    margin: 0 auto; 
    align-items: start;
}

.special-service-row { grid-area: special; }
.pricing-column { grid-area: pricing; }
.calculator-column { grid-area: calculator; }

.pricing-column { display: flex; flex-direction: column; gap: var(--space-6); }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap: var(--space-6); }
.pricing-card { position:relative; background: var(--glass-bg); backdrop-filter: blur(10px) saturate(1.3); padding: var(--space-5) var(--space-4); border-radius: var(--border-radius-lg); box-shadow:0 4px 12px -3px rgba(0,0,0,0.15); border:1px solid rgba(255,255,255,0.65); display:flex; flex-direction:column; gap: var(--space-2); transition: var(--transition-normal); cursor:pointer; }
.pricing-card:hover { transform:translateY(-6px); box-shadow:0 14px 32px -8px rgba(0,0,0,0.25); }
.pricing-card.highlight { background: linear-gradient(140deg,#1e40af 0%,#2563eb 60%,#3b82f6 100%); color:var(--white); box-shadow:0 10px 28px -6px rgba(30,58,138,0.5); }
.pricing-card.highlight .pricing-range { color:rgba(255,255,255,0.9); }
.pricing-card.highlight .pricing-value { color:#fff; }
.pricing-card .badge { position:absolute; top:10px; right:10px; background: var(--secondary-color); color:#fff; font-size: var(--font-size-xs); font-weight:600; padding:4px 8px; border-radius:999px; letter-spacing:0.5px; box-shadow:0 4px 8px -2px rgba(0,0,0,0.3); }
.pricing-range { font-weight:600; font-size: 1.05rem; letter-spacing:0.5px; color: var(--gray-700); }
.pricing-value { font-size:1.9rem; font-weight:700; letter-spacing:-0.5px; color: var(--primary-color); line-height:1; }
.pricing-detail { font-size: var(--font-size-xs); text-transform:uppercase; letter-spacing:1px; font-weight:600; color: var(--gray-500); }
.pricing-alt { margin-top:auto; font-size: var(--font-size-sm); color: var(--gray-600); opacity:0.85; }
.pricing-card.highlight .pricing-alt { color:rgba(255,255,255,0.85); }
.pricing-extra { margin-top: var(--space-12); text-align:center; max-width:800px; margin-left:auto; margin-right:auto; font-size: 0.9rem; color: var(--gray-600); line-height:1.65; }
/* Selected pricing card state */
.pricing-card.selected { outline:3px solid var(--secondary-color); box-shadow:0 0 0 4px rgba(245,158,11,0.25),0 12px 34px -8px rgba(0,0,0,0.3); }
.pricing-card.selected .pricing-value { transform:scale(1.05); }

@media (hover:none){
    .pricing-card:hover { transform:none; }
}
.pricing-extra p + p { margin-top: var(--space-2); }

/* Calculator Column - Flexible, fills available space */
.calculator-column { 
    position: static; 
    align-self: start;
}

.calculator-card { 
    background: #fff; 
    border-radius: 14px; 
    padding: var(--space-5); 
    box-shadow: 0 6px 24px rgba(0,0,0,0.06); 
    border: 1px solid rgba(0,0,0,0.05);
    max-width: 100%; /* Fill available space */
    width: 100%;
}

.calculator-title { 
    font-size: 1.4rem; 
    font-weight: 700; 
    margin-bottom: var(--space-4); /* Reduced from var(--space-5) */
    color: var(--gray-900); 
    text-align: center;
}

.calculator-form { display: flex; flex-direction: column; gap: var(--space-3); }

/* Two-column row for paired inputs (desktop) */
.form-row { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 0 var(--space-3); /* no row-gap (single row), column-gap for horizontal spacing */
}
.form-group--half { width: 100%; }
.time-hint { display:none; }

.form-group { display: flex; flex-direction: column; gap: var(--space-2); }

.form-group label { 
    font-size: 0.8rem; 
    font-weight: 500; 
    color: var(--gray-700); 
}

.input-wrapper { 
    position: relative; 
    display: flex; 
    align-items: center;
}

.input-icon { 
    position: absolute; 
    left: 12px; 
    width: 18px; 
    height: 18px; 
    color: var(--gray-400); 
    pointer-events: none;
}

.calculator-form input[type="date"],
.calculator-form input[type="time"] { 
    width: 100%; 
    padding: 12px 12px 12px 38px; 
    border: 1px solid #e2e8f0; 
    border-radius: 8px; 
    font-size: 1rem; 
    font-weight: 500;
    color: var(--gray-900); 
    background: #f1f5f9;
    transition: all 0.18s;
}

.calculator-form input:focus { 
    outline: none; 
    border-color: var(--primary-color); 
    background: #fff;
    box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
}

/* Toggle Switch */
.form-group--toggle { 
    flex-direction: row; 
    justify-content: space-between; 
    align-items: center;
    padding: var(--space-3) 0;
}
.form-group--toggle > label:first-child { 
    font-weight:700; 
    color: var(--gray-800); 
    letter-spacing:0.3px; 
}

.toggle-switch { 
    position: relative; 
    display: flex; 
    align-items: center; 
    gap: var(--space-3);
    cursor: pointer;
}

.toggle-switch input[type="checkbox"] { 
    position: absolute; 
    opacity: 0; 
    width: 0; 
    height: 0;
}

.toggle-slider { 
    position: relative; 
    width: 56px; 
    height: 32px; 
    background: #cbd5e1; 
    border-radius: 999px; 
    transition: all 0.3s;
}

.toggle-slider::before { 
    content: ''; 
    position: absolute; 
    top: 4px; 
    left: 4px; 
    width: 24px; 
    height: 24px; 
    background: #fff; 
    border-radius: 50%; 
    transition: transform 0.3s;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.toggle-switch input:checked + .toggle-slider { 
    background: var(--primary-color); 
}

.toggle-switch input:checked + .toggle-slider::before { 
    transform: translateX(24px); 
}

.toggle-label { 
    font-weight: 600; 
    color: var(--gray-700);
}

/* Calculator Result - Compact since no button needed */
.calc-result { 
    margin-top: var(--space-4); 
    padding: var(--space-5); 
    background: #f9fafb; 
    border-radius: 12px; 
    border: 1px solid #e5e7eb;
}

.calc-result-header { 
    font-size: 1.2rem; 
    font-weight: 700; 
    color: var(--gray-900); 
    margin-bottom: var(--space-3);
    text-align: center;
}

.calc-result-breakdown { 
    display: flex; 
    flex-direction: column; 
    gap: var(--space-2); 
}

.calc-result-item { 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    padding: var(--space-2) 0;
}

.calc-result-item:not(:last-child) { 
    border-bottom: 1px solid #e5e7eb; 
}

.calc-result-label { 
    font-size: 0.9rem; 
    color: var(--gray-600); 
    font-weight: 500;
}

.calc-result-value { 
    font-size: 1.05rem; 
    font-weight: 700; 
    color: var(--gray-900); 
}

.calc-result-total { 
    padding-top: var(--space-3); 
    border-top: 2px solid var(--gray-300); 
}

.calc-result-total .calc-result-label { 
    font-size: 1.05rem; 
    font-weight: 700; 
    color: var(--gray-900);
}

.calc-result-total .calc-result-value { 
    font-size: 1.5rem; 
    color: var(--primary-color);
}

.calc-result-note { 
    margin-top: var(--space-3); 
    padding: var(--space-3); 
    background: rgba(37,99,235,0.05); 
    border-left: 3px solid var(--primary-color); 
    border-radius: 6px;
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
}

.calc-result-note i { 
    width: 16px; 
    height: 16px; 
    color: var(--primary-color); 
    flex-shrink: 0;
    margin-top: 2px;
}

.calc-result-note p { 
    font-size: var(--font-size-xs); 
    color: var(--gray-700); 
    line-height: 1.5; 
    margin: 0;
}

/* Warning messages for transfer issues */
.calc-result-warning { 
    margin-top: var(--space-3); 
    padding: var(--space-3); 
    background: rgba(245, 158, 11, 0.08); 
    border-left: 3px solid #f59e0b; 
    border-radius: 6px;
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
}

.calc-result-warning i { 
    width: 16px; 
    height: 16px; 
    color: #f59e0b; 
    flex-shrink: 0;
    margin-top: 2px;
}

.calc-result-warning p { 
    font-size: var(--font-size-xs); 
    color: #92400e; 
    line-height: 1.5; 
    margin: 0;
    font-weight: 500;
}

@media (max-width:600px){
    .pricing-calc-grid { 
        grid-template-columns: 1fr; 
        grid-template-areas:
            'special'
            'pricing'
            'calculator';
        gap: var(--space-8);
    }
    
    .special-service-card {
        max-width: 100%;
        padding: var(--space-4) var(--space-4); /* Compact on mobile */
    }
    
    .calculator-column { 
        position: static; 
        order: initial; /* Show calculator after pricing on mobile */
    }
    
    .calculator-card {
        max-width: 100%;
        width: 100%;
    }
    
    /* Stack the paired time inputs on mobile for readability */
    .form-row { 
        grid-template-columns: 1fr; 
        gap: var(--space-2);
    }
    
    .pricing-grid { grid-template-columns:1fr; }
    .pricing-card { padding: var(--space-5) var(--space-4); }
    .pricing-value { font-size:1.5rem; }
}

/* Reviews Section */
.reviews { padding: var(--space-24) 0; background: linear-gradient(180deg, #fff 0%, #f8fafc 100%); }
.reviews .section-header { text-align: center; margin-bottom: var(--space-12); }
.reviews-summary { text-align:center; color: var(--gray-600); margin-bottom: var(--space-6); font-weight:600; }
.reviews-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.review-card { background: #fff; border:1px solid var(--gray-200); border-radius: var(--border-radius-lg); padding: var(--space-5); box-shadow: var(--shadow); display:flex; flex-direction: column; gap: var(--space-4); min-height: 180px; }
.review-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); transition: var(--transition-fast); }
.review-card--empty { display:flex; align-items:center; justify-content:center; color: var(--gray-500); font-style: italic; }
.review-header { display:flex; align-items:center; gap: var(--space-4); }
.review-avatar { width: 44px; height:44px; border-radius:999px; object-fit:cover; border:1px solid var(--gray-200); }
.review-meta { display:flex; flex-direction:column; gap:2px; }
.review-author { font-weight:700; color: var(--gray-800); }
.review-rating { color: #f59e0b; font-weight:700; letter-spacing:0.5px; }
.review-rating-number { color: var(--gray-600); font-weight:600; margin-left: 6px; font-size: var(--font-size-sm); }
.review-time { color: var(--gray-500); font-size: var(--font-size-sm); }
.review-text { color: var(--gray-700); line-height:1.6; }
.reviews-cta { margin-top: var(--space-8); display:flex; flex-direction:column; align-items:center; gap: var(--space-4); }
.reviews-cta-primary { text-align: center; width: 100%; }
.reviews-cta-secondary { text-align: center; width: 100%; }
.reviews-cta .btn { min-width: 220px; padding: var(--space-3) var(--space-6); }
/* Override btn-secondary for light backgrounds */
.reviews .btn-secondary { 
    background: transparent; 
    color: var(--primary-color); 
    border: 2px solid var(--primary-color);
    align-items: center;
    justify-content: center;
}
.reviews .btn-secondary:hover { 
    background: var(--primary-color); 
    color: var(--white);
    border-color: var(--primary-color);
}

/* Skeleton loading cards */
.review-card--skeleton { position: relative; overflow: hidden; min-height: 180px; }
.review-card--skeleton::before { content:''; position:absolute; inset:0; background: linear-gradient(90deg, #f3f4f6 0%, #e5e7eb 50%, #f3f4f6 100%); animation: shimmer 1.6s infinite; background-size: 200% 100%; }
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

@media (max-width: 900px){
    .reviews-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px){
    .reviews-grid { grid-template-columns: 1fr; }
}

/* Map fallback */
.map-fallback { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; background:linear-gradient(135deg,#1e293b,#0f172a); color:#e2e8f0; gap: var(--space-4); text-align:center; padding: var(--space-6); }
.map-fallback button { background: var(--secondary-color); border:none; color:#fff; padding:8px 14px; border-radius: var(--border-radius); cursor:pointer; font-weight:600; font-size: var(--font-size-sm); }
.map-fallback button:hover { background:#d97706; }

/* Mobile Navigation Styles */
@media (max-width: 768px) {
    .nav-menu {
        position: fixed;
        top: 70px;
        left: 0;
        right: 0;
        background: var(--white);
        flex-direction: column;
        align-items: stretch;
        padding: var(--space-4);
        box-shadow: var(--shadow-lg);
        transform: translateX(-100%);
        transition: transform var(--transition-normal);
        z-index: 999;
    }
    /* remove fixed positioning to avoid covering brand */
    
    .nav-menu.active {
        transform: translateX(0);
    }
    
    .nav-menu li {
        margin: 0;
    }
    
    .nav-link {
        display: block;
        padding: var(--space-3) 0;
        border-bottom: 1px solid var(--gray-200);
    }
    
    .nav-cta {
        margin-top: var(--space-4);
        text-align: center;
    }
}

/* Header scroll effect */
.header.scrolled {
    background: rgba(255, 255, 255, 0.98);
    box-shadow: var(--shadow-md);
}

/* Responsive Design */
@media (max-width: 1024px) {
    .hero-content {
        grid-template-columns: 1fr;
        text-align: center;
        gap: var(--space-12);
    }
    
    .advantages-content {
        grid-template-columns: 1fr;
        gap: var(--space-12);
    }
    
    .location-content {
        grid-template-columns: 1fr;
    }
    
    .contact-content {
        grid-template-columns: 1fr;
    }
    
    /* reservation layout removed */
}

@media (max-width: 768px) {
    .nav-menu {
        display: none;
    }
    
    .nav-toggle {
        display: block;
    }
    
    .hero-title {
        font-size: var(--font-size-4xl);
    }
    
    .hero-actions {
        flex-direction: column;
    .nav-menu.active { transform: translateX(0); }
        justify-content: center;
    }
    
    .section-title {
        font-size: var(--font-size-3xl);
    }
    
    .services-grid {
        grid-template-columns: 1fr;
        max-width: 1200px;
        margin: 0 auto;
        padding: 0 var(--space-6);
    }
    
    .nav-cta { margin-top: var(--space-4); text-align: center; }
    .advantages-text .section-title {
        text-align: center;
    }
}

@media (max-width: 480px) {
    .hero {
        padding: var(--space-20) 0;
    }
    
    .hero-title {
        font-size: var(--font-size-3xl);
    }
    
    .btn {
        width: 100%;
        justify-content: center;
    }
    
    .stat-number {
        font-size: var(--font-size-2xl);
    }
    
    .visual-number {
        font-size: var(--font-size-4xl);
    }
}

/* Extra small screens - fix text cramming */
@media (max-width: 400px) {
    /* Reduce all section padding for very small screens */
    .services,
    .advantages,
    .location,
    .contact,
    .pricing,
    .footer {
        padding-left: var(--space-4);
        padding-right: var(--space-4);
    }
    
    /* Reduce hero padding */
    .hero-content,
    .nav-container {
        padding-left: var(--space-4);
        padding-right: var(--space-4);
    }
    
    /* Smaller typography for very small screens */
    .hero-title {
        font-size: var(--font-size-2xl);
        line-height: 1.2;
    }
    
    .section-title {
        font-size: var(--font-size-2xl);
    }
    
    .service-title {
        font-size: var(--font-size-lg);
    }
    
    /* Reduce card padding */
    .service-card {
        padding: var(--space-6);
    }
    
    /* Smaller contact cards */
    .contact-card {
        padding: 16px 18px;
        min-height: auto;
    }
    
    .contact-icon {
        width: 48px;
        height: 48px;
    }
    
    /* Better grid layouts for small screens */
    .services-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
    
    .pricing-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
    
    /* Better text spacing */
    .hero-description,
    .section-description {
        font-size: var(--font-size-base);
        line-height: 1.6;
    }
    
    /* Reduce FAQ padding */
    .page-faq .container {
        padding-left: var(--space-4);
        padding-right: var(--space-4);
    }
}

/* Mobile overflow hardening – ensure no horizontal scroll / white bar on very small devices */
@media (max-width: 480px) {
    /* Allow wrapping & breaking long contact values (email / phone) */
    .contact-value,
    .contact-value a { 
        white-space: normal !important; 
        word-break: break-word; 
        overflow-wrap: anywhere; 
    }
    /* Reduce wide card horizontal padding to prevent cumulative overflow with container padding */
    .contact-card,
    .contact-card--wide { 
        padding: 16px 18px; 
        max-width: 100%;
    }
    /* Defensive: ensure grid container never exceeds viewport */
    .contact-methods { 
        width: 100%; 
        overflow: hidden; 
    }
    /* Ensure main layout containers don't accidentally extend beyond viewport due to sub-pixel rounding */
    .container { 
        width: 100%; 
        max-width: 100%; 
    }
}

/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Scroll Animations */
.animate-on-scroll {
    opacity: 0;
    animation: fadeInUp 0.6s ease-out forwards;
}

.animate-on-scroll.animate-left {
    animation: fadeInLeft 0.6s ease-out forwards;
}

.animate-on-scroll.animate-right {
    animation: fadeInRight 0.6s ease-out forwards;
}

/* Focus Styles for Accessibility */
.btn:focus,
.nav-link:focus,
input:focus,
textarea:focus,
button:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* Print Styles */
@media print {
    .header,
    .nav-toggle,
    .hero-actions,
    .footer {
        display: none;
    }
    
    .hero {
        background: none;
        color: var(--gray-900);
    }
}