:root {
    --bg: #090b10;
    --surface: #10131a;
    --surface-light: #161a23;
    --line: rgba(255, 255, 255, .09);
    --text: #f3f5f7;
    --muted: #9da5b4;
    --accent: #9cff57;
    --accent-dark: #6fd32c;
}

html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--text); font-family: Inter, "Segoe UI", sans-serif; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
p { color: var(--muted); line-height: 1.75; }
.container { max-width: 1180px; }
.ambient { position: absolute; border-radius: 50%; filter: blur(130px); pointer-events: none; opacity: .13; }
.ambient-one { width: 520px; height: 520px; background: var(--accent); right: -250px; top: 80px; }
.ambient-two { width: 420px; height: 420px; background: #5372ff; left: -300px; top: 1000px; }

.navbar { padding: 1.2rem 0; transition: .3s ease; }
.navbar.scrolled { padding: .75rem 0; background: rgba(9, 11, 16, .85); border-bottom: 1px solid var(--line); backdrop-filter: blur(18px); }
.brand { display: inline-flex; align-items: center; gap: .7rem; font-size: 1.35rem; font-weight: 800; letter-spacing: -.04em; }
.brand > span:last-child > span { color: var(--accent); }
.brand-mark { width: 29px; height: 29px; display: block; object-fit: contain; }
.navbar-toggler { color: var(--text); border: 1px solid var(--line); }
.navbar-toggler:focus { box-shadow: none; }
.nav-link { color: #c0c5ce; font-size: .9rem; margin: 0 .55rem; }
.nav-link:hover { color: var(--accent); }
.language-switch { display: flex; align-items: center; gap: .3rem; padding: 0 .7rem; color: #555d6a; font-size: .72rem; }
.language-switch a { color: #737b88; }
.language-switch a.active { color: var(--text); font-weight: 700; }

.btn { border-radius: 4px; font-weight: 700; padding: .85rem 1.25rem; border: 0; }
.btn-sm { padding: .65rem 1rem; font-size: .85rem; }
.btn i { margin-left: .55rem; font-size: .8em; }
.btn-primary { color: #0a0c0f; background: var(--accent); }
.btn-primary:hover, .btn-primary:focus { color: #0a0c0f; background: #b1ff7d; transform: translateY(-2px); }

.hero { position: relative; min-height: 820px; display: flex; align-items: center; padding: 140px 0 80px; }
.eyebrow { display: flex; align-items: center; gap: .7rem; color: var(--accent); text-transform: uppercase; letter-spacing: .16em; font-weight: 700; font-size: .75rem; margin-bottom: 1.3rem; }
.eyebrow span { display: block; width: 28px; height: 1px; background: var(--accent); }
h1 { max-width: 760px; font-size: clamp(3.2rem, 6.5vw, 6rem); font-weight: 750; line-height: .98; letter-spacing: -.065em; }
h1 em { display: block; color: var(--accent); font-style: normal; }
.hero-copy { max-width: 650px; margin: 2rem 0; font-size: 1.08rem; }
.hero-actions { display: flex; align-items: center; gap: 2rem; }
.text-link { color: var(--text); font-weight: 600; font-size: .9rem; }
.text-link i { color: var(--accent); margin-left: .45rem; }
.availability { display: flex; align-items: center; gap: .6rem; margin-top: 2.4rem; color: #8f98a7; font-size: .8rem; }
.availability i { color: var(--accent); font-size: .45rem; filter: drop-shadow(0 0 5px var(--accent)); }

.hero-visual { position: relative; background: linear-gradient(145deg, #171b24, #0e1117); border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 35px 90px rgba(0,0,0,.45); transform: perspective(1000px) rotateY(-4deg); }
.browser-bar { height: 48px; display: flex; align-items: center; gap: 7px; padding: 0 17px; border-bottom: 1px solid var(--line); }
.browser-bar > span { width: 7px; height: 7px; border-radius: 50%; background: #3b414c; }
.browser-bar small { margin-left: auto; color: #626a77; font-size: .65rem; }
.visual-content { padding: 2rem; }
.visual-label { color: #6e7683; text-transform: uppercase; letter-spacing: .12em; font-size: .65rem; margin-bottom: 1.2rem; }
.visual-row { display: grid; grid-template-columns: 30px 42px 1fr 20px; align-items: center; gap: .7rem; padding: 1rem 0; border-bottom: 1px solid var(--line); }
.visual-row:last-child { border: 0; }
.visual-number { color: #4e5662; font: .65rem monospace; }
.visual-icon { display: grid; place-items: center; width: 38px; height: 38px; background: rgba(156, 255, 87, .08); color: var(--accent); border-radius: 4px; }
.visual-row strong { font-size: .88rem; }
.visual-row > i { color: var(--accent); font-size: .65rem; }
.code-chip, .spark-chip { position: absolute; display: grid; place-items: center; box-shadow: 0 12px 30px rgba(0,0,0,.35); }
.code-chip { width: 65px; height: 65px; left: -32px; bottom: 40px; background: var(--accent); color: #0b0d10; font: 800 1rem monospace; border-radius: 8px; transform: rotate(-8deg); }
.spark-chip { width: 44px; height: 44px; right: -18px; top: 85px; background: #252b37; color: var(--accent); border: 1px solid var(--line); border-radius: 50%; }

.section { padding: 110px 0; }
.section-heading { margin-bottom: 3.5rem; }
h2 { font-size: clamp(2.3rem, 4.5vw, 4.2rem); line-height: 1.05; letter-spacing: -.05em; font-weight: 750; margin: 0; }
h3 { font-weight: 700; letter-spacing: -.025em; }
.section-heading p { margin: 0 0 .35rem; }
.service-card { height: 100%; min-height: 330px; padding: 2rem; background: var(--surface); border: 1px solid var(--line); transition: .3s ease; }
.service-card:hover { transform: translateY(-7px); border-color: rgba(156,255,87,.35); background: var(--surface-light); }
.card-top { display: flex; justify-content: space-between; color: #525a67; margin-bottom: 4.5rem; font: .75rem monospace; }
.card-top i { color: var(--accent); font-size: 1.4rem; }
.service-card h3 { margin-bottom: 1rem; }
.service-card p { font-size: .9rem; }
.card-line { width: 36px; height: 2px; background: var(--accent); margin-top: 1.8rem; transition: width .3s; }
.service-card:hover .card-line { width: 70px; }

.process-section { background: #0d1016; border-block: 1px solid var(--line); }
.process-section h2 { margin-bottom: 4rem; }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.process-step { position: relative; padding: 2rem 2rem 1rem 0; border-top: 1px solid #363c47; }
.process-step::before { content: ""; position: absolute; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); top: -4px; left: 0; box-shadow: 0 0 0 6px rgba(156,255,87,.08); }
.process-step > span { display: block; margin-bottom: 3rem; color: var(--accent); font: .75rem monospace; }
.process-step h3 { font-size: 1.15rem; }
.process-step p { font-size: .85rem; max-width: 210px; }

.about-panel { padding: 5rem; background: linear-gradient(120deg, #121720, #0e1117); border: 1px solid var(--line); overflow: hidden; }
.about-copy { margin: 1.8rem 0; max-width: 650px; }
.check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .8rem; }
.check-list li { display: flex; align-items: center; gap: .8rem; font-size: .9rem; color: #c6ccd5; }
.check-list i { color: var(--accent); font-size: .7rem; }
.team-graphic { display: flex; justify-content: center; align-items: center; min-height: 330px; position: relative; }
.team-card { width: 155px; height: 205px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.2rem; border: 1px solid var(--line); background: #181d27; box-shadow: 0 20px 50px rgba(0,0,0,.3); }
.team-card i { font-size: 2rem; color: var(--accent); }
.team-card span { font: .7rem monospace; letter-spacing: .2em; color: #747d8c; }
.team-one { transform: rotate(-7deg) translateX(10px); }
.team-two { transform: rotate(7deg) translateX(-10px); margin-top: 50px; }
.team-plus { position: absolute; z-index: 2; display: grid; place-items: center; width: 42px; height: 42px; color: #0b0d10; background: var(--accent); border-radius: 50%; font-weight: 900; }

.contact-section { padding-top: 30px; }
.contact-box { padding: 4.5rem; background: var(--accent); color: #0c0f12; display: flex; align-items: center; justify-content: space-between; gap: 3rem; }
.contact-box .eyebrow { color: #334126; }
.contact-box .eyebrow span { background: #334126; }
.contact-box h2 { max-width: 780px; }
.contact-box p { max-width: 700px; color: #34402c; margin: 1.5rem 0 0; }
.btn-light { flex: 0 0 auto; background: #0d1014; color: var(--text); }
.btn-light:hover { background: #222832; color: white; transform: translateY(-2px); }

footer { padding: 2rem 0; }
.footer-main { display: flex; justify-content: space-between; align-items: center; padding: 2.5rem 0; border-bottom: 1px solid var(--line); }
.footer-main p { margin: .7rem 0 0; font-size: .8rem; }
.footer-links { display: flex; gap: 2rem; font-size: .8rem; color: #8e96a3; }
.footer-links a:hover { color: var(--accent); }
.footer-bottom { padding-top: 1.5rem; font-size: .72rem; color: #59616d; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 991.98px) {
    .navbar-collapse { margin-top: 1rem; padding: 1.2rem; background: #11151c; border: 1px solid var(--line); }
    .navbar-nav { align-items: flex-start !important; gap: .5rem; }
    .language-switch { padding: .5rem .55rem; }
    .hero { min-height: auto; padding-top: 180px; }
    .hero-visual { margin: 2rem auto 0; max-width: 530px; transform: none; }
    .process-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem 0; }
    .about-panel { padding: 3rem; }
    .contact-box { align-items: flex-start; flex-direction: column; }
}

@media (max-width: 575.98px) {
    .hero { padding-top: 135px; }
    h1 { font-size: 3.2rem; }
    .hero-actions { align-items: flex-start; flex-direction: column; gap: 1.3rem; }
    .code-chip, .spark-chip { display: none; }
    .visual-content { padding: 1.25rem; }
    .visual-row { grid-template-columns: 25px 36px 1fr 15px; }
    .section { padding: 80px 0; }
    .process-grid { grid-template-columns: 1fr; }
    .process-step > span { margin-bottom: 1.5rem; }
    .about-panel, .contact-box { padding: 2rem 1.5rem; }
    .team-graphic { transform: scale(.8); margin: -30px; }
    .footer-main { align-items: flex-start; flex-direction: column; gap: 2rem; }
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .reveal { opacity: 1; transform: none; transition: none; }
}
