/* No Show Media – Kontakt & Booking Modul (v3).
   Alle Selektoren unter .nsm-booking gescopt, um Kollisionen mit widgets.css zu vermeiden. */

.nsm-booking{
  --purple:#7F37CA;
  --purple-deep:#7F30D6;
  --purple-ink:#170526;
  --yellow:#FFDE32;
  --orange:#FFC240;
  --paper:#FBF4FF;
  --white:#ffffff;
  --ink:#140320;
  --muted:#6a5878;
  --line:#e7daf2;
  --ease:cubic-bezier(.22,1,.36,1);
  max-width:1140px;
  margin:0 auto;
  padding:48px 24px;
  font-family:'Archivo',system-ui,sans-serif;
  color:var(--ink);
}
.nsm-booking *{box-sizing:border-box;}
.nsm-booking h2,.nsm-booking h3,.nsm-booking h4{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;line-height:.95;letter-spacing:.005em;}
.nsm-booking a{color:inherit;text-decoration:none;}

.nsm-booking .module{width:100%;background:var(--white);border:2px solid var(--purple-ink);border-radius:30px;box-shadow:16px 18px 0 var(--purple-ink);overflow:hidden;display:grid;grid-template-columns:0.92fr 1.08fr;}

/* ===== LEFT RAIL ===== */
.nsm-booking .rail{background:var(--purple-ink);color:#fff;padding:46px 42px;position:relative;overflow:hidden;display:flex;flex-direction:column;}
.nsm-booking .rail .glow{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(127,48,214,.6),transparent 70%);filter:blur(20px);left:-120px;bottom:-120px;pointer-events:none;}
.nsm-booking .rail .glow2{position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(255,194,64,.3),transparent 70%);filter:blur(24px);right:-80px;top:-60px;pointer-events:none;}
.nsm-booking .rail-inner{position:relative;z-index:2;display:flex;flex-direction:column;height:100%;}
.nsm-booking .eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow);}
.nsm-booking .eyebrow::before{content:"";width:24px;height:3px;background:var(--orange);border-radius:2px;}
.nsm-booking .rail h2{font-size:clamp(34px,4vw,52px);margin:18px 0 16px;}
.nsm-booking .rail h2 .hl{color:var(--yellow);}
.nsm-booking .rail .lead{font-size:16.5px;line-height:1.55;color:rgba(255,255,255,.82);font-weight:500;max-width:360px;}

.nsm-booking .props{margin-top:30px;display:flex;flex-direction:column;gap:16px;}
.nsm-booking .prop{display:flex;align-items:flex-start;gap:14px;}
.nsm-booking .prop .pi{width:42px;height:42px;flex:none;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:20px;}
.nsm-booking .prop b{font-size:15.5px;font-weight:800;display:block;}
.nsm-booking .prop span{font-size:13.5px;color:rgba(255,255,255,.66);font-weight:500;line-height:1.4;}

.nsm-booking .proof{margin-top:auto;padding-top:30px;}
.nsm-booking .stars{color:var(--yellow);font-size:15px;letter-spacing:2px;}
.nsm-booking .proof p{font-size:14.5px;line-height:1.5;color:rgba(255,255,255,.9);font-weight:600;margin:10px 0 14px;font-style:italic;}
.nsm-booking .proof .who{display:flex;align-items:center;gap:11px;}
.nsm-booking .proof .av{width:40px;height:40px;border-radius:50%;padding:2px;flex:none;background:conic-gradient(from 30deg,var(--yellow),var(--orange),var(--purple-deep),var(--yellow));}
.nsm-booking .proof .av div{width:100%;height:100%;border-radius:50%;background:var(--purple-ink);display:flex;align-items:center;justify-content:center;font-family:'Anton',sans-serif;font-size:14px;color:#fff;}
.nsm-booking .proof .nm{font-weight:800;font-size:13.5px;}
.nsm-booking .proof .hd{font-size:12px;color:rgba(255,255,255,.6);font-weight:600;}

/* ===== RIGHT PANEL ===== */
.nsm-booking .panel{padding:38px 40px 36px;display:flex;flex-direction:column;}

/* segmented toggle */
.nsm-booking .seg{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:6px;background:#f1e8fa;border:2px solid var(--line);border-radius:16px;padding:6px;position:relative;}
.nsm-booking .seg button{appearance:none;border:0;background:transparent;cursor:pointer;font-family:inherit;font-weight:800;font-size:14px;color:var(--muted);padding:13px 6px;border-radius:11px;display:flex;align-items:center;justify-content:center;gap:7px;transition:color .25s;position:relative;z-index:2;}
.nsm-booking .seg button .badge{font-size:10px;font-weight:800;letter-spacing:.04em;background:var(--orange);color:var(--purple-ink);padding:2px 7px;border-radius:100px;text-transform:uppercase;}
.nsm-booking .seg .thumb{position:absolute;top:6px;left:6px;height:calc(100% - 12px);background:var(--purple-ink);border-radius:11px;transition:transform .32s var(--ease),width .32s var(--ease);z-index:1;}
.nsm-booking .seg button.on{color:#fff;}
.nsm-booking .seg button.on .badge{background:var(--yellow);}
/* Thumb-Position wird per JS gesetzt (variable Tab-Anzahl) */

.nsm-booking .views{margin-top:24px;flex:1;}
.nsm-booking .view{display:none;animation:nsmfade .4s var(--ease);}
.nsm-booking .view.show{display:block;}
@keyframes nsmfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* step progress */
.nsm-booking .steps-head{display:flex;align-items:center;gap:10px;margin-bottom:22px;}
.nsm-booking .dot{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:800;color:var(--muted);}
.nsm-booking .dot .n{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:12px;transition:.3s;}
.nsm-booking .dot.active .n{background:var(--purple-deep);border-color:var(--purple-deep);color:#fff;}
.nsm-booking .dot.done .n{background:var(--yellow);border-color:var(--yellow);color:var(--purple-ink);}
.nsm-booking .dot.active{color:var(--purple-ink);}
.nsm-booking .bar{flex:1;height:2px;background:var(--line);border-radius:2px;}

.nsm-booking .lbl-step{font-family:'Anton',sans-serif;font-size:13px;letter-spacing:.06em;color:var(--purple-deep);text-transform:uppercase;}
.nsm-booking h3.q{font-size:25px;margin:6px 0 18px;}

.nsm-booking .field{margin-bottom:15px;}
.nsm-booking .field label{display:block;font-weight:700;font-size:13.5px;margin-bottom:7px;color:var(--purple-ink);}
.nsm-booking .field input,.nsm-booking .field textarea{width:100%;border:2px solid var(--line);border-radius:13px;padding:13px 15px;font-family:inherit;font-size:15.5px;font-weight:500;color:var(--ink);background:#faf6ff;transition:border-color .2s,box-shadow .2s;}
.nsm-booking .field input:focus,.nsm-booking .field textarea:focus{outline:none;border-color:var(--purple-deep);box-shadow:0 0 0 4px rgba(127,48,214,.13);}
.nsm-booking .field textarea{resize:vertical;min-height:96px;}
/* Theme-/Plugin-globale form{}-Karte im Modul neutralisieren */
.nsm-booking form{background:transparent;border:0;border-radius:0;box-shadow:none;padding:0;}
.nsm-booking .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* chip choices */
.nsm-booking .chips{display:flex;flex-wrap:wrap;gap:9px;}
.nsm-booking .chip{cursor:pointer;}
.nsm-booking .chip input{position:absolute;opacity:0;pointer-events:none;}
.nsm-booking .chip span{display:inline-flex;align-items:center;gap:7px;border:2px solid var(--line);border-radius:100px;padding:10px 16px;font-weight:700;font-size:14px;color:var(--purple-ink);transition:.2s;background:#faf6ff;}
.nsm-booking .chip input:checked + span{background:var(--purple-ink);color:#fff;border-color:var(--purple-ink);}
.nsm-booking .chip input:focus-visible + span{box-shadow:0 0 0 4px rgba(127,48,214,.18);}

.nsm-booking .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;font-size:16px;padding:15px 26px;border-radius:100px;border:0;cursor:pointer;font-family:inherit;transition:transform .25s var(--ease),box-shadow .25s,background .2s;}
.nsm-booking .btn-primary{background:var(--purple-deep);color:#fff;width:100%;}
.nsm-booking .btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(127,48,214,.3);background:var(--purple-ink);}
.nsm-booking .btn-ghost{background:transparent;color:var(--muted);border:2px solid var(--line);}
.nsm-booking .btn-ghost:hover{border-color:var(--purple-deep);color:var(--purple-deep);}
.nsm-booking .actions{display:flex;gap:10px;margin-top:6px;}
.nsm-booking .actions .btn-ghost{flex:none;}
.nsm-booking .actions .btn-primary{flex:1;width:auto;}

.nsm-booking .microcopy{margin-top:13px;font-size:12.5px;color:var(--muted);text-align:center;display:flex;align-items:center;justify-content:center;gap:7px;flex-wrap:wrap;}
.nsm-booking .microcopy b{color:var(--purple-ink);font-weight:800;}

/* calendly embed area */
.nsm-booking .summary{background:#f6efff;border:2px dashed var(--line);border-radius:14px;padding:13px 16px;font-size:13.5px;color:var(--purple-ink);font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.nsm-booking .summary b{font-weight:800;}
.nsm-booking .cal-embed{border:2px solid var(--line);border-radius:18px;min-height:340px;background:repeating-linear-gradient(135deg,#faf6ff 0 12px,#f4ecfd 12px 24px);display:flex;align-items:center;justify-content:center;text-align:center;padding:30px;position:relative;overflow:hidden;}
.nsm-booking .cal-embed .ph{position:relative;z-index:2;max-width:320px;}
.nsm-booking .cal-embed .calico{width:64px;height:64px;border-radius:18px;background:var(--purple-ink);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 16px;}
.nsm-booking .cal-embed h4{font-size:21px;color:var(--purple-ink);}
.nsm-booking .cal-embed p{font-size:13.5px;color:var(--muted);font-weight:500;margin-top:8px;line-height:1.5;}
.nsm-booking .cal-embed .tag{margin-top:14px;display:inline-flex;align-items:center;gap:7px;background:var(--yellow);color:var(--purple-ink);font-weight:800;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border-radius:100px;}

/* ===== WHATSAPP VIEW ===== */
.nsm-booking .wa-hero{display:flex;align-items:center;gap:14px;background:linear-gradient(100deg,#e9f9ee,#f3fbf5);border:2px solid #c7ecd3;border-radius:16px;padding:16px 18px;margin-bottom:6px;}
.nsm-booking .wa-hero .wi{width:50px;height:50px;flex:none;border-radius:14px;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 6px 16px rgba(37,211,102,.4);}
.nsm-booking .wa-hero b{font-size:15.5px;font-weight:800;color:#0c5c2a;display:block;}
.nsm-booking .wa-hero .wa-status{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:800;color:#0c5c2a;}
.nsm-booking .wa-status .blip{width:8px;height:8px;border-radius:50%;background:#25D366;box-shadow:0 0 0 0 rgba(37,211,102,.6);animation:nsmblip 2s infinite;}
@keyframes nsmblip{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 8px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.nsm-booking .btn-wa{background:#25D366;color:#fff;width:100%;}
.nsm-booking .btn-wa:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(37,211,102,.4);background:#1faf4f;}
.nsm-booking .wa-preview{background:#075E54;border-radius:16px;padding:16px;margin:16px 0;position:relative;overflow:hidden;}
.nsm-booking .wa-preview::before{content:"";position:absolute;inset:0;opacity:.06;background-image:radial-gradient(#fff 1px,transparent 1px);background-size:14px 14px;}
.nsm-booking .wa-bubble{position:relative;background:#DCF8C6;border-radius:12px 12px 12px 4px;padding:11px 14px 6px;font-size:14px;line-height:1.45;color:#0b2e1a;font-weight:500;max-width:92%;box-shadow:0 1px 1px rgba(0,0,0,.15);}
.nsm-booking .wa-bubble .t{display:block;text-align:right;font-size:10px;color:#5a8a6b;margin-top:3px;}
.nsm-booking .wa-edit{font-size:12.5px;color:var(--muted);margin:12px 0 0;text-align:center;}

/* ===== FLOATING WHATSAPP FAB ===== */
.nsm-wa-fab{position:fixed;right:24px;bottom:24px;z-index:80;display:flex;align-items:center;background:#25D366;color:#fff;border-radius:100px;height:60px;box-shadow:0 10px 28px rgba(37,211,102,.45);cursor:pointer;overflow:hidden;transition:transform .25s cubic-bezier(.22,1,.36,1);text-decoration:none;font-family:'Archivo',system-ui,sans-serif;}
.nsm-wa-fab .ic{width:60px;height:60px;flex:none;display:flex;align-items:center;justify-content:center;font-size:30px;}
.nsm-wa-fab .tx{max-width:0;white-space:nowrap;font-weight:800;font-size:15px;overflow:hidden;transition:max-width .35s cubic-bezier(.22,1,.36,1),padding .35s cubic-bezier(.22,1,.36,1);}
.nsm-wa-fab:hover{transform:translateY(-2px);}
.nsm-wa-fab:hover .tx{max-width:220px;padding-right:22px;}
.nsm-wa-fab .ping{position:absolute;top:9px;right:13px;width:13px;height:13px;background:#FFC240;border:2px solid #fff;border-radius:50%;}
@media(max-width:560px){
  .nsm-wa-fab{height:52px;right:16px;bottom:16px;}
  .nsm-wa-fab .ic{width:52px;height:52px;font-size:26px;}
  .nsm-wa-fab .ping{top:7px;right:11px;width:11px;height:11px;}
}

/* ===== LEGAL / DSGVO ===== */
.nsm-booking .opt{font-weight:600;color:var(--muted);font-size:12.5px;}
.nsm-booking .req-legend{font-size:12px;color:var(--muted);font-weight:600;margin:-2px 0 16px;}
.nsm-booking .req-legend b{color:var(--purple-deep);font-weight:800;}
.nsm-booking .legal{margin-top:12px;font-size:12px;line-height:1.5;color:var(--muted);text-align:center;font-weight:500;}
.nsm-booking .legal a{color:var(--purple-deep);font-weight:700;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1.5px;}
.nsm-booking .legal a:hover{color:var(--purple-ink);}

/* consent gate (Calendly) */
.nsm-booking .consent{border:2px solid var(--line);border-radius:18px;padding:26px 24px;text-align:center;background:#faf6ff;}
.nsm-booking .consent .clock{width:60px;height:60px;border-radius:16px;background:var(--purple-ink);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px;}
.nsm-booking .consent h4{font-size:20px;color:var(--purple-ink);}
.nsm-booking .consent .sub{font-size:13.5px;color:var(--muted);font-weight:500;margin:8px auto 0;max-width:300px;line-height:1.5;}
.nsm-booking .consent .privacy-note{display:flex;align-items:flex-start;gap:10px;text-align:left;background:#f1e6fb;border:1px solid #e0cdf5;border-radius:12px;padding:12px 14px;margin:18px 0 16px;font-size:12.5px;line-height:1.5;color:#4a2d68;font-weight:500;}
.nsm-booking .consent .privacy-note .ji{flex:none;font-size:16px;line-height:1.3;}
.nsm-booking .consent .privacy-note b{font-weight:800;}
.nsm-booking .consent .btn{width:100%;}
.nsm-booking .consent .remember{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;font-size:12.5px;color:var(--muted);font-weight:600;cursor:pointer;user-select:none;}
.nsm-booking .consent .remember input{width:16px;height:16px;accent-color:var(--purple-deep);cursor:pointer;}

/* success */
.nsm-booking .done-state{display:none;text-align:center;padding:26px 8px;}
.nsm-booking .done-state.show{display:block;animation:nsmfade .4s var(--ease);}
.nsm-booking .done-state .ok{width:74px;height:74px;border-radius:50%;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 16px;animation:nsmpop .5s var(--ease);}
@keyframes nsmpop{0%{transform:scale(0)}60%{transform:scale(1.12)}100%{transform:scale(1)}}
.nsm-booking .done-state h3{font-size:28px;color:var(--purple-ink);}
.nsm-booking .done-state p{margin-top:10px;color:var(--muted);font-weight:500;max-width:340px;margin-left:auto;margin-right:auto;line-height:1.5;}

@media(max-width:880px){
  .nsm-booking .module{grid-template-columns:1fr;box-shadow:10px 12px 0 var(--purple-ink);}
  .nsm-booking .rail{padding:36px 30px;}
  .nsm-booking .proof{margin-top:30px;}
  .nsm-booking .panel{padding:30px 26px;}
}
@media(max-width:480px){
  .nsm-booking{padding:20px 14px;}
  .nsm-booking .row2{grid-template-columns:1fr;}
  .nsm-booking .seg button .badge{display:none;}
}
@media(prefers-reduced-motion:reduce){
  .nsm-booking .view,.nsm-booking .done-state.show,.nsm-booking .done-state .ok,.nsm-wa-fab,.nsm-booking .wa-status .blip{animation:none!important;}
}
