*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ══════════════════════════════════════
   LIGHT THEME
══════════════════════════════════════ */
:root, [data-theme="light"] {
  --bg:               #f9f9ff;
  --bg-2:             #f0f3ff;
  --bg-3:             #ffffff;
  --surface:          #ffffff;
  --surface-2:        #e7eeff;
  --surface-3:        #dee8ff;

  --primary: #1E3A8A;         /* Core Blue */
--primary-light: #38BDF8;   /* Tech Blue */
--primary-glow: rgba(30,58,138,0.15);

  --secondary: #0F172A;        /* Dark Security */
--secondary-light: #334155;
--secondary-glow: rgba(15,23,42,0.2);

  --accent-grad: linear-gradient(90deg, #1E3A8A, #38BDF8);
--accent-grad-vivid: linear-gradient(90deg, #38BDF8, #22C55E);

--success: #22C55E;

  --text:             #111c2d;



  --headerfooterlogo: #918484;
  


  --text-muted:       #3b4a45;
  --text-dim:         #6b7a75;

  --border:           rgba(0,107,90,0.11);
  --border-accent:    rgba(0,107,90,0.26);

  --chip-bg:          rgba(0,209,178,0.11);
  --chip-border:      rgba(0,209,178,0.32);
  --chip-text:        #006b5a;

  --card-shadow:      0 4px 24px rgba(0,107,90,0.07);
  --card-shadow-h:    0 16px 40px rgba(0,107,90,0.13);

  --nav-bg:           rgba(249,249,255,0.88);
  --footer-bg:        #111c2d;
  --footer-text:      rgba(255,255,255,0.6);

  --input-bg:         #f0f3ff;
  --input-border:     rgba(0,107,90,0.16);

  --terminal-bg:      #0f1e1a;
  --terminal-bar:     #162920;

  --boxshadowforcallbutton: rgba(1, 1, 1, 1);
}

/* ══════════════════════════════════════
   DARK THEME
══════════════════════════════════════ */
[data-theme="dark"] {
  --bg: #0B1220;   /* deep navy black */
  --bg-2:             #0C1A2B;
  --bg-3:             #111f18;
  --surface: #111827;
  --surface-2: #162447;
  --surface-3: #1f4068;

  --card: #1E293B;

  --primary: #38BDF8;
  --primary-light: #60A5FA;
  --primary-glow: rgba(56,189,248,0.2);

  --primary-dark: #1E3A8A;


  --secondary: #0F172A;
  --secondary-light: #1E293B;
  --secondary-glow: rgba(0,0,0,0.4);

  --accent-grad:       linear-gradient(90deg, #00d1b2, #0f6df3);
  --accent-grad-vivid: linear-gradient(90deg, #58fbda, #60a5fa);

  --text:             #e8f5f0;



  --headerfooterlogo: #8394cc;
  


  --text-muted:       #9ab8ad;
  --text-dim:         #5e8a78;

  --border:           rgba(0,209,178,0.1);
  --border-accent:    rgba(0,209,178,0.26);

  --chip-bg:          rgba(0,209,178,0.09);
  --chip-border:      rgba(0,209,178,0.28);
  --chip-text:        #00d1b2;

  --card-shadow:      0 4px 24px rgba(0,0,0,0.3);
  --card-shadow-h:    0 16px 40px rgba(0,209,178,0.1);

  --nav-bg: linear-gradient(
  180deg,
  rgba(15,23,42,0.85),
  rgba(22,36,71,0.65)
);
  --footer-text: rgba(255,255,255,0.65);
  --footer-text:      rgba(255,255,255,0.5);

  --footer-bg: #070d18;
  --input-bg:         #0C1A2B;
  --input-border:     rgba(0,209,178,0.16);

  --terminal-bg:      #060d09;
  --terminal-bar:     #1f4068;

  --boxshadowforcallbutton: rgba(255, 255, 255, 0.2);
}

/* ══════════════════════════════════════
   BASE
══════════════════════════════════════ */
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background 0.35s, color 0.35s;
}

.grid-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 75% 50% at 50% 0%, black, transparent 75%);
}
.orb { position: fixed; border-radius: 50%; pointer-events: none; z-index: 0; filter: blur(90px); transition: background 0.35s; }
.orb-1 { width: 520px; height: 520px; top: -180px; left: -100px; background: var(--primary-glow); }
.orb-2 { width: 420px; height: 420px; top: 35%; right: -140px; background: var(--secondary-glow); }
.orb-3 { width: 360px; height: 360px; bottom: 8%; left: 20%; background: var(--primary-glow); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 clamp(20px,5vw,60px); position: relative; z-index: 1; }

/* ══════════════════════════════════════
   CALL, wa, m.me
══════════════════════════════════════ */
.call-button {
    position: fixed;
    right: 24px;
    bottom: 24px;

    width: 54px;
    height: 54px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;

    text-decoration: none;

    background: var(--primary);

    color: var(--surface);

    outline: 2px solid var(--primary-glow);
    outline-offset: 2px; 

    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    box-shadow: 0 8px 30px var(--boxshadowforcallbutton);

    z-index: 9999;

    transition: all 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}

.call-button:hover {
    transform: translateX(-2px);
    
    outline-color: var(--primary);

    box-shadow: 20px 0px 70px var(--primary);
}



.floating-button {
    position: fixed;
    right: 24px;

    width: 54px;
    height: 54px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;

    text-decoration: none;

    color: white;

    z-index: 9999;

    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    transition: all 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}

.floating-button svg {
    width: 24px;
    height: 24px;

    flex-shrink: 0;
}






.chat-bubble {
    position: absolute;
    right: 70px;
    bottom: 8px;

    padding: 10px 14px;

    border-radius: 14px;

    color: #fff;

    font-size: 13px;
    font-weight: 500;

    white-space: nowrap;

    opacity: 0;
    transform: translateY(0);

    transition: all 0.4s ease;

    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

.chat-bubble.show {
    opacity: 1;
    transform: translateY(0);
}

/* optional different positioning if needed */
.whatsapp { bottom: 7px; background: #25D366;}
.messenger { bottom: 7px; background: #0084FF;}


.call-bubble {
    position: absolute;
    right: 70px;
    bottom: 8px;

    padding: 10px 14px;

    border-radius: 14px;

    background: var(--primary);
    color: #fff;

    font-size: 13px;
    font-weight: 500;

    white-space: nowrap;

    opacity: 0;
    transform: translateY(6px);

    transition: all 0.4s ease;

    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

.call-bubble.show {
    opacity: 1;
    transform: translateY(0);
}







/* Messenger */
.messenger-button {
    bottom: 94px;

    background: #0084FF;

    outline: 2px solid rgba(0, 132, 255, 0.24);
    outline-offset: 2px;

    box-shadow: 0 8px 30px var(--boxshadowforcallbutton);

}

.messenger-button:hover {
    transform: translateX(-2px);

    outline-color: #0084FF;

    box-shadow: 20px 0px 70px var(--primary);
}

/* WhatsApp */
.whatsapp-button {
    bottom: 164px;

    background: #25D366;

    outline: 2px solid rgba(37, 211, 102, 0.25);
    outline-offset: 2px;

    box-shadow: 0 8px 30px var(--boxshadowforcallbutton);
}

.whatsapp-button:hover {
    transform: translateX(-2px);

    outline-color: #25D366;

    box-shadow: 20px 0px 70px var(--primary);
}




/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav {
  position: sticky; top: 0; z-index: 100;
  padding: 0 clamp(20px,5vw,60px); height: 66px;
  display: flex; align-items: center; justify-content: space-between;
  background: var(--nav-bg);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  transition: background 0.35s, border-color 0.35s;
}
.nav-logo {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Syne', sans-serif; font-size: 1.15rem; font-weight: 800;
  color: var(--headerfooterlogo); text-decoration: none; letter-spacing: -0.02em;
}
.logo-mark {
  width: 34px; height: 34px; border-radius: 9px;
  background: var(--accent-grad);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 16px var(--primary-glow);
  transition: box-shadow 0.35s;
}
.logo-mark span { color: white; font-size: 18px; }
.logo-dot { color: #22C55E; /* green accent */ }

.nav-links { display: flex; gap: 2px; list-style: none; }
.nav-links a {
  padding: 7px 14px; border-radius: 7px;
  font-size: 0.875rem; font-weight: 500; color: var(--text-muted);
  text-decoration: none; transition: all 0.2s;
}
.nav-links a:hover { color: var(--text); background: var(--surface-2); }

.nav-right { display: flex; gap: 8px; align-items: center; }

.theme-toggle {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--surface-2); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s; color: var(--text-muted);
}
.theme-toggle:hover { background: var(--surface-3); color: var(--primary); border-color: var(--border-accent); }
.theme-toggle span { font-size: 20px; transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1); }
.theme-toggle:hover span { transform: rotate(20deg); }

.btn-outline {
  padding: 8px 18px; border-radius: 9px; font-size: 0.875rem; font-weight: 600;
  color: var(--primary); border: 1.5px solid var(--border-accent);
  background: transparent; cursor: pointer; transition: all 0.2s;
  text-decoration: none; display: inline-flex; align-items: center; gap: 5px;
  font-family: 'DM Sans', sans-serif;
}
.btn-outline:hover { background: var(--chip-bg); border-color: var(--primary); }

.btn-primary {
  background: linear-gradient(90deg, #38BDF8, #1E3A8A);
  color: white;
  padding: 9px 22px; border-radius: 9px; font-size: 0.875rem; font-weight: 700;
  color: white; background: var(--accent-grad);
  border: none; cursor: pointer; transition: all 0.2s;
  text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 0 20px var(--primary-glow);
  font-family: 'DM Sans', sans-serif;
}
.btn-primary:hover { background: linear-gradient(90deg, #22D3EE, #38BDF8); opacity: 0.88; transform: translateY(-1px); box-shadow: 0 4px 24px var(--primary-glow); }
.btn-primary:active { transform: scale(0.97); }

.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--text); border-radius: 2px; transition: all 0.22s; }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav {
  display: none; position: fixed; top: 66px; left: 0; right: 0; z-index: 99;
  background: var(--nav-bg); backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  padding: 16px 24px 24px; flex-direction: column; gap: 4px;
  text-align: center;
}
.mobile-nav.open { display: flex; }
.mobile-nav a { padding: 11px 16px; border-radius: 8px; font-weight: 500; color: var(--text-muted); text-decoration: none; transition: all 0.2s; }
.mobile-nav a:hover { color: var(--text); background: var(--surface-2); }
.mobile-nav hr { border: none; border-top: 1px solid var(--border); margin: 8px 0; }
.mobile-nav .btn-primary { justify-content: center; margin-top: 4px; }
.theme-toggle-mob { display: none; }

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero { padding: clamp(64px,10vw,110px) 0 clamp(56px,8vw,90px); text-align: center; }

.hero-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 18px; border-radius: 999px;
  border: 1px solid var(--chip-border); background: var(--chip-bg);
  font-size: 0.78rem; font-weight: 700; color: var(--chip-text);
  letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 28px;
  animation: fadeDown 0.7s ease both;
  transition: background 0.35s, border-color 0.35s, color 0.35s;
}
.chip-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--primary-light); box-shadow: 0 0 7px var(--primary-light);
  animation: bpulse 2s ease-in-out infinite;
}
@keyframes bpulse { 0%,100%{opacity:1} 50%{opacity:0.35} }

.hero h1 {
  font-family: 'Syne', sans-serif;
  font-size: clamp(2.6rem,6vw,4.4rem); font-weight: 800;
  line-height: 1.09; letter-spacing: -0.03em; margin-bottom: 22px;
  color: var(--text); animation: fadeDown 0.7s 0.1s ease both; transition: color 0.35s;
}
.line2 { display: block; }
.grad-text {
  background: var(--accent-grad-vivid);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

.hero-sub {
  font-size: clamp(1rem,2vw,1.12rem); color: var(--text-muted); line-height: 1.72;
  max-width: 575px; margin: 0 auto 38px;
  animation: fadeDown 0.7s 0.2s ease both; transition: color 0.35s;
}
.hero-actions {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 60px; animation: fadeDown 0.7s 0.3s ease both;
}
.hero-actions .btn-primary { padding: 13px 30px; font-size: 1rem; border-radius: 12px; }
.hero-actions .btn-outline  { padding: 12px 26px; font-size: 1rem; border-radius: 12px; }

.stats-bar {
  display: flex; justify-content: center; gap: clamp(20px,5vw,60px);
  padding: 26px 32px; background: var(--surface); border: 1px solid var(--border);
  border-radius: 20px; max-width: 680px; margin: 0 auto; box-shadow: var(--card-shadow);
  animation: fadeUp 0.7s 0.4s ease both;
  transition: background 0.35s, border-color 0.35s, box-shadow 0.35s;
}
.stat { text-align: center; }
.stat-num {
  font-family: 'Syne', sans-serif; font-size: clamp(1.6rem,3vw,2.1rem); font-weight: 800;
  background: var(--accent-grad); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.stat-label { font-size: 0.8rem; color: var(--text-dim); margin-top: 4px; transition: color 0.35s; }

@keyframes fadeDown { from{opacity:0;transform:translateY(-18px)} to{opacity:1;transform:none} }
@keyframes fadeUp   { from{opacity:0;transform:translateY(18px)}  to{opacity:1;transform:none} }

/* ══════════════════════════════════════
   SECTIONS
══════════════════════════════════════ */
.section { padding: clamp(56px,8vw,96px) 0; }
.alt-section {
  background: var(--bg-2);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  transition: background 0.35s, border-color 0.35s;
}

.section-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.74rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--primary); margin-bottom: 12px; transition: color 0.35s;
}
.section-tag::before { content:''; width:22px; height:2.5px; background:var(--primary); border-radius:2px; transition: background 0.35s; }
.section-title {
  font-family: 'Syne', sans-serif;
  font-size: clamp(1.7rem,3.5vw,2.5rem); font-weight: 800;
  letter-spacing: -0.025em; line-height: 1.16; margin-bottom: 12px;
  color: var(--text); transition: color 0.35s;
}
.section-desc { font-size: 1rem; color: var(--text-muted); line-height: 1.7; max-width: 500px; transition: color 0.35s; }

/* ══════════════════════════════════════
   SERVICES
══════════════════════════════════════ */
.services-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr));
  gap: 16px; margin-top: 44px;
}
.service-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 18px; padding: 28px;
  transition: all 0.25s; cursor: default; position: relative; overflow: hidden;
}
.service-card::before {
  content:''; position: absolute; inset: 0; border-radius: 18px;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), var(--primary-glow) 0%, transparent 65%);
  opacity: 0; transition: opacity 0.3s;
}
.service-card:hover::before { opacity: 1; }
.service-card:hover { border-color: var(--border-accent); transform: translateY(-4px); box-shadow: var(--card-shadow-h); }

.svc-icon {
  width: 50px; height: 50px; border-radius: 13px;
  display: flex; align-items: center; justify-content: center; margin-bottom: 18px;
}
.svc-icon.teal   { background: rgba(0,209,178,0.12); }
.svc-icon.blue   { background: rgba(15,109,243,0.11); }
.svc-icon.green  { background: rgba(0,107,90,0.11); }
.svc-icon.cyan   { background: rgba(0,209,178,0.09); }
.svc-icon.indigo { background: rgba(99,102,241,0.1); }
.svc-icon.rose   { background: rgba(244,63,94,0.09); }
.svc-icon.teal   span { color: #00d1b2; }
.svc-icon.blue span   { color: #1E3A8A; }
.svc-icon.green span  { color: #22C55E; }
.svc-icon.cyan span   { color: #38BDF8; }
.svc-icon.indigo span { color: #818cf8; }
.svc-icon.rose   span { color: #f43f5e; }
[data-theme="dark"] .svc-icon.green span { color: #00d1b2; }
.svc-icon span { font-size: 24px; }

.service-card h3 { font-family:'Syne',sans-serif; font-size:1.02rem; font-weight:700; margin-bottom:9px; color:var(--text); transition:color 0.35s; }
.service-card p  { font-size:0.875rem; color:var(--text-muted); line-height:1.65; margin-bottom:18px; transition:color 0.35s; }
.svc-tags { display:flex; flex-wrap:wrap; gap:6px; }
.tag { font-size:0.7rem; font-weight:600; padding:3px 10px; border-radius:999px; border:1px solid var(--border); color:var(--text-dim); transition:all 0.35s; }

/* ══════════════════════════════════════
   WHY US
══════════════════════════════════════ */
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.why-points { display:flex; flex-direction:column; gap:14px; margin-top:28px; }
.why-point {
  display:flex; gap:14px; align-items:flex-start;
  padding:16px 18px; border-radius:12px;
  background:var(--surface); border:1px solid var(--border); transition:all 0.2s;
}
.why-point:hover { border-color:var(--border-accent); box-shadow:var(--card-shadow); }
.why-point-icon {
  width:36px; height:36px; border-radius:9px; flex-shrink:0;
  background:var(--chip-bg); display:flex; align-items:center; justify-content:center;
}
.why-point-icon span { font-size:20px; color:var(--primary); transition:color 0.35s; }
.why-point h4 { font-size:0.9rem; font-weight:600; margin-bottom:3px; }
.why-point p  { font-size:0.82rem; color:var(--text-muted); line-height:1.55; }

.terminal {
  background:var(--terminal-bg); border:1px solid rgba(0,209,178,0.15);
  border-radius:16px; overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,0.25), 0 0 0 1px rgba(0,209,178,0.07);
  transition:background 0.35s;
}
.terminal-bar { background:var(--surface-3); padding:11px 16px; display:flex; align-items:center; gap:7px; border-bottom:1px solid rgba(0,209,178,0.1); }
.t-dot { width:11px; height:11px; border-radius:50%; }
.t-dot.r{background:#f43f5e} .t-dot.y{background:#f59e0b} .t-dot.g{background:#10b981}
.terminal-title { font-size:0.76rem; color: var(--text); font-weight: bold; margin-left:6px; font-family:'Courier New',monospace; }
.terminal-body { padding:20px 22px; background: #111827; font-family:'Courier New',monospace; font-size:0.82rem; line-height:1.85; }
.t-line { display:flex; gap:10px; margin-bottom:1px; }
.t-prompt{color:#00d1b2} .t-cmd{color:#e8f5f0}
.t-ok  {color:#10b981; padding-left:16px}
.t-warn{color:#f59e0b; padding-left:16px}
.t-info{color:#5e8a78; padding-left:16px}
.t-cursor { display:inline-block; width:8px; height:14px; background:#00d1b2; animation:blink 1.1s step-end infinite; vertical-align:text-bottom; }
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ══════════════════════════════════════
   PROCESS
══════════════════════════════════════ */
.process-steps {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:0; margin-top:48px; position:relative;
}
.process-steps::before {
  content:''; position:absolute; top:27px; left:10%; right:10%; height:1.5px;
  background:linear-gradient(90deg,transparent,var(--primary-light) 20%,var(--secondary-light) 80%,transparent);
  transition:background 0.35s;
}
.process-step { text-align:center; padding:0 12px; position:relative; }
.step-num {
  width:54px; height:54px; border-radius:50%; margin:0 auto 18px;
  background:var(--surface); border:2px solid var(--primary-light);
  display:flex; align-items:center; justify-content:center;
  font-family:'Syne',sans-serif; font-size:1.05rem; font-weight:800;
  color:var(--primary); position:relative; z-index:1;
  box-shadow:0 0 18px var(--primary-glow); transition:all 0.35s;
}
.process-step h3 { font-family:'Syne',sans-serif; font-size:0.95rem; font-weight:700; margin-bottom:8px; color:var(--text); }
.process-step p  { font-size:0.82rem; color:var(--text-muted); line-height:1.6; }

/* ══════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════ */
.testimonials-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:16px; margin-top:44px;
}
.testi-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:18px; padding:28px; transition:all 0.25s;
}
.testi-card:hover { border-color:var(--border-accent); transform:translateY(-3px); box-shadow:var(--card-shadow-h); }
.testi-stars { color:#f59e0b; font-size:0.85rem; letter-spacing:2px; margin-bottom:12px; }
.testi-text  { font-size:0.875rem; color:var(--text-muted); line-height:1.72; margin-bottom:18px; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:40px; height:40px; border-radius:50%;
  background:var(--accent-grad);
  display:flex; align-items:center; justify-content:center;
  font-size:0.82rem; font-weight:700; color:white; flex-shrink:0;
}
.testi-name { font-size:0.875rem; font-weight:600; color:var(--text); }
.testi-role { font-size:0.74rem; color:var(--text-dim); }

/* ══════════════════════════════════════
   CTA BAND
══════════════════════════════════════ */
.cta-band {
  margin:0 clamp(16px,4vw,40px) 80px;
  border-radius:22px; padding:clamp(40px,6vw,68px);
  background:var(--accent-grad);
  text-align:center; position:relative; overflow:hidden;
  box-shadow:0 0 60px var(--primary-glow), 0 24px 60px rgba(0,0,0,0.1);
}
.cta-band::before {
  content:''; position:absolute; top:-120px; left:50%; transform:translateX(-50%);
  width:600px; height:300px;
  background:radial-gradient(ellipse,rgba(255,255,255,0.12) 0%,transparent 70%);
  pointer-events:none;
}
.cta-band h2 { font-family:'Syne',sans-serif; font-size:clamp(1.7rem,3.5vw,2.6rem); font-weight:800; letter-spacing:-0.02em; color:white; margin-bottom:12px; position:relative; }
.cta-band p  { font-size:1rem; color:rgba(255,255,255,0.82); margin-bottom:34px; position:relative; }
.cta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; position:relative; }
.btn-white {
  padding:13px 30px; border-radius:12px; font-size:0.95rem; font-weight:700;
  color:var(--primary); background:white; border:none; cursor:pointer;
  transition:all 0.2s; text-decoration:none; display:inline-flex; align-items:center; gap:6px;
  box-shadow:0 4px 16px rgba(0,0,0,0.14);
}
.btn-white:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(0,0,0,0.2); }
.btn-outline-white {
  padding:12px 26px; border-radius:12px; font-size:0.95rem; font-weight:700;
  color:white; background:rgba(255,255,255,0.12); border:1.5px solid rgba(255,255,255,0.45);
  cursor:pointer; transition:all 0.2s; text-decoration:none; display:inline-flex; align-items:center; gap:6px;
}
.btn-outline-white:hover { background:rgba(255,255,255,0.22); border-color:white; }

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:44px; align-items:start; margin-top:44px; }
.contact-info { display:flex; flex-direction:column; gap:12px; }
.contact-item {
  display:flex; gap:14px; align-items:center;
  padding:15px 18px; background:var(--surface);
  border:1px solid var(--border); border-radius:12px; transition:all 0.2s;
}
.contact-item:hover { border-color:var(--border-accent); box-shadow:var(--card-shadow); }
.contact-icon { width:40px; height:40px; border-radius:10px; background:var(--chip-bg); flex-shrink:0; display:flex; align-items:center; justify-content:center; transition:background 0.35s; }
.contact-icon span { color:var(--primary); font-size:20px; transition:color 0.35s; }
.contact-label { font-size:0.7rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:2px; }
.contact-value { font-size:0.9rem; font-weight:500; color:var(--text); }

.contact-form { background:var(--surface); border:1px solid var(--border); border-radius:20px; padding:30px; transition:background 0.35s,border-color 0.35s; }
.form-group { margin-bottom:14px; }
.form-label { display:block; font-size:0.72rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.form-input,.form-select,.form-textarea {
  width:100%; padding:11px 14px;
  background:var(--input-bg); border:1.5px solid var(--input-border);
  border-radius:9px; color:var(--text); font-size:0.9rem;
  font-family:'DM Sans',sans-serif; transition:all 0.2s; outline:none; appearance:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus {
  border-color:var(--primary-light); box-shadow:0 0 0 3px var(--primary-glow);
}
.form-input::placeholder,.form-textarea::placeholder { color:var(--text-dim); }
.form-textarea { min-height:108px; resize:vertical; }
.form-select { cursor:pointer; }
.form-select option { background:var(--surface); color:var(--text); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.btn-submit {
  width:100%; padding:13px; background:var(--accent-grad);
  color:white; border:none; border-radius:10px;
  font-size:0.95rem; font-weight:700; cursor:pointer;
  font-family:'DM Sans',sans-serif; transition:all 0.2s;
  box-shadow:0 0 20px var(--primary-glow);
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.btn-submit:hover { opacity:0.88; transform:translateY(-1px); box-shadow:0 6px 28px var(--primary-glow); }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer {
  background:var(--footer-bg); border-top:1px solid var(--border);
  padding:clamp(40px,6vw,64px) clamp(20px,5vw,60px) 28px;
  transition:background 0.35s;
}
.footer-inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px;
}
.footer-brand p { font-size:0.85rem; color:var(--footer-text); line-height:1.65; margin-top:12px; max-width:260px; }
.footer-col h4 { font-size:0.7rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:rgba(255,255,255,0.32); margin-bottom:14px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-col a { font-size:0.85rem; color:var(--footer-text); text-decoration:none; transition:color 0.2s; }
.footer-col a:hover { color:var(--primary-light); }
.footer-bottom {
  max-width:1200px; margin:0 auto;
  padding-top:22px; border-top:1px solid rgba(255,255,255,0.06);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:10px; font-size:0.8rem; color:rgba(255,255,255,0.3);
}

/* ══════════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(26px); transition:opacity 0.6s ease,transform 0.6s ease; }
.reveal.visible { opacity:1; transform:none; }

.material-symbols-outlined { font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 920px) {
  .why-grid { grid-template-columns:1fr; }
  .why-visual { order:-1; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .footer-brand { grid-column:1/-1; }
  nav .nav-links, nav .nav-right { display:none; }
  .hamburger { display:flex; }
  .theme-toggle-mob { display:flex; }
}
@media (max-width: 600px) {
  .process-steps { gap:28px; }
  .process-steps::before { display:none; }
  .hero-actions { flex-direction:column; align-items:center; }
  .stats-bar { flex-direction:column; gap:18px; padding:22px; }
  .form-row { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .cta-actions { flex-direction:column; align-items:center; }
}

/* ══════════════════════════════════════
   DOWNLOADS
══════════════════════════════════════ */
.dl-card {
  margin-top: 44px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 20px; overflow: hidden;
  box-shadow: var(--card-shadow);
  transition: background 0.35s, border-color 0.35s;
}
.dl-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
  padding: 28px 32px;
}
.dl-header { display: flex; align-items: center; gap: 16px; }
.dl-icon-wrap {
  width: 56px; height: 56px; border-radius: 14px; flex-shrink: 0;
  background: var(--chip-bg); display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--chip-border);
}
.dl-card-title { font-family:'Syne',sans-serif; font-size:1.05rem; font-weight:700; color:var(--text); }
.dl-card-sub   { font-size:0.85rem; color:var(--text-muted); margin-top:3px; }
.dl-controls { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.dl-select-wrap { position:relative; display:flex; align-items:center; }
.dl-select-icon { position:absolute; left:13px; font-size:18px; color:var(--text-dim); pointer-events:none; z-index:1; }
.dl-select {
  padding:11px 16px 11px 42px;
  background:var(--input-bg); border:1.5px solid var(--input-border);
  border-radius:10px; color:var(--text); font-size:0.9rem;
  font-family:'DM Sans',sans-serif; outline:none; cursor:pointer;
  appearance:none; min-width:220px; transition:all 0.2s;
}
.dl-select:focus { border-color:var(--primary-light); box-shadow:0 0 0 3px var(--primary-glow); }
.btn-download {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 24px; border-radius:10px;
  font-size:0.9rem; font-weight:700; color:white;
  background:var(--accent-grad); border:none; cursor:pointer;
  transition:all 0.2s; font-family:'DM Sans',sans-serif;
  box-shadow:0 0 16px var(--primary-glow); white-space:nowrap;
}
.btn-download:disabled { opacity:0.4; cursor:not-allowed; box-shadow:none; filter:grayscale(0.4); }
.btn-download:not(:disabled):hover { opacity:0.88; transform:translateY(-1px); box-shadow:0 6px 24px var(--primary-glow); }
.dl-preview {
  display:flex; align-items:center; gap:16px;
  padding:18px 32px; border-top:1px solid var(--border);
  background:var(--bg-2); transition:all 0.35s;
  animation:slideDown 0.28s ease;
}
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
.dl-preview-icon {
  width:48px; height:48px; border-radius:12px; flex-shrink:0;
  background:var(--chip-bg); border:1px solid var(--chip-border);
  display:flex; align-items:center; justify-content:center; color:var(--primary);
}
.dl-preview-name    { font-weight:700; font-size:0.95rem; color:var(--text); }
.dl-preview-version { font-size:0.78rem; color:var(--text-dim); margin-top:2px; }
.dl-preview-desc    { font-size:0.82rem; color:var(--text-muted); margin-top:4px; line-height:1.5; }
.dl-preview-size {
  margin-left:auto; flex-shrink:0;
  display:flex; align-items:center; gap:6px;
  font-size:0.85rem; font-weight:600; color:var(--text-dim);
  background:var(--surface); border:1px solid var(--border);
  padding:6px 14px; border-radius:999px;
}
/* MODAL */
.modal-overlay {
  position:fixed; inset:0; z-index:999;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:20px; animation:mFadeIn 0.2s ease;
}
@keyframes mFadeIn { from{opacity:0} to{opacity:1} }
.modal-box {
  background:var(--surface); border:1px solid var(--border-accent);
  border-radius:22px; padding:36px 32px 32px;
  max-width:440px; width:100%; position:relative;
  box-shadow:0 32px 80px rgba(0,0,0,0.3);
  animation:modalPop 0.28s cubic-bezier(0.34,1.56,0.64,1);
  transition:background 0.35s;
}
@keyframes modalPop { from{opacity:0;transform:scale(0.92) translateY(12px)} to{opacity:1;transform:none} }
.modal-close {
  position:absolute; top:14px; right:14px;
  width:32px; height:32px; border-radius:8px;
  background:var(--surface-2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--text-muted); transition:all 0.2s;
}
.modal-close:hover { background:var(--surface-3); color:var(--text); }
.modal-close span { font-size:18px; }
.modal-icon-wrap {
  width:72px; height:72px; border-radius:18px; margin:0 auto 20px;
  background:var(--chip-bg); border:1.5px solid var(--chip-border);
  display:flex; align-items:center; justify-content:center; color:var(--primary);
}
.modal-title    { font-family:'Syne',sans-serif; font-size:1.3rem; font-weight:800; text-align:center; margin-bottom:6px; color:var(--text); }
.modal-subtitle { font-size:0.9rem; color:var(--text-muted); text-align:center; margin-bottom:22px; }
.modal-file-row {
  display:flex; align-items:center; gap:14px;
  padding:16px 18px; border-radius:12px;
  background:var(--bg-2); border:1px solid var(--border); margin-bottom:18px;
}
.modal-file-name { font-weight:700; font-size:0.95rem; color:var(--text); }
.modal-file-meta { font-size:0.78rem; color:var(--text-dim); margin-top:3px; }
.modal-notice {
  display:flex; align-items:flex-start; gap:8px;
  padding:12px 14px; border-radius:10px;
  background:rgba(0,209,178,0.07); border:1px solid var(--chip-border);
  font-size:0.82rem; color:var(--text-muted); line-height:1.5; margin-bottom:24px;
}
.modal-notice strong { color:var(--primary); }
.modal-actions { display:flex; gap:10px; }
.modal-btn-cancel {
  flex:1; padding:12px; border-radius:10px;
  font-size:0.9rem; font-weight:600; color:var(--text-muted);
  background:var(--surface-2); border:1px solid var(--border);
  cursor:pointer; transition:all 0.2s; font-family:'DM Sans',sans-serif;
}
.modal-btn-cancel:hover { background:var(--surface-3); color:var(--text); }
.modal-btn-confirm {
  flex:1.4; padding:12px; border-radius:10px;
  font-size:0.9rem; font-weight:700; color:white;
  background:var(--accent-grad); border:none;
  cursor:pointer; transition:all 0.2s; font-family:'DM Sans',sans-serif;
  display:flex; align-items:center; justify-content:center; gap:6px;
  box-shadow:0 0 16px var(--primary-glow);
}
.modal-btn-confirm:hover { opacity:0.88; transform:translateY(-1px); }
.modal-btn-confirm:active { transform:scale(0.97); }
@media (max-width:600px) {
  .dl-top { flex-direction:column; align-items:flex-start; }
  .dl-preview { flex-wrap:wrap; }
  .dl-preview-size { margin-left:0; }
  .modal-box { padding:28px 20px 24px; }
}

