/* ================================================================
   NEXORA AI · Futuristic Dark Theme
   ================================================================ */

/* ── VARIABLES ──────────────────────────────────────────────────── */
:root {
    --bg:       #020817;
    --bg-2:     #070F23;
    --bg-3:     #0A1628;
    --bg-4:     #0F1E38;
    --bg-5:     #162442;
    --cyan:     #06B6D4;
    --cyan-2:   #22D3EE;
    --cyan-dim: #0891B2;
    --purple:   #8B5CF6;
    --purple-2: #A78BFA;
    --purple-dim:#7C3AED;
    --blue:     #3B82F6;
    --text:     #F1F5F9;
    --text-dim: #94A3B8;
    --text-muted:#4B5E78;
    --border:   rgba(6,182,212,0.12);
    --border-p: rgba(139,92,246,0.15);
    --glow-c:   0 0 30px rgba(6,182,212,0.25);
    --glow-p:   0 0 30px rgba(139,92,246,0.25);
    --ease:     cubic-bezier(0.25,0.46,0.45,0.94);
    --ease-out: cubic-bezier(0.16,1,0.3,1);
    --font-head:'Space Grotesk', sans-serif;
    --font-body:'Inter', sans-serif;
    --font-tech:'Orbitron', monospace;
}

/* ── RESET ──────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 1.05rem;
    line-height: 1.8;
    overflow-x: hidden;
}
img,video { display:block; max-width:100%; }
a { text-decoration:none; color:inherit; transition:color 0.3s; }
ul { list-style:none; }
button { border:none; cursor:pointer; background:none; }
strong { color: var(--text); }

/* ── SCROLLBAR ──────────────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:linear-gradient(var(--cyan),var(--purple)); border-radius:3px; }

/* ── SCROLL PROGRESS ────────────────────────────────────────────── */
.scroll-progress {
    position:fixed; top:0; left:0; height:2px; width:0%;
    background:linear-gradient(90deg,var(--cyan),var(--purple));
    z-index:9999;
    box-shadow: 0 0 10px var(--cyan);
    transition:width 0.1s linear;
}

/* ── CONTAINER ──────────────────────────────────────────────────── */
.container { max-width:1180px; margin:0 auto; padding:0 2rem; }

/* ── GRADIENT TEXT ──────────────────────────────────────────────── */
.grad-text {
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}

/* ── SECTION HEADER ─────────────────────────────────────────────── */
.sec-header { text-align:center; margin-bottom:4rem; }
.sec-tag {
    display:inline-block;
    font-family: var(--font-tech);
    font-size:0.65rem;
    letter-spacing:0.3em;
    text-transform:uppercase;
    color:var(--cyan);
    border:1px solid rgba(6,182,212,0.3);
    padding:0.35rem 1rem;
    margin-bottom:1.2rem;
    background:rgba(6,182,212,0.04);
}
.sec-title {
    font-family:var(--font-head);
    font-size:clamp(2rem,4vw,3rem);
    font-weight:700;
    line-height:1.2;
    color:var(--text);
    margin-bottom:1.2rem;
}
.sec-line {
    width:60px; height:2px;
    background:linear-gradient(90deg,var(--cyan),var(--purple));
    margin:0 auto 1rem;
    box-shadow:0 0 10px var(--cyan);
}
.sec-desc {
    max-width:600px;
    margin:0 auto;
    color:var(--text-dim);
    font-size:1.05rem;
}

/* ── SCROLL REVEAL ──────────────────────────────────────────────── */
.reveal-up,.reveal-left,.reveal-right,.reveal-fade {
    opacity:0;
    transition:opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
    transition-delay:var(--d,0s);
}
.reveal-up    { transform:translateY(50px); }
.reveal-left  { transform:translateX(-60px); }
.reveal-right { transform:translateX(60px); }
.reveal-fade  { transform:translateY(20px); }
.reveal-up.visible,.reveal-left.visible,.reveal-right.visible,.reveal-fade.visible {
    opacity:1; transform:none;
}

/* ── BUTTONS ────────────────────────────────────────────────────── */
.btn {
    display:inline-flex;
    align-items:center;
    gap:0.5rem;
    padding:0.85rem 2rem;
    font-family:var(--font-head);
    font-size:0.9rem;
    font-weight:600;
    letter-spacing:0.03em;
    border-radius:4px;
    transition:all 0.35s var(--ease);
    position:relative;
    overflow:hidden;
}
.btn-primary {
    background:linear-gradient(135deg,var(--cyan-dim),var(--purple-dim));
    color:#fff;
    border:1px solid rgba(6,182,212,0.3);
    box-shadow:0 0 20px rgba(6,182,212,0.15);
}
.btn-primary:hover {
    box-shadow:0 0 35px rgba(6,182,212,0.35), 0 0 35px rgba(139,92,246,0.2);
    transform:translateY(-2px);
}
.btn-ghost {
    background:transparent;
    color:var(--text);
    border:1px solid rgba(255,255,255,0.15);
}
.btn-ghost:hover {
    border-color:var(--cyan);
    color:var(--cyan);
    box-shadow:var(--glow-c);
}
.btn-full { width:100%; justify-content:center; }
.btn-arrow { transition:transform 0.3s; }
.btn:hover .btn-arrow { transform:translateX(4px); }

/* ═══════════════════════════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════════════════════════ */
.navbar {
    position:fixed; top:0; left:0; right:0;
    z-index:1000;
    padding:1.4rem 0;
    transition:all 0.5s var(--ease);
}
.navbar.scrolled {
    background:rgba(2,8,23,0.92);
    backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    padding:0.8rem 0;
    box-shadow:0 4px 40px rgba(0,0,0,0.5), 0 1px 0 rgba(6,182,212,0.1);
}
.nav-container {
    max-width:1280px; margin:0 auto; padding:0 2rem;
    display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
    display:flex; align-items:center; gap:0.8rem;
}
.logo-icon {
    width:38px; height:38px;
    background:linear-gradient(135deg,var(--cyan-dim),var(--purple-dim));
    border-radius:8px;
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-tech);
    font-size:1rem; font-weight:700;
    color:#fff;
    position:relative;
    box-shadow:var(--glow-c);
}
.logo-icon.sm { width:32px; height:32px; font-size:0.85rem; }
.logo-pulse {
    position:absolute; inset:-4px;
    border:1px solid rgba(6,182,212,0.3);
    border-radius:12px;
    animation:pulseLogo 2s ease-in-out infinite;
}
@keyframes pulseLogo {
    0%,100% { opacity:0.5; transform:scale(1); }
    50%      { opacity:1;   transform:scale(1.05); }
}
.logo-text { display:flex; flex-direction:column; }
.logo-name {
    font-family:var(--font-tech);
    font-size:0.9rem;
    font-weight:700;
    color:var(--text);
    letter-spacing:0.1em;
}
.logo-name em {
    font-style:normal;
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.logo-sub {
    font-size:0.65rem;
    color:var(--text-muted);
    letter-spacing:0.15em;
    font-family:var(--font-body);
}
.nav-links {
    display:flex; align-items:center; gap:2.5rem;
}
.nav-links a {
    font-family:var(--font-head);
    font-size:0.85rem;
    font-weight:500;
    color:var(--text-dim);
    transition:color 0.3s;
    position:relative;
}
.nav-links a::after {
    content:'';
    position:absolute;
    bottom:-4px; left:0;
    width:0; height:1px;
    background:linear-gradient(90deg,var(--cyan),var(--purple));
    transition:width 0.35s var(--ease);
}
.nav-links a:hover { color:var(--text); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
    padding:0.5rem 1.2rem !important;
    border:1px solid rgba(6,182,212,0.4) !important;
    border-radius:4px;
    color:var(--cyan) !important;
    background:rgba(6,182,212,0.05);
    transition:all 0.35s !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover {
    background:rgba(6,182,212,0.12) !important;
    box-shadow:var(--glow-c) !important;
    color:var(--cyan-2) !important;
}
.nav-toggle {
    display:none; flex-direction:column; gap:5px; padding:4px;
}
.nav-toggle span {
    display:block; width:22px; height:1.5px;
    background:var(--text);
    transition:all 0.35s var(--ease);
}
.nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px); }
.nav-toggle.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px); }

/* ═══════════════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════════════ */
.hero {
    position:relative;
    min-height:100vh;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden;
}
.hero-video {
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover; z-index:0;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    will-change: transform;
}
@media (max-width: 768px) {
    .hero-video { display: none; }
    .hero {
        background:
            radial-gradient(ellipse 80% 60% at 20% 30%, rgba(6,182,212,0.18) 0%, transparent 60%),
            radial-gradient(ellipse 60% 80% at 80% 70%, rgba(139,92,246,0.18) 0%, transparent 60%),
            linear-gradient(135deg, #020817 0%, #0A1628 50%, #070F23 100%);
    }
}
.hero-overlay {
    position:absolute; inset:0;
    background:
        linear-gradient(180deg, rgba(2,8,23,0.6) 0%, rgba(2,8,23,0.75) 50%, rgba(2,8,23,0.97) 100%),
        linear-gradient(135deg, rgba(6,182,212,0.12) 0%, transparent 50%, rgba(139,92,246,0.12) 100%);
    z-index:1;
}
.hero-grid {
    position:absolute; inset:0; z-index:1;
    background-image:
        linear-gradient(rgba(6,182,212,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(6,182,212,0.04) 1px, transparent 1px);
    background-size:60px 60px;
}

/* Particles */
.particle {
    position:absolute; border-radius:50%; z-index:1;
    animation:floatParticle 8s ease-in-out infinite;
}
.p1 { width:4px; height:4px; background:var(--cyan); top:20%; left:15%; box-shadow:0 0 10px var(--cyan); animation-delay:0s; }
.p2 { width:3px; height:3px; background:var(--purple); top:35%; right:20%; box-shadow:0 0 8px var(--purple); animation-delay:2s; }
.p3 { width:5px; height:5px; background:var(--cyan); bottom:30%; left:25%; box-shadow:0 0 12px var(--cyan); animation-delay:4s; }
.p4 { width:3px; height:3px; background:var(--purple-2); top:60%; right:15%; box-shadow:0 0 8px var(--purple); animation-delay:1s; }
.p5 { width:4px; height:4px; background:var(--blue); bottom:20%; right:30%; box-shadow:0 0 10px var(--blue); animation-delay:3s; }
@keyframes floatParticle {
    0%,100% { transform:translateY(0) translateX(0); opacity:0.6; }
    33%      { transform:translateY(-30px) translateX(15px); opacity:1; }
    66%      { transform:translateY(15px) translateX(-10px); opacity:0.8; }
}

.hero-content {
    position:relative; z-index:2;
    text-align:center; padding:2rem;
    max-width:900px;
}
.hero-tag {
    display:inline-flex; align-items:center; gap:0.6rem;
    font-family:var(--font-tech);
    font-size:0.65rem;
    letter-spacing:0.25em;
    color:var(--cyan);
    border:1px solid rgba(6,182,212,0.25);
    padding:0.4rem 1.2rem;
    background:rgba(6,182,212,0.04);
    margin-bottom:1.8rem;
    border-radius:2px;
}
.tag-dot {
    width:6px; height:6px; border-radius:50%;
    background:var(--cyan);
    box-shadow:0 0 8px var(--cyan);
    animation:blink 1.5s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }

.hero-title {
    font-family:var(--font-head);
    font-size:clamp(2.5rem,6vw,5rem);
    font-weight:700;
    line-height:1.15;
    color:var(--text);
    margin-bottom:1.5rem;
    text-shadow:0 0 60px rgba(6,182,212,0.1);
}
.hero-subtitle {
    font-family:var(--font-body);
    font-size:1.1rem;
    color:var(--text-dim);
    max-width:620px;
    margin:0 auto 2.5rem;
    line-height:1.75;
}
.hero-ctas {
    display:flex; gap:1rem; justify-content:center;
    flex-wrap:wrap; margin-bottom:3.5rem;
}
.hero-stats {
    display:flex; align-items:center; justify-content:center;
    gap:2rem; flex-wrap:wrap;
    padding:1.5rem 2.5rem;
    background:rgba(255,255,255,0.03);
    border:1px solid var(--border);
    border-radius:8px;
    backdrop-filter:blur(10px);
}
.h-stat { text-align:center; }
.h-stat-num {
    font-family:var(--font-tech);
    font-size:2rem;
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    display:inline;
}
.h-stat-label {
    display:block;
    font-size:0.75rem;
    color:var(--text-muted);
    letter-spacing:0.1em;
    margin-top:0.2rem;
}
.h-stat-sep { width:1px; height:40px; background:var(--border); }

/* Scroll indicator */
.scroll-indicator {
    position:absolute; bottom:2.5rem; left:50%;
    transform:translateX(-50%);
    z-index:2;
    display:flex; flex-direction:column; align-items:center; gap:0.6rem;
    color:var(--text-muted);
    font-size:0.65rem;
    letter-spacing:0.3em;
    text-transform:uppercase;
    font-family:var(--font-tech);
    animation:scrollBounce 2.5s ease-in-out infinite;
}
.scroll-line {
    width:1px; height:40px;
    background:linear-gradient(180deg,var(--cyan),transparent);
    box-shadow:0 0 8px var(--cyan);
    animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
    0%   { height:0; opacity:1; }
    70%  { height:40px; opacity:1; }
    100% { height:40px; opacity:0; }
}
@keyframes scrollBounce {
    0%,100% { transform:translateX(-50%) translateY(0); }
    50%      { transform:translateX(-50%) translateY(-6px); }
}

/* ═══════════════════════════════════════════════════════════════
   ABOUT
═══════════════════════════════════════════════════════════════ */
.about-section {
    padding:8rem 0;
    background:var(--bg-2);
    position:relative;
}
.about-section::before {
    content:'';
    position:absolute; inset:0;
    background:
        radial-gradient(ellipse 60% 50% at 80% 50%, rgba(139,92,246,0.05) 0%, transparent 70%);
    pointer-events:none;
}
.about-grid {
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:5rem;
    align-items:center;
}
.about-text p { color:var(--text-dim); margin-bottom:1rem; }
.about-lead {
    font-size:1.15rem;
    color:var(--text) !important;
    margin-bottom:1.2rem !important;
    line-height:1.7;
}
.about-visual { position:relative; display:flex; align-items:center; justify-content:center; }
.vision-card {
    background:rgba(15,30,56,0.7);
    border:1px solid var(--border-p);
    padding:2.5rem;
    border-radius:12px;
    backdrop-filter:blur(10px);
    position:relative;
    z-index:2;
    box-shadow:var(--glow-p);
    transition:box-shadow 0.4s;
}
.vision-card:hover { box-shadow:0 0 50px rgba(139,92,246,0.3); }
.vision-icon {
    font-size:2.5rem;
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:1rem;
}
.vision-card h3 {
    font-family:var(--font-head);
    font-size:1.2rem;
    font-weight:600;
    color:var(--text);
    margin-bottom:0.8rem;
}
.vision-card p { color:var(--text-dim); font-size:1rem; }
.about-deco {
    position:absolute;
    width:300px; height:300px;
    display:flex; align-items:center; justify-content:center;
    z-index:1;
}
.deco-ring {
    position:absolute; border-radius:50%; border:1px solid;
    animation:ringPulse 3s ease-in-out infinite;
}
.r1 { width:200px; height:200px; border-color:rgba(6,182,212,0.15); animation-delay:0s; }
.r2 { width:280px; height:280px; border-color:rgba(139,92,246,0.1); animation-delay:0.8s; }
.deco-dot {
    width:8px; height:8px; border-radius:50%;
    background:var(--cyan);
    box-shadow:0 0 20px var(--cyan);
}
@keyframes ringPulse {
    0%,100% { transform:scale(1); opacity:0.5; }
    50%      { transform:scale(1.05); opacity:1; }
}

/* ═══════════════════════════════════════════════════════════════
   SERVICES
═══════════════════════════════════════════════════════════════ */
.services-section {
    padding:8rem 0;
    background:var(--bg);
    position:relative;
    overflow:hidden;
}
.services-bg-glow {
    position:absolute;
    width:600px; height:600px;
    background:radial-gradient(circle, rgba(6,182,212,0.06) 0%, transparent 70%);
    top:50%; left:50%;
    transform:translate(-50%,-50%);
    pointer-events:none;
}
.services-grid {
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:1.5rem;
    position:relative; z-index:1;
}
.srv-card {
    background:rgba(10,22,40,0.8);
    border:1px solid var(--border);
    border-radius:12px;
    padding:2.5rem;
    position:relative;
    transition:all 0.4s var(--ease);
    transition-delay:var(--d,0s);
    display:flex; flex-direction:column; gap:1rem;
    overflow:hidden;
}
.srv-card::before {
    content:'';
    position:absolute;
    top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg,var(--cyan),var(--purple));
    transform:scaleX(0); transform-origin:left;
    transition:transform 0.5s var(--ease);
}
.srv-card:hover {
    border-color:rgba(6,182,212,0.25);
    transform:translateY(-6px);
    box-shadow:0 20px 60px rgba(0,0,0,0.4), var(--glow-c);
}
.srv-card:hover::before { transform:scaleX(1); }
.srv-glow {
    position:absolute; top:-50%; left:-50%;
    width:200%; height:200%;
    background:radial-gradient(circle at center, rgba(6,182,212,0.04) 0%, transparent 60%);
    pointer-events:none;
    opacity:0;
    transition:opacity 0.4s;
}
.srv-card:hover .srv-glow { opacity:1; }
.srv-number {
    font-family:var(--font-tech);
    font-size:0.65rem;
    letter-spacing:0.3em;
    color:var(--text-muted);
}
.srv-icon {
    font-size:2.5rem;
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    line-height:1;
}
.srv-card h3 {
    font-family:var(--font-head);
    font-size:1.2rem;
    font-weight:600;
    color:var(--text);
}
.srv-card > p { color:var(--text-dim); font-size:0.98rem; }
.srv-card ul {
    display:flex; flex-direction:column; gap:0.4rem;
    flex-grow:1;
}
.srv-card li {
    font-size:0.9rem; color:var(--text-dim);
    padding-left:1.4rem; position:relative;
}
.srv-card li::before {
    content:'›';
    position:absolute; left:0;
    color:var(--cyan); font-size:1rem;
}
.srv-footer { padding-top:1rem; border-top:1px solid var(--border); margin-top:auto; }
.srv-link {
    font-family:var(--font-head);
    font-size:0.85rem;
    font-weight:600;
    color:var(--cyan-dim);
    transition:color 0.3s;
}
.srv-link:hover { color:var(--cyan-2); }

/* ═══════════════════════════════════════════════════════════════
   WHY
═══════════════════════════════════════════════════════════════ */
.why-section {
    padding:8rem 0;
    background:var(--bg-2);
    position:relative;
}
.why-section::before {
    content:'';
    position:absolute; inset:0;
    background:radial-gradient(ellipse 50% 60% at 30% 50%, rgba(6,182,212,0.04) 0%, transparent 70%);
    pointer-events:none;
}
.why-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.5rem;
    position:relative; z-index:1;
}
.why-card {
    background:rgba(10,22,40,0.6);
    border:1px solid var(--border);
    border-radius:12px;
    padding:2rem;
    transition:all 0.35s var(--ease);
    transition-delay:var(--d,0s);
}
.why-card:hover {
    border-color:rgba(6,182,212,0.3);
    transform:translateY(-4px);
    background:rgba(15,30,56,0.8);
    box-shadow:var(--glow-c);
}
.why-icon {
    font-size:1.8rem;
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:1rem;
}
.why-card h4 {
    font-family:var(--font-head);
    font-size:1.05rem;
    font-weight:600;
    color:var(--text);
    margin-bottom:0.6rem;
}
.why-card p { color:var(--text-dim); font-size:0.92rem; line-height:1.7; }

/* ═══════════════════════════════════════════════════════════════
   COMMITMENT
═══════════════════════════════════════════════════════════════ */
.commitment-section {
    padding:8rem 0;
    background:var(--bg);
    position:relative;
    overflow:hidden;
}
.commit-bg-glow {
    position:absolute;
    width:800px; height:500px;
    background:radial-gradient(ellipse, rgba(139,92,246,0.07) 0%, transparent 70%);
    top:50%; left:50%;
    transform:translate(-50%,-50%);
    pointer-events:none;
}
.commit-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.5rem;
    position:relative; z-index:1;
}
.commit-card {
    background:rgba(10,22,40,0.7);
    border:1px solid var(--border);
    border-radius:12px;
    padding:2.5rem 2rem;
    position:relative;
    transition:all 0.4s var(--ease);
    transition-delay:var(--d,0s);
    overflow:hidden;
}
.commit-card:hover {
    transform:translateY(-6px);
    border-color:rgba(139,92,246,0.3);
    box-shadow:var(--glow-p);
}
.commit-num {
    font-family:var(--font-tech);
    font-size:0.65rem;
    letter-spacing:0.3em;
    color:var(--text-muted);
    margin-bottom:1.2rem;
}
.commit-icon {
    font-size:2.5rem;
    line-height:1;
    margin-bottom:1rem;
}
.commit-icon.cyan {
    background:linear-gradient(135deg,var(--cyan),var(--blue));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.commit-icon.purple {
    background:linear-gradient(135deg,var(--purple),var(--purple-2));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.commit-icon.blue {
    background:linear-gradient(135deg,var(--blue),var(--cyan));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.commit-card h3 {
    font-family:var(--font-head);
    font-size:1.3rem;
    font-weight:700;
    color:var(--text);
    margin-bottom:0.8rem;
}
.commit-card p { color:var(--text-dim); font-size:0.98rem; line-height:1.75; }

/* ═══════════════════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════════════════════ */
.contact-section {
    padding:8rem 0;
    background:var(--bg-2);
    position:relative;
}
.contact-section::before {
    content:'';
    position:absolute; inset:0;
    background:
        radial-gradient(ellipse 40% 50% at 20% 50%, rgba(6,182,212,0.05) 0%, transparent 70%),
        radial-gradient(ellipse 40% 50% at 80% 50%, rgba(139,92,246,0.05) 0%, transparent 70%);
    pointer-events:none;
}
.contact-grid {
    display:grid;
    grid-template-columns:1fr 1.1fr;
    gap:4rem;
    position:relative; z-index:1;
}
.contact-info-card {
    background:rgba(10,22,40,0.7);
    border:1px solid var(--border);
    border-radius:12px;
    padding:2.5rem;
    height:100%;
}
.contact-info-card h3 {
    font-family:var(--font-head);
    font-size:1.4rem;
    font-weight:700;
    color:var(--text);
    margin-bottom:1rem;
}
.contact-info-card > p { color:var(--text-dim); margin-bottom:2rem; }
.info-item {
    display:flex; gap:1rem; align-items:flex-start;
    margin-bottom:1.2rem;
}
.ii-icon {
    width:36px; height:36px;
    background:linear-gradient(135deg,rgba(6,182,212,0.15),rgba(139,92,246,0.15));
    border:1px solid var(--border);
    border-radius:8px;
    display:flex; align-items:center; justify-content:center;
    font-size:1rem;
    color:var(--cyan);
    flex-shrink:0;
}
.info-item div { display:flex; flex-direction:column; gap:0.1rem; }
.info-item strong {
    font-size:0.75rem;
    letter-spacing:0.1em;
    text-transform:uppercase;
    color:var(--text-muted);
    font-family:var(--font-tech);
}
.info-item span { color:var(--text-dim); font-size:0.95rem; }
.info-item a { color:var(--cyan); font-size:0.95rem; transition:color 0.3s; }
.info-item a:hover { color:var(--cyan-2); }
.contact-features {
    display:grid; grid-template-columns:1fr 1fr;
    gap:0.6rem; margin-top:2rem;
    padding-top:2rem;
    border-top:1px solid var(--border);
}
.cf-item {
    display:flex; align-items:center; gap:0.6rem;
    font-size:0.88rem; color:var(--text-dim);
}
.cf-item span { color:var(--cyan); font-weight:700; }

/* Form */
.contact-form {
    background:rgba(10,22,40,0.7);
    border:1px solid var(--border);
    border-radius:12px;
    padding:2.5rem;
    display:flex; flex-direction:column; gap:1.2rem;
}
.contact-form h3 {
    font-family:var(--font-head);
    font-size:1.4rem; font-weight:700;
    color:var(--text);
    margin-bottom:0.5rem;
}
.form-group { display:flex; flex-direction:column; gap:0.4rem; }
label {
    font-family:var(--font-tech);
    font-size:0.65rem;
    letter-spacing:0.2em;
    text-transform:uppercase;
    color:var(--text-muted);
}
input, select, textarea {
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.08);
    color:var(--text);
    padding:0.8rem 1rem;
    font-family:var(--font-body);
    font-size:0.95rem;
    outline:none;
    border-radius:6px;
    transition:border-color 0.3s, box-shadow 0.3s;
    width:100%;
}
input::placeholder, textarea::placeholder { color:var(--text-muted); }
input:focus, select:focus, textarea:focus {
    border-color:rgba(6,182,212,0.4);
    box-shadow:0 0 15px rgba(6,182,212,0.1);
}
select option { background:var(--bg-3); color:var(--text); }
textarea { resize:vertical; min-height:100px; }
.form-note {
    font-size:0.8rem; color:var(--text-muted);
    text-align:center; font-style:italic;
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════════ */
.footer {
    background:var(--bg);
    border-top:1px solid var(--border);
    position:relative;
    overflow:hidden;
}
.footer-glow {
    position:absolute; top:0; left:50%; transform:translateX(-50%);
    width:600px; height:1px;
    background:linear-gradient(90deg,transparent,var(--cyan),var(--purple),transparent);
    box-shadow:0 0 20px var(--cyan);
}
.footer-top {
    max-width:1280px; margin:0 auto;
    padding:3rem 2rem;
    display:flex; flex-direction:column; align-items:center; gap:2rem;
    text-align:center;
}
.footer-logo {
    display:flex; align-items:center; gap:0.8rem;
}
.footer-name {
    display:block;
    font-family:var(--font-tech);
    font-size:1rem; font-weight:700;
    letter-spacing:0.15em;
    color:var(--text);
}
.footer-name em {
    font-style:normal;
    background:linear-gradient(135deg,var(--cyan),var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.footer-sub {
    display:block;
    font-size:0.72rem;
    color:var(--text-muted);
    letter-spacing:0.15em;
}
.footer-nav {
    display:flex; gap:2.5rem; flex-wrap:wrap; justify-content:center;
}
.footer-nav a {
    font-family:var(--font-head);
    font-size:0.85rem; font-weight:500;
    color:var(--text-muted);
    transition:color 0.3s;
}
.footer-nav a:hover { color:var(--cyan); }
.footer-email {
    font-family:var(--font-body);
    color:var(--cyan-dim);
    font-size:0.95rem;
    transition:color 0.3s;
    border-bottom:1px solid transparent;
}
.footer-email:hover { color:var(--cyan-2); border-color:var(--cyan); }
.footer-bottom {
    border-top:1px solid var(--border);
    padding:1.2rem 2rem;
    display:flex; align-items:center; justify-content:space-between;
    max-width:1280px; margin:0 auto;
    font-size:0.8rem; color:var(--text-muted);
    flex-wrap:wrap; gap:0.5rem;
}
.footer-tagline {
    font-family:var(--font-tech);
    font-size:0.65rem;
    letter-spacing:0.2em;
    color:var(--text-muted);
    opacity:0.5;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════ */
@media (max-width:1024px) {
    .services-grid { grid-template-columns:1fr; }
    .why-grid { grid-template-columns:repeat(2,1fr); }
    .about-grid { gap:3rem; }
}
@media (max-width:768px) {
    .nav-links {
        position:fixed; top:0; right:0;
        width:80vw; max-width:300px; height:100vh;
        background:rgba(2,8,23,0.98);
        backdrop-filter:blur(20px);
        border-left:1px solid var(--border);
        flex-direction:column; align-items:flex-start;
        justify-content:center; padding:2rem; gap:2rem;
        transform:translateX(100%);
        transition:transform 0.4s var(--ease); z-index:999;
    }
    .nav-links.open { transform:translateX(0); }
    .nav-links a { font-size:1rem; }
    .nav-toggle { display:flex; z-index:1000; }

    .hero-title { font-size:2rem; }
    .hero-stats { flex-direction:column; gap:1rem; }
    .h-stat-sep { width:80px; height:1px; }

    .about-grid { grid-template-columns:1fr; }
    .about-deco { display:none; }

    .why-grid { grid-template-columns:1fr; }
    .commit-grid { grid-template-columns:1fr; }
    .contact-grid { grid-template-columns:1fr; }
    .services-grid { grid-template-columns:1fr; }

    .footer-bottom { flex-direction:column; text-align:center; }
    .contact-features { grid-template-columns:1fr; }

    .about-section,.services-section,.why-section,
    .commitment-section,.contact-section { padding:5rem 0; }
}
@media (max-width:480px) {
    .container { padding:0 1rem; }
    .hero-ctas { flex-direction:column; align-items:center; }
}
