:root {--ice: #e8f4fd; --sky: #0ea5e9; --deep: #0369a1; --dark: #0a1628; --darker: #060d1a; --frost: rgba(255,255,255,0.07); --card-bg: rgba(255,255,255,0.04); --accent: #38bdf8; --warm: #f97316; --text: #cbd5e1; --white: #ffffff;}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {font-family: 'DM Sans', sans-serif;background: var(--darker);color: var(--text);overflow-x: hidden;}
/* ========= NOISE OVERLAY ========= */
body::before {content:''; position: fixed; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events: none; z-index: 0; opacity: 0.4;}
/* ========= NAV ========= */
nav {position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: 1.2rem 5%; background: rgba(6,13,26,0.8); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(56,189,248,0.1); transition: all .3s;}
.nav-logo {font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.4rem; color: var(--white); text-decoration: none; display: flex; align-items: center; gap: .5rem;}
.nav-logo span { color: var(--accent); }
.logo-icon {width: 36px; height: 36px; background: linear-gradient(135deg, var(--sky), var(--deep)); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem;}
.nav-links { display: flex; gap: 2rem; list-style: none; }
.nav-links a {text-decoration: none; color: var(--text); font-size: .9rem; font-weight: 500; transition: color .3s; }
.nav-links a:hover {color: var(--accent);}
.nav-cta {background: linear-gradient(135deg, var(--sky), var(--deep)); color: white !important; padding: .55rem 1.4rem; border-radius: 50px; font-weight: 600 !important; transition: transform .2s, box-shadow .2s !important;}
.nav-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(14,165,233,.4) !important; }
.hamburger {display: none; background: none; border: none;cursor: pointer; flex-direction: column; gap: 5px;}
.hamburger span {display: block; width: 24px; height: 2px;background: var(--white); border-radius: 2px; transition: .3s;}

/* ========= HERO ========= */
.hero {min-height: 100vh; display: flex; align-items: center; padding: 120px 5% 80px; position: relative; overflow: hidden;}
.hero-bg {position: absolute; inset: 0; background:radial-gradient(ellipse 80% 60% at 70% 50%, rgba(14,165,233,.15) 0%, transparent 60%), radial-gradient(ellipse 50% 80% at 10% 80%, rgba(3,105,161,.2) 0%, transparent 50%), ar(--darker);}

/* Floating orbs */
.orb {position: absolute; border-radius: 50%; filter: blur(60px); opacity: .3; animation: drift 8s ease-in-out infinite;}
.orb-1 { width: 400px; height: 400px; background: var(--sky); top: -100px; right: -50px; animation-delay: 0s; }
.orb-2 { width: 300px; height: 300px; background: var(--deep); bottom: 0; left: 10%; animation-delay: -4s; }
.orb-3 { width: 200px; height: 200px; background: #7dd3fc; top: 40%; right: 20%; animation-delay: -2s; }
@keyframes drift { 0%, 100% { transform: translate(0, 0) scale(1); } 33% { transform: translate(20px, -20px) scale(1.05); } 66% { transform: translate(-15px, 10px) scale(.95); }}
.hero-content {position: relative; z-index: 1; max-width: 600px;}
.hero-badge {display: inline-flex; align-items: center; gap: .5rem; background: rgba(56,189,248,.1); border: 1px solid rgba(56,189,248,.2); color: var(--accent); padding: .4rem 1rem; border-radius: 50px; font-size: .82rem; font-weight: 500; margin-bottom: 1.5rem; animation: fadeUp .8s ease both;}
.badge-dot {width: 7px; height: 7px; border-radius: 50%;background: var(--accent); animation: pulse 2s infinite;}

@keyframes pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: .5; transform: scale(.8); }}
.hero h1 {font-family: 'Syne', sans-serif; font-size: clamp(2.8rem, 6vw, 5rem); font-weight: 800; line-height: 1.05; color: var(--white); margin-bottom: 1.5rem; animation: fadeUp .8s ease .15s both;}
.hero h1 .highlight {background: linear-gradient(135deg, var(--accent), #7dd3fc); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero p {font-size: 1.1rem; line-height: 1.7; color: var(--text); margin-bottom: 2.5rem; animation: fadeUp .8s ease .3s both;}
.hero-buttons {display: flex; gap: 1rem; flex-wrap: wrap; animation: fadeUp .8s ease .45s both;}
.btn-primary {display: inline-flex; align-items: center; gap: .5rem; background: linear-gradient(135deg, var(--sky), var(--deep)); color: white; padding: .85rem 2rem; border-radius: 50px; font-weight: 600; font-size: .95rem; text-decoration: none; transition: transform .2s, box-shadow .2s; box-shadow: 0 4px 20px rgba(14,165,233,.3);}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(14,165,233,.4); }
.btn-secondary {display: inline-flex; align-items: center; gap: .5rem;background: transparent; color: var(--white);padding: .85rem 2rem; border-radius: 50px;font-weight: 600; font-size: .95rem; text-decoration: none;border: 1px solid rgba(255,255,255,.2);transition: all .2s;}
.btn-secondary:hover { border-color: var(--accent); color: var(--accent); background: rgba(56,189,248,.05); }

/* Hero visual */
.hero-visual {position: absolute; right: 5%; top: 50%; transform: translateY(-50%);width: 42%; max-width: 520px;animation: fadeLeft .8s ease .3s both;display: flex; align-items: center; justify-content: center;}
.ac-unit-visual {width: 100%; max-width: 420px;background: linear-gradient(135deg, #0f2a47, #1e4d6b);border-radius: 24px;border: 1px solid rgba(56,189,248,.2);padding: 2rem;position: relative;box-shadow: 0 40px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(56,189,248,.05);}
.ac-display {background: #0a1628;border-radius: 14px;padding: 1.5rem;margin-bottom: 1.5rem;border: 1px solid rgba(56,189,248,.15);}
.ac-temp {font-family: 'Syne', sans-serif;font-size: 4rem; font-weight: 800;color: var(--accent);text-shadow: 0 0 30px rgba(56,189,248,.5);line-height: 1;}
.ac-status {font-size: .8rem; color: var(--text); margin-top: .3rem; display: flex; align-items: center; gap: .4rem;}
.status-dot { width: 6px; height: 6px; background: #4ade80; border-radius: 50%; }
.ac-controls {display: flex; gap: .8rem; flex-wrap: wrap;}
.ac-btn {flex: 1; min-width: 80px; background: rgba(56,189,248,.1); border: 1px solid rgba(56,189,248,.15); border-radius: 10px; padding: .8rem .5rem; text-align: center; cursor: pointer; transition: all .2s; color: var(--text); font-size: .75rem; }
.ac-btn:hover { background: rgba(56,189,248,.2); border-color: var(--accent); }
.ac-btn .icon { font-size: 1.3rem; display: block; margin-bottom: .3rem; }
.floating-card {position: absolute; background: rgba(10,22,40,.9); border: 1px solid rgba(56,189,248,.2); border-radius: 14px; padding: 1rem 1.2rem; backdrop-filter: blur(10px); animation: float 4s ease-in-out infinite;}
.floating-card.card-1 { left: -80px; top: 20%; animation-delay: 0s; }
.floating-card.card-2 { right: -60px; bottom: 15%; animation-delay: -2s; }

@keyframes float {0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); }}
.fc-label { font-size: .7rem; color: var(--text); margin-bottom: .2rem; }
.fc-val { font-family: 'Syne', sans-serif; font-weight: 700; color: var(--white); font-size: 1.1rem; }
.fc-val.green { color: #4ade80; }
.fc-val.orange { color: #fb923c; }
@keyframes fadeUp {from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); }}
@keyframes fadeLeft {from { opacity: 0; transform: translateY(-50%) translateX(30px); } to { opacity: 1; transform: translateY(-50%) translateX(0); }}

/* ========= STATS ========= */
.stats {padding: 4rem 5%;border-top: 1px solid rgba(255,255,255,.06);border-bottom: 1px solid rgba(255,255,255,.06);}
.stats-grid {display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; max-width: 1100px; margin: 0 auto;}
.stat-item { text-align: center; }
.stat-num {font-family: 'Syne', sans-serif; font-size: 2.8rem; font-weight: 800; color: var(--white); background: linear-gradient(135deg, var(--accent), #7dd3fc); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;}
.stat-label { font-size: .88rem; color: var(--text); margin-top: .3rem; }

/* ========= SECTIONS ========= */
section { position: relative; z-index: 1; }
.section-tag {display: inline-flex; align-items: center; gap: .4rem; color: var(--accent); font-size: .82rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; margin-bottom: .8rem;}
.section-tag.mt-60 {margin-top:60px}
.section-title {font-family: 'Syne', sans-serif;font-size: clamp(2rem, 4vw, 3rem);font-weight: 800; color: var(--white);line-height: 1.15; margin-bottom: 1rem;}
.section-sub {font-size: 1rem; line-height: 1.7; color: var(--text);max-width: 560px;}

/* ========= SERVICES ========= */
.services { padding: 100px 5%; }
.services-header { text-align: center; margin-bottom: 4rem; }
.services-header .section-sub { margin: 0 auto; }
.services-grid {display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; max-width: 1200px; margin: 0 auto;}
.service-card {background: var(--card-bg);border: 1px solid rgba(255,255,255,.07);border-radius: 20px; padding: 2rem;transition: all .3s; cursor: default;position: relative; overflow: hidden;}
.service-card::before {content: '';position: absolute; top: 0; left: 0; right: 0; height: 2px;background: linear-gradient(90deg, var(--sky), transparent);opacity: 0; transition: opacity .3s;}
.service-card:hover {background: rgba(14,165,233,.06);border-color: rgba(56,189,248,.2);transform: translateY(-6px);box-shadow: 0 20px 50px rgba(0,0,0,.3);}
.service-card:hover::before {opacity: 1;}
.service-icon {width: 56px; height: 56px; background: linear-gradient(135deg, rgba(14,165,233,.2), rgba(3,105,161,.2)); border: 1px solid rgba(56,189,248,.2); border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; margin-bottom: 1.2rem;}
.service-card h3 {font-family: 'Syne', sans-serif;font-weight: 700; font-size: 1.1rem;color: var(--white); margin-bottom: .6rem;}
.service-card p { font-size: .9rem; line-height: 1.6; color: var(--text); }
.service-list {list-style: none; margin-top: 1rem; display: flex; flex-direction: column; gap: .4rem;}
.service-list li {font-size: .85rem; color: var(--text);display: flex; align-items: center; gap: .5rem;}
.service-list li::before {content: '✓'; color: var(--accent);font-weight: 700; font-size: .8rem;}

/* ========= AC TYPES ========= */
.ac-types { padding: 80px 5%; background: rgba(255,255,255,.02); }
.ac-types-inner { max-width: 1200px; margin: 0 auto; }
.ac-types-header { margin-bottom: 3rem; }
.ac-tabs {display: flex; gap: .8rem; margin-bottom: 3rem; flex-wrap: wrap;}
.tab-btn {padding: .6rem 1.4rem; border-radius: 50px; background: transparent; border: 1px solid rgba(255,255,255,.12); color: var(--text); font-size: .9rem; cursor: pointer; font-family: 'DM Sans', sans-serif; transition: all .3s;}
.tab-btn.active, .tab-btn:hover {background: linear-gradient(135deg, var(--sky), var(--deep));border-color: transparent; color: white;}
.tab-content { display: none; }
.tab-content.active { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.tab-img {background: linear-gradient(135deg, #0f2a47, #1a3a5c); border-radius: 20px; height: 320px; display: flex; align-items: center; justify-content: center; font-size: 8rem; border: 1px solid rgba(56,189,248,.15); position: relative; overflow: hidden;}
.tab-img img {width: 100%;}
.tab-img::after {content: '';position: absolute; inset: 0;background: radial-gradient(ellipse at center, rgba(14,165,233,.1), transparent);}
.tab-text h3 {font-family: 'Syne', sans-serif;font-size: 1.8rem; font-weight: 800;color: var(--white); margin-bottom: 1rem;}
.tab-text p { font-size: .95rem; line-height: 1.7; color: var(--text); margin-bottom: 1.5rem; }
.feature-pills { display: flex; gap: .6rem; flex-wrap: wrap; }
.pill {display: inline-flex; align-items: center; gap: .3rem;background: rgba(56,189,248,.1);border: 1px solid rgba(56,189,248,.15);color: var(--accent); padding: .35rem .9rem;border-radius: 50px; font-size: .8rem; font-weight: 500;}

/* ========= REPAIR PARTS ========= */
.repair { padding: 100px 5%; }
.repair-inner { max-width: 1200px; margin: 0 auto; }
.repair-grid {display: grid;grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));gap: 1rem; margin-top: 3rem;}
.part-card {background: var(--card-bg);border: 1px solid rgba(255,255,255,.07); border-radius: 16px; padding: 1.5rem 1rem; text-align: center; transition: all .3s; cursor: default;}
.part-card:hover {background: rgba(14,165,233,.07);border-color: rgba(56,189,248,.25);transform: translateY(-4px);}
.part-icon { font-size: 2rem; margin-bottom: .8rem; }
.part-card h4 {font-family: 'Syne', sans-serif;font-size: .95rem; font-weight: 700;color: var(--white); margin-bottom: .3rem;}
.part-card p { font-size: .78rem; color: var(--text); }

/* ======== Gallery ======= */
.gallery {display: flex; justify-content: center;padding: 24px;}
.gallery .gallery-inner {display:flex; gap: 16px; flex-direction:row; max-width: 1200px;}

/* ========= WHY US ========= */
.why-us { padding: 100px 5%; background: rgba(255,255,255,.02); }
.why-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.why-list { margin-top: 2rem; display: flex; flex-direction: column; gap: 1.5rem; }
.why-item { display: flex; gap: 1rem; align-items: flex-start; }
.why-num {width: 40px; height: 40px; min-width: 40px; background: linear-gradient(135deg, rgba(14,165,233,.2), rgba(3,105,161,.2)); border: 1px solid rgba(56,189,248,.2); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-family: 'Syne', sans-serif; font-weight: 800; color: var(--accent); font-size: .9rem;}
.why-text h4 { font-family: 'Syne', sans-serif; color: var(--white); font-size: 1rem; margin-bottom: .3rem; }
.why-text p { font-size: .88rem; color: var(--text); line-height: 1.6; }
.testimonial-stack { display: flex; flex-direction: column; gap: 1.2rem; }
.testimonial {background: var(--card-bg); border: 1px solid rgba(255,255,255,.07); border-radius: 16px; padding: 1.5rem; position: relative;}
.testimonial::before {content: '"'; position: absolute; top: .8rem; right: 1.2rem; font-size: 3rem; color: rgba(56,189,248,.15); font-family: 'Syne', sans-serif; line-height: 1;}
.stars { color: #fbbf24; font-size: .85rem; margin-bottom: .6rem; }
.testimonial p { font-size: .88rem; line-height: 1.6; color: var(--text); margin-bottom: .8rem; }
.t-author { display: flex; align-items: center; gap: .7rem; }
.t-avatar {width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--sky), var(--deep)); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .85rem; color: white;}
.t-name { font-weight: 600; color: var(--white); font-size: .88rem; }
.t-loc { font-size: .78rem; color: var(--text); }

/* ========= PRICING ========= */
.pricing { padding: 100px 5%; }
.pricing-header { text-align: center; margin-bottom: 4rem; }
.pricing-grid {display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));gap: 1.5rem; max-width: 1000px; margin: 0 auto;}
.price-card {background: var(--card-bg);border: 1px solid rgba(255,255,255,.07);border-radius: 24px; padding: 2.5rem 2rem;transition: all .3s; position: relative; overflow: hidden;}
.price-card.popular {background: linear-gradient(135deg, rgba(14,165,233,.12), rgba(3,105,161,.08)); border-color: rgba(56,189,248,.3); transform: scale(1.03);}
.popular-badge {position: absolute; top: 1.2rem; right: 1.2rem; background: linear-gradient(135deg, var(--sky), var(--deep)); color: white; padding: .25rem .8rem; border-radius: 50px; font-size: .72rem; font-weight: 700;}
.price-card h3 {font-family: 'Syne', sans-serif; font-size: 1.2rem; font-weight: 800; color: var(--white); margin-bottom: .5rem;}
.price-card .desc { font-size: .85rem; color: var(--text); margin-bottom: 1.5rem; }
.price-amount {font-family: 'Syne', sans-serif; font-size: 2.8rem; font-weight: 800; color: var(--white); margin-bottom: 1.5rem;}
.price-amount span { font-size: 1rem; font-weight: 400; color: var(--text);}
.price-features { list-style: none; display: flex; flex-direction: column; gap: .7rem; margin-bottom: 2rem; }
.price-features li {display: flex; align-items: center; gap: .6rem; font-size: .9rem; color: var(--text);}
.price-features li::before { content: '✓'; color: var(--accent); font-weight: 700; }

/* ========= CONTACT ========= */
.contact { padding: 100px 5%; background: rgba(255,255,255,.02); }
.contact-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; }
.contact-form {background: var(--card-bg); border: 1px solid rgba(255,255,255,.07); border-radius: 24px; padding:0;}
.contact-form h3 {font-family: 'Syne', sans-serif; font-size: 1.6rem; font-weight: 800; color: var(--white); margin-bottom: 2rem;}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { margin-bottom: 1.2rem; }
.form-group label { display: block; font-size: .82rem; color: var(--text); margin-bottom: .4rem; font-weight: 500; }
.form-group input, .form-group select, .form-group textarea {width:100%; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 10px; padding: .75rem 1rem; color: var(--white); font-family: 'DM Sans', sans-serif; font-size: .9rem; outline: none; transition: border-color .3s;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus {border-color: var(--accent);background: rgba(56,189,248,.05);}
.form-group select option { background: var(--dark); }
.form-group textarea { resize: vertical; min-height: 100px; }
.submit-btn {width: 100%;background: linear-gradient(135deg, var(--sky), var(--deep));color: white; border: none; padding: 1rem;border-radius: 10px; font-size: 1rem; font-weight: 600;cursor: pointer; font-family: 'DM Sans', sans-serif;transition: transform .2s, box-shadow .2s;}
.submit-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(14,165,233,.4); }
.contact-info h3 {font-family: 'Syne', sans-serif;font-size: 2rem; font-weight: 800;color: var(--white); margin-bottom: 1rem;}
.contact-info > p { font-size: .95rem; line-height: 1.7; color: var(--text); margin-bottom: 2.5rem; }
.contact-cards { display: flex; flex-direction: column; gap: 1rem; }
.contact-card {display:flex; align-items:flex-start; gap:1rem; background:var(--card-bg); border:1px solid rgba(255,255,255,.07); border-radius:14px; padding:1.2rem 1.5rem;}
.contact-card a {text-decoration: none;}
.cc-icon {width: 44px; height: 44px; min-width: 44px; background: linear-gradient(135deg, rgba(14,165,233,.2), rgba(3,105,161,.2)); border: 1px solid rgba(56,189,248,.2); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.2rem;}
.cc-label { font-size: .78rem; color: var(--text); margin-bottom: .40rem; margin-top:.30rem; }
.cc-val { font-weight: 600; color: var(--white); font-size: .95rem; }
.hours-grid {margin-top:2rem; background: var(--card-bg); border: 1px solid rgba(255,255,255,.07); border-radius: 14px; padding: 1.5rem;}
.hours-grid h4 {font-family: 'Syne', sans-serif; color: var(--white); margin-bottom: 1rem;}
.hours-row {display: flex; justify-content: space-between; padding: .5rem 0; border-bottom: 1px solid rgba(255,255,255,.05); font-size: .88rem;}
.hours-row:last-child { border-bottom: none; }
.hours-row .day { color: var(--text); }
.hours-row .time { color: var(--accent); font-weight: 500; }
.map-container iframe {width: 100%; height: 450px; border-radius: 24px;}

/* ========= FOOTER ========= */
footer {background: var(--darker); border-top: 1px solid rgba(255,255,255,.06); padding: 3rem 5% 1.5rem;}
.footer-top {display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;gap: 3rem; margin-bottom: 3rem;}
.footer-brand .nav-logo { margin-bottom: 1rem; display: inline-flex; }
.footer-brand p { font-size: .88rem; line-height: 1.7; color: var(--text); max-width: 280px; }
.footer-col h4 {font-family: 'Syne', sans-serif; color: var(--white); font-size: .95rem; margin-bottom: 1.2rem;}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.footer-col ul a { text-decoration: none; color: var(--text); font-size: .88rem; transition: color .3s; }
.footer-col ul a:hover { color: var(--accent);}
.footer-bottom {border-top: 1px solid rgba(255,255,255,.06);padding-top: 1.5rem;display: flex; justify-content: space-between; align-items: center;flex-wrap: wrap; gap: 1rem;}
.footer-bottom p { font-size: .82rem; color: var(--text); }
.social-links { display: flex; gap: .8rem;}
.social-link {width: 36px; height: 36px;background: rgba(255,255,255,.06);border: 1px solid rgba(255,255,255,.08);border-radius: 8px;display: flex; align-items: center; justify-content: center;font-size: .9rem; text-decoration: none; color: #fff; transition: all .3s;}
.social-link:hover { background: rgba(14,165,233,.2); border-color: rgba(56,189,248,.3); }
.toast {position: fixed; bottom: 2rem; right: 2rem; background: linear-gradient(135deg, #064e3b, #065f46); border: 1px solid #059669; color: white; padding: 1rem 1.5rem; border-radius: 12px; font-size: .9rem; font-weight: 500; display: flex; align-items: center; gap: .6rem; transform: translateY(120px); opacity: 0; transition: all .4s; z-index: 1000; box-shadow: 0 8px 24px rgba(0,0,0,.4);}
.toast.show { transform: translateY(0); opacity: 1; }
.reveal {opacity: 0; transform: translateY(30px); transition: opacity .7s ease, transform .7s ease;}
.reveal.visible { opacity: 1; transform: translateY(0); }
.m-view-social-icons {display: none;} .mt-10 {margin-top: 10px;} .googleReviewBtn {display: flex; justify-content: center; padding: 16px;}

/* ========= RESPONSIVE ========= */
@media (max-width: 1100px) {
.hero-visual { display: none; }
.hero-content { max-width: 100%; }
.tab-content.active { grid-template-columns: 1fr; }
.why-inner { grid-template-columns: 1fr; gap: 3rem; }
.contact-inner { grid-template-columns: 1fr; }
.footer-top { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
.stats-grid { grid-template-columns: repeat(2, 1fr); }
.nav-links { display: none; flex-direction: column; position: fixed; top: 70px; left: 0; right: 0; background: rgba(6,13,26,.97); padding: 2rem 5%; border-bottom: 1px solid rgba(255,255,255,.06); z-index: 99; }
.nav-links.open { display: flex; }
.hamburger { display: flex; }
.form-row { grid-template-columns: 1fr; }
.footer-top { grid-template-columns: 1fr; gap: 2rem; }
.hero h1 { font-size: 2.4rem;}
.price-card.popular { transform: none;}
.gallery .gallery-inner {flex-direction: column; max-width: 100%;}
.carousel-wrapper {max-width: 100% !important;}
.section-tag.mt-60 {margin-top: 0px;}
.tab-img {height: auto;}
.map-container iframe {height: 250px;}
footer {padding-bottom: 84px;}
.m-view-social-icons {display:grid; grid-template-columns: 1fr 1fr; justify-content: center; position: fixed; bottom: 0px; left: 0px; z-index:99; width: 100%; background:#215295;}
.m-view-social-icons a {color: #fff; font-size:20px; display: inline-block; padding:8px 30px; text-decoration: none; text-align: center;}
.m-view-social-icons a.call {background:#1b8cd0;} .m-view-social-icons a.whatsapp {background:#00b85a;}
.m-view-social-icons a .icon-text {display:block; font-size:12px; font-weight: 600; padding-top:2px;}
.m-view-social-icons a i.fa-solid.fa-phone {font-size:17px;}
}

@media (max-width: 480px) { .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; } .hero-buttons { flex-direction: column; } .btn-primary, .btn-secondary { justify-content: center; }}

/* MOBILE MENU OVERLAY */
.nav-mobile-overlay {display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 98;}
.nav-mobile-overlay.open { display: block; }

/* Carousel container */
.carousel-wrapper {position: relative; width: 100%; max-width:650px; z-index: 1;}
.carousel-track-container {overflow: hidden; border-radius: var(--radius); cursor: grab; user-select: none;}
.carousel-track-container:active { cursor: grabbing; }
.carousel-track {display: flex; transition: transform 0.55s cubic-bezier(0.77, 0, 0.18, 1); will-change: transform;}

/* Cards */
.card {min-width: 100%; min-height: 460px; position: relative; border-radius: var(--radius); overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; flex-shrink: 0;}
.card-bg {position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.55s cubic-bezier(0.77, 0, 0.18, 1);}
.card:hover .card-bg { transform: scale(1.03); }
.card-overlay {position: absolute; inset: 0; background: linear-gradient(to top,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.3) 50%,rgba(0,0,0,0.0) 100%);}
.card-content {position: relative; z-index: 2; padding: 36px 40px;}
.card-tag {display: inline-block;font-size: 10px;letter-spacing: 3px;text-transform: uppercase;color: var(--accent);border: 1px solid rgba(232, 200, 122, 0.4);padding: 5px 12px;border-radius: 100px;margin-bottom: 14px;backdrop-filter: blur(8px);background: rgba(232, 200, 122, 0.08);}
.card-title {font-family: 'Playfair Display', serif;font-size: clamp(1rem, 2.5vw, 1.4rem);line-height: 1.2;margin-bottom: 10px;}
.card-desc {font-size: 14px;color: rgba(245, 240, 232, 0.65);line-height: 1.6;max-width: 480px;margin-bottom: 24px;}
.card-btn {display: inline-flex;align-items: center;gap: 8px;background: var(--accent);color: #0d0d0d;font-family: 'DM Sans', sans-serif;font-size: 13px;font-weight: 400;letter-spacing: 0.5px;padding: 12px 24px;border-radius: 100px;border: none;cursor: pointer;transition: transform 0.2s, box-shadow 0.2s;text-decoration: none;}
.card-btn:hover {transform: translateY(-2px);box-shadow: 0 8px 24px rgba(232, 200, 122, 0.35);}
.card-btn svg { transition: transform 0.2s; }
.card-btn:hover svg { transform: translateX(3px); }

/* Counter badge */
.card-counter {position: absolute;top: 28px;right: 36px;z-index: 2;font-family: 'Playfair Display', serif;font-size: 13px;color: rgba(255,255,255,0.5);}
.card-counter strong {font-size: 22px;font-weight: 700;color: var(--text);font-style: italic;}
.nav-btn {position: absolute;top: 50%;transform: translateY(-50%);z-index: 10;width: 48px; height: 48px;border-radius: 50%;border: 1px solid rgba(255,255,255,0.12);background: rgba(20,20,20,0.7);backdrop-filter: blur(12px);color: var(--text);cursor: pointer;display: flex;align-items: center;justify-content: center;transition: background 0.2s, border-color 0.2s, transform 0.2s;}
.nav-btn:hover {background: var(--accent);border-color: var(--accent);color: #0d0d0d;transform: translateY(-50%) scale(1.08);}
.nav-btn.prev { left: -22px; }
.nav-btn.next { right: -22px; }
.dots {display: flex;align-items: center;justify-content: center;gap: 8px;margin-top: 28px;}
.dot {width: 6px; height: 6px;border-radius: 100px;background: rgba(255,255,255,0.2);border: none;cursor: pointer;padding: 0; transition: width 0.35s cubic-bezier(0.77, 0, 0.18, 1), background 0.35s;}
.dot.active {width: 28px;background: var(--accent);}
.thumbnails {display: flex;gap: 12px; margin-top: 20px; justify-content: center;}
.thumb {width: 56px; height: 56px; border-radius: 12px; background-size: cover; background-position: center; cursor: pointer; border: 2px solid transparent; transition: border-color 0.3s, transform 0.3s, opacity 0.3s; opacity: 0.45; flex-shrink: 0;}
.thumb.active {border-color: var(--accent); opacity: 1; transform: scale(1.08);}
.carousel-track-container {  touch-action: pan-y;}
@media (max-width: 600px) {.nav-btn.prev { left: 8px; } .nav-btn.next { right: 8px; } .card-content { padding: 28px 24px; } .card-counter { right: 20px; } .card { min-height: 380px; width: 100%;} .thumbnails { display: none; }}