/* ============================================
   CyberSafe - Modern 2026 Theme Stylesheet
   Light & Dark Mode with Glassmorphism
   ============================================ */

/* --- 1. RESET & VARIABLES --- */
:root {
  /* Color Accents */
  --primary-green: #7ab648;
  --primary-dark-green: #5a9a2f;
  --primary-blue: #1a3a5c;
  --primary-dark-blue: #0f2640;

  /* Dark Mode (Default) */
  --bg-body: #0a0f1c;
  --bg-section: #0e1428;
  --bg-section-alt: #111832;
  --bg-card: #151d38;
  --bg-card-hover: #1a2444;
  --bg-input: #151d38;
  --text-white: #ffffff;
  --text-primary: #f0f2f5;
  --text-secondary: #a0aec0;
  --text-muted: #718096;
  --border-dark: rgba(255,255,255,0.12);
  --border-card: rgba(255,255,255,0.10);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.5);

  /* Glassmorphism - Dark Mode */
  --glass-bg: rgba(255,255,255,0.04);
  --glass-border: rgba(255,255,255,0.08);

  /* Spacing & Layout */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --transition: all 0.3s ease;
  --font-main: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --max-width: 1200px;
}

/* Light Mode */
[data-theme="light"] {
  --bg-body: #f8fafc;
  --bg-section: #ffffff;
  --bg-section-alt: #f1f5f9;
  --bg-card: #ffffff;
  --bg-card-hover: #f8fafc;
  --bg-input: #f8fafc;
  --text-white: #1a202c;
  --text-primary: #1a202c;
  --text-secondary: #4a5568;
  --text-muted: #718096;
  --border-dark: rgba(0,0,0,0.08);
  --border-card: rgba(0,0,0,0.06);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.1);

  /* Glassmorphism - Light Mode */
  --glass-bg: rgba(255,255,255,0.7);
  --glass-border: rgba(0,0,0,0.06);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-main);color:var(--text-primary);background:var(--bg-body);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color 0.3s ease,color 0.3s ease}
.header,.feature-card,.customer-story-card,.industry-card,.faq-item,.footer,.btn,.nav-links a{transition:background-color 0.3s ease,color 0.3s ease,border-color 0.3s ease,box-shadow 0.3s ease}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;border:none;font-family:inherit}

/* --- 2. UTILITY --- */
.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}
.section-padding{padding:100px 0}
.section-label{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--primary-green);margin-bottom:12px}
.section-title{font-size:2.5rem;font-weight:800;line-height:1.15;background:linear-gradient(135deg,var(--text-white) 0%,var(--primary-green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px}
[data-theme="light"] .section-title{background:linear-gradient(135deg,#1a202c 0%,#2d6b22 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-subtitle{font-size:1.1rem;color:var(--text-secondary);max-width:640px;line-height:1.7}
.section-header--center{text-align:center}
.section-header--center .section-subtitle{margin:0 auto}

/* --- 3. BUTTONS --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-size:.95rem;font-weight:600;border-radius:50px;transition:var(--transition);letter-spacing:.3px}
.btn-primary{background:linear-gradient(135deg,#7ab648 0%,#5a9a2f 100%);color:#fff;box-shadow:0 4px 15px rgba(122,182,72,0.3)}
.btn-primary:hover{box-shadow:0 8px 30px rgba(122,182,72,0.4);transform:translateY(-3px)}
.btn-outline{border:2px solid rgba(255,255,255,0.3);color:#fff;background:transparent}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,0.08)}
.btn-dark{background:rgba(255,255,255,0.08);color:#fff;border:1px solid var(--border-dark)}
.btn-dark:hover{background:rgba(255,255,255,0.15);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--primary-green);font-weight:700}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3)}
.btn-full{width:100%;justify-content:center}

/* --- 4. HEADER --- */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:var(--transition);padding:16px 0;background:rgba(12,18,32,0.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.header.scrolled{background:rgba(12,18,32,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border-dark);padding:10px 0}
[data-theme="light"] .header{background:rgba(255,255,255,0.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
[data-theme="light"] .header.scrolled{background:rgba(255,255,255,0.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(0,0,0,0.08)}
[data-theme="light"] .header.scrolled{background:rgba(255,255,255,0.85);backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,0.06)}
[data-theme="light"] .header.scrolled .nav-links a,
[data-theme="light"] .nav-links--dark a{color:rgba(26,32,44,0.7)!important}
[data-theme="light"] .nav-links a:hover,
[data-theme="light"] .nav-links a.active{color:var(--primary-green)!important}
[data-theme="light"] .logo--dark,
[data-theme="light"] .header.scrolled .logo{filter:brightness(0) saturate(100%)}
.header .container{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;font-size:1.5rem;font-weight:800;color:#fff}
.header.scrolled .logo,.logo--dark{color:#fff}
.logo-icon{width:36px;height:36px}
.logo-text span{color:var(--primary-green)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:.9rem;font-weight:500;color:rgba(255,255,255,0.7);transition:var(--transition);position:relative}
.header.scrolled .nav-links a,.nav-links--dark a{color:rgba(255,255,255,0.7)!important}
.nav-links a:hover,.nav-links a.active{color:var(--primary-green)!important}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--primary-green);transition:width .3s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{padding:10px 24px!important;background:var(--primary-green)!important;color:#fff!important;border-radius:50px;font-weight:600!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--primary-dark-green)!important;transform:translateY(-1px)}
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;padding:4px}
.mobile-toggle span{width:24px;height:2px;background:#fff;transition:var(--transition)}
.header.scrolled .mobile-toggle span,.mobile-toggle--dark span{background:#fff}

/* --- 5. HERO --- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--bg-body);overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35}
.hero-video-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-video-bg video{width:100%;height:100%;object-fit:cover;opacity:.25;filter:brightness(0.6)}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(12,18,32,0.95) 0%,rgba(12,18,32,0.7) 50%,rgba(12,18,32,0.5) 100%);z-index:1}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(122,182,72,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(122,182,72,0.03) 1px,transparent 1px);background-size:60px 60px;z-index:1}
.hero .container{position:relative;z-index:2;width:100%}
.hero-content{max-width:700px;padding:160px 0 80px}
.hero h1{font-size:4rem;font-weight:800;color:#fff;line-height:1.1;margin-bottom:24px;text-transform:uppercase;letter-spacing:-1px}
.hero p{font-size:1.2rem;color:rgba(255,255,255,0.65);line-height:1.8;margin-bottom:40px;max-width:560px}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats-bar{display:none}
.hero-stats{display:flex;justify-content:space-between;padding:28px 0}
.hero-stats-inline{display:flex;flex-wrap:wrap;gap:28px;margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,0.1)}
.hero-stats-inline .hero-stat{text-align:left}
.hero-stat h3{font-size:2rem;font-weight:800;color:var(--primary-green)}
.hero-stat p{font-size:.82rem;color:rgba(255,255,255,0.4);margin-top:2px}

/* --- 6. TRUSTED BAR --- */
.trusted-bar{background:var(--bg-section);padding:48px 0;border-bottom:1px solid var(--border-dark)}
.trusted-label{text-align:center;font-size:.8rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:24px}
.partner-logos{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,#000 10%,#000 90%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 10%,#000 90%,transparent 100%)}
.partner-logos span{font-size:1rem;font-weight:700;color:var(--text-secondary);letter-spacing:.5px;white-space:nowrap}
.partner-logos-track img{height:160px;width:auto;opacity:.75;transition:opacity .3s ease;flex-shrink:0;object-fit:contain}
.partner-logos-track img:hover{opacity:1}

/* --- 7. SERVICES GRID --- */
.services-section{background:var(--bg-section)}
.services-section .section-header{margin-bottom:64px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.services-grid--four{grid-template-columns:repeat(4,1fr)}
.service-card{display:block;background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:36px 28px;transition:var(--transition);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-green);transform:scaleX(0);transition:transform .3s ease;z-index:2}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(122,182,72,0.2);background:var(--bg-card-hover)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{width:52px;height:52px;border-radius:var(--radius-sm);background:rgba(122,182,72,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--primary-green)}
.service-icon svg{width:24px;height:24px}
.service-card h3{font-size:1.2rem;font-weight:700;margin-bottom:10px;color:var(--text-white)}
.service-card p{font-size:.9rem;color:var(--text-secondary);line-height:1.7;margin-bottom:20px}
.service-link{font-size:.88rem;font-weight:600;color:var(--primary-green);display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.service-card:hover .service-link{gap:10px}

/* --- 8. ABOUT --- */
.about-section{background:var(--bg-section-alt)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-content .section-title{color:var(--text-white)}
.about-content p{color:var(--text-secondary);margin-bottom:20px;line-height:1.8}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:32px}
.about-feature{display:flex;align-items:flex-start;gap:12px}
.about-feature-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:rgba(122,182,72,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-green)}
.about-feature-icon svg{width:20px;height:20px}
.about-feature h4{font-size:.9rem;font-weight:700;margin-bottom:4px;color:var(--text-white)}
.about-feature p{font-size:.82rem;color:var(--text-muted);margin-bottom:0;line-height:1.5}
.about-visual{position:relative}
.about-visual-image{width:100%;height:400px;border-radius:var(--radius-lg);overflow:hidden;position:relative}
.about-visual-image img{width:100%;height:100%;object-fit:cover}
.about-visual-card{background:linear-gradient(135deg,rgba(20,28,43,0.95),rgba(13,18,32,0.95));border:1px solid var(--border-dark);border-radius:var(--radius-lg);padding:48px;color:#fff;position:relative;overflow:hidden}
.about-visual-card::after{content:'';position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(122,182,72,0.08) 0%,transparent 70%)}
.about-visual-card h3{font-size:1.5rem;font-weight:700;margin-bottom:16px;position:relative;z-index:1}
.about-visual-card>p{color:rgba(255,255,255,0.6);line-height:1.7;position:relative;z-index:1;margin-bottom:32px}
.about-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;position:relative;z-index:1}
.about-stat-item{background:rgba(255,255,255,0.05);border:1px solid var(--border-dark);border-radius:var(--radius-sm);padding:20px;text-align:center}
.about-stat-item h4{font-size:1.8rem;font-weight:800;color:var(--primary-green)}
.about-stat-item p{font-size:.8rem;color:rgba(255,255,255,0.4);margin-top:4px}

/* --- 9. SOC SECTION --- */
.soc-section{background:var(--bg-section)}
.soc-section .section-header{margin-bottom:48px}
.soc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
.soc-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:28px;text-align:center;transition:var(--transition)}
.soc-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:rgba(122,182,72,0.15)}
.soc-card-icon{width:32px;height:32px;color:var(--primary-green);margin:0 auto 16px}
.soc-card h4{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--text-white)}
.soc-card p{font-size:.85rem;color:var(--text-secondary);line-height:1.6}
.soc-services-bar{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.soc-service-tag{background:rgba(122,182,72,0.12);color:var(--primary-green);border:1px solid rgba(122,182,72,0.2);padding:10px 24px;border-radius:50px;font-size:.85rem;font-weight:600;letter-spacing:.5px}

/* --- 10. NEWS --- */
.news-section{background:var(--bg-section-alt)}
.news-section .section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.news-month-heading{font-size:1.2rem;font-weight:700;color:var(--text-white);margin-bottom:16px;padding-bottom:6px;border-bottom:2px solid var(--primary-green);display:inline-block;margin-top:32px;letter-spacing:0.5px}
.news-month-heading:first-of-type{margin-top:0}
.news-grid+.news-month-heading{margin-top:32px}
.news-card{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-card);transition:var(--transition)}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(122,182,72,0.15)}
.news-card--featured{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr}
.news-card-image{height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background-size:cover;background-position:center}
.news-card--featured .news-card-image{height:auto;min-height:280px}
.news-card-bg-icon{width:80px;height:80px;opacity:.2;position:relative;z-index:1}
.news-tag{position:absolute;top:16px;left:16px;background:rgba(122,182,72,0.9);color:#fff;font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:50px;text-transform:uppercase;letter-spacing:1px;z-index:2}
.news-card-body{padding:24px}
.news-card--featured .news-card-body{padding:32px;display:flex;flex-direction:column;justify-content:center}
.news-date{font-size:.78rem;color:var(--text-muted);margin-bottom:8px}
.news-card-body h3{font-size:1.05rem;font-weight:700;line-height:1.4;margin-bottom:12px;color:var(--text-white)}
.news-card--featured .news-card-body h3{font-size:1.3rem}
.news-card-body p{font-size:.88rem;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}
.news-read-more{font-size:.85rem;font-weight:600;color:var(--primary-green);display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.news-read-more:hover{gap:10px}

/* --- 11. CTA --- */
.consulting-cta{background:var(--bg-section)}
.consulting-cta-inner{background:linear-gradient(135deg,var(--primary-green),var(--primary-dark-green));border-radius:var(--radius-lg);padding:80px 64px;text-align:center;color:#fff;position:relative;overflow:hidden}
.consulting-cta-inner::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,0.08) 0%,transparent 50%)}
.consulting-cta-inner h2{font-size:2.5rem;font-weight:800;margin-bottom:16px;position:relative;z-index:2}
.consulting-cta-inner p{font-size:1.15rem;opacity:.9;max-width:600px;margin:0 auto 36px;line-height:1.7;position:relative;z-index:2}
.consulting-cta-inner .btn{position:relative;z-index:2}

/* --- 12. CONTACT --- */
.contact-section{background:var(--bg-section-alt)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.contact-form-wrapper h3{font-size:1.5rem;font-weight:700;margin-bottom:8px;color:var(--text-white)}
.contact-form-wrapper>p{color:var(--text-secondary);margin-bottom:32px}
.contact-form{display:grid;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--border-dark);border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font-main);transition:var(--transition);background:var(--bg-input);color:var(--text-primary)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}
.form-group select{color:var(--text-secondary)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px rgba(122,182,72,0.15)}
.form-group textarea{resize:vertical;min-height:120px}
.contact-info-wrapper{display:flex;flex-direction:column;gap:24px}
.contact-info-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:32px}
.contact-info-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}
.contact-info-item:last-child{margin-bottom:0}
.contact-info-icon{width:44px;height:44px;background:rgba(122,182,72,0.1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-green)}
.contact-info-icon svg{width:20px;height:20px}
.contact-info-text h4{font-size:.9rem;font-weight:700;margin-bottom:4px;color:var(--text-white)}
.contact-info-text p{font-size:.88rem;color:var(--text-secondary);line-height:1.5}

/* Service Pills */
.service-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.service-pill{display:inline-flex;align-items:center;padding:8px 18px;border-radius:50px;font-size:.85rem;font-weight:600;background:var(--bg-input);border:1px solid var(--border-dark);color:var(--text-secondary);cursor:pointer;transition:var(--transition);user-select:none}
.service-pill:hover{border-color:var(--primary-green);color:var(--text-primary)}
.service-pill.active{background:rgba(122,182,72,0.15);border-color:var(--primary-green);color:var(--primary-green)}

/* Detailed Consultation CTA */
.contact-detailed-cta{margin-top:24px;text-align:center;padding:16px 0;border-top:1px solid var(--border-dark)}
.contact-detailed-cta p{font-size:.9rem;color:var(--text-secondary)}
.detailed-consult-link{color:var(--primary-green);font-weight:600;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}
.detailed-consult-link:hover{color:var(--primary-dark-green);text-decoration:underline}
.detailed-consult-link svg{transition:transform 0.2s ease}
.detailed-consult-link:hover svg{transform:translateX(3px)}

/* Trust Bar */
.contact-trust-bar{display:flex;justify-content:center;gap:32px;margin-top:20px;padding:16px 0;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--text-secondary)}
.trust-item svg{color:var(--primary-green);flex-shrink:0}

/* --- 13. FOOTER --- */
.footer{background:var(--bg-body);color:rgba(255,255,255,0.7);padding:80px 0 0;border-top:1px solid var(--border-dark)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border-dark)}
.footer-brand .logo{margin-bottom:16px}
.footer-brand p{font-size:.9rem;line-height:1.7;color:var(--text-muted);max-width:300px}
.footer-col h4{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#fff;margin-bottom:20px}
.footer-col a{display:block;font-size:.88rem;color:var(--text-muted);padding:6px 0;transition:var(--transition)}
.footer-col a:hover{color:var(--primary-green)}
.footer-bottom{padding:24px 0;display:flex;align-items:center;justify-content:space-between;font-size:.82rem;color:var(--text-muted)}
.footer-social{display:flex;gap:16px}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.05);display:flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--text-muted)}
.footer-social a:hover{background:var(--primary-green);color:#fff}
.footer-social a svg{width:16px;height:16px}

/* --- 14. PAGE HEADER (Inner Pages) --- */
.page-header{background:var(--bg-body);padding:160px 0 80px;position:relative;overflow:hidden}
.page-header-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(122,182,72,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(122,182,72,0.03) 1px,transparent 1px);background-size:60px 60px}
.page-header-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.15}
.page-header .container{position:relative;z-index:1}
.page-header h1{font-size:3rem;font-weight:800;color:#fff;margin-bottom:16px}
.page-header p{font-size:1.15rem;color:rgba(255,255,255,0.5);max-width:600px}
.breadcrumbs{display:flex;align-items:center;gap:8px;font-size:.85rem;color:rgba(255,255,255,0.4);margin-bottom:20px}
.breadcrumbs a{color:rgba(255,255,255,0.4);transition:var(--transition)}
.breadcrumbs a:hover{color:var(--primary-green)}
.breadcrumbs svg{opacity:.4}
.breadcrumbs span{color:var(--primary-green)}

/* --- 15. SERVICE DETAIL PAGE --- */
.service-hero{background:var(--bg-body);padding:160px 0 80px;position:relative;overflow:hidden}
.service-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.15}
.service-hero .hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(122,182,72,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(122,182,72,0.03) 1px,transparent 1px);background-size:60px 60px}
.service-hero .container{position:relative;z-index:1}
.service-hero h1{font-size:2.8rem;font-weight:800;color:#fff;margin-bottom:16px}
.service-hero p{font-size:1.15rem;color:rgba(255,255,255,0.5);max-width:600px}

.service-content{padding:80px 0;background:var(--bg-section)}
.service-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:flex-start;margin-bottom:64px}
.service-content-grid:nth-child(even){direction:rtl}
.service-content-grid:nth-child(even)>*{direction:ltr}
.service-content-block h2{font-size:1.6rem;font-weight:700;margin-bottom:16px;color:var(--text-white)}
.service-content-block p{color:var(--text-secondary);line-height:1.8;margin-bottom:16px}
.service-content-block ul{margin:16px 0}
.service-content-block ul li{font-size:.9rem;color:var(--text-secondary);padding:8px 0 8px 20px;position:relative;line-height:1.6}
.service-content-block ul li::before{content:'';position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%;background:var(--primary-green)}

.service-detail-block{margin-bottom:16px;border:1px solid var(--border-card);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card)}
.service-detail-header{padding:24px 28px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:var(--transition)}
.service-detail-header:hover{background:var(--bg-card-hover)}
.service-detail-header-left{display:flex;align-items:center;gap:12px}
.service-detail-number{font-size:.75rem;font-weight:800;color:var(--primary-green);background:rgba(122,182,72,0.1);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.service-detail-header h3{font-size:1.1rem;font-weight:700;color:var(--text-white)}
.toggle-icon{font-size:1.3rem;color:var(--text-muted);transition:transform .3s ease;font-weight:300}
.service-detail-block.open .toggle-icon{transform:rotate(45deg)}
.service-detail-body{max-height:0;overflow:hidden;transition:max-height .5s ease}
.service-detail-block.open .service-detail-body{max-height:5000px}
.service-detail-content{padding:0 28px 28px}
.service-detail-content>p{color:var(--text-secondary);margin-bottom:20px;line-height:1.7}
.service-subcategories{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.sub-service{background:var(--bg-section);border:1px solid var(--border-dark);border-radius:var(--radius-sm);padding:24px}
.sub-service h4{font-size:1rem;font-weight:700;color:var(--text-white);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.sub-service h4::before{content:'';width:4px;height:18px;background:var(--primary-green);border-radius:2px;flex-shrink:0}
.sub-service ul li{font-size:.85rem;color:var(--text-secondary);padding:5px 0 5px 16px;position:relative;line-height:1.6}
.sub-service ul li::before{content:'';position:absolute;left:0;top:12px;width:5px;height:5px;border-radius:50%;background:var(--primary-green)}

/* Feature cards */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}
.feature-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;padding:28px;transition:var(--transition);position:relative}
.feature-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(122,182,72,0.15);border-color:var(--glass-border)}
.feature-card::after{content:'';position:absolute;inset:-1px;border-radius:17px;background:linear-gradient(135deg,rgba(122,182,72,0.3),transparent,rgba(122,182,72,0.1));z-index:-1;opacity:0;transition:opacity 0.4s ease}
.feature-card:hover::after{opacity:1}
.feature-card-icon{width:48px;height:48px;border-radius:var(--radius-sm);background:rgba(122,182,72,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--primary-green)}
.feature-card-icon svg{width:24px;height:24px}
.feature-card h4{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--text-white)}
.feature-card p{font-size:.88rem;color:var(--text-secondary);line-height:1.6}

/* Vendor/solution tags */
.vendor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:20px}
.vendor-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:24px}
.vendor-card h4{font-size:1rem;font-weight:700;color:var(--text-white);margin-bottom:12px}
.vendor-tags{display:flex;flex-wrap:wrap;gap:8px}
.vendor-tag{background:var(--bg-section);border:1px solid var(--border-dark);padding:6px 14px;border-radius:50px;font-size:.82rem;font-weight:500;color:var(--text-secondary)}

/* --- 16. BLOG ARTICLE --- */
.blog-article-section{padding:80px 0;background:var(--bg-section)}
.blog-grid{display:grid;grid-template-columns:2fr 1fr;gap:48px}
.article-content{line-height:1.8;color:var(--text-secondary)}
.article-content p{margin-bottom:20px}
.article-content h2{font-size:1.5rem;font-weight:700;color:var(--text-white);margin:36px 0 16px}
.article-content h3{font-size:1.2rem;font-weight:700;color:var(--text-white);margin:28px 0 12px}
.article-content ul{margin:16px 0;padding-left:0}
.article-content ul li{padding:6px 0 6px 20px;position:relative}
.article-content ul li::before{content:'';position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%;background:var(--primary-green)}
.article-meta{display:flex;gap:16px;margin-bottom:32px;font-size:.85rem;color:var(--text-muted)}
.article-meta-tag{background:rgba(122,182,72,0.1);color:var(--primary-green);padding:4px 12px;border-radius:50px;font-weight:600;font-size:.78rem}
.blog-sidebar{position:sticky;top:100px}
.sidebar-widget{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:28px;margin-bottom:24px}
.sidebar-widget h4{font-size:1rem;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--primary-green);color:var(--text-white)}
.sidebar-widget a{display:block;padding:10px 0;font-size:.88rem;color:var(--text-secondary);border-bottom:1px solid var(--border-dark);transition:var(--transition)}
.sidebar-widget a:last-child{border-bottom:none}
.sidebar-widget a:hover{color:var(--primary-green)}
.sidebar-cta{background:linear-gradient(135deg,rgba(122,182,72,0.15),rgba(122,182,72,0.05));border:1px solid rgba(122,182,72,0.2);border-radius:var(--radius-md);padding:28px;color:#fff}
.sidebar-cta h4{font-size:1.1rem;font-weight:700;margin-bottom:12px;border:none;padding:0;color:var(--text-white)}
.sidebar-cta p{font-size:.88rem;color:var(--text-secondary);line-height:1.6;margin-bottom:20px}

/* --- 17. PLATFORMS SECTION --- */
.platforms-section{background:var(--bg-section)}
.platforms-section .section-header{margin-bottom:64px}
.platforms-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.platform-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:40px;transition:var(--transition);position:relative;overflow:hidden}
.platform-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-green)}
.platform-card:hover{border-color:rgba(122,182,72,0.2);box-shadow:var(--shadow-lg)}
.platform-icon{width:56px;height:56px;border-radius:var(--radius-sm);background:rgba(122,182,72,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--primary-green)}
.platform-icon svg{width:28px;height:28px}
.platform-card h3{font-size:1.4rem;font-weight:800;color:var(--text-white);margin-bottom:4px}
.platform-subtitle{font-size:.82rem;font-weight:600;color:var(--primary-green);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:16px}
.platform-card>p{font-size:.92rem;color:var(--text-secondary);line-height:1.7;margin-bottom:20px}
.platform-features{list-style:none;padding:0;margin:0}
.platform-features li{font-size:.88rem;color:var(--text-secondary);padding:6px 0 6px 20px;position:relative;line-height:1.6}
.platform-features li::before{content:'';position:absolute;left:0;top:13px;width:6px;height:6px;border-radius:50%;background:var(--primary-green)}

/* --- 18. WHY CYBERSAFE SECTION --- */
.why-section{background:var(--bg-section-alt)}
.why-section .section-header{margin-bottom:64px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.why-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:36px 28px;text-align:center;transition:var(--transition)}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(122,182,72,0.2)}
.why-number{font-size:2.8rem;font-weight:800;color:var(--primary-green);margin-bottom:8px;line-height:1}
.why-card h4{font-size:1rem;font-weight:700;color:var(--text-white);margin-bottom:12px}
.why-card p{font-size:.88rem;color:var(--text-secondary);line-height:1.6}

/* --- 19. INDUSTRIES SECTION --- */
.industries-section{background:var(--bg-section)}
.industries-section .section-header{margin-bottom:64px}
.industries-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.industry-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;padding:36px 28px;transition:var(--transition);position:relative}
.industry-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(122,182,72,0.15);border-color:var(--glass-border)}
.industry-icon{width:52px;height:52px;border-radius:var(--radius-sm);background:rgba(122,182,72,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--primary-green)}
.industry-icon svg{width:24px;height:24px}
.industry-card h4{font-size:1.1rem;font-weight:700;color:var(--text-white);margin-bottom:10px}
.industry-card p{font-size:.88rem;color:var(--text-secondary);line-height:1.7}

/* Photo-based industry cards */
.industry-card--photo{display:flex;flex-direction:column;padding:0;overflow:hidden;min-height:340px;text-decoration:none;color:inherit;cursor:pointer;background:#0e1428;backdrop-filter:none;-webkit-backdrop-filter:none}
.industry-card--photo:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,0.4),0 0 40px rgba(122,182,72,0.15)}
.industry-card--photo .industry-card-img{position:absolute!important;inset:0;width:100%;height:100%;background-size:cover;background-position:center;transition:transform 0.6s ease,filter 0.6s ease;z-index:0}
.industry-card--photo:hover .industry-card-img{transform:scale(1.08);filter:brightness(0.6)}
.industry-card--photo .industry-card-overlay{position:absolute!important;inset:0;width:100%;height:100%;background:linear-gradient(180deg,rgba(0,0,0,0.1) 0%,rgba(0,0,0,0.55) 50%,rgba(0,0,0,0.85) 100%);z-index:1;transition:background 0.4s ease}
.industry-card--photo:hover .industry-card-overlay{background:linear-gradient(180deg,rgba(0,0,0,0.2) 0%,rgba(0,0,0,0.6) 40%,rgba(10,15,28,0.92) 100%)}
.industry-card--photo .industry-card-content{position:relative;z-index:2;margin-top:auto;padding:28px 24px;display:flex;flex-direction:column}
.industry-card--photo .industry-icon{background:rgba(122,182,72,0.2);backdrop-filter:blur(8px);border:1px solid rgba(122,182,72,0.3)}
.industry-card--photo h4{font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:8px}
.industry-card--photo p{font-size:.85rem;color:rgba(255,255,255,0.8);line-height:1.6;margin:0;opacity:0;max-height:0;transition:opacity 0.4s ease,max-height 0.4s ease;overflow:hidden}
.industry-card--photo:hover p{opacity:1;max-height:100px}

/* --- 20. CERTIFICATIONS BAR --- */
.certifications-bar{background:var(--bg-section-alt);padding:48px 0;border-top:1px solid var(--border-dark);border-bottom:1px solid var(--border-dark)}
.cert-logos{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.cert-logos span{font-size:.88rem;font-weight:700;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;padding:10px 20px;border:1px solid var(--border-dark);border-radius:50px;background:rgba(255,255,255,0.02)}

/* --- 21. RESPONSIVE --- */
@media(max-width:1024px){
  .services-grid,.services-grid--four,.news-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:3rem}
  .soc-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
  .blog-sidebar{position:static}
  .service-content-grid{grid-template-columns:1fr}
  .service-content-grid:nth-child(even){direction:ltr}
  .news-card--featured{grid-template-columns:1fr}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .industries-grid{grid-template-columns:repeat(2,1fr)}
  .platforms-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-links.active{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--bg-card);padding:24px;box-shadow:var(--shadow-lg);gap:16px;border-top:1px solid var(--border-dark)}
  .nav-links.active a{color:var(--text-primary)!important}
  .mobile-toggle{display:flex}
  .hero h1{font-size:2.4rem}
  .hero-content{padding:120px 0 60px}
  .hero-stats{flex-wrap:wrap;gap:24px}
  .hero-stats-inline{gap:20px;margin-top:28px;padding-top:24px}
  .hero-stats-inline .hero-stat{min-width:calc(50% - 12px)}
  .hero-stat{min-width:40%}
  .services-grid,.services-grid--four,.news-grid{grid-template-columns:1fr}
  .section-title{font-size:2rem}
  .form-row{grid-template-columns:1fr}
  .contact-trust-bar{gap:20px;justify-content:flex-start}
  .service-pills{gap:8px}
  .service-pill{padding:6px 14px;font-size:.8rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center}
  .news-section .section-header{flex-direction:column;align-items:flex-start;gap:16px}
  .consulting-cta-inner{padding:48px 24px}
  .consulting-cta-inner h2{font-size:1.8rem}
  .video-play-btn{width:60px;height:60px}
  .video-play-btn svg{width:32px;height:32px}
  .about-features{grid-template-columns:1fr}
  .soc-grid{grid-template-columns:1fr}
  .page-header{padding:120px 0 60px}
  .page-header h1{font-size:2.2rem}
  .service-subcategories{grid-template-columns:1fr}
  .vendor-grid{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .industries-grid{grid-template-columns:1fr}
  .platforms-grid{grid-template-columns:1fr}
  .cert-logos{gap:16px}
  .cert-logos span{font-size:.75rem;padding:8px 14px}
  .customer-stories-grid{grid-template-columns:1fr}
}

/* ============================================
   22. ANIMATIONS & EFFECTS
   ============================================ */

/* --- Keyframe Animations --- */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.8)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes glow{0%,100%{box-shadow:0 0 5px rgba(122,182,72,0.2),0 0 20px rgba(122,182,72,0.1)}50%{box-shadow:0 0 20px rgba(122,182,72,0.4),0 0 60px rgba(122,182,72,0.2)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes scanLine{0%{top:-100%}100%{top:200%}}
@keyframes borderGlow{0%,100%{border-color:rgba(122,182,72,0.1)}50%{border-color:rgba(122,182,72,0.4)}}
@keyframes textGlitch{0%,100%{text-shadow:none}25%{text-shadow:-2px 0 rgba(122,182,72,0.7),2px 0 rgba(0,200,255,0.5)}50%{text-shadow:2px 0 rgba(122,182,72,0.7),-2px 0 rgba(0,200,255,0.5)}75%{text-shadow:-1px 0 rgba(122,182,72,0.7),1px 0 rgba(0,200,255,0.5)}}
@keyframes dataStream{0%{background-position:0 0}100%{background-position:0 100%}}
@keyframes rotateGlow{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes countUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes typeWriter{from{width:0}to{width:100%}}
@keyframes blink{0%,100%{border-color:var(--primary-green)}50%{border-color:transparent}}
@keyframes gridPulse{0%,100%{opacity:.03}50%{opacity:.08}}
@keyframes hexFloat{0%,100%{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-15px) rotate(2deg)}66%{transform:translateY(5px) rotate(-1deg)}}
@keyframes particleDrift{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-100vh) translateX(50px);opacity:0}}

/* --- Scroll-triggered animation classes --- */
.animate-on-scroll{opacity:0;transform:translateY(15px);transition:opacity 0.3s ease-out,transform 0.3s ease-out}
.animate-on-scroll.animate-visible{opacity:1;transform:translateY(0)}
.animate-on-scroll.animate-left{transform:translateX(-15px)}
.animate-on-scroll.animate-left.animate-visible{transform:translateX(0)}
.animate-on-scroll.animate-right{transform:translateX(15px)}
.animate-on-scroll.animate-right.animate-visible{transform:translateX(0)}
.animate-on-scroll.animate-scale{transform:scale(0.95)}
.animate-on-scroll.animate-scale.animate-visible{transform:scale(1)}
.stagger-1{transition-delay:.05s}
.stagger-2{transition-delay:.1s}
.stagger-3{transition-delay:.15s}
.stagger-4{transition-delay:.2s}
.stagger-5{transition-delay:.25s}
.stagger-6{transition-delay:.3s}

/* --- Particle Canvas --- */
#particleCanvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.4}

/* --- Hero Enhancements --- */
.hero h1{animation:fadeInUp .4s ease-out forwards}
.hero p{animation:fadeInUp .4s ease-out .1s forwards;opacity:0}
.hero-buttons{animation:fadeInUp .4s ease-out .2s forwards;opacity:0}
.hero-typing-wrapper{display:inline-block;position:relative}
.hero-subtitle-typed{color:var(--primary-green);font-weight:700;font-size:.55em;text-transform:none;display:block;min-height:1.3em}
.hero-typing{display:inline;border-right:3px solid var(--primary-green);animation:blink .8s infinite;white-space:nowrap;padding-right:4px}

/* Scan line overlay on hero (subtle) */
.hero::after{content:'';position:absolute;top:-100%;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(122,182,72,0.15),transparent);z-index:3;animation:scanLine 6s linear infinite;pointer-events:none}

/* Animated grid on hero */
.hero-grid{animation:gridPulse 4s ease-in-out infinite}

/* --- Glowing border cards --- */
.service-card,.platform-card,.soc-card,.why-card,.industry-card,.customer-story-card{position:relative;overflow:hidden}
.service-card::after,.platform-card::after,.industry-card::after,.customer-story-card::after{content:'';position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:inherit;background:linear-gradient(135deg,rgba(122,182,72,0.15),transparent 40%,transparent 60%,rgba(122,182,72,0.1));opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:0}
.service-card:hover::after,.platform-card:hover::after,.industry-card:hover::after,.customer-story-card:hover::after{opacity:1}
.service-card>*,.platform-card>*,.industry-card>*,.customer-story-card>*{position:relative;z-index:1}

/* --- Data stream effect on about card --- */
.about-visual-card::before{content:'01001 10110 01010 11001 00111 10010 01101 10011 00100 11010';position:absolute;top:0;left:0;right:0;bottom:0;font-family:monospace;font-size:.6rem;line-height:1.8;color:rgba(122,182,72,0.04);word-break:break-all;overflow:hidden;padding:16px;z-index:0;background-size:100% 200%;animation:dataStream 20s linear infinite}

/* --- Floating hex elements (disabled for cleaner look) --- */
.cyber-hex{display:none}

/* --- Animated stat counters --- */
.counter-animated{display:inline-block}

/* --- Enhanced partner logos scroll --- */
.partner-logos-track{display:flex;align-items:center;gap:48px;animation:scrollLogos 30s linear infinite;white-space:nowrap;width:max-content}
@keyframes scrollLogos{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* --- SOC service tags --- */
.soc-service-tag{transition:var(--transition)}

/* --- CTA section enhanced --- */
.consulting-cta-inner::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}

/* --- Logo image --- */
.logo-img{height:40px;width:auto;object-fit:contain;filter:brightness(1.1)}

/* --- Video Showcase --- */
.video-showcase-section{background:var(--bg-section)}
.video-showcase{max-width:960px;margin:0 auto}
.video-wrapper{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(122,182,72,0.2);box-shadow:0 0 60px rgba(122,182,72,0.08),var(--shadow-lg);aspect-ratio:16/9;background:#000;cursor:pointer}
.video-wrapper video{width:100%;height:100%;object-fit:cover;display:block}
.video-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,9,16,0.4),rgba(6,9,16,0.15));pointer-events:none;transition:opacity .4s ease}
.video-wrapper.playing .video-overlay{opacity:0}
.video-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:rgba(122,182,72,0.9);color:#fff;display:flex;align-items:center;justify-content:center;border:none;z-index:2;transition:all .3s ease;box-shadow:0 0 40px rgba(122,182,72,0.4)}
.video-play-btn:hover{background:var(--primary-green);transform:translate(-50%,-50%) scale(1.1);box-shadow:0 0 60px rgba(122,182,72,0.6)}
.video-play-btn svg{margin-left:4px}
.video-wrapper.playing .video-play-btn{opacity:0;pointer-events:none}

/* --- Cyber grid decorative lines --- */
.cyber-grid-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.cyber-grid-bg::before{content:'';position:absolute;top:0;left:10%;width:1px;height:100%;background:linear-gradient(180deg,transparent,rgba(122,182,72,0.06) 30%,rgba(122,182,72,0.06) 70%,transparent)}
.cyber-grid-bg::after{content:'';position:absolute;top:0;right:10%;width:1px;height:100%;background:linear-gradient(180deg,transparent,rgba(122,182,72,0.06) 30%,rgba(122,182,72,0.06) 70%,transparent)}
.services-section,.industries-section,.customer-stories-section,.platforms-section{position:relative}

/* --- Glowing section dividers --- */
.section-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(122,182,72,0.3),transparent);margin:0;border:none}

/* --- 23. CUSTOMER SUCCESS STORIES --- */
.customer-stories-section{background:var(--bg-section-alt)}
.customer-stories-section .section-header{margin-bottom:64px}
.customer-stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:stretch}
.customer-story-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;padding:36px;transition:var(--transition);position:relative;display:flex;flex-direction:column}
.customer-story-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(122,182,72,0.15);border-color:var(--glass-border)}
.customer-story-header{display:flex;flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}
.customer-story-logo{width:160px;height:80px;object-fit:contain;object-position:left;background:none;padding:0;flex-shrink:0}
.customer-story-header .customer-story-industry{margin-bottom:0}
.customer-story-header h4{margin-bottom:0}
.customer-story-industry{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary-green);background:rgba(122,182,72,0.1);padding:4px 14px;border-radius:50px;margin-bottom:16px}
.customer-story-card h4{font-size:1.15rem;font-weight:700;color:var(--text-white);margin-bottom:12px}
.customer-story-card p{font-size:.9rem;color:var(--text-secondary);line-height:1.7;margin-bottom:16px;flex:1}
.customer-story-results{display:flex;flex-wrap:wrap;gap:12px;margin-top:auto;padding-top:16px}
.customer-story-result{background:rgba(122,182,72,0.06);border:1px solid rgba(122,182,72,0.15);padding:8px 16px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;color:var(--primary-green)}
.customer-story-quote{font-style:italic;color:var(--text-secondary);border-left:3px solid var(--primary-green);padding-left:16px;margin:16px 0}
.customer-story-engagement{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.customer-story-tag{font-size:.75rem;font-weight:600;color:var(--text-muted);background:rgba(255,255,255,0.04);border:1px solid var(--border-dark);padding:4px 10px;border-radius:50px}
[data-theme="light"] .customer-story-logo{background:none;filter:brightness(0) saturate(100%);opacity:0.7}

/* --- Responsive for customer stories --- */
@media(max-width:1024px){
  .customer-stories-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .customer-stories-grid{grid-template-columns:1fr}
}

/* --- THREAT LANDSCAPE --- */
.threat-landscape{background:var(--bg-section);position:relative;overflow:hidden}
.threat-landscape::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;background:radial-gradient(circle,rgba(122,182,72,0.05) 0%,transparent 70%);transform:translate(-50%,-50%);pointer-events:none}
.threat-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:64px}
.threat-stat-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:36px 28px;text-align:center;transition:var(--transition);position:relative;overflow:hidden}
.threat-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(122,182,72,0.2)}
.threat-stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-green),rgba(122,182,72,0.3));transform:scaleX(0);transition:transform .4s ease}
.threat-stat-card:hover::before{transform:scaleX(1)}
.threat-stat-icon{width:56px;height:56px;border-radius:50%;background:rgba(122,182,72,0.1);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--primary-green)}
.threat-stat-icon svg{width:28px;height:28px}
.threat-stat-number{font-size:2.5rem;font-weight:800;color:var(--primary-green);margin-bottom:8px;line-height:1}
.threat-stat-label{font-size:.88rem;color:var(--text-secondary);margin-bottom:20px}
.threat-stat-bar{height:4px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden}
.threat-stat-fill{height:100%;background:linear-gradient(90deg,var(--primary-green),rgba(122,182,72,0.5));border-radius:2px;transition:width 1.5s ease}
@media(max-width:1024px){.threat-stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.threat-stats-grid{grid-template-columns:1fr}}

/* --- GEMINI VIDEO GENERATION --- */
.video-gen-status{text-align:center;padding:40px;color:var(--text-secondary)}
.video-gen-spinner{width:40px;height:40px;border:3px solid rgba(122,182,72,0.2);border-top-color:var(--primary-green);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.video-gen-error{color:#ef4444}
.gemini-generated-video{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}

/* --- CLIENT & PARTNER LOGOS --- */
.logo-strip{display:flex;align-items:center;gap:48px;flex-wrap:wrap;justify-content:center;padding:20px 0}
.logo-strip img{height:100px;width:auto;opacity:.75;transition:all .3s ease;object-fit:contain}
.logo-strip img:hover{opacity:1}
.logo-strip--small img{height:110px}
.logo-strip--large img{height:120px}

/* Scrolling client logos */
.client-logos-section{background:var(--bg-section-alt);padding:80px 0;border-top:1px solid var(--border-dark);border-bottom:1px solid var(--border-dark)}
.client-logos-section .section-label{text-align:center;display:block;margin-bottom:40px}
.client-logos-track{display:flex;align-items:center;gap:32px;animation:scrollLogos 60s linear infinite;white-space:nowrap;width:max-content}
.client-logos-track img{height:150px;width:auto;opacity:.85;transition:opacity .3s ease;flex-shrink:0;filter:brightness(1.1)}
.client-logos-track img:hover{opacity:1;filter:brightness(1.3)}

/* Logo grid for about/customer sections */
.logo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:32px}
.logo-grid-item{background:rgba(255,255,255,0.04);border:1px solid var(--border-dark);border-radius:var(--radius-sm);padding:16px;display:flex;align-items:center;justify-content:center;min-height:120px;transition:var(--transition)}
.logo-grid-item:hover{border-color:rgba(122,182,72,0.2);background:rgba(255,255,255,0.07)}
.logo-grid-item img{height:120px;width:auto;max-width:100%;opacity:.75;transition:opacity .3s ease;object-fit:contain}
.logo-grid-item:hover img{opacity:1}
@media(max-width:768px){
  .logo-grid{grid-template-columns:repeat(2,1fr)}
  .logo-strip{gap:24px}
  .client-logos-track img{height:100px}
  .partner-logos-track img{height:110px}
}

/* --- MODERN 2026 EFFECTS --- */

/* Subtle dot grid background overlay */
.cyber-grid-bg {
  background-image: radial-gradient(circle at 1px 1px, rgba(122,182,72,0.07) 1px, transparent 0);
  background-size: 40px 40px;
}

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

/* Service cards with glassmorphism */
.service-card {
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
}

/* --- THEME TOGGLE BUTTON --- */
.theme-toggle {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  color: var(--primary-green);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  transition: all 0.3s ease;
}

.theme-toggle:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 30px rgba(122,182,72,0.3);
}

.theme-toggle svg {
  width: 22px;
  height: 22px;
}

[data-theme="light"] .theme-toggle {
  background: var(--bg-card);
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}

.theme-toggle .icon-sun {
  display: none;
}

[data-theme="light"] .theme-toggle .icon-sun {
  display: block;
}

[data-theme="light"] .theme-toggle .icon-moon {
  display: none;
}

/* --- LIGHT MODE FOOTER --- */
[data-theme="light"] .footer {
  background: #1a202c;
  color: #f0f2f5;
}

[data-theme="light"] .footer .section-title,
[data-theme="light"] .footer h4 {
  background: none;
  -webkit-text-fill-color: #fff;
  color: #fff;
}

[data-theme="light"] .footer-col h4 {
  color: #fff;
}

[data-theme="light"] .footer-brand p {
  color: rgba(255,255,255,0.7);
}

[data-theme="light"] .footer-col a {
  color: rgba(255,255,255,0.7);
}

[data-theme="light"] .footer-col a:hover {
  color: var(--primary-green);
}

[data-theme="light"] .footer-bottom {
  color: rgba(255,255,255,0.7);
}

[data-theme="light"] .footer-social a {
  background: rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
}

[data-theme="light"] .footer-social a:hover {
  background: var(--primary-green);
  color: #fff;
}

/* ============================================
   COMPREHENSIVE LIGHT MODE OVERRIDES
   ============================================ */

/* --- Canvas: reduce opacity in light mode --- */
[data-theme="light"] #particleCanvas {
  opacity: 0.15;
}

/* --- Hero Section --- */
[data-theme="light"] .hero {
  background: var(--bg-body);
}
[data-theme="light"] .hero::before {
  background: linear-gradient(to right, rgba(248,250,252,0.97) 0%, rgba(248,250,252,0.85) 50%, rgba(248,250,252,0.7) 100%);
}
[data-theme="light"] .hero h1 {
  color: #1a202c;
}
[data-theme="light"] .hero p {
  color: #4a5568;
}
[data-theme="light"] .hero-stats-inline {
  border-top-color: rgba(0,0,0,0.1);
}
[data-theme="light"] .hero-stat p {
  color: #4a5568;
}
[data-theme="light"] .hero-stats-bar {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(12px);
  border-top: 1px solid rgba(0,0,0,0.06);
}
[data-theme="light"] .hero-stat h3 {
  color: var(--primary-green);
}
[data-theme="light"] .hero-stat p {
  color: #718096;
}
[data-theme="light"] .hero-grid {
  background-image: linear-gradient(rgba(122,182,72,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(122,182,72,0.06) 1px, transparent 1px);
}

/* --- Header & Nav --- */
[data-theme="light"] .logo {
  color: #1a202c;
}
[data-theme="light"] .logo-img {
  filter: brightness(0) saturate(100%);
}
[data-theme="light"] .nav-links a {
  color: rgba(26,32,44,0.7) !important;
}

/* --- Trusted / Partner Logos --- */
[data-theme="light"] .partner-logos-track img,
[data-theme="light"] .client-logos-track img {
  filter: brightness(0) saturate(100%);
  opacity: 0.6;
}
[data-theme="light"] .partner-logos-track img:hover,
[data-theme="light"] .client-logos-track img:hover {
  opacity: 0.85;
}

/* --- Buttons --- */
[data-theme="light"] .btn-outline {
  border-color: rgba(0,0,0,0.2);
  color: #1a202c;
}
[data-theme="light"] .btn-outline:hover {
  border-color: var(--primary-green);
  color: var(--primary-green);
  background: rgba(122,182,72,0.05);
}
[data-theme="light"] .btn-dark {
  background: rgba(0,0,0,0.04);
  color: #1a202c;
  border-color: rgba(0,0,0,0.1);
}
[data-theme="light"] .btn-dark:hover {
  background: rgba(0,0,0,0.08);
}

/* --- About Visual Card --- */
[data-theme="light"] .about-visual-card {
  background: linear-gradient(135deg, #ffffff, #f1f5f9);
  border-color: rgba(0,0,0,0.08);
  color: #1a202c;
}
[data-theme="light"] .about-visual-card h3 {
  color: #1a202c;
}
[data-theme="light"] .about-visual-card > p {
  color: #4a5568;
}
[data-theme="light"] .about-stat-item {
  background: rgba(122,182,72,0.06);
  border-color: rgba(0,0,0,0.06);
}
[data-theme="light"] .about-stat-item p {
  color: #718096;
}

/* --- Page Header (inner pages) --- */
[data-theme="light"] .page-header {
  background: var(--bg-body);
}
[data-theme="light"] .page-header h1 {
  color: #1a202c;
}
[data-theme="light"] .page-header p {
  color: #4a5568;
}
[data-theme="light"] .breadcrumbs {
  color: #718096;
}
[data-theme="light"] .breadcrumbs a {
  color: #718096;
}
[data-theme="light"] .breadcrumbs svg {
  opacity: 0.5;
}

/* --- Service Hero (inner pages) --- */
[data-theme="light"] .service-hero h1 {
  color: #1a202c;
}
[data-theme="light"] .service-hero p {
  color: #4a5568;
}
[data-theme="light"] .service-hero .hero-grid {
  background-image: linear-gradient(rgba(122,182,72,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(122,182,72,0.06) 1px, transparent 1px);
}

/* --- Sidebar CTA --- */
[data-theme="light"] .sidebar-cta {
  color: #1a202c;
}

/* --- Light Mode Card Borders --- */
[data-theme="light"] .service-card,
[data-theme="light"] .feature-card,
[data-theme="light"] .soc-card,
[data-theme="light"] .news-card,
[data-theme="light"] .vendor-card,
[data-theme="light"] .sidebar-widget,
[data-theme="light"] .contact-info-card {
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}

/* --- Scan line (hero after) - subtler in light mode --- */
[data-theme="light"] .hero::after {
  background: linear-gradient(90deg, transparent, rgba(122,182,72,0.08), transparent);
}

/* ============================================
   INDUSTRY PAGES
   ============================================ */

/* Features Section */
.features-section {
  padding: 80px 0;
}
.features-section h2 {
  font-size: 1.75rem;
  font-weight: 800;
  margin-bottom: 40px;
  color: var(--text-white);
}
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.feature-icon {
  margin-bottom: 12px;
  color: var(--primary-green);
}
.feature-icon svg {
  width: 32px;
  height: 32px;
}

/* Clients Section */
.clients-section {
  padding: 80px 0;
  background: var(--bg-section-alt);
  border-top: 1px solid var(--border-dark);
  border-bottom: 1px solid var(--border-dark);
}
.clients-section h2 {
  font-size: 1.75rem;
  font-weight: 800;
  margin-bottom: 12px;
  color: var(--text-white);
}
.clients-section > .container > p {
  color: var(--text-secondary);
  margin-bottom: 40px;
}
.clients-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 40px;
  align-items: center;
  justify-items: center;
}
.client-logo {
  max-height: 100px;
  width: auto;
  max-width: 100%;
  opacity: 0.9;
  transition: opacity 0.3s ease, filter 0.3s ease;
  object-fit: contain;
  filter: brightness(1.1);
}
.client-logo:hover {
  opacity: 1;
  filter: brightness(1.3);
}

/* Case Study Section */
.case-study-section {
  padding: 80px 0;
}
.case-study-content {
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 48px;
}
.case-study-content h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-white);
  margin-bottom: 16px;
}
.case-study-content p {
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 16px;
}
.case-study-content ul {
  list-style: none;
  padding: 0;
  margin: 24px 0;
}
.case-study-content li {
  color: var(--text-secondary);
  line-height: 1.7;
  padding: 10px 0 10px 28px;
  position: relative;
  border-bottom: 1px solid var(--border-dark);
}
.case-study-content li:last-child {
  border-bottom: none;
}
.case-study-content li::before {
  content: '✓';
  color: var(--primary-green);
  font-weight: 700;
  position: absolute;
  left: 0;
}
.case-study-content li strong {
  color: var(--text-white);
}

/* Compliance Section */
.compliance-section {
  padding: 80px 0;
  background: var(--bg-section-alt);
  border-top: 1px solid var(--border-dark);
  border-bottom: 1px solid var(--border-dark);
}
.compliance-section h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-white);
  margin-bottom: 12px;
}
.compliance-section > .container > p {
  color: var(--text-secondary);
  margin-bottom: 24px;
  line-height: 1.7;
}
.compliance-section ul {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.compliance-section li {
  color: var(--text-secondary);
  line-height: 1.6;
  padding: 16px 20px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
}
.compliance-section li strong {
  color: var(--text-white);
  display: block;
  margin-bottom: 4px;
}

/* CTA Section (industry pages) */
.cta-section {
  padding: 80px 0;
  text-align: center;
}
.cta-section h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-white);
  margin-bottom: 16px;
}
.cta-section p {
  color: var(--text-secondary);
  margin-bottom: 32px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.cta-button {
  display: inline-block;
  padding: 14px 36px;
  background: var(--primary-green);
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  border-radius: 8px;
  text-decoration: none;
  transition: var(--transition);
}
.cta-button:hover {
  background: var(--primary-green-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(122,182,72,0.3);
}

/* Industry page content section */
.content-section {
  padding: 80px 0;
}
.content-section h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-white);
  margin-bottom: 16px;
}
.content-section p {
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 16px;
}

/* Section images (stock photos between sections) */
.section-image {
  width: 100%;
  max-height: 400px;
  overflow: hidden;
  position: relative;
}
.section-image img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  display: block;
}

/* Threat landscape, challenges, devsecops, threats, manufacturing-risks, tech-threats sections */
.threat-landscape-section,
.challenges-section,
.devsecops-section,
.threats-section,
.manufacturing-risks-section,
.tech-threat-landscape-section {
  padding: 80px 0;
}
.threat-landscape-section h2,
.challenges-section h2,
.devsecops-section h2,
.threats-section h2,
.manufacturing-risks-section h2,
.tech-threat-landscape-section h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-white);
  margin-bottom: 12px;
}
.threat-landscape-section p,
.challenges-section p,
.devsecops-section p,
.threats-section p,
.manufacturing-risks-section p,
.tech-threat-landscape-section p {
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 16px;
}
.threat-landscape-section ul,
.challenges-section ul,
.devsecops-section ul,
.threats-section ul,
.manufacturing-risks-section ul,
.tech-threat-landscape-section ul {
  list-style: none;
  padding: 0;
  margin: 24px 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.threat-landscape-section li,
.challenges-section li,
.devsecops-section li,
.threats-section li,
.manufacturing-risks-section li,
.tech-threat-landscape-section li {
  color: var(--text-secondary);
  line-height: 1.7;
  padding: 20px 20px 20px 44px;
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: 12px;
}
.threat-landscape-section li::before,
.challenges-section li::before,
.devsecops-section li::before,
.threats-section li::before,
.manufacturing-risks-section li::before,
.tech-threat-landscape-section li::before {
  content: '→';
  color: var(--primary-green);
  font-weight: 700;
  position: absolute;
  left: 20px;
  top: 20px;
}
.threat-landscape-section li strong,
.challenges-section li strong,
.devsecops-section li strong,
.threats-section li strong,
.manufacturing-risks-section li strong,
.tech-threat-landscape-section li strong {
  color: var(--text-white);
}

/* Industry responsive */
@media(max-width:1024px) {
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .clients-grid { grid-template-columns: repeat(3, 1fr); }
  .compliance-section ul { grid-template-columns: 1fr; }
  .threat-landscape-section ul,
  .challenges-section ul,
  .devsecops-section ul,
  .threats-section ul,
  .manufacturing-risks-section ul,
  .tech-threat-landscape-section ul { grid-template-columns: 1fr; }
}
@media(max-width:768px) {
  .features-grid { grid-template-columns: 1fr; }
  .clients-grid { grid-template-columns: repeat(2, 1fr); }
  .client-logo { max-height: 75px; }
  .case-study-content { padding: 28px; }
  .section-image, .section-image img { height: 240px; }
}

/* Industry light mode */
[data-theme="light"] .features-section h2,
[data-theme="light"] .clients-section h2,
[data-theme="light"] .case-study-content h2,
[data-theme="light"] .compliance-section h2,
[data-theme="light"] .cta-section h2,
[data-theme="light"] .content-section h2,
[data-theme="light"] .threat-landscape-section h2,
[data-theme="light"] .challenges-section h2,
[data-theme="light"] .devsecops-section h2,
[data-theme="light"] .threats-section h2,
[data-theme="light"] .manufacturing-risks-section h2,
[data-theme="light"] .tech-threat-landscape-section h2 {
  color: #1a202c;
}
[data-theme="light"] .case-study-content li strong,
[data-theme="light"] .compliance-section li strong,
[data-theme="light"] .threat-landscape-section li strong,
[data-theme="light"] .challenges-section li strong,
[data-theme="light"] .threats-section li strong,
[data-theme="light"] .manufacturing-risks-section li strong,
[data-theme="light"] .tech-threat-landscape-section li strong {
  color: #1a202c;
}
[data-theme="light"] .client-logo {
  filter: brightness(0) saturate(100%);
  opacity: 0.6;
}
[data-theme="light"] .client-logo:hover {
  opacity: 0.85;
}

/* (Old industry footer CSS removed - now uses main site footer-grid/footer-col) */

/* ============================================
   ANIMATION & VISUAL ENHANCEMENTS
   ============================================ */

/* 1. SCROLL PROGRESS BAR */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  background: linear-gradient(90deg, #7ab648, #5a9a2f);
  z-index: 9999;
  transition: width 0.1s linear;
  width: 0;
}

/* 3. CARD 3D TILT STYLES */
.card-tilt-active {
  transition: transform 0.1s ease;
  transform-style: preserve-3d;
}

/* 4. ANIMATED GRADIENT ORBS */
.gradient-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.15;
  pointer-events: none;
  z-index: 0;
  animation: orbFloat 20s ease-in-out infinite;
}

.gradient-orb--green {
  background: radial-gradient(circle, #7ab648, transparent 70%);
}

.gradient-orb--blue {
  background: radial-gradient(circle, #1a3a5c, transparent 70%);
}

@keyframes orbFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25% { transform: translate(30px, -20px) scale(1.05); }
  50% { transform: translate(-20px, 30px) scale(0.95); }
  75% { transform: translate(20px, 20px) scale(1.02); }
}

[data-theme="light"] .gradient-orb {
  display: none;
}

/* 5. SECTION DIVIDER GLOW */
.section-divider {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, #7ab648, transparent);
  animation: dividerGlow 3s ease-in-out infinite;
}

@keyframes dividerGlow {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 0.8; }
}


/* 8. MAGNETIC BUTTON EFFECT */
.btn-magnetic {
  transition: transform 0.2s ease;
}

/* 9. ENHANCED FEATURE CARDS ON INDUSTRY PAGES */
.feature-card {
  position: relative;
  overflow: hidden;
}

.feature-card::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle at center, rgba(122, 182, 72, 0.05) 0%, transparent 70%);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.feature-card:hover::before {
  opacity: 1;
}

/* 10. PULSING CTA SECTION */
.consulting-cta-inner {
  position: relative;
  overflow: hidden;
}

.consulting-cta-inner::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: linear-gradient(45deg, #7ab648, #1a3a5c, #7ab648, #1a3a5c);
  background-size: 300% 300%;
  animation: ctaGlow 6s linear infinite;
  z-index: -1;
  opacity: 0.5;
}

@keyframes ctaGlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* 11. ANIMATED SERVICE ICONS */
.service-card:hover .service-icon svg,
.feature-card:hover .feature-icon svg {
  transform: scale(1.15) rotate(5deg);
  transition: transform 0.3s ease;
}

.service-icon svg,
.feature-icon svg {
  transition: transform 0.3s ease;
}

/* 12. NEWS CARD HOVER ENHANCEMENT */
.news-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.news-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.news-card:hover .news-card-image {
  transform: scale(1.05);
}

.news-card .news-card-image {
  transition: transform 0.6s ease;
  overflow: hidden;
}

/* 13. CUSTOMER STORY CARDS */
.customer-story-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.customer-story-card:hover {
  transform: translateY(-6px);
}

/* 14. PLATFORM CARD HOVER */
.platform-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.platform-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.platform-card:hover .platform-icon svg {
  transform: scale(1.15);
}

.platform-icon svg {
  transition: transform 0.3s ease;
}

/* 15. PREFERS REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .gradient-orb {
    display: none;
  }

  .hero-stats-bar {
    transform: none;
    opacity: 1;
    animation: none;
  }
}

/* ============================================
   PROCESS TIMELINE - "How We Protect You"
   ============================================ */
.process-section { background:var(--bg-section-alt); position:relative; overflow:hidden; }
.process-timeline { position:relative; max-width:800px; margin:60px auto 0; }
.process-line { position:absolute; left:32px; top:0; bottom:0; width:2px; background:linear-gradient(180deg, var(--primary-green), var(--primary-dark-blue)); opacity:0.3; }
.process-step { display:flex; gap:32px; margin-bottom:48px; position:relative; align-items:flex-start; }
.process-step:last-child { margin-bottom:0; }
.process-node { position:relative; flex-shrink:0; }
.process-node-inner { width:64px; height:64px; border-radius:50%; background:var(--bg-card); border:2px solid var(--primary-green); display:flex; align-items:center; justify-content:center; color:var(--primary-green); position:relative; z-index:2; transition:all 0.4s ease; box-shadow:0 0 0 0 rgba(122,182,72,0); }
.process-step:hover .process-node-inner { box-shadow:0 0 20px rgba(122,182,72,0.3); border-color:#fff; background:var(--primary-green); color:#fff; transform:scale(1.1); }
.process-number { position:absolute; top:-8px; right:-8px; width:24px; height:24px; border-radius:50%; background:var(--primary-green); color:#fff; font-size:0.65rem; font-weight:700; display:flex; align-items:center; justify-content:center; z-index:3; }
.process-content { padding-top:8px; flex:1; }
.process-content h3 { font-size:1.3rem; font-weight:700; color:var(--text-white); margin-bottom:8px; }
.process-content p { color:var(--text-secondary); line-height:1.7; margin-bottom:12px; }
.process-tags { display:flex; flex-wrap:wrap; gap:8px; }
.process-tags span { display:inline-block; padding:4px 12px; font-size:0.75rem; font-weight:600; border-radius:20px; background:rgba(122,182,72,0.1); color:var(--primary-green); border:1px solid rgba(122,182,72,0.2); letter-spacing:0.3px; }
[data-theme="light"] .process-tags span { background:rgba(45,107,34,0.08); color:#2d6b22; border-color:rgba(45,107,34,0.15); }
[data-theme="light"] .process-node-inner { border-color:#2d6b22; color:#2d6b22; }
[data-theme="light"] .process-step:hover .process-node-inner { background:#2d6b22; color:#fff; border-color:#2d6b22; box-shadow:0 0 20px rgba(45,107,34,0.2); }
[data-theme="light"] .process-number { background:#2d6b22; }
[data-theme="light"] .process-line { background:linear-gradient(180deg, #2d6b22, #1a3a5c); }

@media(max-width:768px){
  .process-timeline { margin-top:40px; }
  .process-step { gap:20px; }
  .process-node-inner { width:48px; height:48px; }
  .process-node-inner svg { width:20px; height:20px; }
  .process-content h3 { font-size:1.1rem; }
  .process-line { left:24px; }
}

/* ============================================
   ENHANCED CERTIFICATION BADGES
   ============================================ */
.cert-logos span {
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  padding:10px 20px;
  border-radius:8px;
  font-size:0.8rem;
  font-weight:600;
  letter-spacing:1px;
  color:var(--text-secondary);
  transition:all 0.3s ease;
  cursor:default;
}
.cert-logos span:hover {
  border-color:var(--primary-green);
  color:var(--primary-green);
  background:rgba(122,182,72,0.08);
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(122,182,72,0.15);
}
.certifications-bar {
  padding:60px 0;
  background:var(--bg-section);
  border-top:1px solid var(--border-dark);
}
.cert-logos {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  margin-top:20px;
}

/* ============================================
   ENHANCED CONSULTING CTA
   ============================================ */
.consulting-cta { background:linear-gradient(135deg, #0a1628 0%, #122a1a 50%, #0a1628 100%); position:relative; overflow:hidden; }
[data-theme="light"] .consulting-cta { background:linear-gradient(135deg, #e8f5e9 0%, #f1f5f9 50%, #e8f5e9 100%); }
.consulting-cta-inner { text-align:center; max-width:700px; margin:0 auto; padding:60px 40px; border-radius:var(--radius-lg); background:var(--glass-bg); border:1px solid var(--glass-border); backdrop-filter:blur(10px); }

/* ============================================
   PREMIUM FAQ ACCORDION
   ============================================ */
.faq-section { background: var(--bg-section); }
.faq-section h2 { font-size: 2rem; font-weight: 800; margin-bottom: 40px; text-align: center; background: linear-gradient(135deg, var(--text-white) 0%, var(--primary-green) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
[data-theme="light"] .faq-section h2 { background: linear-gradient(135deg, #1a202c 0%, #2d6b22 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.faq-grid { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-md); overflow: hidden; transition: all 0.3s ease; }
.faq-item:hover { border-color: rgba(122,182,72,0.3); box-shadow: 0 4px 20px rgba(0,0,0,0.15); }
.faq-item.faq-active { border-color: rgba(122,182,72,0.4); box-shadow: 0 4px 24px rgba(122,182,72,0.08); }
.faq-question { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 24px; cursor: pointer; user-select: none; }
.faq-question h3 { font-size: 1rem; font-weight: 600; color: var(--text-white); line-height: 1.5; margin: 0; flex: 1; transition: color 0.3s ease; }
.faq-item.faq-active .faq-question h3 { color: var(--primary-green); }
[data-theme="light"] .faq-item.faq-active .faq-question h3 { color: #2d6b22; }
.faq-icon { width: 32px; height: 32px; border-radius: 50%; background: rgba(122,182,72,0.1); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 0.3s ease; }
.faq-item.faq-active .faq-icon { background: var(--primary-green); transform: rotate(45deg); }
.faq-icon svg { width: 16px; height: 16px; stroke: var(--primary-green); transition: stroke 0.3s ease; }
.faq-item.faq-active .faq-icon svg { stroke: #fff; }
[data-theme="light"] .faq-icon { background: rgba(45,107,34,0.08); }
[data-theme="light"] .faq-icon svg { stroke: #2d6b22; }
[data-theme="light"] .faq-item.faq-active .faq-icon { background: #2d6b22; }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
.faq-answer-inner { padding: 0 24px 20px 24px; color: var(--text-secondary); line-height: 1.8; font-size: 0.95rem; }
.faq-item.faq-active .faq-answer { max-height: 500px; }
.faq-number { font-size: 0.75rem; font-weight: 700; color: var(--primary-green); opacity: 0.5; margin-right: 12px; min-width: 24px; }
[data-theme="light"] .faq-number { color: #2d6b22; }

/* --- Vendor Logo Images --- */
.vendor-logo-img { height:50px; width:auto; object-fit:contain; margin-bottom:12px; opacity:0.85; transition:opacity 0.3s ease }
.feature-card:hover .vendor-logo-img { opacity:1 }
[data-theme="light"] .vendor-logo-img { filter:brightness(0) saturate(100%); opacity:0.7 }
[data-theme="light"] .feature-card:hover .vendor-logo-img { opacity:0.9 }
