/* ==========================================================================
   Labelflow - interactive modules (homepage islands)
   Component styles for back-catalog (live), release-health, comms,
   deliverables, memory graph, A&R. Tokens come from redesign.css.
   ========================================================================== */

.compounds{background:var(--aubergine-soft)}
.mem__frame{background:#120E1A;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:8px}
.mem__cap{font-size:12px;color:var(--cream-mute);margin-top:10px;line-height:1.5;max-width:70ch}
.mem__ctrls{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.ctrl{display:flex;gap:6px;align-items:center}
.ctrl__lbl{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray)}
.lgnd{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px}
.lgnd span{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--cream-mute)}
.lgnd i{border-radius:50%;display:inline-block}
.mem__scrub{display:flex;align-items:center;gap:10px;margin-top:12px;font-family:var(--font-mono);font-size:10px;color:var(--gray)}
.mem__scrub input{flex:1;accent-color:var(--acid)}
.mem__node-list{position:absolute;width:1px;height:1px;overflow:hidden;clip-path:inset(50%)}

/* segmented control + rows (release health) */
.seg{display:inline-flex;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden}
.seg span{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;color:var(--gray);cursor:pointer;user-select:none}
.seg span.on{background:var(--acid);color:var(--aubergine)}
.dn{display:flex;gap:18px;align-items:center;margin-top:10px}
.dn__ring{--p:53;width:108px;height:108px;border-radius:50%;background:conic-gradient(var(--acid) calc(var(--p)*1%),var(--plum) 0);display:grid;place-items:center;flex-shrink:0;transition:--p .4s ease}
.dn__ring::after{content:attr(data-v);width:78px;height:78px;border-radius:50%;background:var(--card);display:grid;place-items:center;font-family:var(--font-mark);font-weight:600;font-size:21px;color:var(--cream)}
.dn__rows{flex:1;display:flex;flex-direction:column;gap:7px}
.row{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--cream)}
.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot--a{background:var(--acid)}.dot--v{background:var(--app-violet)}.dot--p{background:var(--plum)}
.row__n{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--gray)}

/* comms email */
.pk{display:flex;flex-direction:column;gap:9px;margin-top:8px}
.pk__row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.pk__lbl{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray);width:64px;flex-shrink:0}
.pill{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;border:1px solid var(--plum);border-radius:999px;padding:5px 10px;color:var(--cream-mute);cursor:pointer}
.pill.on{border-color:var(--violet-light);color:var(--cream);background:rgba(176,127,229,.12)}
.mail{background:#0E0B14;border:1px solid var(--line);border-radius:12px;padding:16px;margin-top:14px;font-size:13px;max-width:620px}
.mail__k{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}
.mail__h{font-family:var(--font-display);font-style:italic;font-size:19px;color:var(--cream);margin:6px 0 10px}
.mail__b{color:var(--cream-mute);line-height:1.55;font-size:13px;white-space:pre-line}
.mail__b b{color:var(--cream);font-weight:600}
.mail__div{height:1px;background:var(--line);margin:11px 0}
.mail__sec{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--violet-light);margin-bottom:6px}
.mail__cta{display:inline-block;background:var(--cream);color:#0E0B14;border-radius:7px;padding:8px 14px;font-size:12px;font-weight:600;margin-top:10px}
.caret{display:inline-block;width:2px;height:14px;background:var(--violet-light);vertical-align:-2px;animation:lfbl 1s steps(1) infinite}
@keyframes lfbl{50%{opacity:0}}
.rotate{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--violet-light);margin-top:10px;display:inline-block;cursor:pointer;background:none;border:none;padding:0}

/* deliverables */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.tab{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;padding:6px 11px;border-radius:7px;color:var(--gray);border:1px solid transparent;cursor:pointer;background:none}
.tab.on{color:var(--cream);border-color:var(--line-strong);background:var(--aubergine)}
.tl{display:flex;gap:4px;margin:14px 0}
.tl span{flex:1;height:4px;border-radius:2px;background:var(--plum)}
.tl span.done{background:var(--acid)}
.tl span.now{background:var(--violet-light)}
.dlist{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.dl{background:var(--aubergine);border:1px solid var(--line);border-radius:8px;padding:9px 11px;cursor:pointer}
.dl__top{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--cream)}
.dl__crit{margin-top:8px;padding-top:8px;border-top:1px solid var(--line);font-size:12px;color:var(--cream-mute);line-height:1.5}
.dl__crit .miss{color:var(--acid)}
.st{margin-left:auto;font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--gray)}

/* release readiness (deliverables) */
.dlv__head{display:flex;gap:20px;align-items:center;margin-top:8px}
.dlv__ring{--p:90;width:104px;height:104px;border-radius:50%;flex-shrink:0;background:conic-gradient(var(--acid) calc(var(--p)*1%),var(--plum) 0);display:grid;place-items:center}
.dlv__hole{width:78px;height:78px;border-radius:50%;background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1}
.dlv__hole b{font-family:var(--font-mark);font-weight:600;font-size:25px;color:var(--cream)}
.dlv__hole b sup{font-size:12px;margin-left:1px}
.dlv__hole span{display:block;margin-top:5px;font-family:var(--font-mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray)}
.dlv__kick{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray)}
.dlv__h{font-family:var(--font-serif,var(--font-mark));font-style:italic;font-size:20px;color:var(--cream);margin:4px 0 6px}
.dlv__sub{font-size:12px;line-height:1.5;color:var(--cream-mute)}
.dlv__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.dcat{border:1px solid var(--line);border-radius:11px;padding:12px 14px;cursor:pointer;align-self:start;transition:border-color .2s,background .2s}
.dcat:hover,.dcat:focus-visible{border-color:var(--line-strong);background:var(--aubergine);outline:none}
.dcat__top{display:flex;align-items:center;gap:9px}
.dcat__lab{font-size:14px;color:var(--cream)}
.dcat__n{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--gray)}
.dcat__chev{font-family:var(--font-mono);font-size:13px;color:var(--gray);width:12px;text-align:center}
.dcat__bar{height:5px;border-radius:3px;background:var(--plum);margin-top:11px;overflow:hidden}
.dcat__bar i{display:block;height:100%;border-radius:3px;background:var(--app-violet);transition:width .5s var(--ease)}
.dcat--done .dcat__bar i{background:var(--acid)}
.dcat--none .dcat__bar i{background:var(--plum)}
.dcat__items{display:none;margin-top:4px}
.dcat.is-open .dcat__items{display:block}
.ditem{padding:9px 0 7px;border-top:1px solid var(--line)}
.ditem__top{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--cream)}
.ditem__crit{margin:5px 0 0 17px;font-size:11.5px;line-height:1.5;color:var(--cream-mute)}
.ditem__crit .miss{color:var(--acid)}
@media (max-width:640px){.dlv__grid{grid-template-columns:1fr}.dlv__head{gap:14px}.dlv__ring{width:88px;height:88px}.dlv__hole{width:66px;height:66px}.dlv__hole b{font-size:21px}}

/* back catalog live */
.bc__bar{display:flex;gap:8px;margin-top:8px;align-items:center;background:var(--aubergine);border:1px solid var(--plum);border-radius:9px;padding:4px 4px 4px 12px}
.bc__bar svg{flex-shrink:0;color:var(--gray)}
.bc__bar:focus-within{border-color:var(--violet-light)}
.bc__in{flex:1;background:none;border:none;color:var(--cream);font-family:var(--font-sans);font-size:14px;outline:none;padding:8px 0}
.bc__in::placeholder{color:var(--gray)}
.bc__out{margin-top:14px;min-height:120px}
.bc__hint{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray)}
.bc__scan{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--violet-light);display:flex;align-items:center;gap:8px;margin-bottom:12px}
.bc__spin{width:13px;height:13px;border:2px solid rgba(176,127,229,.3);border-top-color:var(--violet-light);border-radius:50%;animation:lfsp .8s linear infinite}
@keyframes lfsp{to{transform:rotate(360deg)}}
.bc__skel{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.bc__skel div{aspect-ratio:1;border-radius:6px;background:linear-gradient(90deg,rgba(255,255,255,.04),rgba(255,255,255,.10),rgba(255,255,255,.04));background-size:200% 100%;animation:lfsk 1.3s linear infinite}
@keyframes lfsk{to{background-position:-200% 0}}
.bc__found{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}
.bc__found b{color:var(--cream);font-weight:400}
.bc__count{font-family:var(--font-display);font-style:italic;font-size:30px;color:var(--acid);margin-top:4px}
.bc__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:12px}
.bc__cover{aspect-ratio:1;border-radius:6px;object-fit:cover;width:100%;border:1px solid var(--line);background:var(--plum)}
.bc__cta{margin-top:14px;display:inline-block;background:var(--violet);color:var(--cream);border:none;border-radius:8px;padding:10px 16px;font-size:13px;font-weight:500;cursor:pointer}
.bc__err{font-size:13px;color:#F0A795;background:rgba(224,80,80,.08);border:1px solid rgba(224,80,80,.3);border-radius:8px;padding:11px 13px}

/* A&R */
.ar__demos{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.ar{display:flex;gap:12px;align-items:flex-start;background:var(--aubergine);border:1px solid var(--line);border-radius:10px;padding:11px}
.ar__cover{width:54px;height:54px;border-radius:7px;object-fit:cover;flex-shrink:0;border:1px solid var(--line)}
.ar__main{flex:1;min-width:0}
.ar__name{font-family:var(--font-mark);font-weight:600;font-size:14px;letter-spacing:-.01em;color:var(--cream)}
.ar__ctx{font-size:11.5px;color:var(--gray);margin-top:1px}
.ar__clip{display:flex;align-items:center;gap:7px;margin-top:7px}
.ar__play{width:22px;height:22px;border-radius:50%;background:var(--violet);color:var(--cream);display:grid;place-items:center;font-size:9px;cursor:pointer;flex-shrink:0;border:none}
.ar__wave{display:flex;align-items:center;gap:2px;height:18px}
.ar__wave i{width:2px;background:var(--plum);border-radius:1px}
.ar__wave.on i{background:var(--violet-light)}
.ar__dur{font-family:var(--font-mono);font-size:9px;color:var(--gray)}
.ar__ai{font-size:11.5px;color:var(--violet-light);margin-top:8px;line-height:1.45}
.ar__ai b{color:var(--cream);font-weight:500}
.ar__why{position:relative;font-family:var(--font-mono);font-size:9px;letter-spacing:.04em;color:var(--gray);border-bottom:1px dotted var(--gray);cursor:help;margin-left:4px}
.ar__why:hover .ar__tip,.ar__why.show .ar__tip{opacity:1;visibility:visible}
.ar__tip{position:absolute;bottom:150%;left:0;width:230px;background:#0E0B14;border:1px solid var(--violet-light);border-radius:8px;padding:9px 11px;font-family:var(--font-sans);font-size:11px;color:var(--cream-mute);letter-spacing:0;text-transform:none;opacity:0;visibility:hidden;transition:.15s;z-index:5;line-height:1.45}
.ar__tip b{color:var(--acid)}
.ar__acts{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.ar__btn{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;border-radius:7px;padding:6px 12px;cursor:pointer;border:1px solid var(--plum);background:transparent;color:var(--cream-mute)}
.ar__btn--sign:hover,.ar__btn--sign.on{border-color:var(--acid);color:var(--acid);background:rgba(197,220,63,.1)}
.ar__btn--maybe:hover,.ar__btn--maybe.on{border-color:var(--violet-light);color:var(--violet-light)}
.ar__btn--pass:hover,.ar__btn--pass.on{border-color:var(--cream-mute);color:var(--cream)}
.ar__chip{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;border-radius:999px;padding:4px 10px;margin-top:10px;display:inline-block}
.ar__chip--signed{color:var(--acid);border:1px solid var(--acid)}
.ar__chip--passed{color:var(--gray);border:1px solid var(--plum)}
.ar__chip--maybe{color:var(--violet-light);border:1px solid var(--violet-light)}
.ar__sum{background:linear-gradient(150deg,var(--card-2),var(--card));border:1px solid rgba(176,127,229,.3);border-radius:12px;padding:20px;margin-top:14px;text-align:center}
.ar__sum h4{font-family:var(--font-display);font-style:italic;font-size:22px;margin-bottom:6px;color:var(--cream)}
.ar__sum .tally{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--cream-mute);text-transform:uppercase}
.ar__sum .cta{display:inline-block;margin-top:12px;background:var(--violet);color:var(--cream);border-radius:8px;padding:9px 16px;font-size:13px;font-weight:500;cursor:pointer}
.ar__reset{display:block;margin:10px auto 0;font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--gray);cursor:pointer;background:none;border:none}
@media(min-width:760px){.ar__demos{flex-direction:row}.ar{flex:1}}

@media (prefers-reduced-motion:reduce){.bc__spin,.bc__skel div,.caret,.ar__wave.on i{animation:none}}

/* AI-native chat demo (section 04) - Claude chat style */
.mcpc{font-family:var(--font-sans);font-size:14px;background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;max-width:600px}
.mcpc__head{display:flex;align-items:center;gap:9px;padding:12px 16px;border-bottom:1px solid var(--line)}
.mcpc__avatar{width:22px;height:22px;border-radius:6px;background:var(--acid);display:grid;place-items:center}
.mcpc__who{font-family:var(--font-mark);font-weight:600;font-size:13px;letter-spacing:-.01em;color:var(--cream)}
.mcpc__dot{margin-left:auto;width:7px;height:7px;border-radius:50%;background:var(--acid);box-shadow:0 0 0 3px rgba(197,220,63,.15)}
.mcpc__thread{padding:16px;min-height:170px;display:flex;flex-direction:column;gap:14px}
.mcpc__msg{max-width:90%;animation:mcpc-in .3s var(--ease) both}
@keyframes mcpc-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.mcpc__msg--user{align-self:flex-end;background:rgba(176,127,229,.13);border:1px solid rgba(176,127,229,.22);color:var(--cream);border-radius:14px 14px 4px 14px;padding:10px 14px;line-height:1.45;overflow-wrap:anywhere}
.mcpc__msg--claude{align-self:flex-start;display:flex;gap:10px}
.mcpc__cav{width:25px;height:25px;border-radius:7px;background:var(--acid);display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.mcpc__cbody{min-width:0}
.mcpc__rtext{color:var(--cream);line-height:1.55;overflow-wrap:anywhere}
.mcpc__chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.mcpc__chip{font-size:11.5px;color:var(--acid);border:1px solid rgba(197,220,63,.35);border-radius:999px;padding:4px 10px;background:rgba(197,220,63,.06)}
.mcpc__lines{margin-top:9px;display:flex;flex-direction:column;gap:6px}
.mcpc__line{color:var(--cream-mute);font-size:13px;display:flex;gap:8px;line-height:1.4}.mcpc__line::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--violet-light);margin-top:6px;flex-shrink:0}
.mcpc__caret{display:inline-block;width:2px;height:15px;background:var(--violet-light);vertical-align:-3px;animation:lfbl 1s steps(1) infinite}
.mcpc__replay{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--gray);cursor:pointer;background:none;border:none;border-top:1px solid var(--line);width:100%;text-align:left;padding:10px 16px}
.mcpc__replay:hover{color:var(--cream-mute)}
.mcpc__sr{position:absolute;width:1px;height:1px;overflow:hidden;clip-path:inset(50%)}
@media (prefers-reduced-motion:reduce){.mcpc__caret{animation:none}.mcpc__msg{animation:none}}

/* memory graph tooltip */
.memg__tip{position:absolute;width:220px;background:#0E0B14;border:1px solid var(--violet-light);border-radius:8px;padding:9px 11px;font-size:11px;color:var(--cream);line-height:1.45;z-index:5;pointer-events:none;font-family:var(--font-sans)}
.memg__tip-k{display:block;font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:4px}
.memg__tip-d{display:block;color:var(--acid);font-size:10px;margin-top:5px}
