@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

:root {
    --primary: #5D0F11;
    --primary-light: #8B1A1D;
    --secondary: #341A1F;
    --accent: #D4A853;
    --accent-light: #E8C97A;
    --dark: #0a0a0a;
    --text: #2d2d2d;
    --text-light: #888;
    --white: #ffffff;
    --off-white: #f8f6f3;
    --transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1);
    --shadow-sm: 0 4px 20px rgba(0,0,0,0.06);
    --shadow-md: 0 10px 40px rgba(0,0,0,0.1);
    --shadow-lg: 0 25px 60px rgba(0,0,0,0.15);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body { font-family:'Poppins',sans-serif; color:var(--text); line-height:1.7; overflow-x:hidden; background:var(--white); max-width:100vw; }
a { text-decoration:none; color:inherit; transition:var(--transition); }
ul { list-style:none; }
img { max-width:100%; display:block; }

.container { max-width:1240px; margin:0 auto; padding:0 24px; }
section { padding:120px 0; position:relative; overflow:hidden; }

/* ── Reveal Animations ── */
.reveal { opacity:0; transform:translateY(40px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.active { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-60px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal-left.active { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(60px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal-right.active { opacity:1; transform:translateX(0); }

/* ── Section Titles ── */
.section-header { text-align:center; margin-bottom:70px; }
.section-header .label { display:inline-block; font-size:0.85rem; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--accent); margin-bottom:15px; }
.section-header h2 { font-size:2.8rem; font-weight:800; color:var(--secondary); line-height:1.2; }
.section-header p { max-width:600px; margin:20px auto 0; color:var(--text-light); font-size:1.05rem; }
.title-line { width:60px; height:4px; background:linear-gradient(90deg,var(--primary),var(--accent)); margin:18px auto 0; border-radius:2px; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:16px 36px; font-weight:600; font-size:0.9rem; text-transform:uppercase; letter-spacing:1.5px; border:none; border-radius:50px; cursor:pointer; transition:var(--transition); position:relative; overflow:hidden; }
.btn::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent); transition:0.6s; }
.btn:hover::before { left:100%; }
.btn-primary { background:linear-gradient(135deg,var(--primary),var(--secondary)); color:var(--white); box-shadow:0 8px 30px rgba(93,15,17,0.3); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(93,15,17,0.4); }
.btn-outline { border:2px solid rgba(255,255,255,0.5); color:var(--white); background:transparent; backdrop-filter:blur(10px); }
.btn-outline:hover { background:var(--white); color:var(--primary); border-color:var(--white); }
.btn-accent { background:linear-gradient(135deg,var(--accent),var(--accent-light)); color:var(--secondary); font-weight:700; }
.btn-accent:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(212,168,83,0.4); }

/* ── Navbar ── */
.navbar {
    position:fixed; top:0; left:0; width:100%; z-index:1000;
    padding:6px 0;
    background:rgba(255,255,255,0.98);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    box-shadow:0 2px 30px rgba(0,0,0,0.08);
    transition:var(--transition);
}
.navbar.scrolled { padding:4px 0; box-shadow:0 2px 40px rgba(0,0,0,0.12); }
.navbar .container { display:flex; justify-content:space-between; align-items:center; }

/* Logo — always visible on white header */
.logo { display:flex; align-items:center; transition:var(--transition); }
.logo img { height:72px; transition:var(--transition); object-fit:contain; filter:none; }
.navbar.scrolled .logo img { height:58px; }

.nav-links { display:flex; align-items:center; gap:36px; }
.nav-links a { font-weight:600; font-size:0.82rem; text-transform:uppercase; letter-spacing:1.5px; color:var(--text); position:relative; padding:6px 0; }
.navbar.scrolled .nav-links a { color:var(--text); }
.nav-links a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:linear-gradient(90deg,var(--primary),var(--accent)); transition:var(--transition); border-radius:2px; }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-links a:hover { color:var(--primary); }
.nav-links .btn { padding:13px 30px; font-size:0.78rem; letter-spacing:1.5px; }
/* Btn items in nav should NOT have underline pseudo-element */
.nav-links .btn::after { display:none !important; }
.menu-header { display: none; } /* Hidden on desktop */
.menu-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:1001; }
.menu-toggle span { width:28px; height:2px; background:var(--text); transition:var(--transition); border-radius:2px; }
.navbar.scrolled .menu-toggle span { background:var(--text); }
.menu-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.menu-toggle.active span:nth-child(2) { opacity:0; }
.menu-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

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

/* Mobile actions in menu - Premium Styling */
.mobile-actions { 
    display: none; 
    flex-direction: column; 
    gap: 12px; 
    width: 100%; 
    margin-top: 30px;
    padding-top: 30px;
    border-top: 1px solid rgba(0,0,0,0.08);
}
/* Hide close btn on desktop */
.menu-close-btn { display: none; }
.mobile-action-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: 100%;
    padding: 12px;
    border-radius: 12px;
    color: var(--white) !important;
    font-weight: 700;
    font-size: 0.95rem;
    line-height: 1.5;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}
.mobile-action-link.call { 
    background: linear-gradient(135deg, var(--primary), #8B1A1D) !important; 
}
.mobile-action-link.whatsapp { 
    background: linear-gradient(135deg, #25D366, #128C7E) !important; 
}
.mobile-action-link i { font-size: 1.1rem; }
.mobile-action-link:active { transform: scale(0.96); box-shadow: 0 2px 8px rgba(0,0,0,0.1); }






/* ── Hero ── */
.hero { height:100vh; display:flex; align-items:center; position:relative; overflow:hidden; }
.hero-slider { position:absolute; inset:0; }
.hero-slide { position:absolute; inset:0; opacity:0; transition:opacity 1.8s ease; }
.hero-slide.active { opacity:1; }

/* Ken Burns — slow zoom + pan per slide */
.hero-slide img { width:100%; height:100%; object-fit:cover; transform-origin:center center; animation:none; }
.hero-slide.active img { animation:kenburns-1 8s ease-in-out forwards; }
.hero-slide:nth-child(2).active img { animation:kenburns-2 8s ease-in-out forwards; }
.hero-slide:nth-child(3).active img { animation:kenburns-3 8s ease-in-out forwards; }
.hero-slide:nth-child(4).active img { animation:kenburns-4 8s ease-in-out forwards; }
@keyframes kenburns-1 { 0%{transform:scale(1)   translateX(0)   translateY(0);}   100%{transform:scale(1.12) translateX(-2%) translateY(-1%);} }
@keyframes kenburns-2 { 0%{transform:scale(1.1) translateX(-1%) translateY(0);}   100%{transform:scale(1)   translateX(1%)  translateY(-2%);} }
@keyframes kenburns-3 { 0%{transform:scale(1)   translateX(2%)  translateY(-1%);} 100%{transform:scale(1.1) translateX(-1%) translateY(1%);} }
@keyframes kenburns-4 { 0%{transform:scale(1.08) translateX(-2%) translateY(1%);} 100%{transform:scale(1)   translateX(0)   translateY(-1%);} }

.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(52,26,31,0.82),rgba(93,15,17,0.65),rgba(0,0,0,0.55)); }
.hero-particles { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.particle { position:absolute; width:3px; height:3px; background:rgba(212,168,83,0.4); border-radius:50%; animation:float-particle linear infinite; }
@keyframes float-particle { 0%{transform:translateY(100vh) rotate(0deg);opacity:0;} 10%{opacity:1;} 90%{opacity:1;} 100%{transform:translateY(-10vh) rotate(720deg);opacity:0;} }

/* Hero content entrance animation */
.hero-content { position:relative; z-index:2; max-width:850px; animation:hero-enter 1.2s cubic-bezier(0.23,1,0.32,1) both; }
@keyframes hero-enter { 0%{opacity:0;transform:translateY(50px);} 100%{opacity:1;transform:translateY(0);} }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,0.1); backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,0.15); padding:10px 24px; border-radius:50px; color:var(--accent); font-size:0.85rem; font-weight:600; letter-spacing:2px; text-transform:uppercase; margin-bottom:30px; animation:hero-enter 1.2s 0.2s cubic-bezier(0.23,1,0.32,1) both; }
.hero h1 { font-size:4.2rem; font-weight:900; color:var(--white); line-height:1.08; text-transform:uppercase; margin-bottom:24px; animation:hero-enter 1.2s 0.35s cubic-bezier(0.23,1,0.32,1) both; }
.hero h1 span { color:var(--accent); display:block; }
.hero-desc { font-size:1.2rem; color:rgba(255,255,255,0.8); max-width:600px; margin-bottom:45px; line-height:1.8; animation:hero-enter 1.2s 0.5s cubic-bezier(0.23,1,0.32,1) both; }
.hero-btns { display:flex; gap:18px; flex-wrap:wrap; animation:hero-enter 1.2s 0.65s cubic-bezier(0.23,1,0.32,1) both; }
.scroll-indicator { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:10px; color:rgba(255,255,255,0.5); font-size:0.75rem; letter-spacing:2px; text-transform:uppercase; }
.scroll-line { width:1px; height:50px; background:linear-gradient(to bottom,var(--accent),transparent); animation:scroll-anim 2s ease infinite; }
@keyframes scroll-anim { 0%,100%{opacity:0.3;transform:scaleY(0.5);} 50%{opacity:1;transform:scaleY(1);} }

/* ── Services ── */
.services-section { background:var(--off-white); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.service-card { background:var(--white); padding:45px 35px; border-radius:16px; position:relative; overflow:hidden; transition:var(--transition); border:1px solid rgba(0,0,0,0.04); }
.service-card::before { content:''; position:absolute; top:0; left:0; width:100%; height:4px; background:linear-gradient(90deg,var(--primary),var(--accent)); transform:scaleX(0); transform-origin:left; transition:var(--transition); }
/* Shimmer sweep on hover */
.service-card::after { content:''; position:absolute; top:0; left:-100%; width:60%; height:100%; background:linear-gradient(90deg,transparent,rgba(212,168,83,0.06),transparent); transition:0.7s ease; pointer-events:none; }
.service-card:hover { transform:translateY(-14px); box-shadow:var(--shadow-lg); }
.service-card:hover::before { transform:scaleX(1); }
.service-card:hover::after { left:150%; }
.service-icon { width:70px; height:70px; background:linear-gradient(135deg,rgba(93,15,17,0.08),rgba(93,15,17,0.03)); border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:25px; transition:var(--transition); }
.service-icon i { font-size:1.8rem; color:var(--primary); transition:var(--transition); }
.service-card:hover .service-icon { background:linear-gradient(135deg,var(--primary),var(--secondary)); transform:rotate(-6deg) scale(1.1); }
.service-card:hover .service-icon i { color:var(--white); }
.service-card h3 { font-size:1.3rem; font-weight:700; margin-bottom:12px; color:var(--secondary); }
.service-card p { color:var(--text-light); font-size:0.95rem; margin-bottom:20px; }
.service-link { display:inline-flex; align-items:center; gap:8px; font-weight:600; color:var(--primary); font-size:0.9rem; }
.service-link i { transition:var(--transition); font-size:0.8rem; }
.service-card:hover .service-link i { transform:translateX(8px); }

/* ── Stats ── */
.stats-section { background:linear-gradient(135deg,var(--secondary),var(--primary)); padding:100px 0; position:relative; overflow:hidden; }
.stats-section::before { content:''; position:absolute; inset:0; background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 80 80"><rect fill="none" stroke="rgba(255,255,255,0.03)" stroke-width="1" width="80" height="80"/></svg>'); background-size:80px; }
/* Radial glow orb animation */
.stats-section::after { content:''; position:absolute; top:-30%; left:-10%; width:600px; height:600px; background:radial-gradient(circle,rgba(212,168,83,0.1),transparent 65%); border-radius:50%; animation:orb-float 8s ease-in-out infinite; pointer-events:none; }
@keyframes orb-float { 0%,100%{transform:translate(0,0);} 50%{transform:translate(6%,4%);} }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:40px; position:relative; z-index:1; }
.stat-card { text-align:center; padding:30px; transition:var(--transition); }
.stat-card:hover { transform:translateY(-6px); }
.stat-card .stat-number { font-size:3.5rem; font-weight:900; color:var(--accent); line-height:1; margin-bottom:8px; text-shadow:0 0 30px rgba(212,168,83,0.4); }
.stat-card .stat-suffix { font-size:2rem; color:var(--accent); }
.stat-card p { color:rgba(255,255,255,0.7); text-transform:uppercase; font-size:0.85rem; font-weight:600; letter-spacing:2px; }

/* ── About Preview ── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-image { position:relative; }
.about-image img { border-radius:20px; box-shadow:var(--shadow-lg); transition:transform 0.7s cubic-bezier(0.23,1,0.32,1), box-shadow 0.7s ease; }
.about-image:hover img { transform:scale(1.03) translateY(-6px); box-shadow:0 35px 80px rgba(0,0,0,0.2); }
.about-image .exp-badge { position:absolute; bottom:-20px; right:12px; background:linear-gradient(135deg,var(--primary),var(--secondary)); color:var(--white); padding:25px 30px; border-radius:16px; text-align:center; box-shadow:var(--shadow-md); animation:badge-float 4s ease-in-out infinite; }
@keyframes badge-float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-10px);} }
.exp-badge h3 { font-size:2.5rem; font-weight:900; line-height:1; color:var(--accent); }
.exp-badge p { font-size:0.8rem; text-transform:uppercase; letter-spacing:2px; margin-top:5px; }
.about-content h2 { font-size:2.5rem; font-weight:800; color:var(--secondary); margin-bottom:20px; line-height:1.2; }
.about-content > p { color:var(--text-light); margin-bottom:30px; font-size:1.05rem; }
.feature-list { margin-bottom:35px; }
.feature-item { display:flex; align-items:center; gap:15px; padding:12px 0; transition:transform 0.3s ease; }
.feature-item:hover { transform:translateX(6px); }
.feature-item .check { width:28px; height:28px; background:linear-gradient(135deg,var(--primary),var(--accent)); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--white); font-size:0.7rem; flex-shrink:0; transition:transform 0.3s ease; }
.feature-item:hover .check { transform:scale(1.2) rotate(10deg); }
.feature-item span { font-weight:500; color:var(--text); }

/* ── Client Slider ── */
.clients-section { background:var(--off-white); padding:80px 0; overflow:hidden; }
.client-slider { display:flex; width:max-content; animation:slide-clients 25s linear infinite; }
.client-slider:hover { animation-play-state:paused; }
.client-item { padding:30px 60px; display:flex; align-items:center; justify-content:center; }
.client-item h3 { font-size:1.5rem; font-weight:800; color:#c5c5c5; white-space:nowrap; transition:var(--transition); letter-spacing:1px; }
.client-item:hover h3 { color:var(--primary); }
@keyframes slide-clients { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }

/* ── Gallery ── */
.gallery-filter { display:flex; justify-content:center; gap:12px; margin-bottom:50px; flex-wrap:wrap; }
.filter-btn { padding:12px 28px; border:2px solid #e0e0e0; background:transparent; cursor:pointer; font-weight:600; font-size:0.85rem; text-transform:uppercase; letter-spacing:1px; border-radius:50px; transition:var(--transition); font-family:'Poppins',sans-serif; }
.filter-btn.active, .filter-btn:hover { background:var(--primary); color:var(--white); border-color:var(--primary); }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.gallery-item { position:relative; overflow:hidden; border-radius:16px; cursor:pointer; aspect-ratio:4/3; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease; }
.gallery-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(52,26,31,0.95),rgba(93,15,17,0.4),transparent); display:flex; flex-direction:column; justify-content:flex-end; padding:30px; opacity:0; transition:var(--transition); color:var(--white); }
.gallery-item:hover img { transform:scale(1.12); }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay h3 { font-size:1.2rem; margin-bottom:5px; }
.gallery-overlay p { font-size:0.85rem; color:var(--accent); font-weight:500; }

/* ── Contact ── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; }
.contact-info-card { display:flex; gap:20px; align-items:flex-start; padding:25px 0; border-bottom:1px solid rgba(0,0,0,0.06); }
.contact-icon { width:55px; height:55px; background:linear-gradient(135deg,rgba(93,15,17,0.08),rgba(93,15,17,0.03)); border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-icon i { font-size:1.2rem; color:var(--primary); }
.contact-info-card h4 { font-size:0.9rem; text-transform:uppercase; letter-spacing:1px; margin-bottom:5px; color:var(--secondary); font-weight:700; }
.contact-info-card p { color:var(--text-light); }
.contact-form { background:var(--white); padding:50px; border-radius:20px; box-shadow:var(--shadow-md); border:1px solid rgba(0,0,0,0.04); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { margin-bottom:22px; }
.form-group label { display:block; margin-bottom:8px; font-weight:600; font-size:0.88rem; color:var(--secondary); }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:14px 18px; border:2px solid #eee; border-radius:12px; font-size:0.95rem; font-family:'Poppins',sans-serif; transition:var(--transition); background:var(--off-white); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--primary); background:var(--white); }
.form-group textarea { height:140px; resize:vertical; }

/* ── Page Header ── */
.page-header { padding:180px 0 100px; text-align:center; color:var(--white); position:relative; background-size:cover; background-position:center; }
.page-header::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(52,26,31,0.9),rgba(93,15,17,0.8)); }
.page-header .container { position:relative; z-index:1; }
.page-header h1 { font-size:3.5rem; font-weight:900; text-transform:uppercase; margin-bottom:15px; }
.page-header p { font-size:1.1rem; color:rgba(255,255,255,0.7); }
.breadcrumb { display:flex; justify-content:center; gap:10px; margin-top:20px; font-size:0.9rem; color:rgba(255,255,255,0.5); }
.breadcrumb a { color:var(--accent); }

/* ── CTA Banner ── */
.cta-section { background:linear-gradient(135deg,var(--primary),var(--secondary)); padding:100px 0; text-align:center; position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; top:-50%; right:-20%; width:500px; height:500px; background:radial-gradient(circle,rgba(212,168,83,0.15),transparent 70%); border-radius:50%; }
.cta-section h2 { font-size:2.8rem; color:var(--white); font-weight:800; margin-bottom:20px; position:relative; z-index:1; }
.cta-section p { color:rgba(255,255,255,0.7); font-size:1.1rem; margin-bottom:40px; position:relative; z-index:1; }

/* ── Footer ── */
footer { background:var(--white); color:var(--text); padding:100px 0 0; border-top:1px solid rgba(0,0,0,0.08); }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:50px; padding-bottom:60px; border-bottom:1px solid rgba(0,0,0,0.08); }
.footer-about p { color:var(--text-light); margin:20px 0; font-size:0.95rem; }
.footer-col h4 { font-size:1rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; margin-bottom:25px; color:var(--primary); }
.footer-col li { margin-bottom:14px; }
.footer-col li a { color:var(--text-light); font-size:0.9rem; transition:var(--transition); }
.footer-col li a:hover { color:var(--primary); padding-left:5px; }
.footer-col .contact-line { display:flex; align-items:flex-start; gap:12px; margin-bottom:18px; color:var(--text-light); font-size:0.9rem; }
.footer-col .contact-line i { color:var(--primary); margin-top:4px; }
.social-links { display:flex; gap:12px; margin-top:25px; }
.social-links a { width:42px; height:42px; background:rgba(0,0,0,0.05); border:1px solid rgba(0,0,0,0.08); display:flex; align-items:center; justify-content:center; border-radius:10px; color:var(--text-light); transition:var(--transition); }
.social-links a:hover { background:var(--primary); border-color:var(--primary); color:var(--white); }
.footer-bottom { padding:30px 0; text-align:center; border-top:1px solid rgba(0,0,0,0.06); }
.footer-bottom p { color:var(--text-light); font-size:0.85rem; }

/* ── Floating Buttons ── */
.floating-btns { position:fixed; right:28px; bottom:28px; display:flex; flex-direction:column; gap:14px; z-index:999; }
.float-btn { width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--white); font-size:1.3rem; box-shadow:0 8px 25px rgba(0,0,0,0.25); transition:var(--transition); }
.float-btn:hover { transform:translateY(-4px) scale(1.1); }
.whatsapp-btn { background:#25d366; }
.call-btn { background:var(--primary); }
.quote-btn { background:var(--accent); color:var(--secondary); }

/* ── Loader ── */
#loader { position:fixed; inset:0; background:var(--white); display:flex; flex-direction:column; justify-content:center; align-items:center; z-index:10000; transition:opacity 0.5s ease; }
#loader img { height:60px; margin-bottom:30px; }
.loader-bar { width:200px; height:3px; background:#eee; border-radius:3px; overflow:hidden; }
.loader-bar::after { content:''; display:block; width:40%; height:100%; background:linear-gradient(90deg,var(--primary),var(--accent)); border-radius:3px; animation:loader-move 1.2s ease infinite; }
@keyframes loader-move { 0%{transform:translateX(-100%);} 100%{transform:translateX(350%);} }

/* ── Quote Form ── */
.quote-form-wrap { max-width:860px; margin:0 auto; background:var(--white); padding:60px; border-radius:24px; box-shadow:var(--shadow-lg); border:1px solid rgba(0,0,0,0.04); }

/* ════════════════════════════════════════
   RESPONSIVE — Full Mobile-First Overhaul
   ════════════════════════════════════════ */

/* ── Tablet (≤1024px) ── */
@media(max-width:1024px) {
    .container { padding:0 20px; }
    .logo img { height:65px; }
    .navbar.scrolled .logo img { height:52px; }

    /* Hero */
    .hero h1 { font-size:3.2rem; }
    .hero-content { max-width:100%; }

    /* Grids */
    .services-grid { grid-template-columns:repeat(2,1fr); gap:22px; }
    .gallery-grid  { grid-template-columns:repeat(2,1fr); gap:18px; }
    .stats-grid    { grid-template-columns:repeat(2,1fr); gap:30px; }
    .about-grid    { gap:50px; }
    .contact-grid  { gap:40px; }
    .footer-top    { grid-template-columns:1fr 1fr; gap:36px; }

    /* CTA */
    .cta-section h2 { font-size:2.2rem; }

    /* Sections */
    section { padding:100px 0; }
}

/* ── Large Mobile (≤768px) ── */
@media(max-width:768px) {
    /* ── Navbar ── */
    .navbar { padding:3px 0; }
    .navbar.scrolled { padding:2px 0; }
    .logo img { height:52px; }
    .navbar.scrolled .logo img { height:44px; }
    
    .mobile-actions { display: flex; }
    .menu-toggle { margin-left: 6px; transition: opacity 0.2s ease; }

    /* Slide-out mobile menu */
    .nav-links {
        position:fixed; top:0; right:-100%; width:82%; max-width:320px; height:100vh;
        background:#ffffff; flex-direction:column;
        align-items: stretch; /* Override desktop center alignment */
        padding:0 0 40px; gap:0;
        transition:right 0.45s cubic-bezier(0.16, 1, 0.3, 1);
        box-shadow:-10px 0 50px rgba(0,0,0,0.18); z-index:1000;
        overflow-y:auto;
    }
    .nav-links.active { right:0; }
    
    /* Menu Header with logo & close btn */
    .menu-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 20px 28px 18px;
        margin-bottom: 8px;
        border-bottom: 1px solid #f0f0f0;
        position: sticky;
        top: 0;
        background: #fff;
        z-index: 2;
    }
    .menu-header img { height: 40px; width: auto; object-fit: contain; }
    .menu-close-btn {
        width: 36px; height: 36px;
        border-radius: 50%;
        background: #f5f5f5;
        border: none;
        display: flex; align-items: center; justify-content: center;
        cursor: pointer;
        font-size: 1.1rem;
        color: var(--secondary);
        transition: all 0.2s ease;
        flex-shrink: 0;
    }
    .menu-close-btn:hover { background: var(--primary); color: #fff; }

    /* Nav link items padding */
    .nav-links > li:not(.menu-header):not(.mobile-actions) {
        padding: 0 28px;
    }

    /* Staggered Entrance Animation */
    .nav-links.active li {
        animation: slideInMenu 0.45s cubic-bezier(0.23, 1, 0.32, 1) forwards;
        opacity: 0;
    }
    .nav-links.active li:nth-child(1) { animation-delay: 0.02s; }
    .nav-links.active li:nth-child(2) { animation-delay: 0.08s; }
    .nav-links.active li:nth-child(3) { animation-delay: 0.13s; }
    .nav-links.active li:nth-child(4) { animation-delay: 0.18s; }
    .nav-links.active li:nth-child(5) { animation-delay: 0.23s; }
    .nav-links.active li:nth-child(6) { animation-delay: 0.28s; }
    .nav-links.active li:nth-child(7) { animation-delay: 0.33s; }
    .nav-links.active li:nth-child(8) { animation-delay: 0.38s; }
    .nav-links.active .mobile-actions { animation-delay: 0.43s; }

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

    /* Nav links in mobile menu (exclude header and mobile-actions area) */
    .nav-links > li:not(.menu-header):not(.mobile-actions) > a {
        color:var(--secondary) !important;
        font-size:0.95rem;
        font-weight:700;
        padding:16px 0;
        border-bottom: 1px solid #f5f5f5;
        letter-spacing:0.8px;
        width:100%;
        display: flex;
        justify-content: space-between;
        align-items: center;
        text-transform: uppercase;
        position: relative;
    }
    /* Override desktop underline pseudo, use chevron instead */
    .nav-links > li:not(.menu-header):not(.mobile-actions) > a::after { 
        content: '\f105' !important; 
        font-family: 'Font Awesome 5 Free' !important; 
        font-weight: 900 !important;
        font-size: 0.85rem;
        color: #ccc;
        position: static !important;
        width: auto !important;
        height: auto !important;
        background: none !important;
        transition: all 0.2s ease;
        transform: none !important;
    }
    .nav-links > li:not(.menu-header):not(.mobile-actions) > a:hover { color: var(--primary) !important; padding-left: 6px; }
    .nav-links > li:not(.menu-header):not(.mobile-actions) > a:hover::after { color: var(--primary); }
    .nav-links > li:not(.menu-header):not(.mobile-actions) > a.active::after { color: var(--primary) !important; }

    /* Get Quote btn in mobile */
    .nav-links > li > a.btn {
        margin-top:8px; width:100%; justify-content:center !important;
        padding:12px 24px; font-size:0.95rem;
        border-radius: 12px;
        box-shadow: 0 8px 24px rgba(212,168,83,0.25);
        border-bottom: none !important;
        line-height: 1.5;
    }
    /* Hide chevron on btn */
    .nav-links > li > a.btn::after { display:none !important; }
    /* Mobile actions section padding */
    .mobile-actions { padding: 0 28px; }

    /* Show hamburger, hide it when menu is open (panel has its own × btn) */
    .menu-toggle { display:flex; z-index:1001; }
    body.menu-open .menu-toggle { opacity:0; pointer-events:none; }

    /* Overlay when menu is open */
    body.menu-open::after {
        content:''; position:fixed; inset:0;
        background:rgba(0,0,0,0.45); z-index:999; backdrop-filter:blur(3px);
    }

    /* ── Hero ── */
    .hero { height:100svh; min-height:600px; }
    .hero-content { padding:0 4px; }
    .hero h1 { font-size:2.2rem; line-height:1.15; margin-bottom:18px; }
    .hero h1 span { font-size:2rem; }
    .hero-badge { font-size:0.75rem; padding:8px 18px; margin-bottom:20px; }
    .hero-desc { font-size:0.95rem; margin-bottom:32px; line-height:1.7; }
    .hero-btns { flex-direction:column; gap:12px; align-items:flex-start; }
    .hero-btns .btn { width:100%; justify-content:center; padding:15px 24px; }
    .scroll-indicator { display:none; }

    /* ── Section headings ── */
    section { padding:72px 0; }
    .section-header { margin-bottom:48px; }
    .section-header h2 { font-size:1.85rem; }
    .section-header p  { font-size:0.95rem; }

    /* ── Services ── */
    .services-grid { grid-template-columns:1fr; gap:18px; }
    .service-card  { padding:34px 28px; }

    /* ── Stats ── */
    .stats-section { padding:72px 0; }
    .stats-grid { grid-template-columns:1fr 1fr; gap:16px; }
    .stat-card { padding:24px 16px; }
    .stat-card .stat-number { font-size:2.8rem; }

    /* ── About ── */
    .about-grid { grid-template-columns:1fr; gap:40px; }
    .about-content h2 { font-size:2rem; }
    .about-image .exp-badge { bottom:-12px; right:12px; padding:18px 22px; }
    .exp-badge h3 { font-size:2rem; }

    /* ── Gallery ── */
    .gallery-grid { grid-template-columns:1fr; gap:16px; }
    .gallery-item  { aspect-ratio:16/9; }
    .gallery-overlay { opacity:1; padding:20px; }

    /* ── Clients ── */
    .clients-section { padding:60px 0; }
    .client-item { padding:20px 36px; }
    .client-item h3 { font-size:1.2rem; }

    /* ── CTA ── */
    .cta-section { padding:72px 0; }
    .cta-section h2 { font-size:1.9rem; }
    .cta-section p  { font-size:1rem; }

    /* ── Contact & Forms ── */
    .contact-grid   { grid-template-columns:1fr; gap:32px; }
    .contact-form   { padding:28px 20px; border-radius:16px; }
    .form-row       { grid-template-columns:1fr; gap:0; }
    .quote-form-wrap { padding:28px 18px; border-radius:16px; }

    /* ── Page Header ── */
    .page-header { padding:110px 0 60px; }
    .page-header h1 { font-size:2rem; }
    .page-header p  { font-size:0.92rem; }
    .breadcrumb { font-size:0.82rem; flex-wrap:wrap; justify-content:center; gap:6px; }

    /* ── About page mission/vision inline grid fix ── */
    .mission-vision-grid { grid-template-columns:1fr !important; gap:20px !important; }
    /* Clients page 4-col → 2-col */
    .client-cards-grid { grid-template-columns:repeat(2,1fr) !important; gap:20px !important; }

    /* ── Contact page heading fix ── */
    .contact-grid > div:first-child h2 { font-size:1.8rem !important; }

    /* ── Footer ── */
    footer { padding:70px 0 0; }
    .footer-top { grid-template-columns:1fr; gap:36px; padding-bottom:40px; }
    .footer-col h4 { margin-bottom:16px; }
    .footer-col li  { margin-bottom:10px; }
    .footer-about p { font-size:0.9rem; }
    .social-links   { margin-top:18px; }

    /* ── Floating Buttons ── */
    .floating-btns { right:16px; bottom:20px; gap:10px; }
    .float-btn { width:50px; height:50px; font-size:1.15rem; }

    /* ── Loader ── */
    #loader img { height:80px; }
}

/* ── Small Mobile (≤480px) ── */
@media(max-width:480px) {
    .container { padding:0 16px; }
    .logo img { height:46px; }
    .navbar.scrolled .logo img { height:40px; }
    .navbar { padding:3px 0; }
    .page-header { padding:100px 0 50px; }
    .page-header h1 { font-size:1.7rem; }

    /* Hero */
    .hero h1 { font-size:1.85rem; }
    .hero h1 span { font-size:1.7rem; }
    .hero-badge { font-size:0.7rem; padding:7px 14px; letter-spacing:1px; }
    .hero-desc { font-size:0.88rem; }

    /* Sections */
    section { padding:60px 0; }
    .section-header h2 { font-size:1.6rem; }

    /* Stats */
    .stats-grid { grid-template-columns:1fr 1fr; gap:10px; }
    .stat-card .stat-number { font-size:2.4rem; }

    /* Services */
    .service-card { padding:28px 22px; }
    .service-card h3 { font-size:1.15rem; }

    /* About */
    .about-content h2 { font-size:1.7rem; }
    .exp-badge h3 { font-size:1.7rem; }

    /* Gallery */
    .gallery-grid { gap:12px; }

    /* CTA */
    .cta-section h2 { font-size:1.6rem; }

    /* Page headers */
    .page-header h1 { font-size:1.85rem; }

    /* Footer */
    .footer-bottom p { font-size:0.78rem; }

    /* Floating buttons — smaller */
    .floating-btns { right:12px; bottom:16px; gap:8px; }
    .float-btn { width:46px; height:46px; font-size:1.05rem; }
}

