/* ── Landing page layout ── */
.land-header {
    background: var(--color-header-bg);
    padding: 1rem 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}
.land-header .logo { color: var(--color-primary); margin-bottom: 0; font-size: 1.25rem; }
.land-header .logo img { width: 32px; height: 32px; vertical-align: middle; margin-right: .4rem; }
.land-header-actions { display: flex; gap: .75rem; }

.land-hero {
    background: linear-gradient(135deg, #1a1a1e 0%, #2a2022 100%);
    color: #fff;
    text-align: center;
    padding: 5rem 1.5rem 4rem;
}
.land-lang-switcher {
    justify-content: center;
    margin: -3rem auto 2.5rem;
    max-width: 1000px;
}
.land-hero .lang-switch-btn {
    color: #e5e7eb;
    background: rgba(255, 255, 255, .06);
    border-color: rgba(255, 255, 255, .18);
}
.land-hero .lang-switch-btn:hover {
    background: rgba(255, 255, 255, .12);
    border-color: rgba(255, 255, 255, .3);
}
.land-hero .lang-switch-btn.is-active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}
.land-hero h1 {
    font-size: clamp(1.75rem, 5vw, 2.75rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1rem;
    color: #fff;
}
.land-hero h1 span { color: var(--color-primary); }
.land-hero p {
    font-size: 1.125rem;
    color: #b0b3b8;
    max-width: 560px;
    margin: 0 auto 2rem;
}
.land-hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

.land-section {
    padding: 4rem 1.5rem;
    max-width: 1000px;
    margin: 0 auto;
}
.land-section-title {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: .5rem;
}
.land-section-sub {
    text-align: center;
    color: var(--color-muted);
    margin-bottom: 2.5rem;
}

.land-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
}
.land-feature-card {
    background: var(--color-card);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}
.land-feature-icon {
    font-size: 2rem;
    margin-bottom: .75rem;
    display: block;
}
.land-feature-card h3 { font-size: 1rem; margin-bottom: .5rem; }
.land-feature-card p { color: var(--color-muted); font-size: .9rem; line-height: 1.55; }

.land-steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
    counter-reset: steps;
}
.land-step {
    text-align: center;
    padding: 1.5rem 1rem;
    counter-increment: steps;
}
.land-step::before {
    content: counter(steps);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 1rem;
}
.land-step h3 { margin-bottom: .4rem; }
.land-step p { color: var(--color-muted); font-size: .9rem; }

.land-cta-band {
    background: linear-gradient(135deg, #1a1a1e 0%, #2a2022 100%);
    color: #fff;
    text-align: center;
    padding: 4rem 1.5rem;
}
.land-cta-band h2 { color: #fff; font-size: 1.75rem; margin-bottom: .75rem; }
.land-cta-band p { color: #b0b3b8; margin-bottom: 2rem; }

.land-footer {
    background: var(--color-header-bg);
    color: #6b7280;
    text-align: center;
    padding: 1.5rem 1rem;
    font-size: .875rem;
}
.land-footer a { color: var(--color-primary); text-decoration: none; }
.land-footer a:hover { text-decoration: underline; }

/* Button variants for the dark hero */
.btn-hero-outline {
    display: inline-block;
    padding: .75rem 1.75rem;
    border-radius: var(--radius);
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
    font-weight: 600;
    text-decoration: none;
    font-size: 1rem;
    transition: background .15s, color .15s;
}
.btn-hero-outline:hover { background: var(--color-primary); color: #fff; }

/* Divider between sections */
.land-divider { border: none; border-top: 1px solid var(--color-border); margin: 0; }

/* ── Early access badge ── */
.early-access-badge {
    display: inline-block;
    background: var(--color-primary);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    padding: .25rem .7rem;
    border-radius: 999px;
    margin-bottom: 1.1rem;
}

/* ── Waitlist section ── */
.land-waitlist {
    background: var(--color-bg);
    padding: 4rem 1.5rem;
}
.land-waitlist-form {
    max-width: 460px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
.land-waitlist-form .form-group { margin-bottom: 0; }
.land-waitlist-form label { font-size: .875rem; font-weight: 600; display: block; margin-bottom: .3rem; }
.land-waitlist-form input[type="text"],
.land-waitlist-form input[type="email"] {
    width: 100%;
    box-sizing: border-box;
    padding: .5rem .65rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: .9rem;
    background: var(--color-card);
    color: var(--color-text);
}
.land-waitlist-small {
    font-size: .8rem;
    color: var(--color-muted);
    text-align: center;
    margin: 0;
}
.land-waitlist-success {
    text-align: center;
    color: var(--color-success, #16a34a);
    font-weight: 600;
    padding: 1rem 0;
}

@media (max-width: 499px) {
    .land-header-actions {
        display: none;
    }
}

/* ── Public calendar viewer (calendar.html) ── */
.calview-hero {
    background: var(--color-bg);
    color: var(--color-text);
    text-align: center;
    padding: 1rem 1.5rem 3.5rem;
}
.calview-lang-switcher {
    justify-content: center;
    margin: 0 auto .15rem;
    max-width: 1000px;
}
.calview-hero h1 {
    font-size: clamp(1.5rem, 4vw, 2.25rem);
    margin-top: .25rem;
    margin-bottom: .1rem;
    color: var(--color-text);
    word-break: break-word;
}
.calview-subtitle {
    font-size: 1rem;
    color: var(--color-muted);
    margin: 0 auto .65rem;
    max-width: 620px;
}
.calview-card {
    max-width: 960px;
    margin: 0 auto;
    background: var(--color-card);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.25rem;
    text-align: left;
}
.calview-notice {
    text-align: center;
}
.calview-actions {
    max-width:  960px;
    margin:     1.25rem auto 0;
    text-align: center;
}
.calview-copy-btn {
    width:      auto;
    padding:    .75rem 2rem;
    font-size:  1rem;
}
@media (max-width: 640px) {
    .calview-hero {
        padding: .75rem .75rem 2.5rem;
    }
    .calview-card {
        padding: .75rem;
    }
}
