/* Kontakte / CRM (Mockup 04) — viewspezifische Klassen 1:1 aus dem Mockup.
   Basis-Tokens/Komponenten aus design-system.css; --wa-Token hier ergänzt. */
:root{--wa:#4f9d7a}
:root[data-theme="light"]{--wa:#3f8a68}

/* Kontaktliste */
.ct{display:flex;align-items:flex-start;gap:12px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--r,14px);padding:13px;margin-bottom:9px;color:inherit;transition:.15s}
.ct:hover{border-color:var(--border-2)}
.ct.sel{border-color:color-mix(in srgb,var(--gold) 60%,transparent);box-shadow:var(--shadow);background:linear-gradient(180deg,var(--surface),var(--grad-card))}
.av{width:40px;height:40px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:13.5px;background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff)}
.av.dl{background:linear-gradient(180deg,#6e93b5,#3d5d80)}
.av.bw{background:linear-gradient(180deg,#7fa07a,#4d6b48)}
.av.eg{background:linear-gradient(180deg,#c0855a,#7a4f2e)}
.ct .cb{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:3px}
.ct .ctop{display:flex;align-items:center;gap:8px}
.ct .nm{font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0}
.ct .sub{font-size:12px;color:var(--mist);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ct .sub2{font-size:11px;color:var(--mist-dim);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ct .sub2 svg{width:11px;height:11px;flex:0 0 auto}
.rb{font-size:9.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:3px 8px;border-radius:999px;flex:0 0 auto}
.rb.mieter{color:var(--gold-soft);background:color-mix(in srgb,var(--gold) 13%,transparent)}
.rb.bewerber{color:var(--ok);background:color-mix(in srgb,var(--ok) 14%,transparent)}
.rb.dienstleister{color:#9cc0e0;background:color-mix(in srgb,var(--info) 14%,transparent)}
.rb.eigentuemer{color:var(--warn);background:color-mix(in srgb,var(--warn) 14%,transparent)}
.listbar{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);flex:0 0 auto}
.listbar .ln{font-size:11.5px;color:var(--mist-dim);flex:1 1 auto;min-width:0;line-height:1.35}

/* Kontakt-Hero */
.chero{flex:0 0 auto;padding:24px 28px 0;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--grad-card),transparent)}
.chero .top{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.chero .lav{width:64px;height:64px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:23px;background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff)}
.chero .lav.dl{background:linear-gradient(180deg,#6e93b5,#3d5d80)}.chero .lav.bw{background:linear-gradient(180deg,#7fa07a,#4d6b48)}.chero .lav.eg{background:linear-gradient(180deg,#c0855a,#7a4f2e)}
.chero h1{font-family:var(--font-display);font-weight:600;font-size:25px;margin:0;line-height:1.1}
.chero .roles{display:flex;gap:7px;margin-top:6px;flex-wrap:wrap}
.chero .cd{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap;color:var(--mist);font-size:12.5px}
.chero .cd span{color:var(--mist);display:inline-flex;align-items:center;gap:7px}
.chero .cd svg{width:14px;height:14px;color:var(--gold-soft)}
.chero .acts{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.chero .tabbar{padding:16px 0 0;background:transparent;border:0;position:static}

/* KI-Karte */
.ai-card{border:1px solid color-mix(in srgb,var(--gold) 30%,transparent);background:color-mix(in srgb,var(--gold) 7%,transparent);border-radius:var(--r,14px);padding:16px 18px}
.ai-card .h{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-bottom:9px}
.ai-card p{margin:0;font-size:13px;color:var(--mist);line-height:1.6}.ai-card b{color:var(--champagne)}

/* Kommunikations-Timeline */
.kanchips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.kanchip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:999px;border:1px solid var(--border-2);background:var(--surface);color:var(--mist)}
.kanchip svg{width:13px;height:13px}
.cm{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.cm:last-child{border-bottom:0}
.chav{width:34px;height:34px;border-radius:10px;flex:0 0 auto;display:grid;place-items:center;color:#fff}
.chav svg{width:16px;height:16px}
.chav.whatsapp{background:var(--wa)}.chav.mail{background:linear-gradient(180deg,var(--gold-soft),var(--bronze))}.chav.phonio{background:linear-gradient(180deg,#6e93b5,#3d5d80)}.chav.in_app,.chav.notiz{background:linear-gradient(180deg,#9c7a33,#6b5320)}
.cm .cbody{flex:1 1 auto;min-width:0}
.cm .chd{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:5px;font-size:11.5px;color:var(--mist-dim)}
.cm .chd .who{color:var(--text);font-weight:600;font-size:13px}
.cm .dir{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 7px;border-radius:999px}
.dir.in{color:var(--info);background:color-mix(in srgb,var(--info) 14%,transparent)}
.dir.out{color:var(--gold-soft);background:color-mix(in srgb,var(--gold) 13%,transparent)}
.dir.intern{color:var(--mist);background:var(--surface-2)}
.cm .vlink{margin-left:auto;font-size:10.5px;color:var(--gold-soft);border:1px solid color-mix(in srgb,var(--gold) 30%,transparent);border-radius:999px;padding:3px 9px;background:transparent}
.cm .vlink:hover{background:color-mix(in srgb,var(--gold) 10%,transparent)}
.cm .ctext{font-size:13px;color:var(--mist);line-height:1.55;white-space:pre-wrap}

/* Qualifizierung */
.score{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.ring{--p:0;width:96px;height:96px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;background:conic-gradient(var(--gold-soft) calc(var(--p)*1%),var(--surface-2) 0)}
.ring .in{width:74px;height:74px;border-radius:50%;background:var(--bg);display:grid;place-items:center;text-align:center}
.ring .in b{font-family:var(--font-display);font-size:24px;color:var(--gold-soft);line-height:1}
.ring .in span{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--mist-dim)}
.bars{flex:1 1 240px;min-width:220px;display:grid;gap:10px}
.bar .bl{display:flex;justify-content:space-between;font-size:12px;color:var(--mist);margin-bottom:4px}.bar .bl b{color:var(--champagne)}
.bar .bt{height:7px;border-radius:999px;background:var(--bg);border:1px solid var(--border-2);overflow:hidden}
.bar .bt span{display:block;height:100%;background:linear-gradient(90deg,var(--bronze),var(--gold-soft))}
.chk{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--border)}
.chk:last-child{border-bottom:0}
.chk .ci{width:22px;height:22px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-size:12px;font-weight:700}
.ci.ok{background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff)}
.ci.miss{background:transparent;border:2px dashed color-mix(in srgb,var(--warn) 50%,transparent);color:var(--warn)}
.chk .cn{flex:1 1 auto;font-size:13px;color:var(--text);font-weight:600}
.chk .cs{font-size:11px;color:var(--mist-dim)}
.gate{display:flex;gap:12px;align-items:center;border:1px solid color-mix(in srgb,var(--warn) 35%,transparent);background:color-mix(in srgb,var(--warn) 8%,transparent);border-radius:12px;padding:14px 16px;margin-top:16px}
.gate .t{font-size:12.5px;color:var(--mist);flex:1 1 auto}.gate .t b{color:var(--champagne)}
.filerow{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.filerow:last-child{border-bottom:0}
.filerow svg{width:15px;height:15px;color:var(--gold-soft);flex:0 0 auto}
.filerow .fn{flex:1 1 auto;font-size:13px;color:var(--text);font-weight:600}
.filerow .fm{font-size:11px;color:var(--mist-dim)}

/* Compose-Modal + Vorlagen (kompakte Modal-Variante) */
.modal.modal-sm{width:min(620px,100%)}
.cmp{padding:18px 20px;display:grid;gap:15px}
.cmp code,.cmp-hint code{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--champagne);background:var(--bg);border:1px solid var(--border-2);border-radius:5px;padding:1px 5px}
.cmp-field>label{display:block;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-bottom:7px}
.recips{display:flex;flex-wrap:wrap;gap:6px}
.recip{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text)}
.recip .mini-av{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:8px;font-weight:700;background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff)}
.recip.bulk{color:var(--champagne);font-weight:600}
.seg{display:inline-flex;border:1px solid var(--border-2);border-radius:10px;overflow:hidden}
.seg button{padding:8px 14px;font-size:12.5px;font-weight:600;background:var(--surface);color:var(--mist);border:0;border-right:1px solid var(--border-2)}
.seg button:last-child{border-right:0}
.seg button.on{background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff)}
.cmp select,.cmp textarea{width:100%;background:var(--bg);border:1px solid var(--border-2);border-radius:10px;color:var(--text);font-family:var(--font-ui);font-size:13.5px;padding:11px 13px}
.cmp textarea{resize:vertical;min-height:130px;line-height:1.55;white-space:pre-wrap}
.cmp select:focus,.cmp textarea:focus{outline:none;border-color:var(--gold)}
.cmp-hint{display:flex;gap:9px;align-items:flex-start;font-size:12px;color:var(--mist);border-left:2px solid var(--gold);padding-left:11px;line-height:1.5}
.cmp-foot{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}
.cmp-foot .sp{flex:1 1 auto}
.tpllist{padding:14px 20px;display:grid;gap:10px;max-height:60vh;overflow-y:auto}
.tpl{border:1px solid var(--border);border-radius:12px;padding:13px 15px;background:var(--surface)}
.tpl .tt{display:flex;align-items:center;gap:9px}
.tpl .tn{font-weight:600;font-size:13.5px;color:var(--text);flex:1 1 auto}
.tpl .tch{font-size:9.5px;font-weight:700;text-transform:uppercase;padding:2px 7px;border-radius:999px;color:var(--gold-soft);background:color-mix(in srgb,var(--gold) 12%,transparent)}
.tpl .tedit{font-size:11.5px;color:var(--gold-soft);background:transparent;border:1px solid var(--border-2);border-radius:8px;padding:4px 9px}
.tpl .tedit:hover{border-color:var(--gold)}
.tpl .tp{font-size:12px;color:var(--mist-dim);margin-top:7px;line-height:1.5;white-space:pre-wrap;max-height:40px;overflow:hidden}
.tpl-new{border:1px dashed var(--border-2);border-radius:12px;padding:12px;text-align:center;color:var(--gold-soft);font-weight:600;font-size:13px;background:transparent}
.tpl-new:hover{border-color:var(--gold)}
