/* Genidom public landing page — light, airy, dark text on light surfaces. */

:root {
    --ls-bg: #f7f9fc;
    --ls-surface: #ffffff;
    --ls-ink: #0f172a;
    --ls-ink-soft: #475569;
    --ls-accent: #2563eb;
    --ls-accent-2: #0ea5e9;
    --ls-border: rgba(15, 23, 42, 0.08);
    --ls-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

* { box-sizing: border-box; }

body.landing {
    margin: 0;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--ls-ink);
    background: var(--ls-bg);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }

/* ---- Top bar ---- */
.landing-topbar {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.85rem clamp(1rem, 4vw, 3rem);
    backdrop-filter: saturate(160%) blur(8px);
    background: rgba(247, 249, 252, 0.72);
    border-bottom: 1px solid var(--ls-border);
}

.landing-brand {
    font-weight: 800;
    font-size: 1.25rem;
    letter-spacing: -0.02em;
    color: var(--ls-accent);
}
.landing-brand-logo { display: block; height: 40px; width: auto; }
.landing-hero-logo {
    display: block;
    height: clamp(96px, 15vw, 150px);
    width: auto;
    margin: 0 auto 1.5rem;
}

.landing-topnav { display: flex; align-items: center; gap: clamp(0.6rem, 2vw, 1.4rem); }
.landing-topnav > a { color: var(--ls-ink-soft); font-weight: 500; }
.landing-topnav > a:hover { color: var(--ls-ink); }

.landing-langswitch { display: inline-flex; gap: 0.4rem; color: var(--ls-ink-soft); font-size: 0.9rem; }
.landing-langswitch a.active { color: var(--ls-accent); font-weight: 700; }

/* ---- Buttons ---- */
.landing-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.6rem 1.15rem;
    border-radius: 999px;
    font-weight: 600;
    border: 1px solid transparent;
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
    white-space: nowrap;
}
.landing-btn:hover { transform: translateY(-1px); }
.landing-btn-primary { background: var(--ls-accent); color: #fff; box-shadow: 0 6px 18px rgba(37, 99, 235, 0.32); }
.landing-btn-primary:hover { background: #1d4ed8; }
.landing-btn-outline { border-color: var(--ls-border); color: var(--ls-ink); background: var(--ls-surface); }
.landing-btn-ghost { color: var(--ls-ink); }
.landing-btn-ghost:hover { color: var(--ls-accent); }
.landing-btn-lg { padding: 0.8rem 1.6rem; font-size: 1.05rem; }

/* ---- Hero ---- */
.landing-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background:
        radial-gradient(1200px 600px at 70% -10%, rgba(14, 165, 233, 0.12), transparent 60%),
        radial-gradient(900px 500px at 10% 110%, rgba(37, 99, 235, 0.10), transparent 60%),
        linear-gradient(180deg, #ffffff 0%, #eef3fb 100%);
}

#landing-hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

.landing-hero-inner {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 820px;
    padding: 6rem 1.25rem 2rem;
}

.landing-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--ls-accent);
    margin: 0 0 0.75rem;
}

.landing-hero-title {
    font-size: clamp(2.2rem, 6vw, 4rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
    font-weight: 800;
    margin: 0 0 1rem;
    color: var(--ls-ink);
}

.landing-hero-subline {
    font-size: clamp(1.05rem, 2.2vw, 1.35rem);
    color: var(--ls-ink-soft);
    margin: 0 auto 2rem;
    max-width: 640px;
}

.landing-hero-cta { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }

.landing-scroll-hint {
    position: absolute;
    bottom: 1.5rem; left: 50%; transform: translateX(-50%);
    z-index: 2; color: var(--ls-ink-soft); font-size: 1.4rem;
    animation: ls-bounce 2s infinite;
}
@keyframes ls-bounce { 0%,100% { transform: translate(-50%, 0); } 50% { transform: translate(-50%, 8px); } }

/* ---- Features ---- */
.landing-features { max-width: 1180px; margin: 0 auto; padding: clamp(3.5rem, 8vw, 6rem) clamp(1rem, 4vw, 2rem); }

.landing-section-head { text-align: center; max-width: 680px; margin: 0 auto 2.75rem; }
.landing-section-head h2 { font-size: clamp(1.8rem, 4vw, 2.6rem); letter-spacing: -0.02em; margin: 0 0 0.6rem; }
.landing-section-head p { color: var(--ls-ink-soft); font-size: 1.1rem; margin: 0; }

.landing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.25rem;
}

.landing-card {
    background: var(--ls-surface);
    border: 1px solid var(--ls-border);
    border-radius: 1rem;
    padding: 1.5rem;
    box-shadow: var(--ls-shadow);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.landing-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12); }

.landing-card-icon {
    width: 3rem; height: 3rem;
    display: grid; place-items: center;
    border-radius: 0.85rem;
    font-size: 1.4rem;
    color: var(--ls-accent);
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.12), rgba(14, 165, 233, 0.12));
    margin-bottom: 1rem;
}
.landing-card h3 { font-size: 1.15rem; margin: 0 0 0.4rem; letter-spacing: -0.01em; }
.landing-card p { color: var(--ls-ink-soft); margin: 0; font-size: 0.97rem; }

/* Scroll reveal */
.landing-reveal { opacity: 0; transform: translateY(18px); transition: opacity 0.5s ease, transform 0.5s ease; }
.landing-reveal.is-visible { opacity: 1; transform: none; }

/* ---- CTA band ---- */
.landing-cta {
    text-align: center;
    max-width: 760px;
    margin: 0 auto;
    padding: clamp(3rem, 7vw, 5rem) 1.25rem;
}
.landing-cta h2 { font-size: clamp(1.8rem, 4vw, 2.4rem); letter-spacing: -0.02em; margin: 0 0 0.6rem; }
.landing-cta p { color: var(--ls-ink-soft); font-size: 1.1rem; margin: 0 0 1.5rem; }

/* ---- Footer ---- */
.landing-footer {
    border-top: 1px solid var(--ls-border);
    padding: 1.5rem clamp(1rem, 4vw, 3rem);
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--ls-ink-soft);
    font-size: 0.9rem;
    flex-wrap: wrap;
    gap: 0.5rem;
}

@media (prefers-reduced-motion: reduce) {
    .landing-scroll-hint { animation: none; }
    .landing-reveal { transition: none; opacity: 1; transform: none; }
    .landing-btn:hover, .landing-card:hover { transform: none; }
}
