.rules-card-collapsed[open] > summary {
    color: var(--ink);
}

.rules-card-collapsed[open] > summary::after {
    content: "\2212";
}

.rules-card-collapsed:not([open]) > :not(summary) {
    display: none;
}

.rage-slider {
    width: 100%;
    accent-color: var(--accent);
}

.rage-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    margin-bottom: 0.4rem;
    font-weight: 600;
}

.rage-preview {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent-deep);
    font-size: 0.85rem;
    font-weight: 700;
    white-space: nowrap;
}

.rage-preview-emoji {
    font-size: 1rem;
    line-height: 1;
}

.btn {
    -webkit-appearance: none;
    appearance: none;
    border: none;
    border-radius: 12px;
    padding: 0.68rem 1.25rem;
    font-weight: 700;
    font-size: 0.96rem;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.btn-small {
    padding: 0.5rem 0.95rem;
    font-size: 0.88rem;
}

.btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 12px rgba(15, 23, 42, 0.12);
}

.btn-primary {
    background: linear-gradient(135deg, var(--fire-grad-start) 0%, var(--fire-grad-mid) 58%, var(--fire-grad-end) 100%);
    color: #2d190d;
    border: 1px solid color-mix(in srgb, var(--fire-grad-mid) 34%, #ffffff 66%);
    box-shadow: 0 8px 16px var(--fire-ring), inset 0 0 0 1px rgba(255, 255, 255, 0.18);
    background-clip: padding-box;
}

.btn-primary:hover {
    box-shadow: 0 10px 18px var(--fire-ring);
}

.composer-btn {
    position: relative;
    isolation: isolate;
    overflow: visible;
    border-radius: 10px;
    border: 1.4px solid #934015;
    color: #fff6ea;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.13) 0%, rgba(255, 255, 255, 0) 34%),
        linear-gradient(180deg, #f59b2d 0%, #df731b 56%, #ae470f 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.42),
        inset 0 -1px 0 rgba(90, 30, 0, 0.2),
        0 6px 12px rgba(201, 106, 38, 0.16);
}

.composer-btn::before {
    content: "";
    position: absolute;
    inset: 2px;
    border-radius: 8px;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 56%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
    z-index: 0;
}

.composer-btn::after {
    content: "";
    position: absolute;
    inset: -6px -8px -8px -8px;
    border-radius: 14px;
    pointer-events: none;
    background: radial-gradient(circle, rgba(201, 106, 38, 0.16) 0%, transparent 66%);
    filter: blur(5px);
    opacity: 0.12;
    z-index: -1;
}

.composer-btn > * {
    position: relative;
    z-index: 1;
}

.composer-btn:hover {
    border-color: #8b3610;
    color: #fff7ee;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.46),
        inset 0 -1px 0 rgba(90, 30, 0, 0.22),
        0 7px 14px rgba(201, 106, 38, 0.2);
}

body[data-theme="dark"] .composer-btn {
    border-color: #8a3812;
    color: #ffeedd;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 34%),
        linear-gradient(180deg, #e98b27 0%, #cd6218 56%, #8b350d 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.32),
        inset 0 -1px 0 rgba(70, 24, 8, 0.34),
        0 6px 12px rgba(103, 42, 12, 0.22);
}

body[data-theme="dark"] .composer-btn::after {
    background: radial-gradient(circle, rgba(198, 96, 38, 0.22) 0%, transparent 66%);
    opacity: 0.1;
}

body[data-theme="dark"] .composer-btn:hover {
    border-color: #a24719;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.38),
        inset 0 -1px 0 rgba(70, 24, 8, 0.4),
        0 8px 14px rgba(111, 44, 12, 0.26);
}

.btn-outline {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(238, 242, 247, 0.92) 100%);
    border: 1px solid var(--border);
    color: var(--ink);
}

.btn-outline:hover {
    border-color: rgba(201, 106, 38, 0.55);
    box-shadow: 0 6px 12px rgba(201, 106, 38, 0.14);
}

.btn:focus-visible,
.menu-trigger:focus-visible,
.modal-close:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible,
.search-clear:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.auth-gate {
    margin-top: 1.2rem;
    border-radius: 18px;
    border: 1px dashed rgba(201, 106, 38, 0.34);
    background: #f3eee7;
    padding: 1.2rem;
}

.auth-gate h3,
.auth-gate .auth-gate-title {
    margin: 0 0 0.4rem;
}

.auth-actions {
    margin-top: 0.8rem;
    display: flex;
    justify-content: flex-start;
}

.auth-forms {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.8rem;
}

.auth-form {
    display: grid;
    gap: 0.65rem;
    padding: 0.85rem;
    border-radius: 16px;
    background: var(--card);
    border: 1px solid var(--border);
}

.auth-note {
    margin: 0.8rem 0 0;
    color: var(--muted);
    font-size: 0.9rem;
}

.feed-header {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    margin-bottom: 0.9rem;
}

.feed-header-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.feed-topic-context {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.feed-topic-context-label {
    font-size: 0.75rem;
    letter-spacing: 0.01em;
    text-transform: none;
    font-weight: 700;
    color: var(--muted);
}

.feed-topic-context-pill {
    padding: 0.18rem 0.56rem;
    min-height: 1.48rem;
    font-size: 0.8rem;
}

.feed-topic-context-pill .filter-text {
    font-size: 0.8rem;
}

.feed-topic-context-pill.is-active::after {
    width: 0.3rem;
    height: 0.3rem;
}

.pill-clear-x {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.18rem;
    height: 1.18rem;
    border: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-soft) 85%, transparent);
    position: relative;
    font-size: 0;
    line-height: 0;
    color: var(--muted);
    transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.pill-clear-x::before,
.pill-clear-x::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 0.52rem;
    height: 2px;
    border-radius: 2px;
    background: currentColor;
    transform-origin: center;
}

.pill-clear-x::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

.pill-clear-x::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.feed-topic-context-pill-clearable {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    text-decoration: none;
}

.topics-active-pill-clearable {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    text-decoration: none;
}

.feed-topic-context-pill-clearable.is-active::after,
.topics-active-pill-clearable.is-active::after {
    display: none;
}

.feed-topic-context-pill-clearable:hover .pill-clear-x,
.topics-active-pill-clearable:hover .pill-clear-x {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 42%, var(--border));
    color: var(--ink);
    background: color-mix(in srgb, var(--fire-grad-mid) 10%, var(--surface-soft));
    transform: scale(1.03);
}

.feed-topic-context-pill-clearable:focus-visible .pill-clear-x,
.topics-active-pill-clearable:focus-visible .pill-clear-x {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.feed-filters {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
    align-items: center;
}

.topic-context-mobile {
    display: none;
}

.feed-value-prop-headline {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
    color: var(--ink);
}

.feed-value-prop-subline {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--muted);
}

.feed-howto {
    margin: 0 0 0.95rem;
    padding: 0.62rem 0.72rem 0.66rem;
    border: 1px solid var(--border);
    border-left: 3px solid color-mix(in srgb, var(--accent) 72%, var(--border));
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface-soft) 66%, var(--card));
    display: grid;
    gap: 0.45rem;
}

.feed-privacy-notice {
    margin: 0 0 0.95rem;
    padding: 0.58rem 0.68rem 0.62rem;
    border: 1px solid var(--border);
    border-left: 3px solid color-mix(in srgb, var(--accent) 55%, var(--border));
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface-soft) 58%, var(--card));
    display: grid;
    gap: 0.4rem;
}

.feed-howto-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.feed-privacy-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.feed-privacy-title {
    margin: 0;
    font-size: 0.84rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ink);
}

.feed-howto-dismiss,
.feed-privacy-dismiss {
    width: 1.4rem;
    height: 1.4rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--card) 88%, transparent);
    color: var(--muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.feed-howto-dismiss:hover,
.feed-privacy-dismiss:hover {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 42%, var(--border));
    color: var(--ink);
    background: color-mix(in srgb, var(--fire-grad-mid) 10%, var(--surface-soft));
    transform: scale(1.03);
}

.feed-howto-dismiss:focus-visible,
.feed-privacy-dismiss:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.feed-howto-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.4rem;
}

.feed-howto-step {
    display: flex;
    align-items: flex-start;
    gap: 0.42rem;
    min-width: 0;
}

.feed-howto-step-num {
    width: 1.05rem;
    height: 1.05rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 24%, transparent);
    color: var(--accent-deep);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.68rem;
    font-weight: 800;
    line-height: 1;
    flex: 0 0 1.05rem;
    margin-top: 0.08rem;
}

.feed-howto-step-text {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--ink);
    overflow-wrap: anywhere;
}

.feed-howto-note {
    margin: 0;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--muted);
}

.feed-privacy-copy {
    margin: 0;
    font-size: 0.8rem;
    color: var(--muted);
}

.feed-privacy-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.feed-privacy-link {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.2rem 0.56rem;
    font-size: 0.74rem;
    font-weight: 700;
    color: var(--ink);
    text-decoration: none;
    background: color-mix(in srgb, var(--surface-soft) 70%, var(--card));
}

.feed-privacy-link:hover {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 45%, var(--border));
    background: color-mix(in srgb, var(--fire-grad-mid) 10%, var(--surface-soft));
}

.feed-privacy-link:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

@media (min-width: 901px) {
    .feed-howto-steps {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.65rem;
    }
}

.feed-filter-pills {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.feed-tag-pills {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    flex: 1 1 100%;
}

.topic-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.topic-follow-form {
    margin: 0;
}

.feed-topic-context-follow {
    margin-left: 0.1rem;
}

.feed-topic-context-follow .topic-follow-btn {
    padding: 0.18rem 0.48rem;
    font-size: 0.68rem;
}

.topic-follow-btn {
    border: 1px solid var(--border);
    background: transparent;
    color: var(--muted);
    border-radius: 999px;
    padding: 0.22rem 0.54rem;
    font-size: 0.72rem;
    line-height: 1;
    font-weight: 700;
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.topic-follow-btn:hover {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 45%, var(--border));
    color: var(--ink);
}

.topic-follow-btn.is-followed {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 55%, var(--border));
    color: color-mix(in srgb, var(--fire-grad-end) 72%, var(--ink));
    background: color-mix(in srgb, var(--fire-grad-mid) 14%, transparent);
}

.topic-follow-btn:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.feed-filter-status {
    display: none;
    align-items: center;
    gap: 0.35rem;
    font-weight: 700;
    color: var(--muted);
    white-space: nowrap;
}

.filter-status-label {
    font-weight: 600;
    color: var(--muted);
}

.filter-status-value {
    color: var(--ink);
}

.filter-status-sep {
    color: var(--muted);
}

.feed-activity-strip {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.feed-activity-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.18rem 0.52rem;
    background: color-mix(in srgb, var(--surface-soft) 74%, var(--card));
    color: var(--muted);
    font-size: 0.72rem;
    line-height: 1.2;
}

.feed-activity-pill.is-opportunity {
    gap: 0.36rem;
    border-color: color-mix(in srgb, var(--fire-grad-mid) 36%, var(--border));
}

.feed-activity-pill strong {
    color: var(--ink);
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}

.feed-activity-opportunity {
    color: var(--accent-deep);
    font-weight: 700;
}

.feed-activity-label {
    color: var(--muted);
    font-weight: 600;
}

.feed-weekly-block {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface-soft) 76%, var(--card));
    overflow: hidden;
}

.feed-weekly-block-summary {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
    width: 100%;
    list-style: none;
    cursor: pointer;
    user-select: none;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 0.46rem 0.62rem;
}

.feed-weekly-block-summary::-webkit-details-marker {
    display: none;
}

.feed-weekly-block-summary::marker {
    display: none;
}

.feed-weekly-block-summary::after {
    content: '';
    width: 0.45rem;
    height: 0.45rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(-1px);
    transition: transform 0.2s ease;
    opacity: 0.8;
}

.feed-weekly-block[open] > .feed-weekly-block-summary::after {
    transform: rotate(-135deg) translateX(-1px);
}

.feed-weekly-block > .feed-weekly-heat {
    border: 0;
    border-top: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 0;
    background: transparent;
    padding: 0.5rem 0.62rem;
}

.feed-weekly-heat {
    width: 100%;
    display: grid;
    gap: 0.4rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 0.5rem 0.62rem;
    background: color-mix(in srgb, var(--surface-soft) 76%, var(--card));
}

.feed-weekly-title {
    margin: 0;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--muted);
}

.feed-weekly-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.4rem 0.5rem;
}

.feed-weekly-item {
    min-width: 0;
    display: grid;
    gap: 0.15rem;
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 10px;
    padding: 0.36rem 0.46rem;
    background: color-mix(in srgb, var(--card) 92%, transparent);
}

.feed-weekly-label {
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--muted);
}

.feed-weekly-link,
.feed-weekly-value {
    display: block;
    min-width: 0;
    font-size: 0.78rem;
    line-height: 1.25;
    font-weight: 700;
    color: var(--ink);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.feed-weekly-link:hover,
.feed-weekly-link:focus-visible {
    color: var(--accent-deep);
}

.feed-weekly-meta,
.feed-weekly-empty {
    font-size: 0.68rem;
    line-height: 1.25;
    color: var(--muted);
}

.feed-weekly-empty {
    font-style: italic;
}

@media (max-width: 900px) {
    .feed-weekly-grid {
        grid-template-columns: 1fr;
    }
}

.topics-weekly-heat {
    margin: 0;
    padding: 0;
    gap: 0.34rem;
    border-radius: 0;
    background: transparent;
}

.topics-weekly-block {
    margin-top: 0.08rem;
    margin-bottom: 0.62rem;
    border-radius: 11px;
    background: color-mix(in srgb, var(--surface-soft) 70%, var(--card));
}

.topics-weekly-block > .feed-weekly-block-summary {
    font-size: 0.72rem;
    padding: 0.4rem 0.54rem;
}

.topics-weekly-block > .feed-weekly-heat {
    padding: 0.42rem 0.54rem;
}

.topics-weekly-heat .feed-weekly-title {
    font-size: 0.72rem;
}

.topics-weekly-heat .feed-weekly-grid {
    grid-template-columns: 1fr;
    gap: 0.34rem;
}

.topics-weekly-heat .feed-weekly-item {
    padding: 0.3rem 0.4rem;
    border-radius: 9px;
}

.topics-weekly-heat .feed-weekly-label {
    font-size: 0.63rem;
}

.topics-weekly-heat .feed-weekly-link,
.topics-weekly-heat .feed-weekly-value {
    font-size: 0.75rem;
}

.topics-weekly-heat .feed-weekly-meta,
.topics-weekly-heat .feed-weekly-empty {
    font-size: 0.66rem;
}

.topics-hall-of-fame-block {
    margin-bottom: 0.58rem;
}

.topics-hall-of-fame-heat {
    gap: 0.42rem;
}

.topics-hall-period {
    display: grid;
    gap: 0.3rem;
}

.topics-hall-period + .topics-hall-period {
    border-top: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    padding-top: 0.34rem;
}

.topics-hall-period-title {
    display: block;
    font-size: 0.61rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.topics-hall-grid {
    grid-template-columns: 1fr;
}

.feed-opportunity-callout {
    width: 100%;
    display: grid;
    gap: 0.36rem;
    border: 1px dashed color-mix(in srgb, var(--fire-grad-mid) 45%, var(--border));
    border-radius: 12px;
    padding: 0.56rem 0.68rem;
    margin: 0.38rem 0 0.72rem;
    background: color-mix(in srgb, var(--fire-grad-mid) 6%, var(--surface-soft));
}

.feed-opportunity-title {
    margin: 0;
    font-size: 0.86rem;
    font-weight: 800;
    color: var(--ink);
}

.feed-opportunity-copy {
    margin: 0;
    font-size: 0.79rem;
    line-height: 1.42;
    color: var(--muted);
}

.feed-opportunity-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.44rem;
}

.feed-opportunity-link {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.2rem 0.56rem;
    background: var(--card);
    color: var(--ink);
    font-size: 0.74rem;
    font-weight: 700;
    text-decoration: none;
    transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.feed-opportunity-link:hover,
.feed-opportunity-link:focus-visible {
    border-color: rgba(201, 106, 38, 0.5);
    color: var(--accent-deep);
    background: color-mix(in srgb, var(--fire-grad-mid) 8%, var(--card));
}

.feed-opportunity-link.is-quiet {
    color: var(--muted);
}

.search-context {
    width: 100%;
    display: grid;
    gap: 0.5rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 0.58rem 0.68rem;
    background: color-mix(in srgb, var(--surface-soft) 72%, var(--card));
}

.search-context-head {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: baseline;
}

.search-context-title {
    font-size: 0.9rem;
    font-weight: 800;
    color: var(--ink);
}

.search-context-meta {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--muted);
}

.search-context-topics {
    display: grid;
    gap: 0.34rem;
}

.search-context-users {
    display: grid;
    gap: 0.34rem;
}

.search-context-topics-label {
    font-size: 0.76rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.feed-tag-pills-search {
    gap: 0.45rem;
}

.search-user-list {
    display: grid;
    gap: 0.38rem;
}

.search-user-row {
    width: 100%;
    border: 1px solid var(--border);
    background: var(--card);
    border-radius: 10px;
    padding: 0.42rem 0.52rem;
    text-align: left;
    display: grid;
    gap: 0.12rem;
    color: var(--ink);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.search-user-row:hover {
    border-color: rgba(201, 106, 38, 0.44);
    background: var(--surface-soft);
    box-shadow: 0 5px 10px rgba(15, 23, 42, 0.08);
}

.search-user-row:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.search-user-name {
    font-size: 0.85rem;
    font-weight: 700;
}

.search-user-meta {
    font-size: 0.74rem;
    font-weight: 600;
    color: var(--muted);
}

.mobile-feed-switch {
    display: none;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem;
    border: 1px solid var(--panel-border);
    border-radius: 999px;
    background: var(--card);
    box-shadow: var(--panel-shadow);
}

.mobile-feed-switch-btn {
    flex: 1;
    border: 1px solid transparent;
    border-radius: 999px;
    padding: 0.35rem 0.68rem;
    text-align: center;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
    text-decoration: none;
}

.mobile-feed-switch-btn.is-active {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 45%, var(--border));
    background: color-mix(in srgb, var(--fire-grad-mid) 14%, var(--card));
    color: var(--ink);
}

.topics-panel {
    gap: 0.68rem;
}

.topics-context-pane {
    border: 1px solid var(--border);
    border-radius: 11px;
    background: var(--surface-soft);
    padding: 0.42rem 0.52rem 0.48rem;
    display: grid;
    gap: 0.34rem;
}

.topics-context-pane h3 {
    margin: 0;
    font-size: 0.82rem;
}

.topics-context-pane p {
    margin: 0;
    font-size: 0.75rem;
    line-height: 1.35;
    color: var(--muted);
}

.topics-context-adjacent {
    display: flex;
    flex-wrap: wrap;
    gap: 0.34rem;
}

.topics-context-adjacent .pill {
    max-width: 100%;
}

.topics-context-pane ul {
    margin: 0;
    padding-left: 1rem;
    display: grid;
    gap: 0.18rem;
}

.topics-context-pane li {
    margin: 0;
    font-size: 0.76rem;
    line-height: 1.3;
}

.topics-context-pane li a {
    color: var(--ink);
    text-decoration: none;
    font-weight: 600;
}

.topics-context-pane li a:hover,
.topics-context-pane li a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 0.14em;
}

.topics-context-more {
    justify-self: start;
    font-size: 0.7rem;
    font-weight: 700;
    text-decoration: none;
    color: var(--accent);
}

.topics-context-more:hover,
.topics-context-more:focus-visible {
    color: var(--accent-deep);
    text-decoration: underline;
    text-underline-offset: 0.14em;
}

.topics-tabs {
    display: flex;
    gap: 0.38rem;
}

.topics-tab {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.3rem 0.58rem;
    font-size: 0.76rem;
    font-weight: 700;
    color: var(--muted);
    background: var(--surface-soft);
}

.topics-tab.is-active {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 45%, var(--border));
    background: color-mix(in srgb, var(--fire-grad-mid) 14%, var(--card));
    color: var(--ink);
}

.topics-tab-panel {
    display: grid;
    gap: 0.62rem;
}

.topics-tab-panel[hidden] {
    display: none !important;
}

.topics-active-topic {
    border: 1px solid var(--border);
    border-radius: 11px;
    background: var(--surface-soft);
    padding: 0.4rem 0.5rem;
    display: flex;
    gap: 0.42rem;
    align-items: center;
    flex-wrap: wrap;
}

.topics-active-label {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.topics-group {
    display: grid;
    gap: 0.38rem;
}

.topics-group h3 {
    margin: 0;
    font-size: 0.86rem;
}

.topics-list {
    display: grid;
    gap: 0.34rem;
}

.topics-item {
    display: flex;
    align-items: center;
    gap: 0.38rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0.32rem 0.36rem;
    background: var(--card);
}

.topics-item-main {
    min-width: 0;
    display: grid;
    gap: 0.14rem;
}

.topics-item .topic-follow-form {
    margin: 0 0 0 auto;
}

.topics-item > .pill,
.topics-item-main .pill {
    justify-self: start;
    padding: 0.24rem 0.72rem;
    font-size: 0.92rem;
    gap: 0.28rem;
}

.topics-impressum {
    margin-top: 0.1rem;
    padding-top: 0.42rem;
    border-top: 1px solid var(--border);
    display: grid;
    gap: 0.34rem;
    font-size: 0.69rem;
    color: var(--muted);
    line-height: 1.3;
}

.topics-impressum-title {
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.topics-legal-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
    align-items: baseline;
}

.topics-legal-link {
    font-size: 0.64rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: inherit;
    text-decoration: none;
    opacity: 0.86;
}

.topics-legal-link:hover {
    text-decoration: underline;
    text-underline-offset: 0.14em;
    color: var(--ink);
    opacity: 1;
}

.feed-search {
    display: flex;
    align-items: center;
}

.search-form {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    width: 100%;
}

.search-label {
    flex: 1 1 240px;
}

.search-form-interactive {
    position: relative;
}

.search-scope {
    flex: 0 0 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
}

.search-scope-label {
    font-size: 0.74rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--muted);
}

.search-scope-pill {
    pointer-events: none;
}

.search-scope-clear {
    font-size: 0.8rem;
    color: var(--muted);
    text-decoration: none;
    font-weight: 700;
}

.search-scope-clear:hover {
    color: var(--ink);
}

.search-autocomplete {
    position: relative;
    flex: 1 1 300px;
    min-width: 0;
}

.search-input {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.5rem 0.85rem;
    font-size: 0.95rem;
    background: var(--surface-soft);
}

.search-clear {
    color: var(--muted);
    text-decoration: none;
    font-weight: 600;
}

.search-clear:hover {
    color: var(--ink);
}

.search-live {
    position: absolute;
    top: calc(100% + 0.35rem);
    left: 0;
    right: 0;
    z-index: 120;
    background: var(--card);
    border: 1px solid var(--panel-border);
    border-radius: 14px;
    box-shadow: var(--panel-shadow);
    padding: 0.45rem;
    display: grid;
    gap: 0.35rem;
    max-height: min(52vh, 420px);
    overflow-y: auto;
}

.search-live-section {
    display: grid;
    gap: 0.22rem;
}

.search-live-section-title {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
    color: var(--muted);
    padding: 0.12rem 0.3rem;
}

.search-live-item {
    width: 100%;
    text-align: left;
    border: 1px solid transparent;
    border-radius: 10px;
    padding: 0.45rem 0.55rem;
    background: transparent;
    color: var(--ink);
    cursor: pointer;
    display: grid;
    gap: 0.12rem;
}

.search-live-item:hover {
    background: var(--surface-soft);
    border-color: var(--border);
}

.search-live-item:focus-visible,
.search-live-item.is-active {
    outline: none;
    background: var(--surface-soft);
    border-color: var(--accent);
    box-shadow: 0 0 0 2px var(--focus-ring);
}

.search-live-item-title {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--ink);
}

.search-live-item-meta {
    font-size: 0.74rem;
    color: var(--muted);
    font-weight: 600;
}

.search-live-empty {
    margin: 0;
    padding: 0.34rem 0.45rem;
    font-size: 0.82rem;
    color: var(--muted);
}

.filter-icon {
    width: 1rem;
    height: 1rem;
    margin-right: 0;
    opacity: 0.92;
}

.filter-text {
    font-weight: 700;
}

.pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface-soft);
    color: var(--muted);
    text-decoration: none;
    font-weight: 700;
    position: relative;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.pill.is-active {
    background: linear-gradient(150deg, #f2f6fc 0%, #dde8f5 100%);
    border-color: #9ab0c9;
    color: #1f3f60;
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.08), inset 0 0 0 1px rgba(255, 255, 255, 0.7);
}

.pill.is-active::after {
    content: "";
    width: 0.4rem;
    height: 0.4rem;
    border-radius: 999px;
    background: var(--fire-grad-mid);
    box-shadow: 0 0 0 1px rgba(143, 67, 20, 0.22), 0 0 10px rgba(201, 106, 38, 0.34);
    flex-shrink: 0;
}

.pill.pill-tag {
    font-weight: 600;
}

.rant-grid {
    display: grid;
    gap: 0.85rem;
}

.rant-card {
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 0.98rem 1.02rem 0.94rem;
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.56) 0%, rgba(255, 255, 255, 0) 58%), var(--card);
    display: grid;
    gap: 0.58rem;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.07);
    position: relative;
    overflow: hidden;
    content-visibility: auto;
    contain-intrinsic-size: 360px;
}

.rant-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 2px;
    background: linear-gradient(180deg, rgba(201, 106, 38, 0.5) 0%, rgba(201, 106, 38, 0.09) 100%);
    opacity: 0.34;
    transition: opacity 0.2s ease;
}

.rant-card.is-clickable {
    cursor: pointer;
}

.rant-card.is-clickable:hover {
    border-color: rgba(201, 106, 38, 0.4);
    box-shadow: 0 12px 22px rgba(15, 23, 42, 0.12);
}

.rant-card.is-clickable:hover::before {
    opacity: 0.74;
}

.rant-card.is-clickable:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.rant-card.is-owner-rant {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 22%, var(--border));
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.1);
}

.rant-card.is-owner-rant::before {
    width: 3px;
    opacity: 0.58;
    background: linear-gradient(180deg, rgba(201, 106, 38, 0.78) 0%, rgba(201, 106, 38, 0.2) 100%);
}

.rant-card header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.7rem;
}

.rant-title {
    display: flex;
    align-items: center;
    gap: 0.52rem;
    cursor: pointer;
}

.rant-title h3 {
    margin: 0;
    font-size: clamp(1.09rem, 1.03rem + 0.22vw, 1.28rem);
    cursor: pointer;
}

.rant-link {
    border: none;
    background: none;
    padding: 0;
    margin: 0;
    font: inherit;
    font-size: clamp(1.09rem, 1.03rem + 0.22vw, 1.28rem);
    line-height: 1.28;
    font-weight: 700;
    color: var(--ink);
    cursor: pointer;
    text-align: left;
    text-decoration: none;
    transition: color 0.2s ease;
}

.rant-link:hover {
    color: var(--accent-deep);
    text-decoration: none;
}

.author-link {
    border: none;
    background: none;
    padding: 0;
    margin: 0;
    font: inherit;
    color: var(--accent);
    font-weight: 700;
    cursor: pointer;
}

.author-link:hover {
    color: var(--accent-deep);
    text-decoration: underline;
}

.author-name {
    font-weight: 700;
    color: var(--muted);
}

.rage-emoji {
    font-size: 1.4rem;
}

.rant-meta {
    margin: 0;
    color: var(--muted);
    font-size: 0.84rem;
    line-height: 1.34;
    margin-top: -0.04rem;
}

.rant-meta-topic {
    display: inline-flex;
    align-items: center;
    max-width: 13rem;
    padding: 0.1rem 0.44rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface-soft);
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 1.1;
    text-decoration: none;
    vertical-align: middle;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

a.rant-meta-topic:hover {
    border-color: color-mix(in srgb, var(--fire-grad-mid) 42%, var(--border));
    color: var(--ink);
    background: color-mix(in srgb, var(--fire-grad-mid) 10%, var(--surface-soft));
}

a.rant-meta-topic:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: 2px;
}

.author-identity-badges {
    display: inline-flex;
    align-items: center;
    gap: 0.24rem;
    margin-left: 0.3rem;
    vertical-align: middle;
}

.identity-badge-chip {
    display: inline-flex;
    align-items: center;
    gap: 0;
    max-width: 100%;
}

.identity-emblem {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface-soft);
    color: var(--muted);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
    overflow: hidden;
}

.identity-emblem.has-image {
    border-color: rgba(255, 255, 255, 0.3);
    background: color-mix(in srgb, var(--surface-soft) 70%, var(--card));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.identity-emblem .badge-image {
    width: 100%;
    height: 100%;
    display: block;
    border-radius: 999px;
    object-fit: contain;
}

.identity-emblem .ui-icon {
    width: 0.62rem;
    height: 0.62rem;
    stroke-width: 2.15;
}

.identity-emblem--founding {
    border-color: rgba(59, 130, 246, 0.42);
    color: #1d4e89;
    background: color-mix(in srgb, #8fb8e8 16%, var(--surface-soft));
}

.identity-emblem--firestarter {
    border-color: rgba(201, 106, 38, 0.44);
    color: var(--accent-deep);
    background: color-mix(in srgb, var(--fire-grad-mid) 14%, var(--surface-soft));
}

.identity-emblem--custom {
    border-color: rgba(124, 142, 168, 0.45);
    color: var(--ink);
    background: color-mix(in srgb, var(--surface-soft) 85%, var(--card));
}

.identity-badge-mobile-label {
    display: none;
}

@media (hover: none), (pointer: coarse), (max-width: 760px) {
    .author-identity-badges {
        gap: 0.18rem;
        flex-wrap: nowrap;
    }

    .identity-badge-chip {
        position: relative;
        border: none;
        border-radius: 0;
        background: transparent;
        padding: 0;
        max-width: none;
    }

    .identity-emblem {
        width: 0.94rem;
        height: 0.94rem;
    }

    .identity-emblem .ui-icon {
        width: 0.5rem;
        height: 0.5rem;
    }

    .identity-badge-chip::before,
    .identity-badge-chip::after {
        pointer-events: none;
        opacity: 0;
        transform: translate(-50%, 0.14rem);
        transition: opacity 0.16s ease, transform 0.16s ease;
        z-index: 8;
    }

    .identity-badge-chip::after {
        content: attr(data-badge-label);
        position: absolute;
        left: 50%;
        bottom: calc(100% + 0.24rem);
        border-radius: 7px;
        border: 1px solid rgba(146, 168, 196, 0.36);
        background: rgba(10, 18, 31, 0.95);
        color: #f4f8ff;
        font-size: 0.56rem;
        font-weight: 700;
        line-height: 1.15;
        white-space: nowrap;
        padding: 0.14rem 0.34rem;
        box-shadow: 0 8px 18px rgba(5, 10, 18, 0.34);
    }

    .identity-badge-chip::before {
        content: "";
        position: absolute;
        left: 50%;
        bottom: calc(100% + 0.08rem);
        width: 0.34rem;
        height: 0.34rem;
        background: rgba(10, 18, 31, 0.95);
        border-right: 1px solid rgba(146, 168, 196, 0.36);
        border-bottom: 1px solid rgba(146, 168, 196, 0.36);
        transform: translate(-50%, 0.14rem) rotate(45deg);
    }

    .identity-badge-chip:active::after,
    .identity-badge-chip:focus::after,
    .identity-badge-chip:focus-visible::after {
        opacity: 1;
        transform: translate(-50%, 0);
    }

    .identity-badge-chip:active::before,
    .identity-badge-chip:focus::before,
    .identity-badge-chip:focus-visible::before {
        opacity: 1;
        transform: translate(-50%, 0) rotate(45deg);
    }

    .identity-badge-chip:focus-visible .identity-emblem {
        outline: 2px solid var(--focus-ring);
        outline-offset: 1px;
    }
}

.rant-body {
    margin: 0;
    color: var(--ink);
    line-height: 1.47;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.rant-spark-prompt {
    margin: 0.28rem 0 0;
    display: inline-flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0.35rem;
    border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border));
    border-radius: 10px;
    padding: 0.3rem 0.5rem;
    background: color-mix(in srgb, var(--fire-grad-mid) 8%, var(--surface-soft));
    color: var(--muted);
    font-size: 0.78rem;
}

.rant-spark-prompt-label {
    color: var(--accent-deep);
    font-weight: 800;
}

.rant-spark-prompt-text {
    color: var(--ink);
}

.fire-meter {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    gap: 0.45rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    flex: 1 1 auto;
    min-width: 0;
    width: 100%;
    position: relative;
    --meter-height: 20px;
    --heat: 18%;
    --heat-peak: var(--heat);
    --heat-intensity: 0.1;
    --heat-glow: calc(0.15 + var(--heat-intensity) * 0.75);
}

.fire-meter::before {
    content: none;
}

.fire-meter.is-flaring::before {
    animation: none;
}

.meter-row {
    display: flex;
    align-items: center;
    gap: 0;
    width: 100%;
}

.meter {
    height: var(--meter-height);
    background: var(--surface-soft);
    border: 1px solid rgba(148, 163, 184, 0.5);
    border-radius: 999px;
    overflow: hidden;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.12),
        0 0 calc(6px + var(--heat-intensity) * 14px) rgba(201, 106, 38, calc(0.08 + var(--heat-intensity) * 0.28));
    width: 100%;
    position: relative;
    flex: 1 1 auto;
    min-width: 0;
}

.meter-ticks {
    position: absolute;
    inset: 4px 10px;
    border-radius: 999px;
    pointer-events: none;
    z-index: 0;
    background-image:
        repeating-linear-gradient(
            90deg,
            rgba(131, 142, 160, 0.35) 0 1px,
            rgba(0, 0, 0, 0) 1px 6px
        ),
        repeating-linear-gradient(
            90deg,
            rgba(131, 142, 160, 0.55) 0 1px,
            rgba(0, 0, 0, 0) 1px 30px
        );
    background-size: 100% 40%, 100% 70%;
    background-position: bottom left, bottom left;
    background-repeat: repeat;
    opacity: 0.55;
    clip-path: inset(0 0 0 var(--heat, 0%));
}

.meter-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--fire-grad-start) 0%, #e89a4d 36%, var(--fire-grad-mid) 66%, var(--fire-grad-end) 100%);
    width: var(--heat, 20%);
    border-radius: 999px 4px 4px 999px;
    box-shadow: 0 0 calc(8px + var(--heat-intensity) * 14px) rgba(201, 106, 38, calc(0.24 + var(--heat-intensity) * 0.35));
    position: relative;
    z-index: 1;
    transition: width 0.45s ease;
    filter: saturate(calc(1.02 + var(--heat-intensity) * 0.32));
}

.meter-fill::after {
    content: none;
}

.meter-peak-marker {
    position: absolute;
    top: 1px;
    bottom: 1px;
    left: min(var(--heat-peak, var(--heat, 0%)), calc(100% - 5px));
    width: 5px;
    transform: none;
    border-radius: 2px;
    border: 1px solid color-mix(in srgb, #fff 74%, var(--fire-grad-mid) 26%);
    background: linear-gradient(180deg, #fff7dc 0%, #ffd487 50%, #f49a2e 100%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--surface) 56%, transparent),
        0 0 10px rgba(244, 154, 46, 0.62);
    opacity: 0.98;
    pointer-events: none;
    z-index: 3;
}

.meter-peak-marker::after {
    content: "";
    position: absolute;
    top: -1px;
    right: -1px;
    bottom: -1px;
    width: 1px;
    background: rgba(15, 23, 42, 0.58);
    border-radius: 1px;
}

body.density-compact .meter-peak-marker {
    left: min(var(--heat-peak, var(--heat, 0%)), calc(100% - 4px));
    width: 4px;
}

body[data-theme="dark"] .meter-peak-marker {
    border-color: rgba(255, 241, 208, 0.96);
    background: linear-gradient(180deg, #fff4ce 0%, #ffcd72 50%, #ed861d 100%);
    box-shadow:
        0 0 0 1px rgba(8, 15, 24, 0.78),
        0 0 11px rgba(255, 166, 66, 0.72);
}

body[data-theme="dark"] .meter-peak-marker::after {
    background: rgba(8, 15, 24, 0.78);
}

.fire-meter[data-level="3"] .meter-fill,
.fire-meter[data-level="4"] .meter-fill,
.fire-meter[data-level="5"] .meter-fill {
    animation: heatPulse 2.6s ease-in-out infinite;
}

.fuel-row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.72rem;
    margin-top: 0.38rem;
}

.heat-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.79rem;
    gap: 0.6rem;
    text-align: right;
    width: 100%;
}

.heat-flame {
    position: relative;
    width: 24px;
    height: 24px;
    background: url("assets/fire_small.png") center / contain no-repeat;
    filter: drop-shadow(0 2px 6px rgba(255, 120, 0, 0.5));
    animation: flameFlicker 1.9s ease-in-out infinite;
}

.heat-flame::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 24px;
    height: 24px;
    background: url("assets/fire_small.png") center / contain no-repeat;
    opacity: 0;
    transform: translateX(-50%) scale(1, 1);
    transform-origin: 50% 100%;
    filter: drop-shadow(0 4px 10px rgba(255, 120, 0, 0.7));
    pointer-events: none;
}

.fire-meter.is-flaring .heat-flame::after {
    animation: flameBurst 0.75s ease-out;
}

.fuel-form {
    display: flex;
    align-items: center;
}

.fuel-actions {
    display: flex;
    align-items: center;
    gap: 0.42rem;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.fuel-hint {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.85rem;
    color: var(--muted);
    font-weight: 600;
}

.fuel-hint-icon {
    font-size: 1rem;
}

.modal-fuel-hint {
    flex-basis: 100%;
    margin-left: 0;
    font-size: 0.8rem;
}

.fuel-btn {
    -webkit-appearance: none;
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.26) 0%, rgba(255, 255, 255, 0) 42%),
        linear-gradient(125deg, var(--fire-grad-start) 0%, var(--fire-grad-mid) 58%, var(--fire-grad-end) 100%);
    border-radius: 999px;
    padding: 0.48rem 0.98rem;
    font-weight: 800;
    font-size: 0.8rem;
    color: #2f1909;
    cursor: pointer;
    border: 1px solid color-mix(in srgb, var(--fire-grad-mid) 34%, #ffffff 66%);
    box-shadow: 0 6px 14px rgba(201, 106, 38, 0.28), inset 0 0 0 1px rgba(255, 255, 255, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
    min-width: 132px;
    white-space: nowrap;
    position: relative;
    overflow: visible;
    background-clip: padding-box;
}

.fuel-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 16px rgba(201, 106, 38, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.44);
    filter: saturate(1.05);
}

.fuel-btn.is-fuel-boost {
    animation: fuelButtonBoost 0.4s ease-out;
}

.fuel-btn.is-cooling {
    filter: saturate(0.85);
    box-shadow: 0 4px 10px rgba(201, 106, 38, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.fuel-btn.is-fueled-state {
    filter: saturate(1.08);
    box-shadow: 0 10px 20px rgba(201, 106, 38, 0.42), 0 0 0 5px rgba(255, 157, 77, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.44);
}

.fuel-delta-pop {
    position: absolute;
    right: 0.3rem;
    top: -0.62rem;
    border-radius: 999px;
    padding: 0.1rem 0.38rem;
    font-size: 0.64rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    background: rgba(15, 23, 42, 0.86);
    color: #ffd7a1;
    border: 1px solid rgba(245, 162, 83, 0.5);
    pointer-events: none;
    animation: fuelDeltaRise 0.9s ease-out forwards;
    z-index: 2;
}

.fuel-delta-pop.is-negative {
    color: #9fd1ff;
    border-color: rgba(116, 189, 255, 0.48);
}

.fuel-icon {
    width: 1.1rem;
    height: 1.1rem;
    display: block;
    object-fit: contain;
}

.fuel-text {
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #5a2b0f;
}

.fuel-note {
    flex: 1 1 100%;
    text-align: right;
    font-size: 0.72rem;
    color: var(--muted);
    min-height: 1rem;
    opacity: 0.9;
}

.fuel-note.is-error {
    color: #c2410c;
}

.feed-action-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    -webkit-appearance: none;
    appearance: none;
    border: 1px solid var(--border);
    background: var(--card);
    border-radius: 999px;
    padding: 0.28rem 0.58rem;
    font-weight: 700;
    font-size: 0.74rem;
    color: var(--muted);
    line-height: 1;
    min-height: 1.92rem;
    height: 1.92rem;
    box-sizing: border-box;
    border-color: color-mix(in srgb, var(--border) 78%, #6f809a);
}

.comment-count {
    cursor: pointer;
    text-decoration: none;
    transition: border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.rant-share-btn {
    flex: 0 0 auto;
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.comment-count,
.rant-share-btn {
    background: color-mix(in srgb, var(--card) 84%, var(--surface-soft));
    color: color-mix(in srgb, var(--muted) 90%, var(--ink));
}

.comment-icon {
    width: 1.1rem;
    height: 1.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    line-height: 1;
}

.comment-number {
    font-variant-numeric: tabular-nums;
}

.comment-count:hover {
    border-color: rgba(201, 106, 38, 0.45);
    color: var(--accent-deep);
    text-decoration: none;
    box-shadow: 0 6px 12px rgba(201, 106, 38, 0.14);
}

.rant-share-btn:hover {
    border-color: rgba(201, 106, 38, 0.45);
    color: var(--accent-deep);
    box-shadow: 0 5px 12px rgba(201, 106, 38, 0.12);
}

.rant-share-btn:focus-visible {
    outline: none;
    border-color: rgba(201, 106, 38, 0.55);
    box-shadow: 0 0 0 2px rgba(201, 106, 38, 0.2);
}

.rant-share-icon {
    width: 1.1rem;
    height: 1.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.rant-share-icon .ui-icon {
    stroke-width: 2.35;
    opacity: 0.98;
}

.rant-share-text {
    letter-spacing: 0.03em;
}

