@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Outfit:wght@300;400;500;600;700;800&display=swap');
:root{--gold:#F5C518;--gold-light:#FFDD57;--gold-dim:rgba(245,197,24,0.15);--bg:#0A0A0A;--bg2:#111111;--bg3:#161616;--border:rgba(245,197,24,0.12);--text:#FFFFFF;--text2:#9CA3AF;--text3:#6B7280;--radius:16px;--radius-lg:36px;--shadow:0 8px 40px rgba(0,0,0,0.6);--transition:0.3s cubic-bezier(0.4,0,0.2,1)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Inter',sans-serif;font-weight:700;line-height:1.1;letter-spacing:-0.03em}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:130px 0}
.section-sm{padding:60px 0}
.gold{color:var(--gold)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:50px;font-family:'Inter',sans-serif;font-weight:600;font-size:15px;cursor:pointer;transition:var(--transition);border:none;text-decoration:none}
.btn-primary{background:var(--gold);color:#0A0A0A}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 12px 40px rgba(245,197,24,0.4)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid rgba(255,255,255,0.2)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.tag{display:inline-block;padding:4px 14px;border-radius:50px;font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;background:var(--gold-dim);color:var(--gold);border:1px solid var(--border)}
.section-label{display:table;margin:0 auto 16px;text-align:center}
.section-title{font-size:clamp(44px,7vw,72px);text-align:center;margin-bottom:20px;letter-spacing:-0.04em;line-height:1.05}
.section-subtitle{text-align:center;color:var(--text2);font-size:18px;max-width:600px;margin:0 auto 60px}
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;transition:var(--transition)}
.card:hover{border-color:rgba(245,197,24,0.4);box-shadow:0 20px 60px rgba(245,197,24,0.08);transform:translateY(-4px)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
/* BENTO GRIDS */
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(320px,auto);gap:24px}
.bento-col-2{grid-column:span 2}
.bento-row-2{grid-row:span 2}
/* PILL INLINE */
.inline-pill{display:inline-block;vertical-align:middle;height:clamp(40px,6vw,60px);width:clamp(80px,12vw,140px);border-radius:50px;background:var(--bg3);margin:0 8px;overflow:hidden;border:1px solid var(--border)}
.inline-pill img, .inline-pill video{width:100%;height:100%;object-fit:cover;opacity:0.8}
/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;background:var(--bg);border-bottom:1px solid rgba(255,255,255,0.05);transition:var(--transition)}
.nav.scrolled{background:rgba(10,10,10,0.95);backdrop-filter:blur(20px);padding:14px 0;border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:84px;width:auto}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--text2);transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-actions{display:flex;align-items:center;gap:16px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--text);transition:var(--transition);display:block}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--bg);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:32px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:28px;font-weight:700;color:var(--text);transition:var(--transition)}
.mobile-menu a:hover{color:var(--gold)}
/* PRELOADER */
#preloader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity 0.8s cubic-bezier(0.4,0,0.2,1), visibility 0.8s cubic-bezier(0.4,0,0.2,1)}
#preloader.hide{opacity:0;visibility:hidden}
.loader-content{display:flex;flex-direction:column;align-items:center;gap:30px}
.loader-text{font-family:'Inter',sans-serif;font-size:clamp(20px, 3.5vw, 32px);font-weight:700;color:var(--text);text-align:center;animation:loaderPulse 2s infinite;letter-spacing:0.02em}
.loader-progress{width:160px;height:2px;background:rgba(255,255,255,0.1);border-radius:2px;overflow:hidden;position:relative}
.loader-progress-bar{position:absolute;top:0;left:0;height:100%;width:0;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:loaderProgress 2s ease-in-out infinite}
@keyframes loaderPulse{0%,100%{opacity:0.6;transform:scale(0.98)}50%{opacity:1;transform:scale(1.02)}}
@keyframes loaderProgress{0%{width:0;left:0}50%{width:100%;left:0}100%{width:100%;left:100%}}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:100px}
.hero-bg{position:absolute;inset:0;z-index:0;background:var(--bg)}
.hero-bg video{width:100%;height:100%;object-fit:cover;opacity:0.6;filter:saturate(1.2)}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at center, rgba(10,10,10,0.3) 0%, #0A0A0A 100%), linear-gradient(to bottom, rgba(10,10,10,0.6) 0%, transparent 40%, rgba(10,10,10,0.8) 100%)}
.hero-content{position:relative;z-index:1;width:100%;max-width:900px;display:flex;flex-direction:column;align-items:center;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:50px;background:var(--gold-dim);border:1px solid var(--border);font-size:13px;color:var(--gold);font-weight:600;margin-bottom:28px}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.5)}}
.hero h1{font-size:clamp(30px,4.5vw,52px);font-weight:800;line-height:1.2;margin-bottom:24px;letter-spacing:-0.01em;text-align:center}
.hero h1 span{color:var(--gold)}
.hero-sub{font-size:18px;color:var(--text2);max-width:640px;margin-bottom:40px;line-height:1.7;text-align:center}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.hero-stats{display:flex;gap:64px;margin-top:64px;padding-top:40px;border-top:1px solid rgba(255,255,255,0.08);justify-content:center;width:100%}
.hero-stat{text-align:center}
.hero-stat span{font-size:28px;font-weight:800;color:var(--gold);display:block}
.hero-stat p{font-size:12px;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em}
/* TRUST BAR */
.trust-bar{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 0;overflow:hidden;margin-bottom:60px}
.trust-track{display:flex;gap:60px;animation:marquee 28s linear infinite;width:max-content}
.trust-track:hover{animation-play-state:paused}
.trust-item{display:flex;align-items:center;gap:10px;white-space:nowrap;font-size:13px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.06em}
.trust-item svg{color:var(--gold);flex-shrink:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* SERVICES */
.service-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;transition:var(--transition);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:var(--transition)}
.service-card:hover::before{opacity:1}
.service-card:hover{border-color:rgba(245,197,24,0.35);transform:translateY(-6px);box-shadow:0 24px 60px rgba(245,197,24,0.08)}
.service-icon{width:56px;height:56px;border-radius:14px;background:var(--gold-dim);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.service-icon svg{color:var(--gold)}
.service-card h3{font-size:19px;margin-bottom:12px}
.service-card p{color:var(--text2);font-size:15px;line-height:1.7;margin-bottom:20px}
.service-link{color:var(--gold);font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.service-link:hover{gap:12px}
/* USP */
.usp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.usp-item{background:var(--bg);padding:40px;transition:var(--transition);border-radius:var(--radius-lg);border:1px solid var(--border)}
.usp-item:hover{background:var(--bg3);border-color:rgba(245,197,24,0.3);transform:translateY(-4px);box-shadow:0 20px 40px rgba(245,197,24,0.05)}
.usp-number{font-size:13px;font-weight:700;color:var(--gold);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:16px;background:var(--gold-dim);display:inline-block;padding:6px 14px;border-radius:50px}
.usp-item h3{font-size:22px;margin-bottom:12px}
.usp-item p{color:var(--text2);font-size:15px;line-height:1.7}
/* STEPS */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.steps-grid::before{content:'';position:absolute;top:56px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);z-index:0}
.step{text-align:center;padding:24px;position:relative;z-index:1}
.step-num{width:64px;height:64px;border-radius:50%;background:var(--gold);color:#0A0A0A;font-family:'Inter',sans-serif;font-weight:900;font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.step h3{font-size:16px;margin-bottom:8px}
.step p{color:var(--text2);font-size:14px}
/* TESTIMONIALS */
.testimonials-track{display:flex;gap:24px;width:max-content;animation:testimonialMarquee 20s linear infinite}
.testimonials-track:hover{animation-play-state:paused}
@keyframes testimonialMarquee{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 12px))}}
.testimonial-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;min-width:360px;flex-shrink:0}
.testimonial-stars{color:var(--gold);font-size:16px;margin-bottom:16px;letter-spacing:2px}
.testimonial-card blockquote{color:var(--text2);font-size:15px;line-height:1.75;font-style:italic;margin-bottom:20px}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--gold-dim);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--gold);font-family:'Inter',sans-serif;font-size:16px}
.testimonial-author strong{font-size:14px;display:block}
.testimonial-author span{font-size:12px;color:var(--text3)}
/* CASE STUDIES */
.case-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}
.case-card:hover{border-color:rgba(245,197,24,0.4);transform:translateY(-4px)}
.case-card-header{padding:28px;background:linear-gradient(135deg,var(--bg3),var(--bg2));border-bottom:1px solid var(--border)}
.case-outcome{display:inline-block;padding:6px 14px;border-radius:50px;background:rgba(245,197,24,0.1);color:var(--gold);font-size:12px;font-weight:700;border:1px solid var(--border)}
.case-card-body{padding:28px}
.case-card-body h3{font-size:18px;margin-bottom:8px}
.case-card-body p{color:var(--text2);font-size:14px;line-height:1.7}
/* BLOG */
.blog-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}
.blog-card:hover{border-color:rgba(245,197,24,0.3);transform:translateY(-4px)}
.blog-card-img{height:200px;object-fit:cover;width:100%}
.blog-card-body{padding:28px}
.blog-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.blog-tag{font-size:11px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:0.08em}
.blog-date{font-size:12px;color:var(--text3)}
.blog-card-body h3{font-size:18px;margin-bottom:10px;line-height:1.4}
.blog-card-body p{color:var(--text2);font-size:14px;line-height:1.7;margin-bottom:20px}
/* CTA SECTION */
.cta-section{background:linear-gradient(135deg,#111111 0%,#0d0d0d 100%);border:1px solid var(--border);text-align:center;padding:110px 0;position:relative;overflow:hidden;border-radius:40px;margin:0 24px 60px 24px}
.cta-section::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(245,197,24,0.06) 0%,transparent 70%);pointer-events:none}
.cta-section h2{font-size:clamp(32px,5vw,52px);margin-bottom:20px}
.cta-section p{color:var(--text2);font-size:18px;max-width:560px;margin:0 auto 40px}
/* FOOTER */
.footer{background:var(--bg2);border:1px solid var(--border);border-radius:40px;padding:80px 40px 40px;margin:0 24px 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.footer-logo img{height:48px;margin-bottom:16px}
.footer-logo p{color:var(--text2);font-size:14px;line-height:1.7;max-width:280px}
.footer-col h4{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--text);margin-bottom:20px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{color:var(--text2);font-size:14px;transition:var(--transition)}
.footer-col ul a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--border);padding-top:28px;display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{color:var(--text3);font-size:13px}
/* FLOATING BUTTONS */
.fab-group{position:fixed;bottom:32px;right:32px;z-index:900;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);border:none;text-decoration:none}
.fab-whatsapp{background:#25D366;box-shadow:0 4px 20px rgba(37,211,102,0.4)}
.fab-whatsapp:hover{background:#20BD5A;transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,0.5)}
.fab-top{background:var(--bg2);border:1px solid var(--border);color:var(--text)}
.fab-top:hover{border-color:var(--gold);color:var(--gold);transform:scale(1.1)}
/* TRANSLATE */
.translate-wrapper{position:relative;display:inline-block}
.translate-btn{background:var(--bg2);border:1px solid var(--border);color:var(--text2);padding:8px 16px;border-radius:50px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:var(--transition)}
.translate-btn:hover{border-color:var(--gold);color:var(--gold)}
.translate-menu{position:absolute;top:calc(100% + 10px);right:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:8px 0;min-width:140px;opacity:0;pointer-events:none;transform:translateY(-10px);transition:var(--transition);z-index:1000}
.translate-menu.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.translate-menu button{display:block;width:100%;text-align:left;padding:8px 16px;background:none;border:none;color:var(--text2);font-size:13px;font-family:'Outfit',sans-serif;cursor:pointer;transition:var(--transition)}
.translate-menu button:hover{background:var(--gold-dim);color:var(--gold)}
#google_translate_element{position:absolute!important;top:-10000px!important;left:-10000px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important}
.goog-te-banner-frame, .goog-tooltip, .goog-tooltip:hover, .goog-text-highlight, #goog-gt-tt {display:none!important;visibility:hidden!important}
body{top:0!important;position:static!important}
/* ANIMATIONS */
.fade-up{opacity:0;transform:translateY(40px);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-in{opacity:0;transition:opacity 0.7s ease}
.fade-in.visible{opacity:1}
.stagger-1{transition-delay:0.1s}
.stagger-2{transition-delay:0.2s}
.stagger-3{transition-delay:0.3s}
.stagger-4{transition-delay:0.4s}
.stagger-5{transition-delay:0.5s}
.stagger-6{transition-delay:0.6s}

/* CURSOR */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);border-radius:50%;display:none;will-change:top, left}
@media(min-width: 1024px) {
  body, a, button, .service-card, .btn { cursor: none !important; }
  .cursor-dot,.cursor-ring{display:block}
}
.cursor-dot{width:8px;height:8px;background:var(--gold);transition:opacity 0.2s}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--gold);transition:width 0.3s cubic-bezier(0.4,0,0.2,1), height 0.3s cubic-bezier(0.4,0,0.2,1), background 0.3s, border-color 0.3s, opacity 0.2s}
.cursor-ring.hover{width:64px;height:64px;background:rgba(245,197,24,0.1);border-color:transparent;backdrop-filter:blur(2px)}
/* PAGE HERO */
.page-hero{padding:160px 0 80px;background:linear-gradient(135deg,#0A0A0A 0%,#111111 100%);border-bottom:1px solid var(--border);text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:400px;background:radial-gradient(ellipse at 50% 0%,rgba(245,197,24,0.07) 0%,transparent 70%)}
.page-hero h1{font-size:clamp(36px,6vw,64px);margin-bottom:20px;position:relative;z-index:1}
.page-hero p{color:var(--text2);font-size:18px;max-width:600px;margin:0 auto;position:relative;z-index:1}
/* FORM */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text2)}
.form-control{width:100%;padding:14px 18px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:'Outfit',sans-serif;font-size:15px;transition:var(--transition)}
.form-control:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(245,197,24,0.1)}
.form-control::placeholder{color:var(--text3)}
textarea.form-control{resize:vertical;min-height:140px}
select.form-control option{background:var(--bg2)}
/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;background:var(--border)}
.stat-item{background:var(--bg);padding:40px 24px;text-align:center}
.stat-num{font-size:clamp(32px,4vw,48px);font-weight:900;color:var(--gold);font-family:'Inter',sans-serif;display:block}
.stat-label{font-size:13px;color:var(--text2);margin-top:8px;line-height:1.4}
/* FAQ */
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;text-align:left;padding:24px 0;background:none;border:none;color:var(--text);font-family:'Inter',sans-serif;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;transition:var(--transition)}
.faq-question:hover{color:var(--gold)}
.faq-icon{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition);color:var(--gold)}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--gold-dim);border-color:var(--gold)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.3s ease}
.faq-item.open .faq-answer{max-height:400px;padding-bottom:24px}
.faq-answer p{color:var(--text2);font-size:15px;line-height:1.75}
/* AFFILIATIONS */
.affil-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;background:var(--border)}
.affil-item{background:var(--bg2);padding:32px 20px;text-align:center;transition:var(--transition)}
.affil-item:hover{background:var(--bg3)}
.affil-item span{font-size:13px;font-weight:600;color:var(--text2);display:block;margin-top:12px;line-height:1.4}
/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text3);margin-bottom:20px;justify-content:center}
.breadcrumb a{color:var(--text3);transition:var(--transition)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb-sep{color:var(--text3)}
/* ============================================
   RESPONSIVE — CLEAN MOBILE-FIRST LAYOUT
   ============================================ */

/* ---------- TABLET (≤ 1024px) ---------- */
@media(max-width:1024px){
  .section { padding: 100px 0; }

  /* Nav */
  .nav-links { gap: 20px; }
  .nav-links a { font-size: 13px; }

  /* Grids → 2 columns */
  .grid-3 { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .steps-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .steps-grid::before { display: none; }
  .stats-grid { grid-template-columns: repeat(3, 1fr); }
  .affil-grid { grid-template-columns: repeat(3, 1fr); }

  /* Bento */
  .bento-grid { grid-template-columns: 1fr 1fr; }
  .bento-col-2 { grid-column: span 2; }

  /* USP — keep 2 col */
  .usp-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .footer { padding: 60px 28px 32px; }

  /* Why section inline */
  section[style*="padding: 130px 60px"] { padding: 80px 32px !important; }
}

/* ---------- MOBILE (≤ 768px) ---------- */
@media(max-width:768px){
  .section { padding: 80px 0; }
  .container { padding: 0 20px; }

  /* Nav */
  .nav-links,
  .nav-actions .btn,
  .nav-actions .translate-wrapper { display: none !important; }
  .hamburger { display: flex; }
  .nav-logo img { height: 60px; }

  /* Hero */
  .hero { padding-top: 90px; min-height: auto; }
  .hero h1 { font-size: clamp(28px, 7vw, 40px); }
  .hero-sub { font-size: 16px; }
  .hero-actions { flex-wrap: wrap; gap: 12px; justify-content: center; }
  .hero-actions .btn { width: auto; }
  .hero-stats {
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
    margin-top: 40px;
    padding-top: 28px;
  }
  .hero-stat span { font-size: 22px; }

  /* Section text */
  .section-title { font-size: clamp(30px, 7vw, 46px); }
  .section-subtitle { font-size: 16px; margin-bottom: 40px; }

  /* All grids → single column */
  .grid-2,
  .grid-3,
  .grid-4 { grid-template-columns: 1fr !important; gap: 20px !important; }

  .usp-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .steps-grid { grid-template-columns: 1fr !important; gap: 20px !important; }
  .steps-grid::before { display: none; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .affil-grid { grid-template-columns: repeat(2, 1fr); }

  /* Bento → single column */
  .bento-grid { grid-template-columns: 1fr !important; }
  .bento-col-2 { grid-column: span 1 !important; }
  .bento-row-2 { grid-row: span 1 !important; }

  /* Sub-covers / profiles */
  .sub-covers-grid,
  .profiles-grid { grid-template-columns: 1fr !important; gap: 20px !important; }

  /* Cards — no overlap, natural stacking */
  .card,
  .service-card,
  .blog-card,
  .case-card,
  .usp-item,
  .step,
  .sub-cover-card,
  .profile-card { width: 100%; }

  /* Steps */
  .step { padding: 20px; }
  .step-num { width: 52px; height: 52px; font-size: 18px; margin-bottom: 16px; }

  /* Blog */
  .blog-card-img { height: 180px; }

  /* Stats */
  .stat-item { padding: 28px 16px; }
  .stat-num { font-size: clamp(26px, 6vw, 36px); }
  .affil-item { padding: 24px 12px; }

  /* Testimonials */
  .testimonials-track { animation-duration: 25s; }
  .testimonial-card { min-width: 300px; padding: 24px; }

  /* Why section */
  section[style*="padding: 130px 60px"] {
    padding: 64px 20px !important;
    margin: 40px 12px !important;
    border-radius: 28px !important;
  }

  /* CTA */
  .cta-section {
    padding: 72px 24px !important;
    margin: 0 12px 40px 12px !important;
    border-radius: 28px !important;
  }
  .cta-section h2 { font-size: clamp(26px, 6vw, 38px); }
  .cta-section p { font-size: 16px; }

  /* Footer */
  .footer {
    padding: 52px 20px 28px !important;
    margin: 0 12px 16px !important;
    border-radius: 28px !important;
  }
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .footer-logo img { height: 40px; }
  .footer-bottom {
    flex-direction: column;
    gap: 10px;
    text-align: center;
  }

  /* FABs */
  .fab-group { bottom: 18px; right: 16px; gap: 10px; }
  .fab { width: 48px; height: 48px; }

  /* Page hero */
  .page-hero { padding: 120px 0 60px; }
  .page-hero h1 { font-size: clamp(28px, 7vw, 44px); }
  .page-hero p { font-size: 16px; }

  /* Timeline (subpages) */
  .timeline-item { padding-left: 56px; }
  .timeline-dot { width: 38px; height: 38px; font-size: 13px; }
  .timeline-container::before { left: 19px; }
}

/* ---------- SMALL PHONE (≤ 480px) ---------- */
@media(max-width:480px){
  .container { padding: 0 16px; }
  .section { padding: 64px 0; }

  /* Hero */
  .hero h1 { font-size: clamp(24px, 8vw, 34px); }
  .hero-sub { font-size: 15px; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .hero-stats { flex-direction: column; gap: 16px; align-items: center; }

  /* Nav logo smaller */
  .nav-logo img { height: 48px; }

  /* Stats — single column */
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .affil-grid { grid-template-columns: 1fr 1fr; }

  /* Section headings */
  .section-title { font-size: clamp(26px, 8vw, 38px); letter-spacing: -0.02em; }
  .section-subtitle { font-size: 15px; }

  /* Cards padding */
  .card { padding: 24px; }
  .service-card { padding: 24px; }
  .usp-item { padding: 28px 20px; }
  .blog-card-body { padding: 20px; }
  .case-card-body { padding: 20px; }

  /* Testimonials */
  .testimonial-card { min-width: 280px; }

  /* Footer further compact */
  .footer { padding: 40px 16px 24px !important; }

  /* CTA */
  .cta-section { padding: 56px 16px !important; margin: 0 10px 32px !important; }
  .cta-section .btn { width: 100%; justify-content: center; }
}

/* SERVICE IMAGES */
.section-image{padding:40px 0}
.split-visual{overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-lg);background:var(--bg2)}
.visual-content img{display:block;transition:transform 0.5s ease;width:100%;object-fit:cover;max-height:450px}
.visual-content:hover img{transform:scale(1.02)}

/* ============================================
   TARGETED RESPONSIVE FIXES — ALL PAGES
   ============================================ */

/* Testimonials: always clipped, scroll on small screens */
.testimonials-overflow { overflow: hidden; width: 100%; }

/* Mobile menu btn width fix */
.mobile-menu .btn { max-width: 240px; }

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-info-icon {
  flex-shrink: 0;
}

@media(max-width:768px){
  /* Contact grid stacks naturally via grid-2 → 1col rule */
  /* Contact icon row — keep inline on mobile */
  .contact-info-row { align-items: flex-start !important; }

  /* Blog image height override for inline-styled heights */
  div[style*="height:220px"],
  div[style*="height: 220px"] {
    height: 180px !important;
  }

  /* Index.html inline-padded sections:
     "Why Invoke Gulf" and "Case Studies" both use:
     style="background:var(--bg2); border-radius:40px; margin:80px 24px; padding:130px 60px;" */
  section[style*="border-radius: 40px"] {
    padding: 64px 20px !important;
    margin: 32px 12px !important;
    border-radius: 24px !important;
  }

  /* Section title left-aligned variants */
  .section-title[style*="text-align: left"],
  h2[style*="text-align: left"] {
    font-size: clamp(24px, 6vw, 36px) !important;
  }

  /* Inline flex rows in contact page */
  div[style*="display: flex; gap: 20px"] {
    gap: 14px;
  }

  /* Footer legal links row */
  .footer-bottom div[style*="display: flex"] {
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
  }

  /* Align center helper */
  .align-center { align-items: flex-start !important; }

  /* Split visual image max height */
  .visual-content img { max-height: 280px; }

  /* Why-Qatar investment sectors box */
  div[style*="padding: 40px"][style*="border-radius"] {
    padding: 24px !important;
  }
}

@media(max-width:480px){
  /* Section inline-padded: even tighter */
  section[style*="border-radius: 40px"] {
    padding: 48px 16px !important;
    margin: 24px 10px !important;
    border-radius: 20px !important;
  }

  div[style*="height:220px"],
  div[style*="height: 220px"] {
    height: 160px !important;
  }

  /* Contact icon circle shrink */
  div[style*="width: 56px"][style*="height: 56px"] {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
  }
}

/* ============================================
   BLOG SUBPAGES & SERVICE SUBPAGES
   All use style.css from parent via ../style.css
   Timeline, profiles, sub-cover cards
   ============================================ */
.timeline-container { position: relative; }
.timeline-item { position: relative; padding-left: 72px; margin-bottom: 40px; }
.timeline-dot {
  position: absolute; left: 0; top: 0;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--gold); color: #0A0A0A;
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-family: 'Inter', sans-serif; font-size: 18px;
}
.timeline-container::before {
  content: ''; position: absolute;
  left: 24px; top: 0; bottom: 0; width: 2px;
  background: linear-gradient(to bottom, var(--gold), transparent);
}

@media(max-width:768px){
  .timeline-item { padding-left: 56px; margin-bottom: 28px; }
  .timeline-dot { width: 38px; height: 38px; font-size: 14px; }
  .timeline-container::before { left: 19px; }

  /* Sub-cover cards */
  .sub-cover-card { padding: 28px 20px; }

  /* Profile cards */
  .profile-card { padding: 28px 20px; }

  /* Services page specific: keep reasonable */
  .section-image { padding: 20px 0; }
  .split-visual { border-radius: var(--radius); }
}

/* ============================================
   MOBILE MENU — FULL SCREEN SAFE
   ============================================ */
@media(max-width:768px){
  .mobile-menu {
    overflow-y: auto;
    padding: 80px 24px 48px;
    gap: 24px;
  }
  .mobile-menu a {
    font-size: 22px;
  }
  .mobile-translate {
    width: 100%;
  }
}

/* ============================================
   GENERAL OVERFLOW GUARD
   ============================================ */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

/* Ensure no element bleeds past viewport */
@media(max-width:768px){
  img, video, iframe, embed, object {
    max-width: 100%;
  }
  /* Testimonials container: clip the marquee overflow on mobile */
  section .testimonials-track {
    overflow-x: visible;
  }
  section:has(.testimonials-track) > .container {
    overflow: hidden;
  }
}
