/* =============================================================
   COMPOSER LANDING — ported from Claude Design (Composer.jsx +
   composer-styles.css). Source:
   docs/design/claude-design-export/project/ui_kits/webapp/
   Note: The design uses kind names lied/cycle/anthem; production
   uses content_type values opera/lieder/art_song/oratorio/cantata/
   choral/mass. The grid templates below map to production names.
   ============================================================= */

.lc-comp {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 96px;
}

/* --- Header --- */
.lc-comp-header {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 36px;
    align-items: end;
    padding: 0 0 28px;
    border-bottom: 1px solid var(--border-subtle);
    margin-bottom: 36px;
}
.lc-comp-portrait {
    position: relative;
    width: 200px;
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-sm);
}
.lc-comp-portrait svg { display: block; width: 100%; height: 100%; }
.lc-comp-portrait-initials {
    position: absolute;
    top: 10px;
    right: 12px;
    font: 600 10px var(--font-interface);
    letter-spacing: .14em;
    color: var(--bg-primary);
    opacity: .72;
    text-transform: uppercase;
    background: rgba(25, 25, 24, .22);
    padding: 3px 7px;
    border-radius: 3px;
    backdrop-filter: blur(2px);
}
.lc-comp-header-text { min-width: 0; }
.lc-comp-kicker { display: block; margin-bottom: 10px; }
.lc-comp-name {
    font-family: 'Crimson Text', Georgia, serif;
    font-weight: 700;
    font-size: clamp(36px, 4.4vw, 56px);
    line-height: 1.08;
    letter-spacing: -0.02em;
    margin: 0 0 10px;
    color: var(--text-primary);
}
.lc-comp-subline {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    color: var(--text-secondary);
    font-variant-numeric: tabular-nums;
}
.lc-comp-dot { color: var(--text-muted); }
.lc-comp-oneliner {
    font-family: 'Crimson Text', Georgia, serif;
    font-style: italic;
    font-size: 17px;
    line-height: 1.5;
    color: var(--text-secondary);
    margin: 14px 0 16px;
    max-width: 640px;
}
.lc-comp-langchip {
    display: inline-flex;
    align-items: center;
    height: 22px;
    padding: 0 8px;
    font: 600 11px ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
    letter-spacing: .08em;
    color: var(--accent-hover);
    background: var(--accent-subtle);
    border: 1px solid rgba(196, 112, 74, .25);
    border-radius: 3px;
}

/* --- Bio row --- */
.lc-comp-bio-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 288px;
    gap: 48px;
    padding-bottom: 40px;
    margin-bottom: 40px;
    border-bottom: 1px solid var(--border-subtle);
}
.lc-comp-bio { min-width: 0; }
.lc-comp-bio-missing {
    font-family: 'Crimson Text', Georgia, serif;
    font-style: italic;
    font-size: 15px;
    color: var(--text-tertiary);
    margin: 8px 0 0;
    padding: 14px 18px;
    border-left: 2px solid var(--border-default);
    background: var(--bg-tertiary);
    border-radius: 0 6px 6px 0;
    max-width: 62ch;
}

/* --- Quick facts card --- */
.lc-comp-facts {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: 20px 22px;
    align-self: start;
    position: sticky;
    top: 20px;
    box-shadow: var(--shadow-sm);
}
.lc-comp-facts .eyebrow { display: block; margin-bottom: 12px; }
.lc-comp-facts dl { margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.lc-comp-facts-row {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-subtle);
}
.lc-comp-facts-row:last-child { border-bottom: none; padding-bottom: 0; }
.lc-comp-facts-row:first-child { padding-top: 0; }
.lc-comp-facts-row dt {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--text-tertiary);
    margin: 0;
}
.lc-comp-facts-row dd {
    margin: 0;
    font-size: 13px;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.45;
}

/* --- Works by type --- */
.lc-comp-works { display: flex; flex-direction: column; gap: 40px; }
.lc-comp-group { display: flex; flex-direction: column; gap: 14px; }
.lc-comp-group-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-subtle);
}
.lc-comp-group-kicker {
    font-family: var(--font-interface);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text-primary);
}
.lc-comp-group-count { color: var(--text-tertiary); font-weight: 500; letter-spacing: .08em; margin-left: 2px; }
.lc-comp-group-all { font-size: 12px; color: var(--text-tertiary); text-decoration: none; cursor: pointer; }
.lc-comp-group-all:hover { color: var(--accent-primary); }

.lc-comp-group-list { display: grid; gap: 10px; }
.lc-comp-group-list--opera,
.lc-comp-group-list--lieder,
.lc-comp-group-list--art_song { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.lc-comp-group-list--mass,
.lc-comp-group-list--oratorio,
.lc-comp-group-list--cantata,
.lc-comp-group-list--choral { grid-template-columns: 1fr; }

.lc-comp-work {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    text-decoration: none;
    color: inherit;
    transition: border-color .12s, box-shadow .12s, transform .12s;
}
.lc-comp-work:hover { border-color: var(--border-default); box-shadow: var(--shadow-sm); }
.lc-comp-work-main { flex: 1; min-width: 0; }
.lc-comp-work-title {
    font: 600 15px var(--font-interface);
    letter-spacing: -0.01em;
    color: var(--text-primary);
    margin: 0 0 4px;
    line-height: 1.3;
}
.lc-comp-work--opera .lc-comp-work-title,
.lc-comp-work--oratorio .lc-comp-work-title { font-size: 16px; }
.lc-comp-work-meta {
    font-size: 12.5px;
    color: var(--text-tertiary);
    font-variant-numeric: tabular-nums;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}
.lc-comp-work-meta .dot { color: var(--text-muted); opacity: .7; }
.lc-comp-cycle { color: var(--accent-hover); font-weight: 500; }

/* --- Mobile stack --- */
@media (max-width: 820px) {
    .lc-comp { padding: 28px 16px 72px; }
    .lc-comp-header { grid-template-columns: 96px 1fr; gap: 16px; align-items: start; padding-bottom: 20px; margin-bottom: 24px; }
    .lc-comp-portrait { width: 96px; }
    .lc-comp-name { font-size: 28px; }
    .lc-comp-oneliner { font-size: 15px; margin: 10px 0 12px; }
    .lc-comp-bio-row { grid-template-columns: 1fr; gap: 20px; padding-bottom: 24px; margin-bottom: 24px; }
    .lc-comp-bio-para { font-size: 16px; line-height: 1.6; }
    .lc-comp-facts { position: static; order: 2; }
    .lc-comp-facts-row { grid-template-columns: 110px 1fr; }
    .lc-comp-group-list--opera,
    .lc-comp-group-list--lieder,
    .lc-comp-group-list--art_song { grid-template-columns: 1fr; }
}

/* --- Footer styling reused from landing.css landing-footer --- */
.landing-footer {
    max-width: 1180px;
    margin: 60px auto 24px;
    padding: 24px;
    border-top: 1px solid var(--border-subtle);
    text-align: center;
}
.landing-footer-links { display: flex; justify-content: center; gap: 24px; margin-bottom: 8px; }
.landing-footer-links a {
    font-size: 13px;
    color: var(--text-secondary);
    text-decoration: none;
}
.landing-footer-links a:hover { color: var(--accent-primary); }
.landing-footer-copy { font-size: 12px; color: var(--text-tertiary); margin: 0; }
