/* DCF Valuation Card — Apple-like redesign */

/* ── Card shell ── */
.dcf-card {
    background: var(--mud-palette-background-gray);
    border-radius: 20px;
    padding: 20px;
    cursor: pointer;
    transition: background 0.15s ease;
    position: relative;
}

.dcf-card:hover {
    background: color-mix(in srgb, var(--mud-palette-background-gray) 85%, var(--mud-palette-text-primary) 15%);
}

/* ── Flip animation ── */
@keyframes dcf-flip-out {
    from { transform: rotateY(0deg); opacity: 1; }
    to   { transform: rotateY(90deg); opacity: 0; }
}

@keyframes dcf-flip-in {
    from { transform: rotateY(-90deg); opacity: 0; }
    to   { transform: rotateY(0deg); opacity: 1; }
}

.dcf-flip-out {
    animation: dcf-flip-out 0.15s ease-in forwards;
}

.dcf-flip-in {
    animation: dcf-flip-in 0.15s ease-out forwards;
}

/* ── Header ── */
.dcf-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.dcf-header-actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ── Flip button ── */
.dcf-flip-btn {
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    color: var(--mud-palette-text-secondary);
    transition: background 0.12s, color 0.12s;
    padding: 0;
}

.dcf-flip-btn:hover {
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-primary);
}

.dcf-header-left {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dcf-date {
    font-size: 13px;
    color: var(--mud-palette-text-secondary);
}

.dcf-type-badge {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3px;
    padding: 2px 7px;
    border-radius: 20px;
}

.dcf-type-badge--dcf {
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
    color: var(--mud-palette-primary);
}

.dcf-type-badge--reverse {
    background: color-mix(in srgb, var(--mud-palette-info) 14%, transparent);
    color: var(--mud-palette-info);
}

/* ── ··· menu button ── */
.dcf-menu-btn {
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 3px;
    padding: 6px 4px;
    border-radius: 6px;
    transition: background 0.12s;
}

.dcf-menu-btn:hover {
    background: var(--mud-palette-action-default-hover);
}

.dcf-menu-btn span {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--mud-palette-text-secondary);
    display: block;
}

/* ── Verdict badge ── */
.dcf-verdict {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-radius: 14px;
    margin-bottom: 16px;
}

.dcf-verdict-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    flex: 0 0 auto;
}

.dcf-verdict-side {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.dcf-verdict-side--right {
    align-items: flex-end;
}

@media (max-width: 480px) {
    .dcf-verdict {
        flex-wrap: wrap;
        gap: 10px 0;
    }

    .dcf-verdict-center {
        order: 3;
        width: 100%;
        padding-top: 10px;
        border-top: 0.5px solid rgba(255, 255, 255, 0.1);
    }

    .dcf-verdict-side {
        flex: 0 0 auto;
    }
}

.dcf-verdict-side-cap {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    opacity: 0.65;
}

.dcf-verdict-side-val {
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.02em;
}


.dcf-verdict--unknown {
    background: rgba(120, 120, 128, 0.12);
}

.dcf-verdict--unknown .dcf-verdict-pct,
.dcf-verdict--unknown .dcf-verdict-label,
.dcf-verdict--unknown .dcf-verdict-cap {
    color: var(--mud-palette-text-secondary);
}

.dcf-verdict--pos {
    background: color-mix(in srgb, var(--mud-palette-success) 12%, transparent);
}

.dcf-verdict--neg {
    background: color-mix(in srgb, var(--mud-palette-error) 12%, transparent);
}

.dcf-verdict--neutral {
    background: color-mix(in srgb, var(--mud-palette-warning) 12%, transparent);
}

.dcf-verdict-pct {
    font-size: 38px;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1;
}

.dcf-verdict--pos .dcf-verdict-pct {
    color: var(--mud-palette-success);
}

.dcf-verdict--neg .dcf-verdict-pct {
    color: var(--mud-palette-error);
}

.dcf-verdict--neutral .dcf-verdict-pct {
    color: var(--mud-palette-warning);
}

.dcf-verdict-cap {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    opacity: 0.7;
}

.dcf-verdict-label {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.02em;
}

.dcf-verdict--pos .dcf-verdict-label {
    color: var(--mud-palette-success);
}

.dcf-verdict--neg .dcf-verdict-label {
    color: var(--mud-palette-error);
}

.dcf-verdict--neutral .dcf-verdict-label {
    color: var(--mud-palette-warning);
}


/* ── Hairline rule ── */
.dcf-rule {
    height: 0.5px;
    background: var(--mud-palette-divider);
    margin-bottom: 14px;
}

/* ── Metrics ── */
.dcf-metrics {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    margin-bottom: 14px;
}

.dcf-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.dcf-metric + .dcf-metric {
    padding-left: 12px;
    border-left: 0.5px solid var(--mud-palette-divider);
}

.dcf-metric-cap {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--mud-palette-text-secondary);
}

.dcf-metric-val {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--mud-palette-text-primary);
}

/* ── Back face analysis label ── */
.dcf-back-analysis-label {
    display: flex;
    align-items: center;
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 8px;
    padding: 0 16px;
}

/* ── Back face analysis text ── */
.dcf-back-analysis {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 14px;
}

.dcf-back-analysis-intro {
    font-size: 12px;
    line-height: 1.5;
    color: var(--mud-palette-text-secondary);
    margin: 0;
    padding: 0;
}

.dcf-back-analysis-verdict {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.5;
    margin: 0;
    padding: 0;
}

.dcf-back-analysis-verdict--green {
    color: var(--mud-palette-success);
}

.dcf-back-analysis-verdict--neutral {
    color: var(--mud-palette-warning);
}

.dcf-back-analysis-verdict--red {
    color: var(--mud-palette-error);
}

/* ── Back face content ── */
.dcf-back-comment,
.dcf-back-empty {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 14px;
    flex: 1;
}

.dcf-back-comment-text {
    font-size: 13px;
    font-weight: 500;
    color: var(--mud-palette-text-primary);
    line-height: 1.5;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
}

/* ── Growth rates ── */
.dcf-growth {
    display: flex;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 0.5px solid var(--mud-palette-divider);
}

.dcf-gr {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
}

.dcf-gr-yr {
    font-size: 10px;
    color: var(--mud-palette-text-secondary);
    font-weight: 500;
    letter-spacing: 0.02em;
}

.dcf-gr-val {
    font-size: 12px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
}

.dcf-gr-val--pos {
    color: var(--mud-palette-success);
}

.dcf-gr-val--neg {
    color: var(--mud-palette-error);
}
