/* ============================================================
   _kit/pflicht.css — PFLICHT-Bausteine für JEDE NovaData-LP
   Token-getrieben & palette-neutral. Lädt NACH der LP-eigenen
   styles.css. Jede LP MUSS die in TOKENS.md gelisteten CSS-Vars
   definieren — dann nehmen diese Module automatisch die Farbwelt
   der LP an. Layout/Optik darf pro LP weiter überschrieben werden.
   Enthält: Voice-Test (.vtest) · Match-Call (.matchcall) ·
            NovaData-Verweis (.ndbrand) · Header-Link (.nav-nd)
   ============================================================ */

/* ---------- Voice-Agent Rückruf-Test (Mini-Orb) ---------- */
.vtest{position:relative;overflow:hidden;background:var(--bg-ice,#eef2f5)}
.vtest::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(50% 80% at 50% 0%,var(--accent-glow,rgba(46,123,140,.12)),transparent 60%)}
.vtest-card{position:relative;z-index:1;max-width:580px;margin:0 auto;background:var(--surface,#fff);border:1px solid var(--line,rgba(0,0,0,.08));
  border-radius:var(--radius-lg,24px);box-shadow:var(--shadow-lg,0 24px 60px -28px rgba(0,0,0,.3));padding:clamp(30px,4vw,48px);text-align:center}
.vtest-orb{width:88px;height:88px;border-radius:50%;margin:0 auto 1.4rem;position:relative;
  background:radial-gradient(ellipse at 32% 28%,var(--accent-lite,#6aa3ad) 0%,var(--accent,#2E7B8C) 42%,var(--accent-deep,#184c5a) 100%);
  box-shadow:0 0 34px var(--accent-glow,rgba(46,123,140,.4)),inset 0 1px 4px rgba(255,255,255,.2);animation:nd-orb 4s var(--ease,cubic-bezier(.16,1,.3,1)) infinite}
@keyframes nd-orb{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.vtest-orb svg{position:absolute;inset:0;margin:auto;width:34px;height:34px;stroke:rgba(255,255,255,.92);stroke-width:1.6;fill:none}
.vtest-orb i{position:absolute;inset:-6px;border-radius:50%;border:1px solid var(--accent,rgba(46,123,140,.4));opacity:.5;animation:nd-pw 2.6s ease-out infinite}
.vtest-orb i:nth-child(2){animation-delay:1.3s}
@keyframes nd-pw{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.9);opacity:0}}
.vtest h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:.6rem;color:var(--ink,#131F26)}
.vtest p.sub{color:var(--ink-soft,#475569);margin-bottom:1.6rem;max-width:42ch;margin-inline:auto}
.vtest-form{display:flex;flex-direction:column;gap:.8rem;text-align:left}
.vtest-row{display:flex;gap:.8rem}
.vtest-input{flex:1;height:54px;border:1px solid var(--line,rgba(0,0,0,.12));border-radius:12px;padding:0 1.1rem;font:inherit;color:var(--ink,#131F26);background:var(--surface,#fff);transition:border-color .2s,box-shadow .2s;min-width:0}
.vtest-input:focus{outline:none;border-color:var(--accent,#2E7B8C);box-shadow:0 0 0 3px var(--accent-soft,rgba(46,123,140,.25))}
.vtest-btn{height:54px;border:none;border-radius:12px;background:var(--accent,#2E7B8C);color:var(--on-accent,#fff);font-family:var(--font-body,sans-serif);font-weight:600;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5em;transition:background .25s,transform .25s var(--ease,ease)}
.vtest-btn:hover{background:var(--accent-deep,#25687A);transform:translateY(-2px)}
.vtest-btn svg{width:1.1em;height:1.1em}
.vtest-note{font-size:.8rem;color:var(--ink-faint,#9CA1A6);margin-top:.9rem}
.vtest-success{display:none;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0}
.vtest-success svg{width:48px;height:48px;color:var(--accent,#2E7B8C)}
.vtest-success b{font-family:var(--font-display,serif);font-size:1.3rem;color:var(--ink,#131F26)}
.vtest.done .vtest-form,.vtest.done .vtest-note{display:none}
.vtest.done .vtest-success{display:flex}
.vtest.done .vtest-orb{animation:nd-orb 1.2s var(--ease,ease) infinite}

/* ---------- Match-Call (Cal.com + echte Tim-Fotos) ---------- */
.matchcall{background:var(--mc-bg,linear-gradient(180deg,var(--bg,#fff) 0%,var(--bg-ice,#eef2f5) 100%))}
.mc-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:clamp(32px,5vw,72px);align-items:center}
.mc-eyebrow{color:var(--accent,#2E7B8C);font-family:var(--font-body,sans-serif);font-size:.8rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1rem}
.mc-grid h2{font-size:clamp(2rem,4vw,3.1rem);margin-bottom:1rem;max-width:18ch;color:var(--ink,#131F26)}
.mc-grid p{color:var(--ink-soft,#475569);font-size:1.1rem;margin-bottom:1.8rem;max-width:46ch}
.mc-cluster{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:16px}
.mc-shot{border-radius:22px;overflow:hidden;box-shadow:0 24px 60px -28px rgba(19,31,38,.4)}
.mc-shot img{width:100%;height:100%;object-fit:cover;display:block}
.mc-shot.tall{grid-row:1/3;aspect-ratio:4/5}
.mc-shot.wide{aspect-ratio:4/3}
.cal-band{margin-top:clamp(40px,6vw,80px);text-align:center}
.cal-band .mc-eyebrow{text-align:center}
.cal-band h3{font-size:clamp(1.7rem,3vw,2.5rem);margin-bottom:clamp(20px,3vw,32px);color:var(--ink,#131F26)}
.cal-shell{background:var(--surface,#fff);border-radius:24px;padding:clamp(10px,2vw,18px);box-shadow:var(--shadow-lg,0 24px 60px -28px rgba(0,0,0,.3));border:1px solid var(--line,rgba(0,0,0,.08))}
.cal-inline{width:100%;min-height:600px;overflow:auto;border-radius:16px}

/* ---------- NovaData-Verweis-Band (Pflicht-CTA → novadata.solutions) ---------- */
.ndbrand{background:var(--nd-bg,linear-gradient(160deg,var(--dark,#131F26),var(--dark-2,#1A2E38)));color:var(--on-dark,#EEF3F4);text-align:center;position:relative;overflow:hidden}
.ndbrand::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 100% at 50% 0%,var(--accent-glow,rgba(46,123,140,.28)),transparent 60%)}
.ndbrand>.wrap{position:relative;z-index:1;max-width:760px}
.ndbrand-logo{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display,serif);font-weight:600;font-size:1.5rem;color:#fff;margin-bottom:1.2rem;letter-spacing:-.01em}
.ndbrand-logo .dot{width:11px;height:11px;border-radius:50%;background:var(--accent,#2E7B8C);box-shadow:0 0 0 4px var(--accent-soft,rgba(46,123,140,.25)),0 0 14px var(--accent,rgba(46,123,140,.8))}
.ndbrand h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.8rem);margin-bottom:1rem;max-width:20ch;margin-inline:auto}
.ndbrand p{color:var(--on-dark-soft,#9FB4BB);font-size:1.12rem;max-width:48ch;margin:0 auto 2rem}
.ndbrand .actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.ndbrand .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.ndbrand .btn-ghost:hover{background:#fff;color:var(--dark,#131F26)}

/* ---------- Header-Link „NovaData Solutions ↗" ---------- */
.nav-nd{display:inline-flex;align-items:center;gap:.3em;font-size:.96rem;font-weight:600;color:var(--accent,#2E7B8C)!important}
.nav-nd svg{width:.95em;height:.95em}

/* ---------- Responsive ---------- */
@media(max-width:860px){ .mc-grid{grid-template-columns:1fr;gap:2.4rem} }
@media(max-width:760px){ .vtest-row{flex-direction:column} }
@media(max-width:540px){
  .mc-cluster{grid-template-columns:1fr}
  .mc-shot.tall{grid-row:auto;aspect-ratio:16/10}
}
@media(prefers-reduced-motion:reduce){
  .vtest-orb,.vtest-orb i{animation:none!important}
}
