﻿/* =====================================================================
   ComWorld — Premium Design System
   All styles organized section by section
   ===================================================================== */

/* ======================
   1. CSS VARIABLES
   ====================== */
:root {
    --bg-primary: #0A0A0A;
    --bg-secondary: #111111;
    --bg-card: rgba(255,255,255,0.03);
    --bg-glass: rgba(255,255,255,0.05);
    --border-glass: rgba(255,255,255,0.08);
    --text-primary: #FFFFFF;
    --text-secondary: rgba(255,255,255,0.6);
    --text-muted: rgba(255,255,255,0.35);
    --accent: #FF6A00;
    --accent-glow: rgba(255,106,0,0.4);
    --accent-soft: rgba(255,106,0,0.15);
    --gradient-card: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0.01) 100%);
    --shadow-glow: 0 0 40px rgba(255,106,0,0.15);
    --radius-sm: 8px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --font-display: 'Inter', 'Poppins', -apple-system, sans-serif;
    --font-body: 'Inter', 'Lato', -apple-system, sans-serif;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ======================
   2. LIGHT MODE OVERRIDES
   ====================== */
[data-theme="light"] {
    --bg-primary: #F0F2F5;
    --bg-secondary: #FFFFFF;
    --bg-card: rgba(0,0,0,0.03);
    --bg-glass: rgba(255,255,255,0.75);
    --border-glass: rgba(0,0,0,0.1);
    --text-primary: #0D0D0D;
    --text-secondary: rgba(0,0,0,0.65);
    --text-muted: rgba(0,0,0,0.38);
    --gradient-card: linear-gradient(135deg, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.6) 100%);
    --shadow-glow: 0 0 40px rgba(255,106,0,0.1);
}
[data-theme="light"] .hero-section { background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%); }
[data-theme="light"] .hero-section * { color: #fff; }
[data-theme="light"] .service-card { background:#fff; border-color:rgb(0 0 0 / 28%); }
[data-theme="light"] .glass { background:rgba(255,255,255,0.85); border-color:rgba(0,0,0,); }

/* ======================
   3. GLOBAL RESET
   ====================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { background: var(--bg-primary); color: var(--text-primary); font-family: var(--font-body); margin: 0; overflow-x: hidden; overflow-y: auto; transition: background 0.5s var(--ease), color 0.5s var(--ease); }
section { height: auto; }
::selection { background: var(--accent); color: #fff; }
a { text-decoration: none; }
ul { list-style: none; margin: 0; padding: 0; }
h1,h2,h3,h4,h5,h6 { margin: 0; font-family: var(--font-display); }
p { margin: 0; }

/* ======================
   4. TYPOGRAPHY CLASSES
   ====================== */
.premium-h1   { font-size: clamp(1.8rem,3.8vw,3rem); font-weight:700; line-height:1.1; letter-spacing:-0.025em; color:var(--text-primary); max-width:820px; }
.premium-h2   { font-size: clamp(1.8rem,3.5vw,3rem); font-weight:700; line-height:1.1; letter-spacing:-0.02em; color:var(--text-primary); }
.premium-h3   { font-size: clamp(1.4rem,2.5vw,2rem); font-weight:600; line-height:1.2; }
.premium-subtitle { font-size: clamp(1rem,1.5vw,1.25rem); color:var(--text-secondary); font-weight:400; line-height:1.6; max-width:600px; }
.premium-label { font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:0.15em; color:var(--accent); }
.text-gradient { background:linear-gradient(90deg,#FF6A00,#FF8C00,#FFB347); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ======================
   5. GLASSMORPHISM
   ====================== */
.glass { background:var(--bg-glass); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid var(--border-glass); border-radius:var(--radius-md); }

/* ======================
   6. NAVIGATION
   ====================== */
.premium-nav { position:fixed; top:0; left:0; right:0; z-index:1000; height:70px; display:flex; align-items:center; padding:0; background:rgba(255,255,255,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid rgba(0,0,0,0.07); box-shadow:0 2px 12px rgba(0,0,0,0.06); transition:all 0.45s var(--ease); margin-top:0; }
.premium-nav .nav-inner { width:100%; }
.premium-nav.scrolled { background:rgba(255,255,255,0.97); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border-bottom:1px solid rgba(0,0,0,0.08); box-shadow:0 4px 30px rgba(0,0,0,0.1), 0 1px 0 rgba(0,0,0,0.05); }
body.dark-mode .premium-nav.scrolled, [data-theme="dark"] .premium-nav.scrolled { background:rgba(255,255,255,0.97); border-bottom:1px solid rgba(0,0,0,0.08); box-shadow:0 4px 30px rgba(0,0,0,0.1), 0 1px 0 rgba(0,0,0,0.05); }
body.light-mode .premium-nav.scrolled, [data-theme="light"] .premium-nav.scrolled { background:rgba(255,255,255,0.97); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border-bottom:1px solid rgba(0,0,0,0.08); box-shadow:0 4px 30px rgba(0,0,0,0.1), 0 1px 0 rgba(0,0,0,0.05); }
[data-theme="light"] .premium-nav { background:rgba(255,255,255,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid rgba(0,0,0,0.07); box-shadow:0 2px 12px rgba(0,0,0,0.06); }
.nav-inner { max-width:1280px; margin:0 auto; padding:0 2rem; display:flex; justify-content:space-between; align-items:center; }
.nav-logo { display:inline-flex; align-items:center; transition:all 0.3s ease; border-radius:10px; }
.nav-logo img { height:40px; width:auto; object-fit:contain; }
.nav-links { display:flex; align-items:center; gap:2.2rem; }
.nav-links a { color:#111111; font-size:0.9rem; font-weight:600; position:relative; transition:color 0.3s ease; padding:0.5rem 0; }
[data-theme="light"] .nav-links a { color:#111111; font-weight:600; }
.nav-links a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--accent); transition:width 0.4s var(--ease); }
.nav-links a:hover { color:var(--accent); }
[data-theme="light"] .nav-links a:hover { color:var(--accent); }
.nav-links a:hover::after { width:100%; }

/* ===== CTA BUTTON — ICON & PRESS (base styles defined in Section 45) ===== */

/* Icon size */
.btn-quote i, .card-cta i, .os-card-cta i { font-size: 13px; }

/* Active press */
.btn-quote:active, .card-cta:active, .os-card-cta:active { transform: scale(0.98); }

/* ===== ALIGN WITH NAVBAR ===== */

.navbar li {
  display: flex;
  align-items: center;
}

/* Mobile Toggle + Nav Right */
.nav-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.nav-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; z-index:1101; }
.nav-toggle span { width:24px; height:2px; background:#111111; transition:all 0.3s ease; border-radius:2px; }
.nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.active span:nth-child(2) { opacity:0; }
.nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* Theme Toggle */
.theme-toggle { display:inline-flex; align-items:center; gap:6px; padding:7px 14px; background:rgba(0,0,0,0.06); border:1px solid rgba(0,0,0,0.18); border-radius:999px; cursor:pointer; transition:all 0.3s ease; font-size:0.82rem; font-weight:600; color:#333333; flex-shrink:0; margin-left:10px; }
.theme-toggle:hover { background:rgba(0,0,0,0.12); border-color:rgba(0,0,0,0.28); }
.theme-toggle::before { display:none !important; }
.theme-toggle .icon { font-size:1rem; line-height:1; }
.theme-toggle .text { font-size:0.82rem; }
body.light-mode .theme-toggle, [data-theme="light"] .theme-toggle { background:rgba(0,0,0,0.06); border-color:rgba(0,0,0,0.18); color:#333; }
body.light-mode .theme-toggle:hover, [data-theme="light"] .theme-toggle:hover { background:rgba(0,0,0,0.12); }

/* ======================
   7. HERO SECTION
   ====================== */
.hero-section { position:relative; min-height:100vh; display:flex; align-items:center; justify-content:flex-start; padding-left:6%; overflow:hidden; background:radial-gradient(ellipse at 50% 50%,#1a1a2e 0%,#0A0A0A 70%); }
.hero-canvas { position:absolute; top:0; left:0; width:100%; height:100%; z-index:1; filter:contrast(1.1) brightness(1.05); }
@keyframes zoomHero { from { transform:scale(1.2); } to { transform:scale(1.4); } }
@keyframes heroCanvasZoom { from { transform:scale(1.2); } to { transform:scale(1.4); } }
.hero-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:radial-gradient(ellipse at center,transparent 0%,rgba(10,10,10,0.55) 65%), linear-gradient(to bottom,rgba(10,10,10,0.25) 0%,transparent 25%,transparent 65%,rgba(10,10,10,0.75) 100%); z-index:2; }
.hero-section::before { content:''; position:absolute; width:720px; height:720px; background:radial-gradient(circle,rgba(255,106,0,0.35) 0%,rgba(255,106,0,0.12) 45%,transparent 70%); top:50%; left:50%; transform:translate(-50%,-50%); filter:blur(130px); z-index:1; pointer-events:none; }
.hero-content { position:relative; z-index:3; text-align:left; max-width:540px; width:50%; margin-left:0; margin-right:auto; padding:2rem 2rem 4rem; }
.hero-content::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:700px; height:320px; background:radial-gradient(ellipse at center,rgba(255,106,0,0.15) 0%,transparent 70%); z-index:-1; pointer-events:none; border-radius:50%; }
.hero-content .premium-label { margin-bottom:1.5rem; display:inline-block; opacity:0; animation:fadeUp 1s 0.3s forwards; }
.hero-content .premium-h1 { color:#fff; font-size:clamp(38px,5vw,56px); line-height:1.2; margin-bottom:1.1rem; opacity:0; animation:fadeUp 1s 0.5s forwards; text-shadow:0 0 60px rgba(255,106,0,0.2), 0 4px 30px rgba(0,0,0,0.5); }
.hero-content .premium-subtitle { color:rgba(255,255,255,0.85); font-size:15px; line-height:1.7; max-width:480px; margin:0 0 3rem; opacity:0; animation:fadeUp 1s 0.7s forwards; font-family:'Inter','Poppins',sans-serif; }
[data-theme="light"] .hero-content .premium-subtitle { color:#d7dbe3; }
.hero-buttons { display:flex; gap:14px; margin-top:18px; justify-content:flex-start; flex-wrap:wrap; }
.scroll-indicator { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); z-index:5; display:flex; flex-direction:column; align-items:center; gap:0.5rem; opacity:0; animation:fadeUp 1s 1.5s forwards; }
.scroll-indicator span { font-size:0.7rem; text-transform:uppercase; letter-spacing:0.2em; color:rgba(255,255,255,0.4); }
.scroll-line { width:1px; height:40px; background:linear-gradient(to bottom,var(--accent),transparent); animation:pulse 2s infinite; }

/* ======================
   8. BUTTONS
   ====================== */
.btn-premium { display:inline-flex; align-items:center; gap:0.5rem; padding:10px 20px; background:linear-gradient(135deg,#FF6A00,#FF8C00,#FFB347); background-size:200% 200%; background-position:left center; color:#fff; font-size:14px; font-weight:600; border:none; border-radius:999px; cursor:pointer; position:relative; overflow:hidden; transition:all 0.4s var(--ease); box-shadow:0 4px 20px rgba(255,106,0,0.4), 0 0 0 1px rgba(255,140,0,0.15); opacity:0; animation:fadeUp 1s 0.9s forwards; }
.btn-premium:hover { transform:translateY(-3px) scale(1.05); background-position:right center; box-shadow:0 8px 35px rgba(255,106,0,0.55), 0 0 50px rgba(255,106,0,0.2), 0 0 0 1px rgba(255,180,0,0.2); color:#fff; }
.btn-premium::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent); transition:left 0.55s ease; }
.btn-premium:hover::before { left:100%; }
.btn-outline { display:inline-flex; align-items:center; gap:0.5rem; padding:9px 18px; background:transparent; color:#FF6A00; font-size:14px; font-weight:600; border:2px solid #FF6A00; border-radius:999px; cursor:pointer; transition:all 0.3s ease; }
.btn-outline:hover { background:#FF6A00; color:#fff; transform:translateY(-2px); box-shadow:0 0 20px rgba(255,106,0,0.4); }
/* Form button — no hero animation */
.premium-form .btn-premium { opacity:1; animation:none; width:100%; justify-content:center; }

/* ======================
   9. SECTION LAYOUT
   ====================== */
.premium-section { padding:clamp(4rem,10vw,8rem) 0; position:relative; scroll-margin-top:80px; }
#enquiry-form { scroll-margin-top:90px; }
.premium-container { max-width:1280px; margin:0 auto; padding:0 2rem; }
.section-header { text-align:center; margin-bottom:clamp(3rem,6vw,5rem); }
.section-header .premium-label { margin-bottom:1rem; display:block; }
.section-header .premium-subtitle { margin:0 auto; }
.section-divider { width:80px; height:4px; background:linear-gradient(90deg,#FF6A00,#FF8C00,#FFB347); border-radius:2px; margin:1.5rem auto 0; box-shadow:0 0 12px rgba(255,106,0,0.45), 0 0 4px rgba(255,106,0,0.3); }

/* ======================
   10. ABOUT SECTION
   ====================== */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.about-image { position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3; background:var(--bg-card); }
.about-image::after { content:''; position:absolute; inset:0; border-radius:var(--radius-lg); border:1px solid var(--border-glass); pointer-events:none; }
.about-features { display:flex; flex-direction:column; gap:2rem; margin-top:2rem; }
.about-feature { display:flex; gap:1.5rem; align-items:flex-start; }
.about-feature .feature-icon { width:50px; height:50px; flex-shrink:0; display:flex; align-items:center; justify-content:center; border-radius:12px; background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,140,0,0.25)); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); color:var(--accent); font-size:1.2rem; box-shadow:0 0 14px rgba(255,106,0,0.18); }
.about-feature h5 { font-size:1.1rem; font-weight:600; margin-bottom:0.3rem; color:var(--text-primary); }
.about-feature p { color:var(--text-secondary); font-size:0.9rem; line-height:1.6; }

/* ======================
   11. SERVICES SECTION
   ====================== */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.service-card { background:var(--gradient-card); border:1px solid var(--border-glass); border-radius:var(--radius-lg); padding:2.5rem 2rem; text-align:center; position:relative; overflow:hidden; transition:all 0.5s var(--ease); cursor:pointer; display:block; color:var(--text-primary); }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--accent),transparent); opacity:0; transition:opacity 0.5s ease; }
.service-card:hover { transform:translateY(-8px); border-color:rgba(255,106,0,0.2); box-shadow:0 20px 60px rgba(0,0,0,0.3),0 0 30px var(--accent-soft); }
.service-card:hover::before { opacity:1; }
.service-card .card-icon { width:70px; height:70px; margin:0 auto 1.5rem; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-md); background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,140,0,0.25)); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); color:var(--accent); font-size:1.6rem; transition:all 0.4s ease; box-shadow:0 0 18px rgba(255,106,0,0.2); }
.service-card:hover .card-icon { background:linear-gradient(135deg,#FF6A00,#FF8C00); color:#fff; transform:scale(1.1); box-shadow:0 0 28px rgba(255,106,0,0.55); }
.service-card h4 { font-size:1.2rem; font-weight:600; margin-bottom:0.75rem; }
.service-card p { color:var(--text-secondary); font-size:0.9rem; line-height:1.6; }

/* ======================
   12. NETWORK SECTION
   ====================== */
.network-section { position:relative; overflow:hidden; }
.network-content { position:relative; z-index:2; }

/* ======================
   13. STATS SECTION
   ====================== */
.stats-section { background:var(--bg-secondary); position:relative; overflow:hidden; }
.stats-section::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 20% 50%,var(--accent-soft) 0%,transparent 50%),radial-gradient(circle at 80% 50%,rgba(255,106,0,0.05) 0%,transparent 50%); pointer-events:none; }
.stats-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; position:relative; }
.stat-card { text-align:center; padding:2.5rem 1.5rem; border-radius:var(--radius-lg); background:var(--bg-glass); border:1px solid var(--border-glass); transition:all 0.4s ease; }
.stat-card:hover { border-color:rgba(255,106,0,0.2); box-shadow:var(--shadow-glow); }
.stat-number { font-size:clamp(2.5rem,4vw,3.5rem); font-weight:700; color:var(--accent); line-height:1; margin-bottom:0.5rem; }
.stat-label { color:var(--text-secondary); font-size:0.95rem; font-weight:500; text-transform:uppercase; letter-spacing:0.1em; }

/* ======================
   14. CONTACT SECTION
   ====================== */
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:2.5rem; align-items:stretch; }
.contact-info-card { display:flex; align-items:flex-start; gap:0.85rem; padding:14px 16px; border-radius:var(--radius-md); background:var(--bg-glass); border:1px solid var(--border-glass); transition:all 0.3s ease; margin-bottom:0; min-height:auto; }
.contact-info-card:hover { border-color:rgba(255,106,0,0.15); }
.contact-info-card .info-icon { width:38px; height:38px; flex-shrink:0; display:flex; align-items:center; justify-content:center; border-radius:10px; background:var(--accent-soft); color:var(--accent); font-size:0.9rem; }
.contact-info-card h5 { font-size:0.85rem; font-weight:600; margin-bottom:3px; color:var(--text-primary); }
.contact-info-card p, .contact-info-card a, .contact-info-card address { color:var(--text-secondary); font-size:0.82rem; line-height:1.4; font-style:normal; margin:0; }
.contact-info-card a:hover { color:var(--accent); }

/* ======================
   15. PREMIUM FORM
   ====================== */
.premium-form .form-group { margin-bottom:10px; }
.premium-form label { display:block; font-size:0.82rem; font-weight:500; color:var(--text-secondary); margin-bottom:4px; }
.premium-form input, .premium-form textarea { width:100%; padding:8px 10px; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-sm); color:var(--text-primary); font-size:0.85rem; font-family:var(--font-body); transition:all 0.25s ease; outline:none; box-shadow:inset 0 2px 6px rgba(0,0,0,0.35); }
.premium-form textarea { min-height:90px; resize:vertical; }
.premium-form input::placeholder, .premium-form textarea::placeholder { color:var(--text-muted); }
.premium-form input:focus, .premium-form textarea:focus { border-color:var(--accent); box-shadow:0 0 0 2px rgba(255,122,0,0.18), inset 0 2px 6px rgba(0,0,0,0.45); }
.premium-form textarea { min-height:120px; resize:vertical; }
/* Light mode: clean white inputs */
[data-theme="light"] .premium-form input, [data-theme="light"] .premium-form textarea { background:#ffffff; border-color:rgba(0,0,0,0.12); box-shadow:inset 0 1px 3px rgba(0,0,0,0.07); }
[data-theme="light"] .premium-form input:focus, [data-theme="light"] .premium-form textarea:focus { border-color:var(--accent); box-shadow:0 0 0 2px rgba(255,122,0,0.14), inset 0 1px 3px rgba(0,0,0,0.06); }

/* ======================
   16. FOOTER
   ====================== */
.premium-footer { background:var(--bg-secondary); border-top:1px solid var(--border-glass); padding:50px 0 20px; }
.footer-grid { display:flex; justify-content:space-between; align-items:center; margin-bottom:2rem; }
.footer-logo { display:inline-flex; align-items:center; transition:all 0.3s ease; border-radius:10px; }
.footer-logo img { height:36px; width:auto; object-fit:contain; }
/* Dark mode: same glass-pill treatment so dark-ink logo stays legible on dark footer */
body.dark-mode .footer-logo,
[data-theme="dark"] .footer-logo { background:rgba(255,255,255,0.92); padding:5px 10px; border-radius:10px; backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); box-shadow:0 4px 15px rgba(255,106,0,0.15); }
.footer-socials { display:flex; gap:0.75rem; list-style:none; padding:0; margin:0; margin-top:1rem; align-items:center; flex-wrap:wrap; }
.footer-socials a { width:42px; height:42px; display:flex; align-items:center; justify-content:center; border-radius:50%; background:transparent; border:1.5px solid rgba(255,106,0,0.6); color:#FF6A00; transition:all 0.3s ease; font-size:16px; }
.footer-socials a i, .footer-socials a .fa { font-size:16px; transition:color 0.3s ease; color:#FF6A00; }
.footer-socials a:hover { background:#FF6A00; border-color:#FF6A00; transform:translateY(-3px); box-shadow:0 8px 20px rgba(255,106,0,0.4); color:#fff; }
.footer-socials a:hover i, .footer-socials a:hover .fa { color:#ffffff; }
[data-theme="dark"] .footer-socials a, body.dark-mode .footer-socials a { border-color:rgba(255,255,255,0.2); color:#FF6A00; }
[data-theme="dark"] .footer-socials a:hover, body.dark-mode .footer-socials a:hover { background:#FF6A00; border-color:#FF6A00; color:#fff; }
.footer-bottom { text-align:center; padding-top:1.5rem; border-top:1px solid var(--border-glass); margin-top:20px; }
.footer-bottom p { color:var(--text-muted); font-size:0.85rem; }
.footer-bottom a { color:var(--accent); }

/* ======================
   17. PRODUCT POPUPS
   ====================== */
.pop-overlay { position:fixed; top:0; bottom:0; left:0; right:0; background:rgba(0,0,0,0.7); transition:opacity 0ms; visibility:hidden; opacity:0; z-index:1100; }
.pop-overlay:target { visibility:visible; opacity:1; }
.pop-overlay .popup { background:var(--bg-secondary); border:1px solid var(--border-glass); border-radius:var(--radius-lg); color:var(--text-primary); max-width:600px; width:90%; padding:2.5rem; margin:8em auto; position:relative; }
.pop-overlay .popup h4 { color:var(--accent); font-weight:600; text-align:center; }
.pop-overlay .popup .table { color:var(--text-secondary); }
.pop-overlay .popup .close { position:absolute; top:10px; right:15px; color:var(--text-secondary); font-size:1.5rem; opacity:0.7; transition:all 0.3s ease; }
.pop-overlay .popup .close:hover { color:var(--accent); opacity:1; }
.pop-overlay .popup td img { border-radius:4px; }

/* ======================
   18. SCROLL ANIMATIONS
   ====================== */
.reveal       { opacity:0; transform:translateY(40px);  transition:opacity 0.8s var(--ease),transform 0.8s var(--ease); }
.reveal-left  { opacity:0; transform:translateX(-40px); transition:opacity 0.8s var(--ease),transform 0.8s var(--ease); }
.reveal-right { opacity:0; transform:translateX(40px);  transition:opacity 0.8s var(--ease),transform 0.8s var(--ease); }
.reveal-scale { opacity:0; transform:scale(0.9);        transition:opacity 0.8s var(--ease),transform 0.8s var(--ease); }
.revealed     { opacity:1 !important; transform:none !important; }
.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; }
.stagger-7 { transition-delay:0.7s; } .stagger-8 { transition-delay:0.8s; }

/* ======================
   19. KEYFRAMES
   ====================== */
@keyframes fadeUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
@keyframes pulse  { 0%,100% { opacity:1; } 50% { opacity:0.5; } }

/* ======================
   20. PRODUCTS MEGA DROPDOWN
   ====================== */
.products-dropdown { position:relative; }
.products-toggle { cursor:pointer; }
.products-toggle i { font-size:0.7em; margin-left:4px; transition:transform 0.3s ease; }
.products-dropdown.open > .products-toggle i { transform:rotate(180deg); }

/* Level 1: right-aligned panel below Products.
   overflow:visible is required so the L2 flyout panel can escape to the left. */
.mega-menu { display:none; position:absolute; top:calc(100% + 8px); right:0; left:auto; transform:none; width:240px; overflow:visible; /* overflow:visible is required — L2 flyouts use position:absolute and would be clipped by overflow:auto */ background:rgba(20,20,20,0.95); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,0.08); border-top:2px solid var(--accent); border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,0.5), 0 0 20px rgba(255,106,0,0.05); padding:10px 0; list-style:none; z-index:9999; box-sizing:border-box; }
[data-theme="light"] .mega-menu { background:rgba(255,255,255,0.95); border-color:rgba(0,0,0,0.1); border-top-color:var(--accent); box-shadow:0 10px 30px rgba(0,0,0,0.15); }
.products-dropdown.open > .mega-menu { display:block; animation:megaDropDown 0.2s ease forwards; }

/* Mega parent items */
.mega-parent { position:relative; }
.mega-toggle { display:flex; align-items:center; justify-content:space-between; padding:8px 14px; margin:1px 6px; border-radius:8px; color:var(--text-secondary); font-size:13px; font-weight:500; line-height:1.3; text-decoration:none; cursor:pointer; transition:all 0.2s ease; white-space:nowrap; overflow:hidden; }
.mega-toggle::after { content:none; }
.mega-toggle i { font-size:0.65em; opacity:0.5; transition:all 0.2s ease; flex-shrink:0; margin-left:8px; transform:scaleX(-1); }
.mega-toggle:hover, .mega-parent.active > .mega-toggle { color:var(--accent); background:rgba(255,106,0,0.08); border-radius:6px; }
.mega-parent.active > .mega-toggle { background:linear-gradient(90deg,rgba(255,106,0,0.14),transparent); border-left:2px solid #FF6A00; padding-left:12px; }
.mega-parent.active > .mega-toggle i { opacity:1; color:var(--accent); transform:scaleX(-1); }

/* Sub menus (level 2+) */
.mega-sub { display:none; list-style:none; padding:0; margin:0; }
.mega-sub.open { display:block; }

/* Desktop: L1 (240px, overflow:visible) → L2 scrollable flyout-left (240px) → L3 inline accordion within L2 scroll */
@media (min-width:992px) {
    /* L2 panel: own max-height + scroll; L3 reveals inline within this scroll container */
    .mega-sub { position:absolute; top:-4px; right:calc(100% + 6px); left:auto; width:240px; max-height:420px; overflow-y:auto; overflow-x:hidden; background:rgba(18,18,18,0.97); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,0.08); border-top:2px solid var(--accent); border-radius:12px; box-shadow:-8px 10px 30px rgba(0,0,0,0.5); padding:0.5rem 0; z-index:1011; scrollbar-width:thin; scrollbar-color:rgba(255,106,0,0.4) transparent; box-sizing:border-box; }
    [data-theme="light"] .mega-sub { background:rgba(255,255,255,0.95); border-color:rgba(0,0,0,0.1); border-top-color:var(--accent); box-shadow:-8px 10px 30px rgba(0,0,0,0.12); }
    .mega-sub.open { animation:megaFlyLeft 0.18s ease forwards; }
    /* L3: inline accordion inside scrollable L2 — visually distinct sub-panel */
    .mega-sub .mega-sub { position:static !important; right:auto !important; left:auto !important; top:auto !important; width:auto !important; min-width:auto !important; max-height:none !important; overflow:visible !important; z-index:auto !important; background:rgba(255,106,0,0.04) !important; backdrop-filter:none !important; -webkit-backdrop-filter:none !important; border:none !important; border-left:2px solid rgba(255,106,0,0.3) !important; border-top:none !important; border-radius:0 !important; box-shadow:none !important; padding:4px 0 !important; margin:2px 4px 4px 14px !important; box-sizing:border-box !important; }
    [data-theme="light"] .mega-sub .mega-sub { background:rgba(255,106,0,0.03) !important; border-left-color:rgba(255,106,0,0.4) !important; }
    .mega-sub .mega-sub.open { animation:none !important; }
    /* L3 service links — compact */
    .mega-sub .mega-sub .service-link { font-size:12px; padding:5px 8px; margin:1px 4px; border-radius:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    /* L2 toggle items — same padding as L1 */
    .mega-sub .mega-parent > .mega-toggle { padding:8px 14px; margin:1px 6px; }
    /* L2 scrollbar (webkit) */
    .mega-sub::-webkit-scrollbar { width:6px; }
    .mega-sub::-webkit-scrollbar-thumb { background:rgba(255,106,0,0.4); border-radius:10px; }
    .mega-sub::-webkit-scrollbar-track { background:transparent; }
}

/* Service links (leaf items) */
.service-link { display:block; padding:7px 14px; margin:1px 6px; border-radius:6px; color:var(--text-secondary); font-size:13px; font-weight:500; line-height:1.3; text-decoration:none; transition:all 0.2s ease; cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; box-sizing:border-box; }
.service-link::after { content:none !important; width:0 !important; }
.service-link:hover { color:var(--accent); background:rgba(255,106,0,0.08); border-radius:6px; }

/* High-specificity overrides: prevent .nav-links a { color:#111 } from bleeding into dark mega menu.
   .mega-menu .mega-toggle / .service-link has specificity 0,2,0 which beats .nav-links a at 0,1,1. */
.mega-menu .mega-toggle,
.mega-menu .service-link { color:rgba(255,255,255,0.72); }
[data-theme="light"] .mega-menu .mega-toggle,
[data-theme="light"] .mega-menu .service-link { color:rgba(0,0,0,0.72); }
.mega-menu .mega-toggle:hover,
.mega-menu .service-link:hover { color:var(--accent); }
[data-theme="light"] .mega-menu .mega-toggle:hover,
[data-theme="light"] .mega-menu .service-link:hover { color:var(--accent); }

@keyframes megaDropDown  { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }
@keyframes megaFlyLeft   { from { opacity:0; transform:translateX(8px); }  to { opacity:1; transform:translateX(0); } }

/* Dropdown scrollbar */
.mega-menu::-webkit-scrollbar { width:6px; }
.mega-menu::-webkit-scrollbar-thumb { background:rgba(255,106,0,0.4); border-radius:10px; }
.mega-menu::-webkit-scrollbar-track { background:transparent; }

/* ======================
   21. SERVICE TOAST NOTIFICATION
   ====================== */
.service-toast { position:fixed; bottom:2rem; right:2rem; display:flex; align-items:center; gap:0.75rem; padding:1rem 1.5rem; background:rgba(15,15,15,0.95); backdrop-filter:blur(20px); border:1px solid rgba(255,106,0,0.3); border-radius:var(--radius-sm); color:#fff; font-size:0.9rem; z-index:9999; transform:translateY(120%); opacity:0; transition:all 0.4s var(--ease); box-shadow:0 10px 40px rgba(0,0,0,0.4), 0 0 20px rgba(255,106,0,0.1); }
[data-theme="light"] .service-toast { background:rgba(255,255,255,0.95); color:var(--text-primary); border-color:rgba(255,106,0,0.4); box-shadow:0 10px 40px rgba(0,0,0,0.15); }
.service-toast.show { transform:translateY(0); opacity:1; }
.service-toast .fa-check-circle { color:var(--accent); font-size:1.2rem; }
.service-toast strong { color:var(--accent); }
.toast-close { background:none; border:none; color:var(--text-muted); font-size:1.2rem; cursor:pointer; margin-left:0.5rem; padding:0 4px; line-height:1; }
.toast-close:hover { color:var(--accent); }

/* ======================
   22. SERVICE BADGE (above form)
   ====================== */
.service-badge { display:flex; align-items:center; gap:0.5rem; margin-bottom:1.5rem; padding:0.8rem 1.2rem; background:rgba(255,106,0,0.08); border:1px solid rgba(255,106,0,0.2); border-radius:var(--radius-sm); color:var(--accent); font-size:0.9rem; font-weight:500; animation:fadeUp 0.4s ease; }
.service-badge .fa-check-circle { font-size:1.1rem; }
.service-badge strong { color:var(--accent); }
.badge-path { color:var(--text-muted); font-weight:400; font-size:0.8rem; }
.badge-close { margin-left:auto; background:none; border:none; color:var(--text-muted); font-size:1.2rem; line-height:1; cursor:pointer; padding:0 0.1rem; transition:color 0.2s ease; flex-shrink:0; }
.badge-close:hover { color:var(--accent); }
.service-field-hint { font-size:0.8rem; color:var(--accent); margin-top:0.4rem; margin-bottom:0; display:none; }
.service-field-hint i { margin-right:0.3rem; }

/* ======================
   23. SERVICE FIELD + WHATSAPP BUTTON
   ====================== */
.service-field { background:rgba(255,106,0,0.04) !important; border-color:rgba(255,106,0,0.2) !important; cursor:pointer; }
.service-field:focus { border-color:var(--accent) !important; }
.form-buttons { display:flex; gap:1rem; flex-wrap:wrap; align-items:center; margin-top:0.5rem; }
.btn-whatsapp { display:inline-flex; align-items:center; gap:0.5rem; padding:12px 20px; background:#25D366; color:#fff !important; font-size:0.9rem; font-weight:600; border-radius:999px; text-decoration:none; transition:all 0.3s ease; cursor:pointer; box-shadow:0 8px 20px rgba(37,211,102,0.4); }
.btn-whatsapp::after { content:none !important; width:0 !important; }
.btn-whatsapp:hover { background:#1ebe5d; transform:scale(1.05); box-shadow:0 12px 30px rgba(37,211,102,0.6); color:#fff !important; }
.btn-whatsapp i, .btn-whatsapp .fa-whatsapp, .btn-whatsapp .fa { font-size:1.1rem; margin-right:4px; }

/* ======================
   24. RESPONSIVE
   ====================== */
@media (max-width:968px) {
    .about-grid   { grid-template-columns:1fr; gap:2rem; }
    .contact-grid { grid-template-columns:1fr; gap:2rem; }
    .stats-grid   { grid-template-columns:repeat(3,1fr); gap:1rem; }
    .footer-grid { flex-direction:column; gap:1.5rem; text-align:center; }
}
@media (max-width:640px) {
    .premium-container { padding:0 1.25rem; }
    .services-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr; }
    .hero-content .premium-h1 { font-size:2.2rem; }
    .service-card { padding:2rem 1.5rem; }
    .service-toast { left:1rem; right:1rem; bottom:1rem; }
    .form-buttons { flex-direction:column; }
    .btn-whatsapp { justify-content:center; }
}
@media (max-width:768px) {
    .hero-canvas { opacity:0.5; }
    .service-card:hover { transform:translateY(-4px); }
}
@media (prefers-reduced-motion:reduce) {
    *,*::before,*::after { animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}

/* ======================
   25. HERO TRUST BADGES
   ====================== */
.hero-trust-badges { display:flex; gap:1.5rem; justify-content:flex-start; flex-wrap:wrap; margin-top:2.5rem; opacity:0; animation:fadeUp 1s 1.3s forwards; }
.hero-trust-badges span { display:flex; align-items:center; gap:0.5rem; font-size:0.85rem; color:rgba(255,255,255,0.6); }
.hero-trust-badges .fa { color:var(--accent); }

/* ======================
   26. PARTNERS BAR — Infinite Carousel
   ====================== */
.partners-bar {
    position:relative;
    background:linear-gradient(to bottom,rgba(10,10,10,1),rgba(18,18,18,1));
    border-top:1px solid var(--border-glass);
    border-bottom:1px solid var(--border-glass);
    padding:2rem 0;
    overflow:hidden;
}
.partners-bar::before {
    display:none; /* fog overlay removed for clarity */
}
.partners-bar .premium-container { position:relative; z-index:1; }

/* Section heading */
.partners-label {
    text-align:center;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:2px;
    color:#bbb;
    margin-bottom:1.5rem;
    text-shadow:0 0 8px rgba(255,106,0,0.2);
}

/* Scroll wrapper with fade edges */
.partner-wrapper {
    position:relative;
    overflow:hidden;
}
.partner-wrapper::before,
.partner-wrapper::after {
    content:'';
    position:absolute;
    top:0;
    width:100px;
    height:100%;
    z-index:2;
    pointer-events:none;
}
.partner-wrapper::before { left:0; background:linear-gradient(to right,rgba(10,10,10,1),transparent); }
.partner-wrapper::after  { right:0; background:linear-gradient(to left,rgba(10,10,10,1),transparent); }

/* Center glow spotlight */
.partner-track-wrap {
    position:relative;
    display:flex;
    justify-content:center;
}
.partner-track-wrap::after {
    content:'';
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    width:220px;
    height:60px;
    background:radial-gradient(ellipse at center,rgba(255,106,0,0.25),transparent 70%);
    filter:blur(20px);
    z-index:0;
    pointer-events:none;
}

/* Track */
.partners-track, .partner-track {
    display:flex;
    width:max-content;
    animation:scrollLeft 30s linear infinite;
    position:relative;
    z-index:1;
}
.partners-track:hover, .partner-track:hover { animation-play-state:paused; }
.partners-logos { display:flex; align-items:center; gap:3rem; padding:0 1.5rem; }

/* Default logo state */
.partner-logo {
    opacity:1;
    filter:none;
    transition:all 0.4s ease;
    transform:scale(0.97);
    border-radius:12px;
    border:1px solid rgba(255,255,255,0.12);
    background:rgba(255,255,255,0.92);
    padding:8px 14px;
    box-shadow:0 4px 20px rgba(0,0,0,0.4);
    position:relative;
    overflow:hidden;
}
/* Inner orange glow — fades in on active */
.partner-logo::before {
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(135deg,rgba(255,106,0,0.28),rgba(255,140,0,0.18));
    opacity:0;
    transition:opacity 0.4s ease;
    z-index:0;
    border-radius:inherit;
}
.partner-logo.active::before { opacity:1; }

/* Center/active logo — primary focus */
.partner-logo.active {
    opacity:1;
    filter:none;
    transform:scale(1.12);
    border:1px solid rgba(255,140,0,0.45);
    border-radius:12px;
    box-shadow:0 0 25px rgba(255,106,0,0.4), 0 0 60px rgba(255,106,0,0.15);
    padding:8px 16px;
}

/* Side logos — hover boost */
.partner-logo:not(.active):hover {
    opacity:1;
    filter:none;
    transform:scale(1.06);
    box-shadow:0 0 15px rgba(255,106,0,0.35);
}

/* Image & fallback text */
.partner-logo img { height:52px; width:auto; max-width:130px; object-fit:contain; display:block; opacity:0.9; transition:opacity 0.3s ease, transform 0.3s ease; filter:none; position:relative; z-index:1; }
.partner-logo:hover img { opacity:1; transform:scale(1.05); }
.partner-logo.active img { opacity:1; }
/* Dark mode — card stays white-glass for photo logo readability */
body.dark-mode .partner-logo,
[data-theme="dark"] .partner-logo { background:rgba(255,255,255,0.92); border-color:rgba(255,255,255,0.15); box-shadow:0 4px 20px rgba(0,0,0,0.5); }
body.dark-mode .partner-logo img,
[data-theme="dark"] .partner-logo img { filter:brightness(1.05) contrast(1.05); }
.partner-logo span {
    font-size:0.9rem;
    font-weight:700;
    color:#d4d4d4;
    padding:0.5rem 1rem;
    border:1px solid rgba(255,255,255,0.15);
    border-radius:var(--radius-sm);
    background:rgba(255,255,255,0.06);
    transition:all 0.3s ease;
}
.partner-logo.active span {
    color:#fff;
    border-color:rgba(255,140,0,0.4);
    background:rgba(255,106,0,0.2);
}
.partner-logo:not(.active):hover span { color:#fff; border-color:rgba(255,255,255,0.25); background:rgba(255,255,255,0.1); }

/* Light mode overrides — improved visibility & contrast */
body.light-mode .partners-bar,
[data-theme="light"] .partners-bar {
    background:linear-gradient(to bottom,#f4f4f4,#fafafa);
}
body.light-mode .partners-bar::before,
[data-theme="light"] .partners-bar::before {
    background:radial-gradient(circle at center,rgba(255,106,0,0.06),transparent 70%);
}
body.light-mode .partner-wrapper::before,
[data-theme="light"] .partner-wrapper::before { background:linear-gradient(to right,#f4f4f4,transparent); }
body.light-mode .partner-wrapper::after,
[data-theme="light"] .partner-wrapper::after  { background:linear-gradient(to left,#f4f4f4,transparent); }
/* Subtle track tint — prevents white-wash */
body.light-mode .partners-track,
body.light-mode .partner-track,
[data-theme="light"] .partners-track,
[data-theme="light"] .partner-track {
    background:linear-gradient(to right,rgba(255,255,255,0),rgba(0,0,0,0.03),rgba(255,255,255,0));
}
/* Default logos — clearly visible, full colour */
body.light-mode .partner-logo,
[data-theme="light"] .partner-logo {
    opacity:0.7;
    filter:grayscale(0%);
    color:#444;
}
/* Inactive logos — dimmed but still readable (not invisible) */
body.light-mode .partner-logo.inactive,
[data-theme="light"] .partner-logo.inactive {
    opacity:0.5;
    filter:grayscale(40%);
}
/* Active / center logo — prominent highlight */
body.light-mode .partner-logo.active,
[data-theme="light"] .partner-logo.active {
    opacity:1;
    filter:none;
    color:#FF6A00;
    transform:scale(1.15);
    background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,179,71,0.2));
    border-color:rgba(255,106,0,0.35);
    border-radius:12px;
    padding:6px 14px;
    box-shadow:0 0 20px rgba(255,106,0,0.25);
}
/* Hover — full opacity, slight lift */
body.light-mode .partner-logo:not(.active):hover,
[data-theme="light"] .partner-logo:not(.active):hover {
    opacity:1;
    filter:grayscale(0%);
    transform:scale(1.08);
    color:#222;
}
/* Span text — readable on light background */
body.light-mode .partner-logo span,
[data-theme="light"] .partner-logo span {
    color:#444;
    font-weight:500;
    border-color:rgba(0,0,0,0.1);
    background:rgba(0,0,0,0.04);
}
body.light-mode .partner-logo.active span,
[data-theme="light"] .partner-logo.active span {
    color:#ff6a00;
    border-color:rgba(255,106,0,0.3);
    background:rgba(255,106,0,0.08);
}
body.light-mode .partner-logo:not(.active):hover span,
[data-theme="light"] .partner-logo:not(.active):hover span {
    color:#222;
    border-color:rgba(0,0,0,0.18);
    background:rgba(0,0,0,0.06);
}
/* Label */
body.light-mode .partners-label,
[data-theme="light"] .partners-label { color:#666; text-shadow:none; }

/* Dark mode — keep strong glow (explicit reinforcement) */
body.dark-mode .partner-logo.active {
    box-shadow:0 0 25px rgba(255,106,0,0.5), 0 0 50px rgba(255,140,0,0.2);
}

@keyframes scrollLeft  { 0% { transform:translateX(0); }    100% { transform:translateX(-50%); } }
@keyframes scrollRight { 0% { transform:translateX(-50%); } 100% { transform:translateX(0); }    }
@keyframes scrollLoop  { 0% { transform:translateX(0); }    100% { transform:translateX(-50%); } } /* alias */
@keyframes marquee     { 0% { transform:translateX(0); }    100% { transform:translateX(-50%); } } /* alias */

/* ======================
   27b. CLIENTS BAR
   ====================== */
.clients-bar {
    position:relative;
    padding:4rem 0 3rem;
    background:linear-gradient(to bottom,rgba(10,10,10,1),rgba(18,18,18,1));
    border-top:1px solid var(--border-glass);
    overflow:hidden;
}

/* Section heading */
.clients-heading {
    text-align:center;
    margin-bottom:2.5rem;
}
.clients-eyebrow {
    display:block;
    font-size:0.72rem;
    font-weight:700;
    letter-spacing:0.18em;
    text-transform:uppercase;
    color:var(--accent, #FF6A00);
    margin-bottom:0.6rem;
    text-shadow:0 0 8px rgba(255,106,0,0.25);
}
.clients-title {
    font-size:1.8rem;
    font-weight:800;
    color:var(--text-primary);
    line-height:1.2;
    margin:0 0 0.75rem;
    position:relative;
    display:inline-block;
    padding-bottom:0.75rem;
}
.clients-title::after {
    content:'';
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:56px;
    height:3px;
    background:linear-gradient(90deg,#FF6A00,#FF8C00);
    border-radius:2px;
}

/* Track wrapper */
.client-wrapper {
    position:relative;
    overflow:hidden;
    width:100%;
}
.client-track-wrap { overflow:hidden; width:100%; }

.clients-track, .client-track {
    display:flex;
    width:max-content;
    animation:scrollRight 30s linear infinite;
    position:relative;
    z-index:1;
}
.clients-track:hover, .client-track:hover { animation-play-state:paused; }
.clients-logos { display:flex; align-items:center; gap:3rem; padding:0 1.5rem; }

/* Logo card — always visible, white-glass (exact match to partner) */
.client-logo {
    opacity:0.9;
    filter:none;
    transition:all 0.4s ease;
    transform:scale(0.97);
    border-radius:12px;
    border:1px solid rgba(255,255,255,0.12);
    background:rgba(255,255,255,0.92);
    padding:8px 14px;
    box-shadow:0 4px 20px rgba(0,0,0,0.4);
    position:relative;
    overflow:hidden;
}
/* Inner orange glow — fades in on active (same as partner) */
.client-logo::before {
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(135deg,rgba(255,106,0,0.28),rgba(255,140,0,0.18));
    opacity:0;
    transition:opacity 0.4s ease;
    z-index:0;
    border-radius:inherit;
}
.client-logo.active::before { opacity:1; }

.client-logo:hover {
    opacity:1;
    transform:scale(1.06);
    border-color:rgba(255,140,0,0.35);
    box-shadow:0 0 15px rgba(255,106,0,0.35);
}
.client-logo.active {
    opacity:1;
    filter:none;
    transform:scale(1.12);
    border:1px solid rgba(255,140,0,0.45);
    border-radius:12px;
    box-shadow:0 0 25px rgba(255,106,0,0.4), 0 0 60px rgba(255,106,0,0.15);
    padding:8px 16px;
}
.client-logo img {
    height:46px;
    width:auto;
    max-width:120px;
    object-fit:contain;
    display:block;
    opacity:0.9;
    transition:opacity 0.3s ease, transform 0.3s ease;
    filter:none;
    position:relative;
    z-index:1;
}
.client-logo:hover img { opacity:1; transform:scale(1.05); }
.client-logo.active img { opacity:1; }

/* Dark mode */
body.dark-mode .clients-bar,
[data-theme="dark"] .clients-bar { background:#0e1016; }
body.dark-mode .client-logo,
[data-theme="dark"] .client-logo { background:rgba(255,255,255,0.92); border-color:rgba(255,255,255,0.15); box-shadow:0 4px 20px rgba(0,0,0,0.5); }
body.dark-mode .client-logo img,
[data-theme="dark"] .client-logo img { filter:brightness(1.05) contrast(1.05); }
body.dark-mode .clients-title,
[data-theme="dark"] .clients-title { color:#fff; }

/* Light mode */
body.light-mode .clients-bar,
[data-theme="light"] .clients-bar { background:#f4f4f4; border-top-color:rgba(0,0,0,0.08); }
body.light-mode .client-logo,
[data-theme="light"] .client-logo { opacity:0.78; background:rgba(255,255,255,0.85); border-color:rgba(0,0,0,0.08); }
body.light-mode .client-logo:hover,
[data-theme="light"] .client-logo:hover { opacity:1; box-shadow:0 4px 16px rgba(255,106,0,0.2); }
body.light-mode .clients-eyebrow,
[data-theme="light"] .clients-eyebrow { text-shadow:none; }

/* scrollRight keyframe defined above (26. PARTNERS BAR section) */

/* ======================
   27. CEO QUOTE
   ====================== */
.ceo-quote { margin-top:1.5rem; padding:1.5rem; }
.ceo-quote blockquote { font-size:0.95rem; font-style:italic; color:var(--text-secondary); line-height:1.7; margin:0 0 1rem 0; }
.ceo-info { display:flex; align-items:center; gap:0.75rem; }
.ceo-avatar { width:40px; height:40px; border-radius:50%; background:var(--accent-soft); display:flex; align-items:center; justify-content:center; color:var(--accent); font-size:1.5rem; }
.ceo-info strong { color:var(--text-primary); font-size:0.9rem; }
.ceo-info span { color:var(--text-muted); font-size:0.8rem; }

/* ======================
   28. TRUST BADGES
   ====================== */
.trust-badges { display:flex; gap:1rem; flex-wrap:wrap; margin-top:2rem; }
.badge-item { display:flex; align-items:center; gap:0.5rem; padding:0.5rem 1rem; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-sm); font-size:0.8rem; color:var(--text-secondary); }
.badge-item .fa { color:var(--accent); }

/* ======================
   29. INDUSTRIES SECTION
   ====================== */
.industries-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); gap:1.5rem; }
.industry-card { text-align:center; padding:2rem 1.5rem; background:var(--gradient-card); border:1px solid var(--border-glass); border-radius:var(--radius-lg); transition:all 0.4s ease; }
.industry-card:hover { border-color:rgba(255,106,0,0.3); transform:translateY(-4px); box-shadow:0 10px 40px rgba(0,0,0,0.2); }
.industry-icon { width:60px; height:60px; margin:0 auto 1rem; display:flex; align-items:center; justify-content:center; border-radius:50%; background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,140,0,0.25)); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); color:var(--accent); font-size:1.4rem; transition:all 0.3s ease; box-shadow:0 0 14px rgba(255,106,0,0.18); }
.industry-card:hover .industry-icon { background:linear-gradient(135deg,#FF6A00,#FF8C00); color:#fff; box-shadow:0 0 24px rgba(255,106,0,0.55); }
.industry-card h5 { font-size:1rem; font-weight:600; margin-bottom:0.5rem; color:var(--text-primary); }
.industry-card p { font-size:0.8rem; color:var(--text-muted); }

/* ======================
   30. TESTIMONIALS SECTION
   ====================== */
.testimonials-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(320px, 1fr)); gap:2rem; }
.testimonial-card { padding:2rem; position:relative; }
.testimonial-quote { position:absolute; top:1.5rem; left:1.5rem; font-size:1.5rem; color:var(--accent); opacity:0.3; }
.testimonial-card p { font-size:0.95rem; line-height:1.7; color:var(--text-secondary); margin-bottom:1.5rem; padding-top:1rem; }
.testimonial-author { display:flex; align-items:center; gap:0.75rem; margin-bottom:1rem; }
.author-avatar { width:44px; height:44px; border-radius:50%; background:var(--accent-soft); display:flex; align-items:center; justify-content:center; color:var(--accent); font-size:1.8rem; }
.testimonial-author strong { color:var(--text-primary); font-size:0.9rem; display:block; }
.testimonial-author span { color:var(--text-muted); font-size:0.8rem; }
.testimonial-metric { display:inline-flex; align-items:center; gap:0.5rem; padding:0.5rem 1rem; background:rgba(255,106,0,0.1); border:1px solid rgba(255,106,0,0.2); border-radius:var(--radius-sm); }
.metric-value { font-size:1.1rem; font-weight:700; color:var(--accent); }

/* ======================
   31. STATS DESCRIPTION
   ====================== */
.stat-desc { font-size:0.8rem; color:var(--text-muted); margin-top:0.5rem; }
.stats-grid { grid-template-columns:repeat(4, 1fr); }

/* ======================
   32. CARD CTA — Always visible
   ====================== */
.card-cta { margin-top:1rem; }
.card-cta .fa { font-size:0.75rem; }

/* ======================
   33. FOOTER CTA
   ====================== */
.footer-cta { background:linear-gradient(135deg, rgba(255,106,0,0.1) 0%, transparent 50%); padding:clamp(4rem,10vw,6rem) 0; }
.cta-content { text-align:center; max-width:700px; margin:0 auto; }
.cta-buttons { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2rem; }
.cta-buttons .btn-premium, .cta-buttons .btn-outline { opacity:1; animation:none; }

/* ======================
   34. ENTERPRISE FOOTER
   ====================== */
.footer-main { display:grid; grid-template-columns:1.5fr 2.5fr; gap:4rem; padding-bottom:3rem; border-bottom:1px solid var(--border-glass); }
.footer-brand p { color:rgba(255,255,255,0.72); font-size:0.9rem; line-height:1.7; margin:1.5rem 0; }
.footer-contact p { color:rgba(255,255,255,0.6); font-size:0.85rem; margin:0.5rem 0; }
.footer-contact .fa { color:var(--accent); width:16px; margin-right:0.5rem; }
.footer-links { display:grid; grid-template-columns:repeat(4, 1fr); gap:2rem; }
.footer-col h5 { font-size:0.9rem; font-weight:600; color:#ffffff; margin-bottom:1.25rem; text-transform:uppercase; letter-spacing:0.05em; }
.footer-col ul { list-style:none; padding:0; margin:0; }
.footer-col li { margin-bottom:0.6rem; }
.footer-col a { color:rgba(255,255,255,0.68); font-size:0.85rem; transition:color 0.2s ease; }
.footer-col a:hover { color:#ff7a00; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:1.5rem; border-top:1px solid var(--border-glass); flex-wrap:wrap; gap:0.5rem 1rem; }
.footer-bottom p { margin:0; color:rgba(255,255,255,0.6); }
.footer-bottom a { color:rgba(255,255,255,0.55); }
.footer-bottom a:hover { color:#ff7a00; }
/* Light mode footer */
[data-theme="light"] .footer-brand p { color:rgba(0,0,0,0.65); }
[data-theme="light"] .footer-contact p { color:rgba(0,0,0,0.55); }
[data-theme="light"] .footer-col h5 { color:#111111; }
[data-theme="light"] .footer-col a { color:rgba(0,0,0,0.58); }
[data-theme="light"] .footer-col a:hover { color:#ff7a00; }
[data-theme="light"] .footer-bottom p { color:rgba(0,0,0,0.5); }
[data-theme="light"] .footer-bottom a { color:rgba(0,0,0,0.45); }
.crafted-by { color:var(--text-muted); font-size:0.8rem; transition:color 0.2s ease; }
.crafted-by:hover { color:var(--accent); }

/* ======================
   35. RESPONSIVE ENTERPRISE
   ====================== */
@media (max-width:1024px) {
    .footer-main { grid-template-columns:1fr; gap:2rem; }
    .footer-links { grid-template-columns:repeat(2, 1fr); }
    .stats-grid { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width:768px) {
    .hero-trust-badges { gap:1rem; }
    .hero-trust-badges span { font-size:0.75rem; }
    .partners-logos { gap:1.5rem; }
    .footer-links { grid-template-columns:1fr 1fr; }
    .footer-socials { justify-content:center; }
    .footer-bottom { flex-direction:column; text-align:center; gap:0.5rem; font-size:12px; line-height:1.6; }
    .crafted-by { order:2; }
    .industries-grid { grid-template-columns:repeat(2, 1fr); }
    .testimonials-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr 1fr; }
    .cta-buttons { flex-direction:column; align-items:center; }
}
@media (max-width:480px) {
    .industries-grid { grid-template-columns:1fr; }
    .footer-links { grid-template-columns:1fr; text-align:center; }
    .stats-grid { grid-template-columns:1fr; }
}

/* ======================
   36. FAQ SECTION
   ====================== */
.faq-section { background:var(--bg-secondary); }
.faq-grid { max-width:800px; margin:0 auto; }
.faq-item { margin-bottom:1rem; border:1px solid var(--border-glass); border-radius:var(--radius-md); overflow:hidden; transition:all 0.3s ease; }
.faq-item:hover { border-color:rgba(255,106,0,0.2); }
.faq-item.open { border-color:var(--accent); box-shadow:0 5px 30px rgba(255,106,0,0.1); }
.faq-question { width:100%; display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:1.25rem 1.5rem; background:transparent; border:none; cursor:pointer; text-align:left; font-size:1rem; font-weight:600; color:var(--text-primary); font-family:var(--font-body); transition:all 0.3s ease; }
.faq-question:hover { background:rgba(255,106,0,0.03); }
.faq-question span { flex:1; }
.faq-question i { color:var(--accent); transition:transform 0.3s ease; }
.faq-item.open .faq-question i { transform:rotate(180deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.4s ease, padding 0.4s ease; }
.faq-item.open .faq-answer { max-height:500px; padding:0 1.5rem 1.5rem; }
.faq-answer p { color:var(--text-secondary); font-size:0.95rem; line-height:1.7; }

/* ======================
   37. MODAL SYSTEM
   ====================== */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.85); backdrop-filter:blur(8px); z-index:2000; display:flex; align-items:center; justify-content:center; padding:2rem; opacity:0; visibility:hidden; transition:all 0.3s ease; overflow-y:auto; -webkit-overflow-scrolling:touch; }
.modal-overlay.open { opacity:1; visibility:visible; }
.modal-content { background:var(--bg-secondary); border:1px solid var(--border-glass); border-radius:var(--radius-lg); max-width:550px; width:100%; max-height:90vh; overflow-y:auto; position:relative; padding:2.5rem; transform:translateY(20px) scale(0.95); transition:transform 0.3s ease; scrollbar-width:none; scroll-behavior:smooth; box-shadow:0 20px 60px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.05); }
.modal-content::before { content:''; position:absolute; inset:0; border-radius:var(--radius-lg); border:1px solid rgba(255,140,0,0.12); pointer-events:none; }
/* Dark mode: stronger modal contrast */
[data-theme="dark"] .modal-content, body.dark-mode .modal-content { background:#0f0f0f; box-shadow:0 20px 60px rgba(0,0,0,0.85), 0 0 0 1px rgba(255,255,255,0.05); }
.modal-content::-webkit-scrollbar { display:none; }
.modal-overlay.open .modal-content { transform:translateY(0) scale(1); }
.modal-content.modal-lg { max-width:700px; }
.modal-close { position:absolute; top:1rem; right:1rem; width:36px; height:36px; display:flex; align-items:center; justify-content:center; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:50%; color:var(--text-secondary); font-size:1.5rem; cursor:pointer; transition:all 0.3s ease; line-height:1; }
.modal-close:hover { background:var(--accent); color:#fff; border-color:var(--accent); }
.modal-title { display:flex; align-items:center; gap:0.75rem; font-size:1.5rem; font-weight:700; color:var(--text-primary); margin-bottom:0.5rem; }
.modal-title i { color:var(--accent); }
.modal-subtitle { color:var(--text-secondary); font-size:0.95rem; margin-bottom:1.5rem; }
.modal-body { color:var(--text-secondary); font-size:0.95rem; line-height:1.7; max-height:80vh; overflow-y:auto; scrollbar-width:none; scroll-behavior:smooth; position:relative; }
.modal-body::-webkit-scrollbar { display:none; }
.modal-body::after { content:''; display:block; position:sticky; bottom:0; height:40px; width:100%; background:linear-gradient(to bottom, transparent, rgba(0,0,0,0.08)); pointer-events:none; }
[data-theme="dark"] .modal-body::after, body.dark-mode .modal-body::after { background:linear-gradient(to bottom, transparent, rgba(0,0,0,0.55)); }
.modal-body h5 { color:var(--text-primary); font-size:1.1rem; font-weight:600; margin:1.5rem 0 0.75rem; }
.modal-body h5:first-child { margin-top:0; }
.modal-body p { margin-bottom:1rem; }
.modal-body a { color:var(--accent); }
.modal-body a:hover { text-decoration:underline; }
.modal-footer { display:flex; gap:15px; justify-content:space-between; flex-wrap:wrap; margin-top:1.5rem; }

/* ======================
   38. PRODUCT POPUP STYLES
   ====================== */
.product-header { display:flex; align-items:center; gap:1rem; margin-bottom:1rem; }
.product-header .product-icon { width:56px; height:56px; display:flex; align-items:center; justify-content:center; background:var(--accent-soft); border-radius:var(--radius-md); color:var(--accent); font-size:1.5rem; }
.product-header h3 { font-size:1.4rem; font-weight:700; color:var(--text-primary); }
.product-desc { color:var(--text-secondary); font-size:0.95rem; line-height:1.6; margin-bottom:1.5rem; }
.product-features { list-style:none; padding:0; margin:0 0 1.5rem 0; }
.product-features li { display:flex; align-items:flex-start; gap:0.75rem; padding:0.5rem 0; color:var(--text-secondary); font-size:0.9rem; }
.product-features li::before { content:'\f00c'; font-family:FontAwesome; color:var(--accent); flex-shrink:0; margin-top:2px; }
.provider-tags { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:1.5rem; }
.provider-tags span { padding:0.35rem 0.75rem; background:var(--accent-soft); border:1px solid rgba(255,106,0,0.2); border-radius:20px; color:var(--accent); font-size:0.8rem; font-weight:500; }
.product-cta { display:flex; gap:1rem; flex-wrap:wrap; }
.product-cta .btn-premium, .product-cta .btn-outline { flex:1; min-width:160px; justify-content:center; opacity:1; animation:none; }

/* ======================
   39. QUICK QUOTE FORM ENHANCEMENTS
   ====================== */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:600px) { .form-row { grid-template-columns:1fr; } }
.premium-form select { width:100%; padding:0.85rem 1.2rem; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-sm); color:var(--text-primary); font-size:0.95rem; font-family:var(--font-body); transition:all 0.25s ease; outline:none; cursor:pointer; appearance:none; box-shadow:inset 0 2px 6px rgba(0,0,0,0.35); background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23999' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e"); background-position:right 1rem center; background-repeat:no-repeat; background-size:1.5em 1.5em; padding-right:2.5rem; }
.premium-form select:focus { border-color:var(--accent); box-shadow:0 0 0 2px rgba(255,122,0,0.18), inset 0 2px 6px rgba(0,0,0,0.45); }
[data-theme="light"] .premium-form select { background-color:#ffffff; border-color:rgba(0,0,0,0.12); box-shadow:inset 0 1px 3px rgba(0,0,0,0.07); }
[data-theme="light"] .premium-form select:focus { box-shadow:0 0 0 2px rgba(255,122,0,0.14), inset 0 1px 3px rgba(0,0,0,0.06); }
.premium-form select option { background:var(--bg-secondary); color:var(--text-primary); }
.premium-form select optgroup { color:var(--accent); font-weight:600; }

/* ======================
   40. WHATSAPP BUTTON
   ====================== */
.form-buttons { display:flex; gap:1rem; flex-wrap:wrap; margin-top:1.5rem; }
.form-buttons .btn-premium { flex:1; min-width:180px; }
.form-buttons .btn-whatsapp { flex:1; min-width:180px; justify-content:center; }

/* ======================
   41. IMPROVED MOBILE NAVIGATION
   ====================== */
@media (max-width:991px) {
    /* Mobile nav panel — light style in all modes */
    .nav-links { position:fixed; top:0; right:-100%; width:85%; max-width:350px; height:100vh; background:rgba(255,255,255,0.98); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); flex-direction:column; padding:5rem 2rem 2rem; gap:0; overflow-y:auto; transition:right 0.4s var(--ease); z-index:1100; border-left:1px solid rgba(0,0,0,0.08); }
    .nav-links.mobile-open { right:0; }
    .nav-links > li { border-bottom:1px solid rgba(0,0,0,0.07); }
    .nav-links > li > a { display:block; padding:1rem 0; font-size:1rem; color:#111111; }
    .nav-links > li > a::after { display:none; }
    
    /* Mobile Products Dropdown - Accordion Style */
    .products-dropdown { position:static; }
    .products-dropdown .mega-menu { position:static; display:none; background:transparent; border:none; border-top:1px solid var(--border-glass); border-radius:0; box-shadow:none; padding:0.5rem 0 0.5rem 1rem; margin-top:0.5rem; animation:none; max-height:min(70vh,480px); overflow-y:auto; overflow-x:hidden; scroll-behavior:smooth; scrollbar-width:thin; scrollbar-color:rgba(255,106,0,0.4) transparent; }
    .products-dropdown.open > .mega-menu { display:block; }
    .products-toggle i { transition:transform 0.3s ease; }
    .products-dropdown.open > .products-toggle i { transform:rotate(180deg); }
    
    /* Mobile Mega Parent - Accordion */
    .mega-parent { position:static; }
    .mega-parent > .mega-sub { position:static; display:none; background:transparent; border:none; border-radius:0; box-shadow:none; padding:0 0 0 1rem; margin:0; animation:none; min-width:auto; }
    .mega-parent.active > .mega-sub { display:block; }
    .mega-toggle { padding:0.75rem 0; font-size:0.9rem; white-space:normal; overflow:visible; }
    .mega-toggle i { transform:rotate(-90deg); }
    .mega-parent.active > .mega-toggle i { transform:rotate(0); }
    
    /* Service links in mobile — dark text on white panel */
    .service-link { display:block; padding:0.5rem 0; font-size:0.85rem; color:#555555; border-radius:0; margin:0; white-space:normal; overflow:visible; text-overflow:clip; }
    .service-link:hover { color:var(--accent); }
    
    /* Theme toggle compact in navbar (next to hamburger) */
    .nav-right { gap:6px; }
    .theme-toggle { padding:4px 10px; font-size:12px; border-radius:20px; margin-left:0; }
    .theme-toggle .text { display:none; }
    .theme-toggle .icon { font-size:0.9rem; }
    .nav-toggle { display:flex; }
}

/* Desktop → Transparent */
[data-theme="light"] .nav-links,
[data-theme="dark"] .nav-links {
    background: transparent;
}

/* Mobile மட்டும் → White background */
@media (max-width: 768px) {
    [data-theme="light"] .nav-links,
    [data-theme="dark"] .nav-links {
        background: rgba(255,255,255,0.98);
    }
}

.hero-desc {
    font-family: 'Inter', 'Segoe UI', 'Roboto', sans-serif;
    font-size: 15.5px; /* slightly smaller & clean */
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.75); /* for dark mode */
    max-width: 680px;
    margin-bottom: 2rem;
}

/* Light mode */
[data-theme="light"] .hero-desc {
    color: rgba(0, 0, 0, 0.65);
}

/* Mobile responsive */
@media (max-width: 768px) {
    .hero-desc {
        font-size: 14px;
        line-height: 1.6;
    }
}

/* [data-theme="light"] .nav-links > li { border-bottom-color:rgba(0,0,0,0.08); } */

/* ======================
   42. SERVICE BADGE
   ====================== */
.service-badge { display:flex; align-items:center; gap:0.5rem; background:var(--accent-soft); border:1px solid rgba(255,106,0,0.3); border-radius:var(--radius-sm); padding:1rem 1.5rem; margin-bottom:2rem; font-size:0.9rem; color:var(--accent); }
.service-badge i { font-size:1.1rem; }
.service-badge strong { color:var(--text-primary); }
.service-badge .badge-path { color:var(--text-muted); font-size:0.8rem; }
.badge-close { margin-left:auto; background:none; border:none; color:var(--text-muted); font-size:1.2rem; line-height:1; cursor:pointer; padding:0; transition:color 0.2s ease; flex-shrink:0; }
.badge-close:hover { color:var(--accent); }

/* ======================
   43. SERVICE TOAST NOTIFICATION
   ====================== */
.service-toast { position:fixed; bottom:-100px; left:50%; transform:translateX(-50%); background:var(--bg-secondary); border:1px solid var(--accent); border-radius:var(--radius-md); padding:1rem 1.5rem; display:flex; align-items:center; gap:0.75rem; box-shadow:0 10px 40px rgba(0,0,0,0.3); z-index:3000; transition:bottom 0.4s var(--bounce); }
.service-toast.show { bottom:2rem; }
.service-toast i { color:var(--accent); font-size:1.2rem; }
.service-toast span { color:var(--text-secondary); font-size:0.9rem; }
.service-toast strong { color:var(--text-primary); }
.toast-close { background:none; border:none; color:var(--text-muted); font-size:1.2rem; cursor:pointer; padding:0 0 0 1rem; transition:color 0.2s ease; }
.toast-close:hover { color:var(--accent); }

/* ======================
   44. CONTACT GRID + MAP
   ====================== */
/* Mobile ≤768px */
@media (max-width:768px) {
    .contact-grid { grid-template-columns:1fr; gap:1.5rem; width:100%; }
    .contact-left { order:2; height:auto; min-height:0; }
    .contact-right { order:1; height:auto; min-height:0; }
    .about-grid { grid-template-columns:1fr; gap:2rem; }
    .form-buttons { flex-direction:column; }
    .form-buttons .btn-premium, .form-buttons .btn-whatsapp { width:100%; justify-content:center; }
    .premium-section { padding-left:0; padding-right:0; }
    .premium-container { padding:0 1rem; width:100%; box-sizing:border-box; }
}
/* Tablet 768–1024px */
@media (min-width:769px) and (max-width:1024px) {
    .contact-grid { grid-template-columns:1fr; gap:2rem; }
    .contact-left { order:2; }
    .contact-right { order:1; }
}
/* Laptop 1024px+ */
@media (min-width:1025px) {
    .contact-grid { grid-template-columns:1fr 1.2fr; gap:2.5rem; }
}
.contact-map iframe { display:block; }

/* ======================
   45. NAVBAR CTA BUTTON
   ====================== */
.nav-cta-btn, .btn-quote, .card-cta, .os-card-cta { display:inline-flex; align-items:center; gap:6px; padding:8px 18px; background:linear-gradient(135deg,#FF6A00,#FF8C00,#FFB347); background-size:200% 200%; background-position:left center; color:#fff !important; font-size:14px; font-weight:500; border-radius:999px; border:none; text-decoration:none; transition:all 0.3s ease; box-shadow:0 4px 20px rgba(255,106,0,0.35); cursor:pointer; letter-spacing:0.01em; }
.nav-cta-btn:hover, .btn-quote:hover, .card-cta:hover, .os-card-cta:hover { transform:scale(1.05); background-position:right center; box-shadow:0 8px 30px rgba(255,140,0,0.5); color:#fff !important; filter:brightness(1.05); }
.nav-cta-btn::after { display:none !important; }
.nav-cta-btn .fa { font-size:0.75rem; }
@media (max-width:768px) {
    .nav-cta-btn { width:100%; justify-content:center; margin-top:1rem; padding:0.9rem 2rem; }
}

/* ======================
   46. WHATSAPP FLOATING BUTTON
   ====================== */
.whatsapp-float { position:fixed; bottom:90px; right:24px; z-index:999; width:56px; height:56px; background:#25D366; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,0.4); transition:all 0.3s ease; animation:pulse-whatsapp 2s infinite; }
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 6px 30px rgba(37,211,102,0.5); }
.whatsapp-float svg { width:28px; height:28px; fill:#fff; }
.whatsapp-float .tooltip { position:absolute; right:70px; background:var(--bg-secondary); color:var(--text-primary); padding:0.5rem 1rem; border-radius:var(--radius-sm); font-size:0.8rem; white-space:nowrap; opacity:0; visibility:hidden; transition:all 0.3s ease; border:1px solid var(--border-glass); }
.whatsapp-float:hover .tooltip { opacity:1; visibility:visible; }
@keyframes pulse-whatsapp { 0%,100% { box-shadow:0 4px 20px rgba(37,211,102,0.4); } 50% { box-shadow:0 4px 30px rgba(37,211,102,0.6), 0 0 0 10px rgba(37,211,102,0.1); } }

/* ======================
   47. SCROLL TO TOP BUTTON
   ====================== */
.scroll-top-btn { position:fixed; bottom:24px; right:24px; z-index:998; width:48px; height:48px; background:linear-gradient(135deg,#FF6A00,#FF8C00); border:none; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; visibility:hidden; transform:translateY(20px); transition:all 0.3s ease; box-shadow:0 4px 20px rgba(255,106,0,0.4); }
.scroll-top-btn.visible { opacity:1; visibility:visible; transform:translateY(0); }
.scroll-top-btn:hover { background:linear-gradient(135deg,#FF8C00,#FFB347); transform:translateY(-3px); box-shadow:0 8px 28px rgba(255,106,0,0.55); }
.scroll-top-btn svg { width:20px; height:20px; fill:#fff; }

/* ======================
   48. BODY SCROLL LOCK
   ====================== */
body.modal-open { overflow:hidden !important; padding-right:var(--scrollbar-width, 0px); }
html.modal-open { overflow:hidden !important; }

/* ======================
   49. WHITE SPACE FIX
   ====================== */
html, body { margin:0; padding:0; }
html { min-height:100%; }
body { padding-top:70px; }
.hero-section { margin-top:-70px; }
.premium-nav { top:0; margin:0; }
body.dark-mode .premium-nav, [data-theme="dark"] .premium-nav { background:rgba(255,255,255,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid rgba(0,0,0,0.07); box-shadow:0 2px 12px rgba(0,0,0,0.06); }
body.light-mode .premium-nav, [data-theme="light"] .premium-nav { background:rgba(255,255,255,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid rgba(0,0,0,0.07); box-shadow:0 2px 12px rgba(0,0,0,0.06); }

/* ======================
   51. NETWORK SECTION ENHANCEMENTS
   ====================== */
.network-section { background:var(--bg-primary); position:relative; overflow:hidden; }
.network-section::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 60%, rgba(255,106,0,0.06) 0%, transparent 65%); pointer-events:none; }
.network-svg-wrap { position:relative; padding:2rem 0; }
.network-svg-wrap::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:60%; height:50%; background:radial-gradient(ellipse at center, rgba(255,106,0,0.07) 0%, transparent 70%); border-radius:50%; pointer-events:none; }

/* ======================
   52. FIBER OPTIC CANVAS
   ====================== */
#fiberCanvas { position:absolute; top:0; left:0; width:100%; height:100%; z-index:0; pointer-events:none; opacity:0.55; }
.hero-section { isolation:isolate; }

/* ======================
   53. SECTION DEPTH & SPACING
   ====================== */
.premium-section { padding:60px 0; position:relative; }
.section-header { margin-bottom:clamp(2.5rem,5vw,3.5rem); }
.section-header .premium-h2 { text-shadow:0 2px 20px rgba(0,0,0,0.3); }
[data-theme="dark"] .section-header .premium-subtitle,
[data-theme="dark"] .service-card p,
[data-theme="dark"] .about-feature p { color:rgba(255,255,255,0.75) !important; }
[data-theme="light"] .section-header .premium-subtitle,
[data-theme="light"] .service-card p,
[data-theme="light"] .about-feature p { color:rgba(0,0,0,0.65) !important; }

/* ======================
   54. HERO CONTENT RESPONSIVE
   ====================== */
.hero-content { max-width:540px; width:50%; }
/* Mobile: re-centre everything + fix 100vh cut-off */
@media (max-width:768px) {
    .hero-section { justify-content:center; padding-left:0; min-height:auto; height:auto; padding-top:90px; padding-bottom:50px; align-items:flex-start; }
    .hero-content { display:flex; flex-direction:column; align-items:center; text-align:center; max-width:92%; width:92%; padding:0 16px 2rem; }
    .hero-buttons { justify-content:center; flex-direction:column; align-items:center; width:100%; }
    .hero-buttons a, .hero-buttons button { width:80%; text-align:center; justify-content:center; }
    .hero-trust-badges { justify-content:center; }
    .hero-content .premium-subtitle { margin:0 auto 2rem; max-width:100%; }
    .hero-content .premium-h1 { font-size:clamp(28px,7vw,38px); line-height:1.3; }
}

/* ======================
   55. CARD ELEVATION, SECTION SEPARATION, ICON BOX
   ====================== */
.card { border-radius:20px; padding:30px; transition:all 0.3s ease; }
[data-theme="light"] .card, body.light-mode .card { background:#ffffff; border:1px solid rgba(0,0,0,0.06); box-shadow:0 8px 20px rgba(0,0,0,0.04), 0 2px 6px rgba(0,0,0,0.06); }
[data-theme="dark"] .card, body.dark-mode .card { background:var(--bg-card); border:1px solid var(--border-glass); box-shadow:0 10px 30px rgba(0,0,0,0.5); }
.card:hover { transform:translateY(-6px); box-shadow:0 20px 50px rgba(0,0,0,0.15), 0 10px 20px rgba(255,106,0,0.15); }
.section-light { background:linear-gradient(180deg,#f8f9fb,#ffffff); padding:60px 0; }
[data-theme="dark"] .section-light { background:linear-gradient(180deg,var(--bg-secondary),var(--bg-primary)); }
.icon-box { width:70px; height:70px; border-radius:16px; background:rgba(255,106,0,0.1); display:flex; align-items:center; justify-content:center; transition:0.3s; }
.card:hover .icon-box { background:#FF6A00; color:#fff; transform:scale(1.1); }

/* ======================
   56. MAP SECTION FULL WIDTH
   ====================== */
.map-section { width:100%; height:400px; margin-top:60px; }
.map-section iframe { width:100%; height:100%; border:0; border-radius:20px; display:block; }

/* ======================
   57. OUR PRESENCE SECTION
   ====================== */
.presence-section { padding:60px 0; }
.presence-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:25px; margin-top:2rem; }
.presence-card { background:#fff; border-radius:20px; padding:2rem 1.75rem; border:1px solid rgba(0,0,0,0.05); box-shadow:0 10px 30px rgba(0,0,0,0.05), 0 1px 2px rgba(0,0,0,0.08); transition:all 0.3s ease; text-align:center; }
[data-theme="dark"] .presence-card { background:var(--bg-card); border-color:var(--border-glass); }
.presence-card:hover { transform:translateY(-8px) scale(1.02); box-shadow:0 20px 60px rgba(0,0,0,0.15), 0 10px 20px rgba(255,106,0,0.2); }
.presence-card .presence-icon { width:70px; height:70px; border-radius:50%; background:rgba(255,106,0,0.1); display:flex; align-items:center; justify-content:center; margin:0 auto 1.25rem; font-size:1.6rem; color:#FF6A00; transition:0.3s; }
.presence-card:hover .presence-icon { background:#FF6A00; color:#fff; transform:scale(1.1); }
.presence-card h4 { font-size:1.15rem; font-weight:700; margin-bottom:0.5rem; color:var(--text-primary); }
.presence-card p { color:#555; font-size:0.9rem; line-height:1.6; margin:0; }
[data-theme="dark"] .presence-card p { color:rgba(255,255,255,0.65); }

/* ======================
   58. TYPOGRAPHY BASE FIX
   ====================== */
[data-theme="light"] p { color:#555; line-height:1.6; }
[data-theme="light"] h2, [data-theme="light"] h3, [data-theme="light"] h4, [data-theme="light"] h5 { color:#111; }

/* ======================
   50. FLOATING BUTTONS RESPONSIVE
   ====================== */
@media (max-width:768px) {
    .whatsapp-float { bottom:80px; right:16px; width:50px; height:50px; }
    .whatsapp-float svg { width:24px; height:24px; }
    .whatsapp-float .tooltip { display:none; }
    .scroll-top-btn { bottom:20px; right:16px; width:42px; height:42px; }
    .scroll-top-btn svg { width:18px; height:18px; }
    .partners-logos { gap:2rem; }
}

/* ======================
   60. NETWORK, ICONS & GLOBAL CLEANUP
   ====================== */

/* Hide unwanted location text below SVG map */
.network-locations-text { display:none !important; }

/* Network label — Tasks 1, 2, 4 */
.network-label { font-size:12px; font-weight:600; white-space:nowrap; fill:rgba(255,255,255,0.85); }
.network-label.highlight { fill:#FF6A00 !important; }
body.light-mode .network-label, [data-theme="light"] .network-label { fill:#222222 !important; }
body.light-mode .network-label.highlight, [data-theme="light"] .network-label.highlight { fill:#FF6A00 !important; }
body.dark-mode .network-label, [data-theme="dark"] .network-label { fill:#eeeeee !important; }
body.dark-mode .network-label.highlight, [data-theme="dark"] .network-label.highlight { fill:#FF6A00 !important; }

/* Network node — Tasks 3, 4, 7 */
@keyframes pulseNode { 0% { transform:scale(1.2); } 50% { transform:scale(1.4); } 100% { transform:scale(1.2); } }
.network-node { width:10px; height:10px; background:#FF6A00; border-radius:50%; box-shadow:0 0 10px rgba(255,106,0,0.6); }
.network-node.active { box-shadow:0 0 20px rgba(255,106,0,0.9); }
.network-node.highlight { background:#FF6A00; transform:scale(1.3); box-shadow:0 0 15px rgba(255,106,0,0.8), 0 0 30px rgba(255,106,0,0.5); animation:pulseNode 2s infinite; }
[data-theme="light"] .network-node, body.light-mode .network-node { box-shadow:0 0 8px rgba(255,106,0,0.4); }

/* Network container — Tasks 5, 6 */
.network-svg-wrap { position:relative; padding:2rem 0; }
.network-svg-wrap svg { transform:scale(1.15); transform-origin:center; }
.network-svg-wrap::before { content:''; position:absolute; width:500px; height:500px; background:radial-gradient(circle,rgba(255,106,0,0.25),transparent); top:50%; left:50%; transform:translate(-50%,-50%); filter:blur(80px); pointer-events:none; border-radius:50%; z-index:0; }

/* Network line visibility */
.network-line { stroke:rgba(255,106,0,0.5); stroke-width:2; }
[data-theme="light"] .network-line, body.light-mode .network-line { stroke:rgba(255,106,0,0.6) !important; }
[data-theme="dark"] .network-line, body.dark-mode .network-line { stroke:rgba(255,106,0,0.8) !important; }

/* Task 6: Compact spacing — card grids */
.services-grid { gap:25px; }
.industries-grid { gap:25px; }
.testimonials-grid { gap:25px; }
.stats-grid { gap:20px; }

/* Task 7: Row gap fix */
.row { row-gap:25px; column-gap:20px; }

/* Task 9: Global cleanup — no double margins */
.section-header .premium-h2 { margin-bottom:0.6rem; }
.section-header .premium-subtitle { margin-bottom:0; }
.about-features { gap:1.5rem; margin-top:1.5rem; }
.about-grid { gap:3rem; }
.contact-grid { gap:2.5rem; }
.footer-main { padding-bottom:2rem; }

/* Contact left column — stretch layout */
.contact-left { display:flex; flex-direction:column; gap:10px; height:100%; width:100%; }
.contact-right { height:100%; display:flex; flex-direction:column; width:100%; }

/* Why Choose Us block */
.contact-why { margin-top:0; padding:1.2rem; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-md); }
.contact-why h5 { font-size:0.82rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--accent); margin-bottom:0.7rem; }
.contact-why ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:0.45rem; }
.contact-why li { display:flex; align-items:center; gap:0.55rem; font-size:0.82rem; color:var(--text-secondary); }
.contact-why li .fa { color:#FF8C00; font-size:0.85rem; flex-shrink:0; }
[data-theme="light"] .contact-why li, body.light-mode .contact-why li { color:#444; }

/* Quick contact strip */
.contact-quick { margin-top:0; padding:1rem 1.2rem; background:linear-gradient(135deg,rgba(255,106,0,0.07),rgba(255,140,0,0.04)); border:1px solid rgba(255,106,0,0.18); border-radius:var(--radius-md); }
.contact-quick h5 { font-size:0.82rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--accent); margin-bottom:0.55rem; }
.contact-quick ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:0.4rem; }
.contact-quick li { display:flex; align-items:center; gap:0.55rem; font-size:0.82rem; color:var(--text-secondary); }
.contact-quick li .fa { color:#FF8C00; font-size:0.8rem; flex-shrink:0; }
[data-theme="light"] .contact-quick li, body.light-mode .contact-quick li { color:#444; }

/* ======================
   61. COMPANY / VISION SPLIT SECTIONS
   ====================== */
.split-section { background:var(--bg-primary); }
.split-section--alt { background:var(--bg-secondary); }
.split-row { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.split-text { display:flex; flex-direction:column; gap:0; }
.split-desc { color:var(--text-secondary); font-size:1rem; line-height:1.75; margin:0 0 1.75rem; }
.split-list { list-style:none; margin:0 0 2rem; padding:0; display:flex; flex-direction:column; gap:0.85rem; }
.split-list li { display:flex; align-items:flex-start; gap:0.75rem; color:var(--text-secondary); font-size:0.95rem; line-height:1.5; }
.split-list li .fa { color:var(--accent); font-size:1rem; margin-top:2px; flex-shrink:0; }
.split-cta { align-self:flex-start; display:inline-flex; align-items:center; gap:0.5rem; padding:11px 24px; background:linear-gradient(135deg,#FF6A00,#FF8C00); color:#fff !important; font-size:0.9rem; font-weight:600; border-radius:999px; border:none; cursor:pointer; transition:all 0.3s ease; box-shadow:none; text-decoration:none; }
.split-cta:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(255,106,0,0.35); color:#fff !important; }
.split-cta .fa { font-size:0.8rem; }
.split-image { position:relative; }
.split-img-wrap { border-radius:20px; overflow:hidden; aspect-ratio:4/3; position:relative; box-shadow:0 20px 60px rgba(0,0,0,0.25); }
.split-img-wrap img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.55s ease; }
.split-img-wrap:hover img { transform:scale(1.05); }
.split-img-wrap::after { content:''; position:absolute; inset:0; border-radius:20px; border:1px solid var(--border-glass); pointer-events:none; }
/* Light mode overrides */
body.light-mode .split-desc, [data-theme="light"] .split-desc { color:#444; }
body.light-mode .split-list li, [data-theme="light"] .split-list li { color:#444; }
/* Responsive */
@media (max-width:900px) {
    .split-row { grid-template-columns:1fr; gap:2.5rem; }
    .split-section--alt .split-image { order:-1; }
}

/* ======================
   62. OUR SERVICES CAROUSEL
   ====================== */
.our-services-section { background:var(--bg-primary); }
.os-carousel-wrap { position:relative; padding:2rem 0 3rem; }

/* Track — perspective stage */
.os-track {
    display:flex;
    justify-content:center;
    align-items:center;
    perspective:1200px;
    min-height:480px;
    position:relative;
}

/* Base card */
.os-card {
    position:absolute;
    width:320px;
    min-height:380px;
    background:#ffffff;
    border:1px solid #eeeeee;
    border-radius:16px;
    padding:24px 22px 20px;
    display:flex;
    flex-direction:column;
    gap:0;
    box-shadow:0 4px 20px rgba(0,0,0,0.07);
    transition:all 0.28s cubic-bezier(0.34,1.1,0.64,1);
    opacity:0;
    pointer-events:none;
    transform:translateX(0) scale(0.75) rotateY(0deg);
    will-change:transform,opacity;
    backface-visibility:hidden;
}
body.dark-mode .os-card, [data-theme="dark"] .os-card {
    background:rgba(255,255,255,0.05);
    border-color:rgba(255,255,255,0.08);
    box-shadow:0 4px 30px rgba(0,0,0,0.4);
}

/* Positional states */
.os-card--center {
    transform:translateX(0) scale(1) rotateY(0deg);
    opacity:1;
    z-index:10;
    pointer-events:all;
    box-shadow:0 20px 60px rgba(255,106,0,0.18), 0 4px 20px rgba(0,0,0,0.12);
    border-color:rgba(255,106,0,0.35);
}
body.dark-mode .os-card--center, [data-theme="dark"] .os-card--center {
    box-shadow:0 0 40px rgba(255,106,0,0.3), 0 20px 50px rgba(0,0,0,0.5);
    border-color:rgba(255,106,0,0.5);
}
.os-card--left1 {
    transform:translateX(-360px) scale(0.88) rotateY(18deg);
    opacity:0.65;
    z-index:7;
    pointer-events:all;
    filter:blur(0.5px);
}
.os-card--right1 {
    transform:translateX(360px) scale(0.88) rotateY(-18deg);
    opacity:0.65;
    z-index:7;
    pointer-events:all;
    filter:blur(0.5px);
}
.os-card--left2 {
    transform:translateX(-680px) scale(0.75) rotateY(28deg);
    opacity:0.3;
    z-index:4;
    filter:blur(1.5px);
}
.os-card--right2 {
    transform:translateX(680px) scale(0.75) rotateY(-28deg);
    opacity:0.3;
    z-index:4;
    filter:blur(1.5px);
}
.os-card--hidden {
    opacity:0;
    pointer-events:none;
    z-index:1;
}

/* Wide card variant */
.os-card--wide { width:380px; }

/* Hover lift on neighbors */
.os-card--left1:hover, .os-card--right1:hover {
    opacity:0.85;
    filter:blur(0);
}

/* Card icon */
.os-card-icon {
    width:54px; height:54px;
    border-radius:14px;
    background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,140,0,0.25));
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    color:#FF6A00;
    display:flex; align-items:center; justify-content:center;
    font-size:1.4rem;
    margin-bottom:1rem;
    flex-shrink:0;
    transition:all 0.3s ease;
    box-shadow:0 0 16px rgba(255,106,0,0.2);
}
.os-card--center:hover .os-card-icon {
    background:linear-gradient(135deg,#FF6A00,#FF8C00);
    color:#fff;
    box-shadow:0 0 28px rgba(255,106,0,0.55);
    transform:scale(1.08);
}

/* Title */
.os-card-title {
    font-size:1.1rem;
    font-weight:700;
    color:var(--text-primary);
    margin-bottom:0.9rem;
}
body.light-mode .os-card-title, [data-theme="light"] .os-card-title { color:#111; }
body.dark-mode .os-card-title, [data-theme="dark"] .os-card-title { color:#fff; }

/* Tag list */
.os-tag-list {
    list-style:none; margin:0; padding:0;
    display:flex; flex-wrap:wrap; gap:6px;
    flex:1;
}
.os-tag-list li {
    background:rgba(255,106,0,0.08);
    color:#FF6A00;
    font-size:0.78rem;
    font-weight:600;
    padding:4px 10px;
    border-radius:20px;
    border:1px solid rgba(255,106,0,0.2);
    white-space:nowrap;
}
body.dark-mode .os-tag-list li, [data-theme="dark"] .os-tag-list li {
    background:rgba(255,106,0,0.12);
    color:#FF9A40;
    border-color:rgba(255,106,0,0.3);
}
.os-tag-list--check { flex-direction:column; flex-wrap:nowrap; }
.os-tag-list--check li {
    background:transparent;
    border:none;
    color:var(--text-secondary);
    padding:3px 0;
    font-size:0.88rem;
}
.os-tag-list--check li .fa { color:#FF6A00; margin-right:6px; }

/* Bullet list — compact format */
.os-bullet-list {
    list-style:none;
    margin:0 0 0.75rem;
    padding:0;
    display:flex;
    flex-direction:column;
    gap:0.45rem;
    flex:1;
}
.os-bullet-list li {
    display:flex;
    align-items:flex-start;
    gap:8px;
    font-size:0.88rem;
    color:var(--text-secondary);
    line-height:1.5;
}
.os-bullet-list li::before {
    content:'•';
    color:#FF6A00;
    font-weight:700;
    flex-shrink:0;
    margin-top:1px;
}
body.light-mode .os-bullet-list li,
[data-theme="light"] .os-bullet-list li { color:#444; }

/* Two-column split inside card */
.os-two-col {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1rem;
    margin-bottom:1rem;
}
.os-col-label {
    font-size:0.75rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.06em;
    color:var(--text-muted);
    margin-bottom:0.5rem;
}
.os-col-label .fa { margin-right:4px; color:#FF6A00; }

/* Note line */
.os-card-note {
    font-size:0.82rem;
    color:var(--text-muted);
    margin:0.6rem 0 0.8rem;
    line-height:1.5;
}

/* Devices grid */
.os-devices-grid { display:flex; flex-direction:column; gap:8px; margin-bottom:1rem; }
.os-device-row {
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:0.5rem;
    padding:7px 10px;
    border-radius:8px;
    background:rgba(255,106,0,0.04);
    border:1px solid rgba(255,106,0,0.1);
}
.os-device-label {
    font-size:0.8rem;
    font-weight:700;
    color:#FF6A00;
    white-space:nowrap;
    flex-shrink:0;
}
.os-device-label .fa { margin-right:5px; }
.os-device-brands {
    font-size:0.78rem;
    color:var(--text-secondary);
    text-align:right;
    line-height:1.4;
}
body.light-mode .os-device-brands, [data-theme="light"] .os-device-brands { color:#555; }

/* CTA link */
.os-card-cta {
    margin-top:auto;
    margin-block-start:1rem;
}
.os-card-cta .fa { font-size:0.75rem; }

/* Dots */
.os-dots {
    display:flex;
    justify-content:center;
    gap:8px;
    margin-top:2.5rem;
}
.os-dot {
    width:8px; height:8px;
    border-radius:50%;
    border:none;
    background:rgba(255,106,0,0.25);
    cursor:pointer;
    transition:all 0.3s ease;
    padding:0;
}
.os-dot--active {
    background:#FF6A00;
    width:24px;
    border-radius:4px;
}

/* Responsive — flat grid below 860px */
@media (max-width:860px) {
    .os-track {
        display:grid;
        grid-template-columns:repeat(2,1fr);
        perspective:none;
        min-height:unset;
        gap:1.25rem;
    }
    .os-card, .os-card--wide {
        position:static;
        width:100%;
        min-height:unset;
        opacity:1;
        transform:none;
        filter:none;
        pointer-events:all;
    }
    .os-card--left1,.os-card--right1,.os-card--left2,.os-card--right2,.os-card--hidden { transform:none; opacity:1; filter:none; }
    .os-dots { display:none; }
}
@media (max-width:540px) {
    .os-track { grid-template-columns:1fr; }
}

/* ======================
   62b. CAROUSEL ARROW CONTROLS
   ====================== */
/* Shared arrow buttons — logo carousels + services carousel */
.carousel-arrow, .os-arrow {
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    z-index:20;
    width:38px; height:38px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,0.15);
    background:rgba(15,15,15,0.75);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    color:#fff;
    font-size:14px;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:background 0.25s ease, box-shadow 0.25s ease;
    padding:0;
    line-height:1;
    flex-shrink:0;
}
.carousel-arrow:hover, .os-arrow:hover {
    background:var(--accent);
    border-color:transparent;
    box-shadow:0 0 16px rgba(255,106,0,0.4);
}
.carousel-arrow--prev, .os-arrow--prev { left:6px; }
.carousel-arrow--next, .os-arrow--next { right:6px; }
[data-theme="light"] .carousel-arrow,
[data-theme="light"] .os-arrow {
    background:rgba(255,255,255,0.88);
    border-color:rgba(0,0,0,0.12);
    color:#111;
    box-shadow:0 2px 8px rgba(0,0,0,0.1);
}
[data-theme="light"] .carousel-arrow:hover,
[data-theme="light"] .os-arrow:hover { background:var(--accent); color:#fff; border-color:transparent; }
/* Hide services arrows in mobile grid view */
@media (max-width:860px) { .os-arrow { display:none; } }

/* Draggable cursor for logo tracks */
.partner-track, .partners-track,
.clients-track, .client-track { cursor:grab; }
.partner-track.is-dragging, .partners-track.is-dragging,
.clients-track.is-dragging, .client-track.is-dragging {
    cursor:grabbing;
    user-select:none;
    -webkit-user-select:none;
}

/* ======================
   63. PREMIUM GRADIENT SYSTEM
   ====================== */

/* Animated gradient shift */
@keyframes gradientShift {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* Stat numbers — gradient text */
.stat-number {
    font-size:clamp(2.5rem,4vw,3.5rem);
    font-weight:700;
    line-height:1;
    margin-bottom:0.5rem;
    background:linear-gradient(135deg,#FF6A00,#FF8C00,#FFB347);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}

/* os-card CTA — hover boost */

/* ======================
   RESPONSIVE — Modal & Navbar Fixes
   ====================== */

/* ── Mobile modal: full-screen, scrollable ── */
@media (max-width:768px) {
    .modal-overlay { padding:0; align-items:flex-start; }
    .modal-content { width:100%; max-width:100%; max-height:100vh; min-height:100vh; border-radius:0; padding:1.5rem; }
    .modal-content::before { border-radius:0; }
    .modal-content.modal-lg { max-width:100%; }
    .modal-body { max-height:calc(100vh - 180px); }
    .modal-title { font-size:1.25rem; }
    .modal-close { top:0.75rem; right:0.75rem; }
}

/* ── Tablet modal: comfortable fit ── */
@media (min-width:769px) and (max-width:1024px) {
    .modal-overlay { padding:1.5rem; }
    .modal-content { max-width:90%; max-height:85vh; }
}

/* ── Navbar inner: tighter padding on small screens ── */
@media (max-width:991px) {
    .nav-inner { padding:0 1rem; }
    .nav-logo img { height:35px; max-width:130px; }
    .nav-toggle { width:36px; height:36px; padding:6px; justify-content:center; }
}

/* ── Prevent horizontal scroll globally ── */
html, body { max-width:100vw; overflow-x:hidden; }
img { max-width:100%; height:auto; }

/* ── Inputs & buttons: full width on mobile ── */
@media (max-width:640px) {
    .premium-form input,
    .premium-form textarea,
    .premium-form select { width:100%; }
    .form-buttons .btn-premium,
    .form-buttons .btn-outline,
    .form-buttons .btn-whatsapp { width:100%; max-width:100%; justify-content:center; }
    .product-cta .btn-premium,
    .product-cta .btn-outline { min-width:auto; width:100%; }
}

/* Contact info icon — gradient glass */
.contact-info-card .info-icon {
    background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,140,0,0.25));
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    box-shadow:0 0 14px rgba(255,106,0,0.18);
}

/* Product header icon — gradient glass */
.product-header .product-icon {
    background:linear-gradient(135deg,rgba(255,106,0,0.15),rgba(255,140,0,0.25));
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    box-shadow:0 0 14px rgba(255,106,0,0.2);
}

/* icon-box generic — gradient glass */
.icon-box {
    background:linear-gradient(135deg,rgba(255,106,0,0.12),rgba(255,140,0,0.22));
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    box-shadow:0 0 12px rgba(255,106,0,0.15);
}
.card:hover .icon-box {
    background:linear-gradient(135deg,#FF6A00,#FF8C00);
    color:#fff;
    transform:scale(1.1);
    box-shadow:0 0 24px rgba(255,106,0,0.5);
}

/* Presence icon — gradient glass */
.presence-card .presence-icon {
    background:linear-gradient(135deg,rgba(255,106,0,0.12),rgba(255,140,0,0.22));
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    box-shadow:0 0 12px rgba(255,106,0,0.15);
}
.presence-card:hover .presence-icon {
    background:linear-gradient(135deg,#FF6A00,#FF8C00);
    box-shadow:0 0 24px rgba(255,106,0,0.5);
}

/* Footer socials hover — gradient */
.footer-socials a:hover {
    background:linear-gradient(135deg,#FF6A00,#FF8C00);
    border-color:transparent;
    box-shadow:0 6px 20px rgba(255,106,0,0.45);
}

/* Animated btn-premium on hero (entrance) */
.btn-premium {
    animation:fadeUp 1s 0.9s forwards, gradientShift 4s 2s ease infinite;
}
.premium-form .btn-premium {
    opacity:1;
    animation:gradientShift 4s ease infinite;
}

/* ---- DARK MODE GLOW BOOST ---- */
body.dark-mode .service-card:hover .card-icon,
[data-theme="dark"] .service-card:hover .card-icon {
    box-shadow:0 0 35px rgba(255,106,0,0.7), 0 0 60px rgba(255,106,0,0.2);
}
body.dark-mode .os-card--center,
[data-theme="dark"] .os-card--center {
    box-shadow:0 0 40px rgba(255,106,0,0.35), 0 20px 50px rgba(0,0,0,0.5);
    border-color:rgba(255,106,0,0.55);
}
body.dark-mode .os-card--center:hover .os-card-icon,
[data-theme="dark"] .os-card--center:hover .os-card-icon {
    box-shadow:0 0 35px rgba(255,106,0,0.75);
}
body.dark-mode .section-divider,
[data-theme="dark"] .section-divider {
    box-shadow:0 0 16px rgba(255,106,0,0.6), 0 0 6px rgba(255,140,0,0.4);
}
body.dark-mode .scroll-top-btn,
[data-theme="dark"] .scroll-top-btn {
    box-shadow:0 4px 24px rgba(255,106,0,0.55);
}

/* ---- LIGHT MODE GLOW REDUCTION ---- */
body.light-mode .service-card .card-icon,
[data-theme="light"] .service-card .card-icon {
    box-shadow:0 0 10px rgba(255,106,0,0.12);
}
body.light-mode .service-card:hover .card-icon,
[data-theme="light"] .service-card:hover .card-icon {
    box-shadow:0 0 18px rgba(255,106,0,0.35);
}
body.light-mode .section-divider,
[data-theme="light"] .section-divider {
    box-shadow:0 0 8px rgba(255,106,0,0.28);
}
body.light-mode .os-card--center,
[data-theme="light"] .os-card--center {
    box-shadow:0 12px 40px rgba(255,106,0,0.12), 0 4px 20px rgba(0,0,0,0.08);
    border-color:rgba(255,106,0,0.3);
}
body.light-mode .nav-cta-btn, [data-theme="light"] .nav-cta-btn,
body.light-mode .btn-quote,    [data-theme="light"] .btn-quote,
body.light-mode .card-cta,     [data-theme="light"] .card-cta,
body.light-mode .os-card-cta,  [data-theme="light"] .os-card-cta {
    box-shadow:0 4px 20px rgba(255,106,0,0.35);
}

/* ---- BTN DARK MODE: subtle gradient ---- */
[data-theme="dark"] .btn-quote,
[data-theme="dark"] .card-cta,
[data-theme="dark"] .os-card-cta,
body.dark-mode .btn-quote,
body.dark-mode .card-cta,
body.dark-mode .os-card-cta {
    background:linear-gradient(135deg,#FF6A00,#FF7A1A,#FFA94D);
    background-size:200% 200%;
    background-position:left center;
    box-shadow:0 4px 18px rgba(255,106,0,0.25);
}
[data-theme="dark"] .btn-quote:hover,
[data-theme="dark"] .card-cta:hover,
[data-theme="dark"] .os-card-cta:hover,
body.dark-mode .btn-quote:hover,
body.dark-mode .card-cta:hover,
body.dark-mode .os-card-cta:hover {
    background-position:right center;
    box-shadow:0 6px 22px rgba(255,140,0,0.35);
    filter:brightness(1.03);
}

/* ---- GLOBAL DARK MODE ORANGE GLOW REDUCTION ---- */
[data-theme="dark"], body.dark-mode {
    --orange-glow:rgba(255,106,0,0.25);
}

/* ── Cloudflare Turnstile CAPTCHA ─────────────────────────────
   Ensure the widget is never collapsed or clipped by form/modal
   container styles.
   ─────────────────────────────────────────────────────────── */
.captcha-box {
    margin: 1rem 0;
    min-height: 70px;
}
#quote-turnstile,
#enquiry-turnstile {
    min-height: 65px;
    min-width: 300px;
}
.cf-turnstile {
    display: block !important;
    min-height: 65px;
    overflow: visible !important;
}
.cf-turnstile iframe {
    display: block !important;
    min-height: 65px !important;
    border: 0 !important;
}
