:root {
    --nr-bg: #07152b;
    --nr-bg-deep: #050f22;
    --nr-card: rgba(11, 28, 56, 0.85);
    --nr-card-2: rgba(9, 22, 43, 0.82);
    --nr-border: rgba(138, 158, 196, 0.2);
    --nr-text: #e8eef9;
    --nr-muted: #a4b2cb;
    --nr-primary: #b8aff2;
    --nr-primary-text: #1a2379;
    --nr-fs-body: 0.9375rem;
    --nr-fs-sm: 0.8125rem;
    --nr-fs-md: 0.875rem;
    --nr-fs-lg: 1rem;
    --nr-fs-xl: 1.0625rem;
}

body.newroom-enterprise {
    margin: 0;
    color: var(--nr-text);
    font-size: var(--nr-fs-body);
    font-family: 'Inter', 'IBM Plex Sans', system-ui, sans-serif;
    background:
        radial-gradient(circle at 20% 10%, rgba(44, 93, 190, 0.22), transparent 45%),
        radial-gradient(circle at 90% 20%, rgba(48, 102, 202, 0.15), transparent 45%),
        linear-gradient(180deg, #041327 0%, #081e3d 55%, #061630 100%);
}

body.newroom-enterprise .body-wrap {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* landing.css sets main { flex: 1 } — avoid stretching empty space below content */
body.newroom-enterprise main {
    flex: 0 0 auto;
}

.nr-container {
    width: min(1120px, calc(100% - 48px));
    margin: 0 auto;
}

.nr-nav {
    position: sticky;
    top: 0;
    z-index: 10;
    border-bottom: 1px solid rgba(138, 158, 196, 0.08);
    backdrop-filter: blur(8px);
    background: rgba(4, 16, 34, 0.72);
}

.nr-nav-inner {
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
}

.nr-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: #f5f8ff;
    font-weight: 700;
    font-size: var(--nr-fs-lg);
}

.nr-brand img {
    width: 28px;
    height: 28px;
}

.nr-login {
    text-decoration: none;
    color: #c0cbdf;
    font-size: var(--nr-fs-md);
}

.nr-nav-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.nr-start-btn {
    height: 38px;
    padding: 0 18px;
    border-radius: 999px;
    background: #8a8eff;
    color: #0f1640;
    font-size: var(--nr-fs-sm);
    font-weight: 700;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
}

.nr-hero {
    flex: none;
    padding: 20px 0 28px;
}

.nr-hero h1 {
    text-align: center;
    margin: 0 auto 10px;
    max-width: 760px;
    font-size: clamp(1.65rem, 3.2vw, 2.35rem);
    line-height: 1.12;
    color: #e7edf8;
    letter-spacing: -0.03em;
}

.nr-hero p#newRoomDescription {
    text-align: center;
    color: #afbdd6;
    max-width: 740px;
    margin: 0 auto 20px;
    font-size: var(--nr-fs-xl);
}

.nr-join-card {
    width: min(100%, 530px);
    margin: 0 auto;
    border-radius: 24px;
    border: 1px solid var(--nr-border);
    background: linear-gradient(180deg, rgba(10, 30, 59, 0.88), rgba(9, 21, 42, 0.94));
    box-shadow: 0 20px 70px rgba(2, 7, 19, 0.5);
    padding: 22px 24px;
}

.nr-join-title {
    margin: 0 0 8px;
    color: #b0bfd9;
    font-size: var(--nr-fs-md);
    font-weight: 500;
}

.nr-input-wrap {
    position: relative;
    margin-bottom: 12px;
}

.newroom-enterprise .nr-input-wrap .form-input {
    width: 100%;
    height: 46px;
    background: #05132a;
    border: 1px solid rgba(127, 149, 185, 0.2);
    border-radius: 10px;
    color: #e8eef9;
    font-size: var(--nr-fs-lg);
    padding: 0 50px 0 16px;
}

.newroom-enterprise .nr-input-wrap .gen-room-btn {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none !important;
    background: transparent !important;
    color: #b3bfda;
    box-shadow: none !important;
}

.nr-btn {
    border: 1px solid transparent;
    border-radius: 10px;
    width: 100%;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: var(--nr-fs-md);
    font-weight: 700;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.nr-btn-primary {
    background: var(--nr-primary);
    color: var(--nr-primary-text);
}

.nr-secondary-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.nr-btn-secondary {
    background: rgba(10, 27, 51, 0.66);
    border-color: rgba(128, 146, 176, 0.18);
    color: #c4d1e8;
    font-size: var(--nr-fs-md);
    height: 48px;
}

.nr-btn-secondary span {
    white-space: nowrap;
}

#scheduleMeetingBtn {
    display: none !important;
}

.nr-last-room {
    margin-top: 10px;
    text-align: center;
    color: #90a1c0;
    font-size: var(--nr-fs-sm);
}

.nr-last-room a {
    color: #d6def0;
    margin-left: 6px;
    text-decoration: none;
}

.nr-feature-row {
    margin: 24px auto 0;
    width: min(100%, 840px);
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.nr-feature-card {
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid rgba(123, 145, 181, 0.14);
    background: var(--nr-card-2);
}

.nr-feature-card i {
    color: #b9c4da;
    font-size: var(--nr-fs-lg);
}

.nr-feature-card h4 {
    margin: 8px 0 6px;
    color: #e8eef8;
    font-size: 1.125rem;
    line-height: 1.05;
    letter-spacing: -0.02em;
}

.nr-feature-card p {
    margin: 0;
    color: #a8b6cf;
    font-size: var(--nr-fs-md);
    line-height: 1.4;
}

.nr-footer {
    background: var(--nr-bg-deep);
    border-top: 1px solid rgba(137, 154, 184, 0.18);
    padding: 22px 0 26px;
    margin-top: auto;
}

.nr-footer-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 16px;
}

.nr-footer-brand p {
    color: #95a5bf;
    font-size: var(--nr-fs-md);
    margin-top: 8px;
    max-width: 280px;
}

.nr-footer-col h5 {
    margin: 0 0 8px;
    color: #c5d0e6;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.nr-footer-col a {
    display: block;
    margin: 4px 0;
    color: #9cadca;
    text-decoration: none;
    font-size: var(--nr-fs-md);
}

@media (max-width: 900px) {
    .nr-feature-row {
        grid-template-columns: 1fr;
    }

    .nr-footer-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 600px) {
    .nr-container {
        width: calc(100% - 28px);
    }

    .nr-join-card {
        padding: 22px 16px;
    }

    .nr-secondary-actions {
        grid-template-columns: 1fr;
    }

    .nr-hero {
        padding: 16px 0 20px;
    }

    .nr-nav-inner {
        height: 56px;
    }

    .nr-brand span {
        font-size: var(--nr-fs-md);
    }

    .nr-footer-grid {
        grid-template-columns: 1fr;
    }
}
