:root {
    color-scheme: dark;
    font-family: Inter, "Segoe UI", Arial, sans-serif;
    color: #f2f5f3;
    background: #101416;
    --bg: #101416;
    --bg-deep: #0d1113;
    --surface: #171d20;
    --surface-raised: #1f272b;
    --surface-soft: #1b2f2b;
    --text: #f2f5f3;
    --text-soft: #d3dbd8;
    --muted: #a8b4b0;
    --line: #2d393d;
    --line-strong: #3b4a4f;
    --accent: #58c7a8;
    --accent-strong: #a5f0dc;
    --blue: #83a9ff;
    --danger: #d06b6b;
    --warning: #f1c66b;
    --success: #76d49a;
    --shadow: 0 24px 60px rgba(0, 0, 0, 0.34);
}

body {
    margin: 0;
    min-height: 100vh;
    background:
        radial-gradient(circle at 18% 8%, rgba(88, 199, 168, 0.13), transparent 32rem),
        linear-gradient(180deg, #101416 0%, #12191b 52%, #0d1113 100%);
    color: var(--text);
}

.page {
    min-height: 100vh;
}

.public-page {
    min-height: 100vh;
    background: #f8f7f2;
}

.public-hero {
    min-height: 76vh;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.65fr);
    gap: clamp(28px, 5vw, 72px);
    align-items: center;
    padding: 64px clamp(22px, 7vw, 112px) 44px;
    color: #182126;
    background:
        radial-gradient(circle at 78% 20%, rgba(88, 199, 168, 0.24), transparent 30rem),
        linear-gradient(135deg, #f8f7f2 0%, #edf3ef 48%, #dce8e3 100%);
}

.public-hero-copy {
    max-width: 820px;
}

.public-hero h1 {
    font-size: clamp(58px, 12vw, 138px);
    letter-spacing: 0;
}

.secondary-link,
.linkedin-link {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    color: #234f79;
    background: #ffffff;
    border: 1px solid #cfd7dd;
    border-radius: 6px;
    font-weight: 700;
    text-decoration: none;
}

.public-hero-panel {
    display: grid;
    gap: 14px;
    align-self: end;
}

.pulse-card,
.pulse-card-grid article {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(36, 49, 56, 0.12);
    border-radius: 8px;
    box-shadow: 0 18px 44px rgba(24, 33, 38, 0.16);
}

.pulse-card-main {
    padding: 24px;
}

.pulse-card span,
.pulse-card-grid span {
    display: block;
    color: #607075;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.pulse-card strong {
    display: block;
    margin-top: 8px;
    font-size: 34px;
}

.pulse-card p {
    margin: 10px 0 0;
    color: #3f4d53;
}

.pulse-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.pulse-card-grid article {
    padding: 18px;
}

.pulse-card-grid strong {
    display: block;
    margin-top: 10px;
    font-size: 28px;
}

.public-section {
    padding: 52px clamp(22px, 7vw, 112px);
}

.public-section h2 {
    margin: 0;
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1;
}

.public-section h3 {
    margin: 0 0 10px;
    font-size: 22px;
}

.public-section p {
    margin: 0;
    color: #4c565a;
    line-height: 1.55;
}

.public-flow {
    display: grid;
    grid-template-columns: minmax(220px, 0.42fr) minmax(0, 1fr);
    gap: clamp(24px, 5vw, 64px);
    background: #ffffff;
}

.flow-steps,
.feature-band {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.flow-steps article,
.feature-band article {
    border: 1px solid #dde2df;
    border-radius: 8px;
    padding: 22px;
    background: #ffffff;
}

.flow-steps span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-bottom: 18px;
    border-radius: 50%;
    color: #ffffff;
    background: #2f6159;
    font-weight: 800;
}

.feature-band {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    background: #e7ece7;
}

.feature-band article {
    background: transparent;
    border-color: rgba(32, 36, 44, 0.16);
    box-shadow: none;
}

.public-owner {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: center;
    background: #20242c;
    color: #ffffff;
}

.public-owner p {
    max-width: 720px;
    color: #d7ddd9;
}

.public-owner .eyebrow {
    color: #9bc4bd;
}

.public-owner .linkedin-link {
    flex-shrink: 0;
    color: #ffffff;
    background: #0a66c2;
    border-color: #0a66c2;
}

.public-legal-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    justify-content: center;
    padding: 22px clamp(22px, 7vw, 112px);
    background: #171a20;
}

.public-legal-footer a {
    color: #d7ddd9;
    font-weight: 700;
    text-decoration: none;
}

.public-legal-footer a:hover,
.legal-nav a:hover,
.legal-document a:hover {
    text-decoration: underline;
}

.legal-page {
    min-height: 100vh;
    background: #f8f7f2;
    color: #20242c;
}

.legal-header {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    justify-content: space-between;
    padding: 24px clamp(22px, 7vw, 112px);
    background: #20242c;
}

.legal-brand {
    color: #ffffff;
    font-size: 24px;
    font-weight: 900;
    text-decoration: none;
}

.legal-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
}

.legal-nav a {
    color: #d8fff5;
    font-weight: 800;
    text-decoration: none;
}

.legal-document {
    width: min(880px, calc(100% - 40px));
    margin: 0 auto;
    padding: clamp(34px, 6vw, 72px) 0;
}

.legal-document h1 {
    margin-bottom: 32px;
    font-size: clamp(44px, 8vw, 92px);
}

.legal-document h2 {
    margin: 30px 0 10px;
    font-size: 24px;
}

.legal-document p,
.legal-document li {
    color: #4c565a;
    line-height: 1.65;
}

.legal-document ul {
    display: grid;
    gap: 8px;
    padding-left: 22px;
}

.legal-document a {
    color: #2f6159;
    font-weight: 800;
}

.hero {
    min-height: 62vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 48px clamp(24px, 8vw, 120px);
    background:
        radial-gradient(circle at 80% 18%, rgba(88, 199, 168, 0.22), transparent 28rem),
        linear-gradient(135deg, #f7f7f4 0%, #edf3ef 52%, #dfe8e4 100%);
}

.eyebrow {
    margin: 0 0 12px;
    color: #4c6f68;
    font-weight: 700;
    text-transform: uppercase;
}

h1 {
    margin: 0;
    font-size: clamp(48px, 9vw, 104px);
    line-height: 0.95;
}

.lead {
    max-width: 680px;
    font-size: clamp(20px, 3vw, 30px);
    line-height: 1.35;
}

.primary-link {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    color: #ffffff;
    background: #2f6159;
    text-decoration: none;
    font-weight: 700;
    border-radius: 6px;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
}

.text-link {
    color: #2f6159;
    font-weight: 700;
    text-decoration: none;
}

.status-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
    padding: 32px clamp(24px, 8vw, 120px) 56px;
}

.status-grid article {
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
    padding: 22px;
}

.status-grid h2 {
    margin: 0 0 8px;
    font-size: 20px;
}

.status-grid p {
    margin: 0;
    line-height: 1.5;
}

.admin-shell {
    width: min(1680px, calc(100vw - 48px));
    max-width: 1680px;
    margin-left: auto;
    margin-right: auto;
    padding: 24px 0 56px;
}

.admin-shell > form {
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 8px;
}

.admin-shell.narrow {
    width: min(760px, calc(100% - 40px));
}

.admin-header {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    margin-bottom: 28px;
}

.admin-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    justify-content: flex-end;
}

.admin-header h1 {
    font-size: clamp(36px, 7vw, 72px);
}

.session-table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
    border: 1px solid #dfded6;
}

.session-table th,
.session-table td {
    padding: 10px;
    border-bottom: 1px solid #e9e8e1;
    text-align: left;
    vertical-align: middle;
}

.session-table th {
    font-size: 13px;
    color: #5e655f;
    text-transform: uppercase;
}

.muted {
    display: block;
    margin-top: 4px;
    color: #6d716c;
}

.link-copy {
    color: #2f6159;
    font-weight: 700;
}

.code {
    font-family: "Cascadia Mono", Consolas, monospace;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    background: #ebe9de;
}

.qr-preview {
    width: 96px;
    height: 96px;
    image-rendering: crisp-edges;
}

.status-active {
    color: #0f5132;
    background: #d9f2df;
}

.status-paused {
    color: #6b4e00;
    background: #fff0c2;
}

.status-ended {
    color: #842029;
    background: #f8d7da;
}

.action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.small-button,
.primary-button {
    min-height: 38px;
    border: 0;
    border-radius: 6px;
    padding: 0 14px;
    color: #ffffff;
    background: #2f6159;
    font-weight: 700;
    cursor: pointer;
}

.small-button.secondary {
    color: #20242c;
    background: #d8d9d1;
}

.small-button.danger {
    background: #9f3333;
}

.small-link {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    border-radius: 6px;
    padding: 0 14px;
    color: #20242c;
    background: #e4e1d7;
    font-weight: 700;
    text-decoration: none;
}

.edit-form {
    display: grid;
    gap: 10px;
    padding: 24px;
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
}

.edit-form label {
    font-weight: 700;
}

.edit-form input,
.edit-form textarea {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid #c9c8bf;
    border-radius: 6px;
    padding: 11px 12px;
    font: inherit;
}

.primary-button {
    justify-self: start;
    margin-top: 8px;
}

.messages,
.field-error {
    color: #9f3333;
    font-weight: 700;
}

.security-warning {
    padding: 10px 12px;
    border-radius: 6px;
    color: #6b4e00;
    background: #fff0c2;
    font-weight: 700;
}

.empty-state {
    padding: 28px;
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
}

.empty-state h2 {
    margin: 0 0 8px;
}

.join-shell,
.participant-shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 28px;
}

.join-panel,
.participant-wait {
    width: min(680px, 100%);
}

.join-panel h1,
.participant-wait h1 {
    margin-bottom: 20px;
    font-size: clamp(42px, 8vw, 86px);
}

.session-meta {
    display: grid;
    gap: 12px;
    margin-top: 24px;
}

.session-meta div {
    padding: 16px;
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
}

.session-meta dt {
    margin-bottom: 4px;
    color: #6d716c;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.session-meta dd {
    margin: 0;
    overflow-wrap: anywhere;
    font-family: "Cascadia Mono", Consolas, monospace;
}

.reaction-counters {
    display: grid;
    grid-template-columns: repeat(3, minmax(52px, 1fr));
    gap: 8px;
    font-size: 16px;
}

.reaction-counters span {
    white-space: nowrap;
}

.reaction-buttons {
    display: grid;
    grid-template-columns: repeat(3, minmax(64px, 1fr));
    gap: 12px;
    margin: 24px 0 10px;
}

.reaction-buttons button {
    min-height: 68px;
    border: 1px solid #d4d2c7;
    border-radius: 8px;
    background: #ffffff;
    font-size: 30px;
    cursor: pointer;
}

.reaction-buttons button:active {
    transform: translateY(1px);
}

.reaction-buttons button:disabled {
    opacity: 0.42;
    cursor: wait;
}

.poll-card {
    margin: 22px 0;
    padding: 18px;
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
}

.audience-question-card {
    display: grid;
    gap: 10px;
    margin: 22px 0;
    padding: 18px;
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
}

.audience-question-card h2 {
    margin: 0;
    font-size: 24px;
}

.audience-question-card textarea {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid #c9c8bf;
    border-radius: 6px;
    padding: 11px 12px;
    font: inherit;
    resize: vertical;
}

.participant-question-list {
    display: grid;
    gap: 10px;
}

.participant-question-card {
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid #dfded6;
    border-radius: 8px;
    background: #ffffff;
}

.participant-question-card strong {
    overflow-wrap: anywhere;
}

.participant-question-card .small-button {
    justify-self: start;
}

.poll-card h2 {
    margin: 0 0 14px;
    font-size: 24px;
}

.poll-options {
    display: grid;
    gap: 10px;
}

.poll-options button {
    min-height: 48px;
    border: 1px solid #c9c8bf;
    border-radius: 6px;
    background: #fdfdfb;
    color: #20242c;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
}

.poll-options button.is-selected {
    border-color: #2f6159;
    box-shadow: inset 0 0 0 2px rgba(47, 97, 89, 0.18);
}

.poll-options button.is-correct {
    border-color: #1f7a43;
    background: #dff5e8;
    color: #0f5132;
}

.poll-options button.is-wrong {
    border-color: #b02a37;
    background: #f8d7da;
    color: #842029;
}

.poll-options button:disabled {
    cursor: default;
}

.poll-summary {
    min-width: 190px;
}

.prepared-questions {
    display: grid;
    gap: 8px;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid #e1dfd5;
}

.prepared-question {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border: 1px solid #e5e3da;
    border-radius: 8px;
    background: #fdfdfb;
}

.prepared-question strong {
    overflow-wrap: anywhere;
}

.prepared-question-active {
    border-color: #9bc7b9;
    background: #eef8f4;
}

.prepared-question-closed {
    opacity: 0.72;
}

.presentation-admin-panel {
    min-width: 190px;
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid #d9ded5;
    border-radius: 8px;
    background: #f6faf7;
}

.presentation-admin-panel .small-link {
    justify-self: start;
}

.presentation-button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.presentation-start-button {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    border-radius: 6px;
    padding: 0 16px;
    color: #ffffff;
    background: #2f6159;
    font-weight: 800;
    text-decoration: none;
}

.deck-status,
.deck-upload {
    display: grid;
    gap: 8px;
}

.deck-status .small-link,
.deck-upload .small-button {
    justify-self: start;
}

.file-input {
    max-width: 260px;
    font: inherit;
}

.file-input.wide {
    max-width: 100%;
}

.upload-summary {
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid #e5e3da;
    border-radius: 8px;
    background: #fdfdfb;
}

.audience-questions {
    min-width: 220px;
    display: grid;
    gap: 10px;
}

.audience-question {
    display: grid;
    gap: 8px;
    padding: 10px;
    border: 1px solid #e1dfd5;
    border-radius: 8px;
    background: #fdfdfb;
}

.audience-question strong {
    display: block;
    overflow-wrap: anywhere;
}

.audience-question-answered {
    opacity: 0.72;
    background: #eef3ef;
}

.audience-question-hidden {
    opacity: 0.58;
    background: #f4eeee;
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.summary-section {
    display: grid;
    gap: 14px;
    padding: 20px;
    background: #ffffff;
    border: 1px solid #dfded6;
    border-radius: 8px;
}

.summary-wide {
    grid-column: 1 / -1;
}

.summary-section h2,
.summary-item h3 {
    margin: 0;
}

.summary-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 0;
}

.summary-meta div {
    padding: 12px;
    border: 1px solid #e5e3da;
    border-radius: 8px;
    background: #fdfdfb;
}

.summary-meta dt {
    margin-bottom: 4px;
    color: #6d716c;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.summary-meta dd {
    margin: 0;
    overflow-wrap: anywhere;
    font-weight: 700;
}

.summary-item {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid #e5e3da;
    border-radius: 8px;
    background: #fdfdfb;
}

.poll-results,
.presentation-poll {
    display: grid;
    gap: 10px;
}

.poll-result-row,
.presentation-poll-row {
    display: grid;
    grid-template-columns: minmax(90px, 1fr) minmax(90px, 1.4fr) auto;
    gap: 10px;
    align-items: center;
}

.poll-result-row span,
.presentation-poll-row span {
    overflow-wrap: anywhere;
}

.poll-result-row meter,
.presentation-poll-row meter {
    width: 100%;
}

.quiz-score,
.presentation-quiz-score {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 10px 0;
    font-weight: 800;
}

.quiz-score span {
    min-width: 112px;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 6px 10px;
    border: 1px solid #dbe5dd;
    border-radius: 6px;
    background: #eef3ef;
}

.quiz-score strong {
    font-size: 20px;
    line-height: 1;
}

.poll-result-row.is-correct,
.presentation-poll-row.is-correct {
    color: #0f5132;
}

.presentation-page {
    background: #16181d;
    height: 100vh;
    overflow: hidden;
    overflow-anchor: none;
}

.presentation-shell {
    height: 100vh;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 24vw);
    gap: clamp(24px, 4vw, 56px);
    padding: clamp(24px, 4vw, 56px);
    box-sizing: border-box;
    background: #16181d;
    color: #ffffff;
    overflow: hidden;
    overflow-anchor: none;
}

.presentation-invalid {
    grid-template-columns: 1fr;
    place-items: center;
}

.presentation-stage {
    min-width: 0;
    min-height: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: clamp(24px, 4vw, 54px);
}

.presentation-topbar {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: flex-start;
}

.presentation-topbar h1 {
    max-width: 14ch;
    font-size: clamp(46px, 7vw, 104px);
    line-height: 0.95;
}

.presentation-status {
    min-width: 108px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #6fa99b;
    border-radius: 999px;
    color: #d8fff5;
    font-weight: 800;
    text-transform: uppercase;
}

.presentation-deck-link {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    margin-top: 16px;
}

.presentation-deck-link span {
    color: #a9c8c0;
    font-weight: 800;
    text-transform: uppercase;
}

.presentation-deck-link a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    border: 1px solid #6fa99b;
    border-radius: 6px;
    padding: 0 12px;
    color: #d8fff5;
    font-weight: 800;
    text-decoration: none;
}

.presentation-poll-main {
    align-self: stretch;
    display: grid;
    align-content: center;
    gap: clamp(22px, 4vw, 48px);
}

.presentation-poll-main h2,
.presentation-poll-side h2 {
    max-width: 18ch;
    margin: 0;
    font-size: clamp(42px, 6vw, 92px);
    line-height: 1;
}

.presentation-poll-side {
    display: none;
}

.browser-slide-deck {
    display: none;
    min-height: 0;
}

.browser-slide-deck.is-ready,
.browser-slide-deck.is-unavailable {
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 14px;
}

.presentation-stage.has-slide-deck {
    gap: 10px;
}

.presentation-shell-slide-mode,
.presentation-shell:has(.presentation-stage.has-slide-deck) {
    grid-template-columns: minmax(0, 1fr) minmax(190px, 15vw);
    gap: clamp(12px, 1.6vw, 24px);
    padding: clamp(10px, 1.5vw, 22px);
}

.presentation-shell-slide-mode {
    --presentation-pad: clamp(10px, 1.5vw, 22px);
    --presentation-gap: clamp(12px, 1.6vw, 24px);
    --presentation-side-width: clamp(300px, 24vw, 460px);
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100dvh;
    min-height: 0;
    display: block;
    padding: 0;
}

.presentation-shell-slide-mode .presentation-stage,
.presentation-stage.has-slide-deck {
    height: 100%;
    overflow: hidden;
}

.presentation-shell-slide-mode .presentation-stage {
    position: fixed;
    top: var(--presentation-pad);
    right: calc(var(--presentation-pad) + var(--presentation-side-width) + var(--presentation-gap));
    bottom: var(--presentation-pad);
    left: var(--presentation-pad);
    height: auto;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 10px;
}

.presentation-shell-slide-mode .presentation-topbar {
    position: fixed;
    top: var(--presentation-pad);
    right: calc(var(--presentation-pad) + var(--presentation-side-width) + var(--presentation-gap));
    left: var(--presentation-pad);
    height: 44px;
}

.presentation-shell-slide-mode .presentation-topbar,
.presentation-stage.has-slide-deck .presentation-topbar {
    align-items: center;
    min-height: 44px;
}

.presentation-shell-slide-mode .eyebrow,
.presentation-shell-slide-mode .presentation-deck-link,
.presentation-stage.has-slide-deck .eyebrow,
.presentation-stage.has-slide-deck .presentation-deck-link {
    display: none;
}

.presentation-shell-slide-mode .presentation-topbar h1,
.presentation-stage.has-slide-deck .presentation-topbar h1 {
    max-width: none;
    font-size: clamp(18px, 1.8vw, 30px);
    line-height: 1.1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.presentation-shell-slide-mode .presentation-status,
.presentation-stage.has-slide-deck .presentation-status {
    min-width: 78px;
    min-height: 30px;
    font-size: 12px;
}

.presentation-shell-slide-mode .presentation-poll-main,
.presentation-stage.has-slide-deck .presentation-poll-main {
    display: none;
}

.presentation-shell-slide-mode .browser-slide-deck {
    position: fixed;
    top: calc(var(--presentation-pad) + 54px);
    right: calc(var(--presentation-pad) + var(--presentation-side-width) + var(--presentation-gap));
    bottom: var(--presentation-pad);
    left: var(--presentation-pad);
    min-height: 0;
    height: auto;
    width: auto;
    overflow: hidden;
    contain: size layout paint;
    grid-template-rows: minmax(0, 1fr) auto;
}

.presentation-shell-slide-mode .browser-slide-frame {
    width: 100%;
    height: auto;
    min-height: 0;
    max-height: none;
    padding: clamp(10px, 1.2vw, 22px);
    contain: size layout paint;
}

.presentation-shell-slide-mode .browser-slide-frame img {
    max-width: 94%;
    max-height: 94%;
}

.browser-slide-frame {
    min-height: 0;
    display: grid;
    place-items: center;
    box-sizing: border-box;
    padding: 0;
    border: 1px solid #3d4a48;
    border-radius: 8px;
    background: #ffffff;
    overflow: hidden;
}

.browser-slide-frame img {
    display: none;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    cursor: pointer;
}

.browser-slide-deck.is-ready .browser-slide-frame img {
    display: block;
}

.browser-slide-fallback {
    display: none;
    max-width: 56ch;
    padding: 28px;
    text-align: center;
}

.browser-slide-fallback strong,
.browser-slide-fallback span {
    display: block;
}

.browser-slide-fallback span {
    margin-top: 10px;
    color: #a9c8c0;
}

.browser-slide-deck.is-unavailable .browser-slide-fallback {
    display: block;
}

.browser-slide-controls {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 12px;
}

.browser-slide-controls button {
    min-height: 42px;
    border: 1px solid #6fa99b;
    border-radius: 6px;
    padding: 0 18px;
    color: #d8fff5;
    background: #233b37;
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.browser-slide-controls button:disabled {
    cursor: default;
    opacity: 0.45;
}

.browser-slide-controls span {
    color: #a9c8c0;
    font-weight: 800;
}

.presentation-poll-results {
    display: grid;
    gap: clamp(14px, 2vw, 24px);
}

.presentation-quiz-score {
    font-size: clamp(26px, 4vw, 58px);
}

.presentation-quiz-score span {
    padding: 8px 14px;
    border: 1px solid #6fa99b;
    border-radius: 8px;
    color: #d8fff5;
}

.presentation-poll-row {
    display: grid;
    grid-template-columns: minmax(180px, 0.9fr) minmax(220px, 1.8fr) minmax(52px, auto);
    gap: clamp(14px, 2vw, 24px);
    align-items: center;
    font-size: clamp(24px, 3vw, 46px);
}

.presentation-poll-row span {
    overflow-wrap: anywhere;
}

.presentation-poll-row meter {
    width: 100%;
    height: clamp(22px, 3vw, 40px);
}

.presentation-side {
    height: 100%;
    min-height: 0;
    display: grid;
    align-content: start;
    gap: 22px;
    overflow-y: auto;
    overscroll-behavior: contain;
    overflow-anchor: none;
    padding-right: 4px;
}

.presentation-shell-slide-mode .presentation-side {
    position: fixed;
    top: var(--presentation-pad);
    right: var(--presentation-pad);
    bottom: var(--presentation-pad);
    width: var(--presentation-side-width);
    height: auto;
    grid-template-rows: auto auto auto auto auto minmax(110px, 1fr);
    gap: 10px;
}

.presentation-join,
.presentation-count,
.presentation-controls,
.presentation-poll-side,
.presentation-audience-questions {
    display: grid;
    gap: 10px;
}

.presentation-join span,
.presentation-count span,
.presentation-poll-side > span,
.presentation-audience-questions > span {
    color: #a9c8c0;
    font-size: clamp(16px, 1.6vw, 24px);
    font-weight: 800;
    text-transform: uppercase;
}

.presentation-poll-side {
    display: none;
}

.presentation-join strong {
    font-family: "Cascadia Mono", Consolas, monospace;
    font-size: clamp(40px, 5vw, 76px);
    line-height: 1;
    letter-spacing: 0.08em;
}

.presentation-qr {
    width: min(100%, 320px);
    aspect-ratio: 1;
    padding: 12px;
    box-sizing: border-box;
    background: #ffffff;
    border-radius: 8px;
    image-rendering: crisp-edges;
}

.presentation-count strong {
    font-size: clamp(64px, 8vw, 140px);
    line-height: 0.9;
}

.presentation-controls button {
    min-height: 44px;
    border: 1px solid #6fa99b;
    border-radius: 6px;
    padding: 0 14px;
    color: #d8fff5;
    background: #233b37;
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.presentation-controls button:disabled {
    cursor: wait;
    opacity: 0.55;
}

.presentation-controls small {
    min-height: 18px;
    color: #a9c8c0;
    font-weight: 700;
}

.presentation-reactions {
    display: grid;
    grid-template-columns: repeat(2, minmax(92px, 1fr));
    gap: 12px;
    font-size: clamp(28px, 3vw, 54px);
}

.presentation-reactions span {
    display: flex;
    gap: 12px;
    align-items: center;
    min-height: 64px;
}

.presentation-audience-questions {
    min-width: 0;
    min-height: 0;
}

.presentation-question-list {
    display: grid;
    gap: 10px;
    min-height: 0;
    max-height: clamp(160px, 34vh, 420px);
    overflow-y: auto;
    overscroll-behavior: contain;
    overflow-anchor: none;
    padding-right: 4px;
}

.presentation-shell-slide-mode .presentation-question-list {
    min-height: 0;
    max-height: none;
}

.presentation-question-card,
.presentation-question-empty {
    display: grid;
    gap: 6px;
    padding: 12px;
    border: 1px solid #3d4a48;
    border-radius: 8px;
    background: #20242c;
}

.presentation-question-card strong {
    overflow-wrap: anywhere;
    font-size: clamp(15px, 1.2vw, 20px);
    line-height: 1.25;
}

.presentation-question-card small,
.presentation-question-empty {
    color: #a9c8c0;
    font-weight: 700;
}

.presentation-question-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.presentation-question-actions button {
    min-height: 30px;
    border: 1px solid #6fa99b;
    border-radius: 6px;
    padding: 0 9px;
    color: #d8fff5;
    background: transparent;
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
}

.presentation-question-actions button:disabled {
    cursor: default;
    opacity: 0.45;
}

.presentation-shell-slide-mode .presentation-question-card,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-question-card {
    padding: 9px;
}

.presentation-shell-slide-mode .presentation-question-card strong,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-question-card strong {
    font-size: clamp(13px, 1vw, 16px);
}

.presentation-shell-slide-mode .presentation-join strong,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-join strong {
    font-size: clamp(28px, 3vw, 46px);
}

.presentation-shell-slide-mode .presentation-count strong,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-count strong {
    font-size: clamp(42px, 5vw, 82px);
}

.presentation-shell-slide-mode .presentation-qr,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-qr {
    width: min(100%, 170px);
}

.presentation-shell-slide-mode .presentation-controls button,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-controls button {
    min-height: 36px;
    padding: 0 10px;
    font-size: 13px;
}

.presentation-shell-slide-mode .presentation-poll-side,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side {
    display: grid;
    gap: 8px;
    order: 1;
    padding: 10px;
    border: 1px solid #6fa99b;
    border-radius: 8px;
    background: #172522;
}

.presentation-shell-slide-mode .presentation-audience-questions,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-audience-questions {
    order: 6;
}

.presentation-shell-slide-mode .presentation-join,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-join {
    order: 2;
}

.presentation-shell-slide-mode .presentation-count,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-count {
    order: 3;
}

.presentation-shell-slide-mode .presentation-controls,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-controls {
    order: 4;
}

.presentation-shell-slide-mode .presentation-reactions,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-reactions {
    order: 5;
}

.presentation-shell-slide-mode .presentation-poll-side h2,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side h2 {
    max-width: none;
    font-size: clamp(18px, 1.7vw, 30px);
    line-height: 1.12;
    overflow-wrap: anywhere;
}

.presentation-shell-slide-mode .presentation-poll-side .presentation-poll-results,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side .presentation-poll-results {
    display: none;
    gap: 6px;
}

.presentation-shell-slide-mode .presentation-poll-side.is-answer-visible .presentation-poll-results,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side.is-answer-visible .presentation-poll-results {
    display: grid;
}

.presentation-shell-slide-mode .presentation-poll-side .presentation-poll-row,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side .presentation-poll-row {
    grid-template-columns: minmax(0, 1fr) minmax(42px, auto);
    gap: 5px 8px;
    font-size: clamp(12px, 1vw, 15px);
}

.presentation-shell-slide-mode .presentation-poll-side .presentation-poll-row meter,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side .presentation-poll-row meter {
    grid-column: 1 / -1;
    grid-row: 2;
    height: 12px;
}

.presentation-shell-slide-mode .presentation-poll-side .presentation-quiz-score,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side .presentation-quiz-score {
    display: none;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 13px;
}

.presentation-shell-slide-mode .presentation-poll-side.is-answer-visible .presentation-quiz-score,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side.is-answer-visible .presentation-quiz-score {
    display: flex;
}

.presentation-shell-slide-mode .presentation-poll-side .presentation-quiz-score span,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-poll-side .presentation-quiz-score span {
    padding: 5px 7px;
}

.presentation-shell-slide-mode .presentation-reactions,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-reactions {
    grid-template-columns: repeat(2, minmax(62px, 1fr));
    gap: 8px;
    font-size: clamp(20px, 2vw, 34px);
}

.presentation-shell-slide-mode .presentation-reactions span,
.presentation-shell:has(.presentation-stage.has-slide-deck) .presentation-reactions span {
    min-height: 40px;
}

.presentation-fly-layer {
    position: fixed;
    inset: 0;
    z-index: 20;
    overflow: hidden;
    pointer-events: none;
}

.presentation-fly-reaction {
    position: absolute;
    right: -64px;
    font-size: clamp(30px, 4.2vw, 64px);
    line-height: 1;
    filter: drop-shadow(0 10px 16px rgba(0, 0, 0, 0.28));
    animation: reaction-flight 4.2s cubic-bezier(0.32, 0.02, 0.24, 1) forwards;
    will-change: transform, opacity;
}

/* CYA-HQ dark theme */
.public-page,
.legal-page,
.page,
.join-shell,
.participant-shell,
.presentation-page {
    background:
        radial-gradient(circle at 18% 8%, rgba(88, 199, 168, 0.13), transparent 32rem),
        linear-gradient(180deg, var(--bg) 0%, #12191b 52%, var(--bg-deep) 100%);
    color: var(--text);
}

.public-hero {
    color: var(--text);
    background:
        radial-gradient(circle at 80% 18%, rgba(88, 199, 168, 0.24), transparent 30rem),
        linear-gradient(135deg, var(--bg) 0%, #15201f 48%, var(--bg-deep) 100%);
}

.public-flow,
.feature-band,
.legal-header,
.public-legal-footer {
    background: rgba(16, 20, 22, 0.72);
}

.public-section {
    border-top: 1px solid var(--line);
}

.public-owner {
    background: linear-gradient(180deg, var(--surface-raised), var(--surface));
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.pulse-card,
.pulse-card-grid article,
.flow-steps article,
.feature-band article,
.status-grid article,
.session-table,
.edit-form,
.empty-state,
.session-meta div,
.poll-card,
.audience-question-card,
.participant-question-card,
.prepared-question,
.presentation-admin-panel,
.upload-summary,
.audience-question,
.summary-section,
.summary-meta div,
.summary-item {
    background: linear-gradient(180deg, var(--surface-raised), var(--surface));
    border-color: var(--line);
    box-shadow: var(--shadow);
}

.feature-band article {
    box-shadow: none;
}

.public-section p,
.pulse-card p,
.legal-document p,
.legal-document li,
.muted,
.session-meta dt,
.summary-meta dt,
.summary-meta,
.summary-item,
.presentation-admin-panel .muted {
    color: var(--muted);
}

.eyebrow,
.pulse-card span,
.pulse-card-grid span,
.legal-nav a,
.public-owner .eyebrow {
    color: var(--accent);
}

.legal-brand,
.public-legal-footer a,
.secondary-link,
.linkedin-link {
    color: var(--accent-strong);
}

.legal-document a,
.text-link,
.link-copy {
    color: var(--blue);
}

.secondary-link,
.small-link,
.small-button.secondary {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--line);
}

.primary-link,
.small-button,
.primary-button,
.presentation-start-button,
.flow-steps span {
    background: var(--accent);
    color: #07110e;
}

.primary-link:hover,
.secondary-link:hover,
.small-link:hover,
.presentation-start-button:hover,
.primary-button:hover,
.small-button:hover {
    filter: brightness(1.08);
}

.small-button.secondary,
.small-link {
    color: var(--accent-strong);
}

.small-button.danger {
    background: #843d42;
    color: #fff1f1;
}

.session-table th,
.session-table td {
    border-bottom-color: var(--line);
}

.session-table th {
    color: var(--muted);
}

.status-pill {
    background: rgba(255, 255, 255, 0.08);
    color: var(--text-soft);
}

.status-active,
.poll-options button.is-correct,
.poll-result-row.is-correct,
.presentation-poll-row.is-correct {
    color: var(--success);
    background: rgba(118, 212, 154, 0.13);
    border-color: rgba(118, 212, 154, 0.48);
}

.status-paused,
.security-warning {
    color: var(--warning);
    background: rgba(241, 198, 107, 0.13);
    border-color: rgba(241, 198, 107, 0.42);
}

.status-ended,
.messages,
.field-error,
.poll-options button.is-wrong {
    color: var(--danger);
}

.poll-options button.is-wrong {
    background: rgba(208, 107, 107, 0.13);
    border-color: rgba(208, 107, 107, 0.5);
}

.quiz-score span:first-child {
    color: #c9f8d9;
    background: rgba(118, 212, 154, 0.16);
    border-color: rgba(118, 212, 154, 0.55);
}

.quiz-score span:nth-child(2) {
    color: #ffd3d3;
    background: rgba(208, 107, 107, 0.16);
    border-color: rgba(208, 107, 107, 0.55);
}

.quiz-score strong {
    color: #ffffff;
}

.edit-form input,
.edit-form textarea,
.audience-question-card textarea,
.poll-options button {
    border-color: var(--line-strong);
    background: #101719;
    color: var(--text);
}

.edit-form input:focus,
.edit-form textarea:focus,
.audience-question-card textarea:focus,
.poll-options button:focus-visible {
    outline: 2px solid rgba(88, 199, 168, 0.58);
    outline-offset: 2px;
}

.reaction-buttons button {
    border-color: var(--line);
    background: var(--surface-raised);
}

.prepared-question-active,
.audience-question-answered {
    background: rgba(88, 199, 168, 0.1);
    border-color: rgba(88, 199, 168, 0.4);
}

.audience-question-hidden {
    background: rgba(208, 107, 107, 0.1);
}

.browser-slide-frame {
    border-color: var(--line);
    background: #050607;
}

@keyframes reaction-flight {
    0% {
        opacity: 0;
        transform: translate3d(0, 0, 0) scale(0.82) rotate(2deg);
    }

    20% {
        opacity: 0.82;
        transform: translate3d(-8vw, calc(-2vh + var(--lift) * 0.06), 0) scale(0.9) rotate(1deg);
    }

    52% {
        opacity: 0.88;
        transform: translate3d(-38vw, calc(-12vh + var(--lift) * 0.34), 0) scale(0.98) rotate(-2deg);
    }

    78% {
        opacity: 0.72;
        transform: translate3d(-72vw, calc(-25vh + var(--lift) * 0.72), 0) scale(1.04) rotate(-5deg);
    }

    100% {
        opacity: 0;
        transform: translate3d(calc(-100vw - 140px), calc(-32vh + var(--lift)), 0) scale(1.08) rotate(-8deg);
    }
}

@media (max-width: 760px) {
    .public-hero {
        min-height: auto;
        grid-template-columns: 1fr;
        padding-top: 42px;
    }

    .public-hero h1 {
        font-size: clamp(54px, 18vw, 82px);
    }

    .public-flow,
    .flow-steps,
    .feature-band {
        grid-template-columns: 1fr;
    }

    .pulse-card-grid {
        grid-template-columns: 1fr 1fr;
    }

    .public-owner {
        align-items: flex-start;
        flex-direction: column;
    }

    .admin-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .session-table,
    .session-table tbody,
    .session-table tr,
    .session-table td {
        display: block;
    }

    .session-table thead {
        display: none;
    }

    .presentation-shell {
        height: auto;
        min-height: 100vh;
        grid-template-columns: 1fr;
    }

    .presentation-page {
        height: auto;
        overflow: auto;
    }

    .presentation-shell-slide-mode {
        position: static;
        width: auto;
        height: auto;
        display: grid;
        padding: clamp(24px, 4vw, 56px);
    }

    .presentation-shell-slide-mode .presentation-stage,
    .presentation-shell-slide-mode .presentation-side {
        position: static;
        width: auto;
        height: auto;
    }

    .presentation-topbar {
        flex-direction: column;
    }

    .presentation-poll-row {
        grid-template-columns: 1fr auto;
    }

    .presentation-poll-row meter {
        grid-column: 1 / -1;
        grid-row: 2;
    }

    .presentation-side {
        grid-template-columns: 1fr 1fr;
    }

    .presentation-join {
        grid-column: 1 / -1;
    }
}

@media (min-width: 761px) and (max-height: 760px) {
    .presentation-shell-slide-mode .presentation-side {
        gap: 8px;
    }

    .presentation-shell-slide-mode .presentation-qr {
        width: min(100%, 150px);
        padding: 8px;
    }

    .presentation-shell-slide-mode .presentation-join,
    .presentation-shell-slide-mode .presentation-count,
    .presentation-shell-slide-mode .presentation-controls,
    .presentation-shell-slide-mode .presentation-audience-questions {
        gap: 6px;
    }

    .presentation-shell-slide-mode .presentation-join span,
    .presentation-shell-slide-mode .presentation-count span,
    .presentation-shell-slide-mode .presentation-audience-questions > span {
        font-size: 12px;
    }

    .presentation-shell-slide-mode .presentation-join strong {
        font-size: clamp(22px, 2.8vw, 34px);
    }

    .presentation-shell-slide-mode .presentation-count strong {
        font-size: clamp(30px, 4vw, 54px);
    }

    .presentation-shell-slide-mode .presentation-reactions {
        gap: 6px;
        font-size: clamp(18px, 1.8vw, 28px);
    }

    .presentation-shell-slide-mode .presentation-reactions span {
        min-height: 30px;
    }

    .presentation-shell-slide-mode .presentation-question-list {
        max-height: none;
    }
}
