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

:root {
    --primary: #8B0000;
    --primary-light: #B71C1C;
    --primary-dark: #4A0000;
    --secondary: #1A0A0D;
    --accent: #C9921A;
    --accent-light: #F0C060;
    --accent-glow: rgba(201,146,26,0.35);
    --dark: #080508;
    --text: #2a2a2a;
    --text-light: #777;
    --white: #ffffff;
    --off-white: #f9f7f5;
    --glass: rgba(255,255,255,0.07);
    --glass-border: rgba(255,255,255,0.13);
    --transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1);
    --transition-fast: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
    --shadow-sm: 0 4px 24px rgba(0,0,0,0.07);
    --shadow-md: 0 12px 48px rgba(0,0,0,0.12);
    --shadow-lg: 0 28px 72px rgba(0,0,0,0.18);
    --shadow-glow: 0 0 40px rgba(139,0,0,0.25);
    --radius-sm: 12px;
    --radius-md: 20px;
    --radius-lg: 32px;
    --radius-pill: 100px;
}

/* ── Reset & Base ── */
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
    font-family:'Outfit', '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:1260px; margin:0 auto; padding:0 28px; }
section { padding:130px 0; position:relative; overflow:hidden; }

/* ── Reveal Animations ── */
.reveal { opacity:0; transform:translateY(50px); transition: opacity 0.9s cubic-bezier(0.23,1,0.32,1), transform 0.9s cubic-bezier(0.23,1,0.32,1); }
.reveal.active { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-70px); transition: opacity 0.9s cubic-bezier(0.23,1,0.32,1), transform 0.9s cubic-bezier(0.23,1,0.32,1); }
.reveal-left.active { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(70px); transition: opacity 0.9s cubic-bezier(0.23,1,0.32,1), transform 0.9s cubic-bezier(0.23,1,0.32,1); }
.reveal-right.active { opacity:1; transform:translateX(0); }

/* ── Section Titles ── */
.section-header { text-align:center; margin-bottom:75px; }
.section-header .label {
    display:inline-flex; align-items:center; gap:10px;
    font-size:0.78rem; font-weight:700; letter-spacing:4px; text-transform:uppercase;
    color:var(--accent); margin-bottom:18px;
    background:linear-gradient(135deg, rgba(201,146,26,0.12), rgba(201,146,26,0.04));
    border:1px solid rgba(201,146,26,0.25);
    padding:7px 20px; border-radius:var(--radius-pill);
}
.section-header .label::before, .section-header .label::after { content:'—'; opacity:0.5; }
.section-header h2 { font-size:3rem; font-weight:800; color:var(--secondary); line-height:1.15; letter-spacing:-0.5px; }
.section-header p { max-width:580px; margin:20px auto 0; color:var(--text-light); font-size:1.05rem; line-height:1.8; }
.title-line { width:80px; height:3px; background:linear-gradient(90deg,var(--primary),var(--accent),transparent); margin:20px auto 0; border-radius:2px; }

/* ── Buttons ── */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    padding:16px 38px; font-weight:700; font-size:0.85rem;
    text-transform:uppercase; letter-spacing:2px;
    border:none; border-radius:var(--radius-pill); cursor:pointer;
    transition:var(--transition); position:relative; overflow:hidden; white-space:nowrap;
}
.btn::before {
    content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);
    transition:0.65s;
}
.btn:hover::before { left:120%; }
.btn-primary {
    background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
    color:var(--white);
    box-shadow:0 8px 32px rgba(139,0,0,0.35);
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(139,0,0,0.45); }
.btn-outline {
    border:2px solid rgba(255,255,255,0.45);
    color:var(--white); background:rgba(255,255,255,0.06);
    backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
}
.btn-outline:hover { background:var(--white); color:var(--primary); border-color:var(--white); transform:translateY(-3px); }
.btn-accent {
    background:linear-gradient(135deg,var(--accent) 0%,var(--accent-light) 100%);
    color:var(--secondary); font-weight:800;
    box-shadow:0 8px 32px rgba(201,146,26,0.3);
}
.btn-accent:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(201,146,26,0.45); }
.btn-brochure {
    background:linear-gradient(135deg,var(--accent) 0%,#e0a820 100%);
    color:var(--secondary); font-weight:800;
    box-shadow:0 8px 32px rgba(201,146,26,0.35);
    animation:brochure-pulse 3s ease-in-out infinite;
}
.btn-brochure:hover { transform:translateY(-4px) scale(1.04); box-shadow:0 16px 48px rgba(201,146,26,0.55); animation:none; }
@keyframes brochure-pulse {
    0%,100% { box-shadow:0 8px 32px rgba(201,146,26,0.35); }
    50% { box-shadow:0 8px 48px rgba(201,146,26,0.65), 0 0 0 8px rgba(201,146,26,0.08); }
}
.btn-ghost {
    background:transparent;
    border:2px solid rgba(139,0,0,0.2);
    color:var(--primary);
}
.btn-ghost:hover { background:var(--primary); color:var(--white); border-color:var(--primary); transform:translateY(-3px); }

/* ── Navbar ── */
.navbar {
    position:fixed; top:0; left:0; width:100%; z-index:1000;
    padding:8px 0;
    background:rgba(255,255,255,0.97);
    backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
    box-shadow:0 1px 0 rgba(0,0,0,0.07), 0 4px 30px rgba(0,0,0,0.06);
    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; gap:20px; }
.logo { display:flex; align-items:center; transition:var(--transition); }
.logo img { height:70px; transition:var(--transition); object-fit:contain; }
.navbar.scrolled .logo img { height:56px; }
.nav-links { display:flex; align-items:center; gap:32px; }
.nav-links a {
    font-weight:600; font-size:0.8rem; text-transform:uppercase; letter-spacing:1.8px;
    color:var(--text); position:relative; padding:6px 0;
}
.nav-links a::after {
    content:''; position:absolute; bottom:-2px; 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:12px 24px; font-size:0.75rem; }
.nav-links .btn::after { display:none !important; }
.menu-header { display:none; }
.menu-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:1001; }
.menu-toggle span { width:26px; height:2px; background:var(--text); transition:var(--transition); border-radius:2px; }
.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); }

/* Mobile action links */
.mobile-actions { display:none; flex-direction:column; gap:12px; width:100%; margin-top:28px; padding-top:28px; border-top:1px solid rgba(0,0,0,0.07); }
.menu-close-btn { display:none; }
.mobile-action-link {
    display:flex; align-items:center; justify-content:center; gap:12px;
    width:100%; padding:14px; border-radius:14px; color:var(--white) !important;
    font-weight:700; font-size:0.95rem; text-transform:uppercase; letter-spacing:1px;
    transition:all 0.3s ease; box-shadow:0 8px 24px rgba(0,0,0,0.15);
}
.mobile-action-link.call { background:linear-gradient(135deg,var(--primary),var(--primary-dark)); }
.mobile-action-link.whatsapp { background:linear-gradient(135deg,#25D366,#128C7E); }
.mobile-action-link i { font-size:1.1rem; }
.mobile-action-link:active { transform:scale(0.96); }

/* ── Hero ── */
.hero { height:100vh; min-height:680px; 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 2s ease; }
.hero-slide.active { opacity:1; }
.hero-slide img { width:100%; height:100%; object-fit:cover; transform-origin:center center; animation:none; }
.hero-slide.active img { animation:kenburns-1 9s ease-in-out forwards; }
.hero-slide:nth-child(2).active img { animation:kenburns-2 9s ease-in-out forwards; }
.hero-slide:nth-child(3).active img { animation:kenburns-3 9s ease-in-out forwards; }
.hero-slide:nth-child(4).active img { animation:kenburns-4 9s ease-in-out forwards; }
@keyframes kenburns-1 { 0%{transform:scale(1) translateX(0) translateY(0);} 100%{transform:scale(1.14) translateX(-2%) translateY(-1%);} }
@keyframes kenburns-2 { 0%{transform:scale(1.12) 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.12) translateX(-1%) translateY(1%);} }
@keyframes kenburns-4 { 0%{transform:scale(1.1) translateX(-2%) translateY(1%);} 100%{transform:scale(1) translateX(0) translateY(-1%);} }

.hero-overlay {
    position:absolute; inset:0;
    background:linear-gradient(160deg,rgba(26,10,13,0.88) 0%,rgba(139,0,0,0.62) 50%,rgba(0,0,0,0.5) 100%);
}
/* Diagonal shine line */
.hero-overlay::after {
    content:''; position:absolute; inset:0;
    background:linear-gradient(105deg, transparent 40%, rgba(201,146,26,0.05) 50%, transparent 60%);
}
.hero-particles { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.particle { position:absolute; width:2px; height:2px; background:rgba(201,146,26,0.5); border-radius:50%; animation:float-particle linear infinite; }
@keyframes float-particle { 0%{transform:translateY(100vh) rotate(0deg);opacity:0;} 10%{opacity:1;} 90%{opacity:0.8;} 100%{transform:translateY(-10vh) rotate(720deg);opacity:0;} }

.hero-content { position:relative; z-index:2; max-width:900px; animation:hero-enter 1.3s cubic-bezier(0.23,1,0.32,1) both; }
@keyframes hero-enter { 0%{opacity:0;transform:translateY(60px);} 100%{opacity:1;transform:translateY(0);} }
.hero-badge {
    display:inline-flex; align-items:center; gap:10px;
    background:rgba(255,255,255,0.08); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
    border:1px solid rgba(255,255,255,0.15);
    padding:10px 26px; border-radius:var(--radius-pill);
    color:var(--accent-light); font-size:0.82rem; font-weight:700;
    letter-spacing:2.5px; text-transform:uppercase; margin-bottom:32px;
    animation:hero-enter 1.3s 0.2s cubic-bezier(0.23,1,0.32,1) both;
}
.hero-badge i { color:var(--accent); }
.hero h1 {
    font-size:4.6rem; font-weight:900; color:var(--white);
    line-height:1.04; text-transform:uppercase; letter-spacing:-1px;
    margin-bottom:26px;
    animation:hero-enter 1.3s 0.35s cubic-bezier(0.23,1,0.32,1) both;
}
.hero h1 span {
    display:block;
    background:linear-gradient(90deg, var(--accent), var(--accent-light), var(--accent));
    background-size:200% 100%;
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
    animation:hero-enter 1.3s 0.35s cubic-bezier(0.23,1,0.32,1) both, shimmer-text 3s linear 1.5s infinite;
}
@keyframes shimmer-text { 0%{background-position:0% 50%;} 100%{background-position:200% 50%;} }
.hero-desc { font-size:1.15rem; color:rgba(255,255,255,0.78); max-width:600px; margin-bottom:48px; line-height:1.9; animation:hero-enter 1.3s 0.5s cubic-bezier(0.23,1,0.32,1) both; }
.hero-btns { display:flex; gap:16px; flex-wrap:wrap; animation:hero-enter 1.3s 0.65s cubic-bezier(0.23,1,0.32,1) both; }

/* Hero bottom stats bar */
.hero-stats-bar {
    position:absolute; bottom:0; left:0; right:0; z-index:3;
    background:linear-gradient(to right, rgba(26,10,13,0.92), rgba(74,0,0,0.88), rgba(26,10,13,0.92));
    backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
    border-top:1px solid rgba(201,146,26,0.2);
    display:flex; justify-content:center; gap:0; animation:hero-enter 1.3s 0.8s cubic-bezier(0.23,1,0.32,1) both;
}
.hero-stat { flex:1; max-width:220px; text-align:center; padding:20px 16px; border-right:1px solid rgba(255,255,255,0.07); }
.hero-stat:last-child { border-right:none; }
.hero-stat .h-num { font-size:2.2rem; font-weight:900; color:var(--accent); line-height:1; }
.hero-stat .h-label { font-size:0.72rem; color:rgba(255,255,255,0.55); text-transform:uppercase; letter-spacing:2px; margin-top:4px; }

.scroll-indicator { position:absolute; bottom:90px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:10px; color:rgba(255,255,255,0.4); font-size:0.72rem; 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:28px; }
.service-card {
    background:var(--white); padding:48px 36px; border-radius:var(--radius-md);
    position:relative; overflow:hidden; transition:var(--transition);
    border:1px solid rgba(0,0,0,0.05);
    box-shadow:var(--shadow-sm);
}
.service-card::before {
    content:''; position:absolute; top:0; left:0; width:100%; height:3px;
    background:linear-gradient(90deg,var(--primary),var(--accent));
    transform:scaleX(0); transform-origin:left; transition:var(--transition);
}
.service-card::after {
    content:''; position:absolute; top:0; right:0; width:120px; height:120px;
    background:radial-gradient(circle at top right, rgba(201,146,26,0.07), transparent 70%);
    pointer-events:none; transition:var(--transition);
}
.service-card:hover { transform:translateY(-16px); box-shadow:var(--shadow-lg); border-color:rgba(201,146,26,0.1); }
.service-card:hover::before { transform:scaleX(1); }
.service-card:hover::after { width:160px; height:160px; }
.service-num { position:absolute; top:30px; right:30px; font-size:3.5rem; font-weight:900; color:rgba(0,0,0,0.04); font-family:'Outfit',sans-serif; line-height:1; transition:var(--transition); }
.service-card:hover .service-num { color:rgba(139,0,0,0.06); }
.service-icon {
    width:68px; height:68px;
    background:linear-gradient(135deg,rgba(139,0,0,0.08),rgba(139,0,0,0.03));
    border-radius:16px; display:flex; align-items:center; justify-content:center;
    margin-bottom:26px; transition:var(--transition);
    border:1px solid rgba(139,0,0,0.06);
}
.service-icon i { font-size:1.7rem; color:var(--primary); transition:var(--transition); }
.service-card:hover .service-icon { background:linear-gradient(135deg,var(--primary),var(--primary-dark)); transform:rotate(-8deg) scale(1.12); border-color:transparent; box-shadow:0 8px 24px rgba(139,0,0,0.3); }
.service-card:hover .service-icon i { color:var(--white); }
.service-card h3 { font-size:1.25rem; font-weight:800; margin-bottom:12px; color:var(--secondary); }
.service-card p { color:var(--text-light); font-size:0.92rem; margin-bottom:24px; line-height:1.75; }
.service-link { display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--primary); font-size:0.85rem; text-transform:uppercase; letter-spacing:1px; }
.service-link i { transition:var(--transition); font-size:0.8rem; }
.service-card:hover .service-link i { transform:translateX(10px); }

/* ── Stats ── */
.stats-section {
    background:linear-gradient(140deg,var(--secondary) 0%,var(--primary-dark) 50%,var(--secondary) 100%);
    padding:110px 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 60 60"><rect fill="none" stroke="rgba(255,255,255,0.025)" stroke-width="1" width="60" height="60"/></svg>');
    background-size:60px;
}
.stats-section::after {
    content:''; position:absolute; top:-20%; left:-5%; width:500px; height:500px;
    background:radial-gradient(circle,rgba(201,146,26,0.12),transparent 65%);
    border-radius:50%; animation:orb-float 9s ease-in-out infinite; pointer-events:none;
}
@keyframes orb-float { 0%,100%{transform:translate(0,0);} 50%{transform:translate(4%,3%);} }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; z-index:1; }
.stat-card {
    text-align:center; padding:40px 20px;
    border-right:1px solid rgba(255,255,255,0.06);
    transition:var(--transition);
    position:relative; overflow:hidden;
}
.stat-card::before {
    content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
    width:0; height:2px; background:linear-gradient(90deg,var(--accent),var(--accent-light));
    transition:var(--transition);
}
.stat-card:hover::before { width:60%; }
.stat-card:last-child { border-right:none; }
.stat-card:hover { background:rgba(255,255,255,0.03); }
.stat-card .stat-number { font-size:3.8rem; font-weight:900; color:var(--accent); line-height:1; margin-bottom:10px; text-shadow:0 0 40px rgba(201,146,26,0.5); }
.stat-card p { color:rgba(255,255,255,0.6); text-transform:uppercase; font-size:0.8rem; font-weight:600; letter-spacing:2.5px; }

/* ── About Preview ── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:center; }
.about-image { position:relative; }
.about-image::before {
    content:''; position:absolute; top:30px; left:30px; right:-30px; bottom:-30px;
    border:2px solid rgba(201,146,26,0.25); border-radius:var(--radius-md);
    z-index:0; transition:var(--transition);
}
.about-image:hover::before { top:20px; left:20px; right:-20px; bottom:-20px; }
.about-image img { border-radius:var(--radius-md); box-shadow:var(--shadow-lg); position:relative; z-index:1; transition:transform 0.7s cubic-bezier(0.23,1,0.32,1), box-shadow 0.7s ease; }
.about-image:hover img { transform:scale(1.02) translateY(-6px); box-shadow:0 40px 90px rgba(0,0,0,0.22); }
.about-image .exp-badge {
    position:absolute; bottom:-20px; right:-20px; z-index:2;
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    color:var(--white); padding:28px 32px; border-radius:var(--radius-md);
    text-align:center; box-shadow:var(--shadow-md);
    animation:badge-float 4.5s ease-in-out infinite;
    border:2px solid rgba(201,146,26,0.2);
}
@keyframes badge-float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-12px);} }
.exp-badge h3 { font-size:2.6rem; font-weight:900; line-height:1; color:var(--accent); }
.exp-badge p { font-size:0.78rem; text-transform:uppercase; letter-spacing:2px; margin-top:6px; opacity:0.8; }
.about-content h2 { font-size:2.6rem; font-weight:800; color:var(--secondary); margin-bottom:22px; line-height:1.18; letter-spacing:-0.5px; }
.about-content > p { color:var(--text-light); margin-bottom:32px; font-size:1.02rem; line-height:1.85; }
.feature-list { margin-bottom:38px; display:grid; grid-template-columns:1fr 1fr; gap:12px 20px; }
.feature-item { display:flex; align-items:center; gap:12px; padding:10px 0; transition:transform 0.3s ease; }
.feature-item:hover { transform:translateX(5px); }
.feature-item .check {
    width:26px; height:26px;
    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.65rem; flex-shrink:0; transition:transform 0.3s ease;
}
.feature-item:hover .check { transform:scale(1.2) rotate(12deg); }
.feature-item span { font-weight:600; color:var(--text); font-size:0.9rem; }

/* ── Client Slider ── */
.clients-section { background:var(--off-white); padding:90px 0; overflow:hidden; }
.client-slider { display:flex; width:max-content; animation:slide-clients 28s linear infinite; align-items:center; }
.client-slider:hover { animation-play-state:paused; }
.client-item { padding:28px 60px; display:flex; align-items:center; justify-content:center; }
.client-logo-img {
    height:58px; width:auto; max-width:190px; object-fit:contain;
    filter:grayscale(100%) opacity(0.55); transition:var(--transition);
}
.client-item:hover .client-logo-img { filter:grayscale(0%) opacity(1); transform:scale(1.1); }
@keyframes slide-clients { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }

/* ── Gallery ── */
.gallery-filter { display:flex; justify-content:center; gap:10px; margin-bottom:55px; flex-wrap:wrap; }
.filter-btn {
    padding:11px 28px; border:2px solid rgba(0,0,0,0.1);
    background:var(--white); cursor:pointer; font-weight:700; font-size:0.8rem;
    text-transform:uppercase; letter-spacing:1.5px; border-radius:var(--radius-pill);
    transition:var(--transition); font-family:'Outfit',sans-serif; color:var(--text-light);
}
.filter-btn.active, .filter-btn:hover { background:var(--primary); color:var(--white); border-color:var(--primary); box-shadow:0 8px 24px rgba(139,0,0,0.25); }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.gallery-item { position:relative; overflow:hidden; border-radius:var(--radius-md); cursor:pointer; aspect-ratio:4/3; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.85s cubic-bezier(0.23,1,0.32,1); }
.gallery-overlay {
    position:absolute; inset:0;
    background:linear-gradient(to top,rgba(26,10,13,0.97) 0%,rgba(139,0,0,0.45) 50%,transparent 100%);
    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.14); }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay h3 { font-size:1.15rem; font-weight:700; margin-bottom:5px; }
.gallery-overlay p { font-size:0.82rem; color:var(--accent); font-weight:600; letter-spacing:1px; text-transform:uppercase; }

/* ── Brochure Download CTA ── */
.brochure-section {
    background:linear-gradient(135deg,var(--secondary) 0%,var(--primary-dark) 100%);
    padding:80px 0; position:relative; overflow:hidden;
}
.brochure-section::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(ellipse at 30% 50%,rgba(201,146,26,0.12) 0%,transparent 60%),
               radial-gradient(ellipse at 80% 50%,rgba(139,0,0,0.2) 0%,transparent 60%);
}
.brochure-content { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.brochure-text .label { color:var(--accent); margin-bottom:16px; }
.brochure-text h2 { font-size:2.4rem; font-weight:900; color:var(--white); letter-spacing:-0.5px; margin-bottom:14px; }
.brochure-text p { color:rgba(255,255,255,0.65); font-size:1rem; max-width:480px; line-height:1.8; }
.brochure-actions { display:flex; gap:14px; flex-shrink:0; flex-wrap:wrap; }
.brochure-icon-badge {
    width:90px; height:90px; border-radius:22px;
    background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.12);
    backdrop-filter:blur(10px); display:flex; align-items:center; justify-content:center;
    flex-shrink:0; animation:badge-float 5s ease-in-out infinite;
}
.brochure-icon-badge i { font-size:2.6rem; color:var(--accent); }

/* ── Contact ── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:70px; }
.contact-info-card { display:flex; gap:22px; align-items:flex-start; padding:28px 0; border-bottom:1px solid rgba(0,0,0,0.06); }
.contact-icon {
    width:58px; height:58px;
    background:linear-gradient(135deg,rgba(139,0,0,0.09),rgba(139,0,0,0.03));
    border-radius:16px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
    border:1px solid rgba(139,0,0,0.07);
    transition:var(--transition);
}
.contact-icon i { font-size:1.2rem; color:var(--primary); }
.contact-info-card:hover .contact-icon { background:var(--primary); border-color:var(--primary); }
.contact-info-card:hover .contact-icon i { color:var(--white); }
.contact-info-card h4 { font-size:0.82rem; text-transform:uppercase; letter-spacing:2px; margin-bottom:6px; color:var(--secondary); font-weight:700; }
.contact-info-card p { color:var(--text-light); font-size:0.95rem; line-height:1.7; }
.contact-form { background:var(--white); padding:56px; border-radius:var(--radius-lg); box-shadow:var(--shadow-md); border:1px solid rgba(0,0,0,0.05); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.form-group { margin-bottom:24px; }
.form-group label { display:block; margin-bottom:9px; font-weight:700; font-size:0.83rem; color:var(--secondary); letter-spacing:0.5px; text-transform:uppercase; }
.form-group input, .form-group select, .form-group textarea {
    width:100%; padding:15px 20px; border:2px solid rgba(0,0,0,0.07); border-radius:var(--radius-sm);
    font-size:0.95rem; font-family:'Outfit',sans-serif; transition:var(--transition);
    background:var(--off-white); color:var(--text);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    outline:none; border-color:var(--primary); background:var(--white);
    box-shadow:0 0 0 4px rgba(139,0,0,0.07);
}
.form-group textarea { height:150px; resize:vertical; }

/* ── Page Header ── */
.page-header { padding:190px 0 110px; 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(160deg,rgba(26,10,13,0.94),rgba(139,0,0,0.75),rgba(0,0,0,0.55));
}
.page-header .container { position:relative; z-index:1; }
.page-header .label { display:inline-block; font-size:0.75rem; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--accent); margin-bottom:16px; }
.page-header h1 { font-size:3.8rem; font-weight:900; text-transform:uppercase; margin-bottom:16px; letter-spacing:-1px; }
.page-header p { font-size:1.1rem; color:rgba(255,255,255,0.65); }
.breadcrumb { display:flex; justify-content:center; gap:10px; margin-top:22px; font-size:0.88rem; color:rgba(255,255,255,0.45); }
.breadcrumb a { color:var(--accent); }

/* ── CTA Banner ── */
.cta-section {
    background:linear-gradient(140deg,var(--primary-dark) 0%,var(--primary) 50%,var(--primary-dark) 100%);
    padding:110px 0; text-align:center; position:relative; overflow:hidden;
}
.cta-section::before {
    content:''; position:absolute; top:-40%; right:-10%; width:600px; height:600px;
    background:radial-gradient(circle,rgba(201,146,26,0.18),transparent 65%); border-radius:50%;
}
.cta-section::after {
    content:''; position:absolute; bottom:-40%; left:-10%; width:500px; height:500px;
    background:radial-gradient(circle,rgba(255,255,255,0.04),transparent 65%); border-radius:50%;
}
.cta-section h2 { font-size:3rem; color:var(--white); font-weight:900; margin-bottom:20px; position:relative; z-index:1; letter-spacing:-0.5px; }
.cta-section p { color:rgba(255,255,255,0.65); font-size:1.1rem; margin-bottom:44px; position:relative; z-index:1; }
.cta-btns { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; position:relative; z-index:1; }

/* ── Footer ── */
footer {
    background:var(--secondary);
    color:rgba(255,255,255,0.75);
    padding:100px 0 0;
    position:relative;
    overflow:hidden;
}
footer::before {
    content:''; position:absolute; top:0; left:0; right:0; height:3px;
    background:linear-gradient(90deg,var(--primary),var(--accent),var(--primary));
}
.footer-top { display:grid; grid-template-columns:2.2fr 1fr 1fr 1.3fr; gap:56px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,0.06); }
.footer-about p { color:rgba(255,255,255,0.5); margin:20px 0; font-size:0.93rem; line-height:1.8; }
.footer-col h4 { font-size:0.85rem; font-weight:700; text-transform:uppercase; letter-spacing:2.5px; margin-bottom:28px; color:var(--accent); }
.footer-col li { margin-bottom:14px; }
.footer-col li a { color:rgba(255,255,255,0.45); font-size:0.9rem; transition:var(--transition); }
.footer-col li a:hover { color:var(--accent); padding-left:8px; }
.footer-col .contact-line { display:flex; align-items:flex-start; gap:14px; margin-bottom:20px; color:rgba(255,255,255,0.5); font-size:0.9rem; }
.footer-col .contact-line i { color:var(--accent); margin-top:4px; flex-shrink:0; }
.footer-col .contact-line a { color:rgba(255,255,255,0.5); }
.footer-col .contact-line a:hover { color:var(--accent); }
.social-links { display:flex; gap:10px; margin-top:28px; }
.social-links a {
    width:42px; height:42px;
    background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08);
    display:flex; align-items:center; justify-content:center; border-radius:10px;
    color:rgba(255,255,255,0.4); transition:var(--transition);
}
.social-links a:hover { background:var(--primary); border-color:var(--primary); color:var(--white); transform:translateY(-3px); }
.footer-bottom {
    padding:28px 0; text-align:center;
    border-top:1px solid rgba(255,255,255,0.05);
    display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
}
.footer-bottom p { color:rgba(255,255,255,0.3); font-size:0.82rem; }
.footer-bottom a { color:var(--accent); }

/* Brochure footer link */
.footer-brochure-link {
    display:inline-flex; align-items:center; gap:8px;
    color:var(--accent); font-size:0.85rem; font-weight:700;
    border:1px solid rgba(201,146,26,0.3);
    padding:8px 20px; border-radius:var(--radius-pill);
    transition:var(--transition);
}
.footer-brochure-link:hover { background:var(--accent); color:var(--secondary); border-color:var(--accent); }

/* ── Floating Buttons ── */
.floating-btns { position:fixed; right:24px; bottom:24px; display:flex; flex-direction:column; gap:12px; z-index:999; }
.float-btn { width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--white); font-size:1.25rem; box-shadow:0 8px 28px rgba(0,0,0,0.28); transition:var(--transition); }
.float-btn:hover { transform:translateY(-5px) scale(1.12); }
.whatsapp-btn { background:linear-gradient(135deg,#25d366,#1aaa52); }
.call-btn { background:linear-gradient(135deg,var(--primary),var(--primary-dark)); }
.quote-btn { background:linear-gradient(135deg,var(--accent),var(--accent-light)); 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.6s ease; }
#loader img { height:64px; margin-bottom:32px; }
.loader-bar { width:220px; height:3px; background:rgba(0,0,0,0.08); 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.4s 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:64px; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); border:1px solid rgba(0,0,0,0.05); }

/* ── Why Choose Us (new section) ── */
.why-section { background:var(--white); }
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.why-card {
    padding:40px 28px; border-radius:var(--radius-md); text-align:center;
    background:var(--off-white); border:1px solid rgba(0,0,0,0.05);
    transition:var(--transition); position:relative; overflow:hidden;
}
.why-card::before {
    content:''; position:absolute; bottom:0; left:0; right:0; height:0;
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    transition:var(--transition); z-index:0;
}
.why-card:hover::before { height:100%; }
.why-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent; }
.why-icon { position:relative; z-index:1; width:72px; height:72px; border-radius:18px; background:linear-gradient(135deg,rgba(139,0,0,0.1),rgba(139,0,0,0.03)); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; transition:var(--transition); }
.why-icon i { font-size:1.8rem; color:var(--primary); transition:var(--transition); }
.why-card:hover .why-icon { background:rgba(255,255,255,0.15); }
.why-card:hover .why-icon i { color:var(--accent); }
.why-card h3 { font-size:1.05rem; font-weight:800; color:var(--secondary); margin-bottom:10px; position:relative; z-index:1; transition:var(--transition); }
.why-card p { font-size:0.88rem; color:var(--text-light); line-height:1.75; position:relative; z-index:1; transition:var(--transition); }
.why-card:hover h3, .why-card:hover p { color:var(--white); }
.why-card:hover p { color:rgba(255,255,255,0.75); }

/* ── Clients page grid ── */
.grid-client-logo { height:48px; width:auto; max-width:140px; fill:var(--primary); transition:var(--transition); }
.grid-client-logo-img { height:55px; width:auto; max-width:150px; object-fit:contain; transition:var(--transition); }

/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */

@media(max-width:1100px) {
    .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
    .why-grid { grid-template-columns:repeat(2,1fr); }
}

@media(max-width:1024px) {
    .container { padding:0 22px; }
    .logo img { height:62px; }
    .hero h1 { font-size:3.4rem; }
    .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); }
    .about-grid { gap:60px; }
    .contact-grid { gap:44px; }
    .cta-section h2 { font-size:2.4rem; }
    .feature-list { grid-template-columns:1fr; }
    section { padding:110px 0; }
    .brochure-content { flex-direction:column; text-align:center; }
    .brochure-text p { margin:0 auto; }
    .brochure-icon-badge { display:none; }
}

@media(max-width:768px) {
    .navbar { padding:4px 0; }
    .navbar.scrolled { padding:2px 0; }
    .logo img { height:52px; }
    .navbar.scrolled .logo img { height:44px; }
    .mobile-actions { display:flex; }
    .menu-toggle { display:flex; margin-left:6px; transition:opacity 0.2s ease; }
    .nav-links {
        position:fixed; top:0; right:-100%; width:84%; max-width:330px; height:100vh;
        background:#ffffff; flex-direction:column;
        align-items:stretch; padding:0 0 40px; gap:0;
        transition:right 0.45s cubic-bezier(0.16,1,0.3,1);
        box-shadow:-12px 0 60px rgba(0,0,0,0.2); z-index:1000; overflow-y:auto;
    }
    .nav-links.active { right:0; }
    .menu-header { display:flex; align-items:center; justify-content:space-between; padding:22px 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-links > li:not(.menu-header):not(.mobile-actions) { padding:0 28px; }
    .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 li:nth-child(9){ animation-delay:0.43s; }
    .nav-links.active .mobile-actions { animation-delay:0.48s; }
    @keyframes slideInMenu { from{opacity:0;transform:translateX(24px);} to{opacity:1;transform:translateX(0);} }
    .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; }
    .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 > a.btn { margin-top:8px; width:100%; justify-content:center !important; padding:13px 24px; font-size:0.9rem; border-radius:12px; box-shadow:0 8px 24px rgba(201,146,26,0.25); border-bottom:none !important; }
    .nav-links > li > a.btn::after { display:none !important; }
    .mobile-actions { padding:0 28px; }
    body.menu-open .menu-toggle { opacity:0; pointer-events:none; }
    body.menu-open::after { content:''; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:999; backdrop-filter:blur(4px); }

    .hero { height:100svh; min-height:640px; }
    .hero .container { padding-bottom:140px; }
    .hero h1 { font-size:2.3rem; line-height:1.12; margin-bottom:18px; }
    .hero h1 span { font-size:2.1rem; }
    .hero-badge { font-size:0.73rem; padding:8px 18px; margin-bottom:22px; }
    .hero-desc { font-size:0.95rem; margin-bottom:28px; }
    .hero-btns { flex-direction:column; gap:12px; align-items:stretch; width:100%; }
    .hero-btns .btn { width:100%; justify-content:center; padding:15px 24px; }
    .hero-stats-bar { flex-wrap:wrap; }
    .hero-stat { min-width:50%; border-bottom:1px solid rgba(255,255,255,0.07); }
    .scroll-indicator { display:none; }

    section { padding:80px 0; }
    .section-header { margin-bottom:52px; }
    .section-header h2 { font-size:1.9rem; }
    .section-header p { font-size:0.93rem; }

    .services-grid { grid-template-columns:1fr; gap:18px; }
    .service-card { padding:36px 28px; }

    .stats-section { padding:80px 0; }
    .stats-grid { grid-template-columns:1fr 1fr; gap:0; }
    .stat-card { padding:28px 14px; }
    .stat-card .stat-number { font-size:3rem; }

    .about-grid { grid-template-columns:1fr; gap:50px; }
    .about-image::before { display:none; }
    .about-image .exp-badge { bottom:-12px; right:12px; padding:20px 24px; }
    .exp-badge h3 { font-size:2rem; }
    .about-content h2 { font-size:2rem; }

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

    .why-grid { grid-template-columns:1fr 1fr; gap:16px; }
    .why-card { padding:28px 18px; }

    .clients-section { padding:60px 0; }
    .client-item { padding:20px 36px; }

    .cta-section { padding:80px 0; }
    .cta-section h2 { font-size:2rem; }
    .cta-btns { flex-direction:column; align-items:center; }

    .contact-grid { grid-template-columns:1fr; gap:36px; }
    .contact-form { padding:30px 22px; border-radius:var(--radius-md); }
    .form-row { grid-template-columns:1fr; gap:0; }
    .quote-form-wrap { padding:30px 20px; border-radius:var(--radius-md); }

    .page-header { padding:130px 0 70px; }
    .page-header h1 { font-size:2.2rem; }
    .page-header p { font-size:0.92rem; }
    .breadcrumb { font-size:0.82rem; flex-wrap:wrap; justify-content:center; gap:6px; }

    .mission-vision-grid { grid-template-columns:1fr !important; gap:20px !important; }
    .client-cards-grid { grid-template-columns:repeat(2,1fr) !important; gap:20px !important; }
    .contact-grid > div:first-child h2 { font-size:1.8rem !important; }

    footer { padding:70px 0 0; }
    .footer-top { grid-template-columns:1fr; gap:36px; padding-bottom:44px; }
    .footer-bottom { flex-direction:column; text-align:center; }
    .social-links { margin-top:18px; }

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

    .brochure-content { flex-direction:column; text-align:center; }
    .brochure-text p { margin:0 auto; }
    .brochure-text h2 { font-size:1.9rem; }
}

@media(max-width:480px) {
    .container { padding:0 16px; }
    .logo img { height:46px; }
    .navbar.scrolled .logo img { height:40px; }
    .page-header { padding:110px 0 60px; }
    .page-header h1 { font-size:1.8rem; }
    .hero h1 { font-size:1.95rem; }
    .hero h1 span { font-size:1.8rem; }
    .hero-badge { font-size:0.68rem; padding:7px 14px; }
    .hero-desc { font-size:0.88rem; }
    .hero .container { padding-bottom:150px; }
    section { padding:64px 0; }
    .section-header h2 { font-size:1.65rem; }
    .stats-grid { grid-template-columns:1fr 1fr; }
    .stat-card .stat-number { font-size:2.6rem; }
    .service-card { padding:30px 22px; }
    .service-card h3 { font-size:1.1rem; }
    .about-content h2 { font-size:1.8rem; }
    .exp-badge h3 { font-size:1.8rem; }
    .gallery-grid { gap:12px; }
    .cta-section h2 { font-size:1.65rem; }
    .why-grid { grid-template-columns:1fr; }
    .footer-bottom p { font-size:0.78rem; }
    .floating-btns { right:12px; bottom:16px; gap:8px; }
    .float-btn { width:46px; height:46px; font-size:1.05rem; }
}

/* ── Global Square Grid Background ── */
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    pointer-events: none;
    background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 50"><rect fill="none" stroke="rgba(0,0,0,0.03)" stroke-width="1" width="50" height="50"/></svg>');
    background-size: 50px 50px;
}


