/* =====================================================================
   BellaFit · components.css — Loader, Nav, Quick-Contact, Buttons,
   Forms, Cards, Footer
   ===================================================================== */

/* ============ BUTTONS ============ */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--font-sans);font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:1rem 1.7rem;border-radius:var(--r-pill);
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
  will-change:transform;text-align:center;line-height:1.2;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn svg{width:1.15em;height:1.15em}
.btn--fl{--bg:var(--fl);--fg:#fff;box-shadow:var(--sh-fl)}
.btn--fl:hover{--bg:var(--fl-deep)}
.btn--pm{--bg:var(--pm);--fg:#fff;box-shadow:var(--sh-pm)}
.btn--pm:hover{--bg:var(--pm-deep)}
.btn--wa{--bg:#25D366;--fg:#fff;box-shadow:0 14px 34px rgba(37,211,102,.28)}
.btn--wa:hover{--bg:#1eb858}
.btn--ghost{--bg:transparent;--fg:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn--ghost:hover{--bg:var(--ink);--fg:#fff;border-color:var(--ink)}
.btn--light{--bg:#fff;--fg:var(--ink);box-shadow:var(--sh)}
.btn--sm{padding:.62rem 1.1rem;font-size:.9rem}
.btn--lg{padding:1.15rem 2.1rem;font-size:1.05rem}
.btn--block{display:flex;width:100%}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}
.btn__spin{width:1.05em;height:1.05em;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn.is-loading .btn__spin{display:inline-block}
.btn.is-loading .btn__label{opacity:.85}
@keyframes spin{to{transform:rotate(360deg)}}

.link-arrow{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--fl);transition:gap .25s var(--ease)}
[data-accent="pm"] .link-arrow{color:var(--pm)}
.link-arrow:hover{gap:.85em}
.link-arrow svg{width:1.1em;height:1.1em}

/* ============ LOADER ============ */
.loader{
  position:fixed;inset:0;z-index:1000;display:grid;place-items:center;
  background:var(--ink);
  transition:opacity .6s var(--ease),visibility .6s;
}
.loader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:26px}
.loader__logo{width:min(56vw,220px);opacity:0;animation:loaderIn .7s var(--ease-out) forwards}
.loader__bar{width:130px;height:2px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.loader__bar span{display:block;height:100%;width:40%;background:linear-gradient(90deg,var(--fl),#ff5e6e);border-radius:2px;animation:loaderBar 1.1s var(--ease) infinite}
@keyframes loaderIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes loaderBar{0%{transform:translateX(-120%)}100%{transform:translateX(360%)}}
.no-js .loader{display:none}
@media (prefers-reduced-motion:reduce){.loader__bar span{animation:none;width:100%}}

/* ============ NAVIGATION (schwebende Pille) ============ */
.nav{position:fixed;top:14px;left:0;right:0;z-index:200;padding-inline:clamp(12px,3vw,22px);
  transition:transform .4s var(--ease)}
.nav__inner{max-width:1140px;margin-inline:auto;border-radius:var(--r-pill);
  padding:9px 10px 9px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px;
  background:rgba(22,24,29,.34);backdrop-filter:blur(16px) saturate(170%);
  border:1px solid rgba(255,255,255,.16);box-shadow:0 12px 34px rgba(0,0,0,.20);
  transition:background .35s var(--ease),box-shadow .35s,border-color .35s}
.nav__logo{height:34px;width:auto;transition:opacity .3s}
.nav__logo--light{position:absolute;top:0;left:0}
.nav__brand{position:relative;display:block;flex:0 0 auto}

/* Default = über dunklem Hero: helle Pille */
.nav__logo--dark{opacity:0}
.nav__logo--light{opacity:1}
.nav__links a{color:rgba(255,255,255,.92)}
.nav__toggle span{background:#fff}

/* Gescrollt / heller Hintergrund -> helle Pille */
.nav.is-solid .nav__inner{background:rgba(255,255,255,.84);border-color:var(--line);box-shadow:0 12px 30px rgba(22,24,29,.13)}
.nav.is-solid .nav__logo--dark{opacity:1}
.nav.is-solid .nav__logo--light{opacity:0}
.nav.is-solid .nav__links a{color:var(--ink-soft)}
.nav.is-solid .nav__toggle span{background:var(--ink)}
.nav.is-hidden{transform:translateY(-135%)}

/* Legal-Seiten: direkt helle Pille */
.nav--light .nav__inner{background:rgba(255,255,255,.88);border-color:var(--line);box-shadow:0 12px 30px rgba(22,24,29,.1)}
.nav--light .nav__logo--dark{opacity:1}
.nav--light .nav__logo--light{opacity:0}
.nav--light .nav__links a{color:var(--ink-soft)}
.nav--light .nav__toggle span{background:var(--ink)}

.nav__links{display:flex;align-items:center;gap:clamp(14px,2vw,30px)}
.nav__links a:not(.btn){font-weight:500;font-size:.95rem;position:relative;transition:color .25s;padding:6px 2px}
.nav__links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--fl);transition:width .3s var(--ease);border-radius:2px}
[data-accent="pm"] .nav__links a:not(.btn)::after{background:var(--pm)}
.nav__links a:not(.btn):hover::after,.nav__links a[aria-current="page"]::after{width:100%}

/* CTA in Seitenfarbe + Icon */
.nav__cta{background:var(--fl);color:#fff;border-radius:var(--r-pill);padding:.6rem 1.15rem;font-size:.92rem;
  box-shadow:0 6px 16px rgba(226,0,26,.32);gap:.5em}
[data-accent="pm"] .nav__cta{background:var(--pm);box-shadow:0 6px 16px rgba(0,58,120,.3)}
.nav__cta:hover{background:var(--fl-deep);transform:translateY(-1px)}
[data-accent="pm"] .nav__cta:hover{background:var(--pm-deep)}
.nav__cta svg{width:1.05em;height:1.05em}

.nav__toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:210}
.nav__toggle span{width:24px;height:2px;border-radius:2px;transition:transform .3s var(--ease),opacity .3s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__mobile{position:fixed;inset:0;z-index:205;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:clamp(28px,8vw,60px);
  opacity:0;transform:translateY(-14px);transition:opacity .3s var(--ease),transform .4s var(--ease)}
.nav__mobile[hidden]{display:none}
.nav__mobile.is-open{opacity:1;transform:none}
.nav__mobile a:not(.btn){font-family:var(--font-display);font-size:1.8rem;color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line)}
.nav__mobile .btn{margin-top:14px}

@media (max-width:840px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
}

/* ============ SCHNELLKONTAKT (Desktop: rechter Rand · Mobil: unten full-width) === */
.qc{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:185;
  display:flex;flex-direction:column;gap:8px}
.qc__tab{display:none} /* kein Toggle nötig – Icons direkt sichtbar */
.qc__panel{display:flex;flex-direction:column;gap:8px}
.qc__item{
  position:relative;display:flex;align-items:center;gap:0;
  width:50px;height:50px;border-radius:14px 0 0 14px;overflow:hidden;
  background:var(--ink);color:#fff;box-shadow:0 8px 22px rgba(22,24,29,.22);
  transition:width .32s var(--ease),background .25s}
.qc__item svg{flex:0 0 50px;width:50px;height:22px;padding:0;display:block;margin-inline:auto}
.qc__item span{white-space:nowrap;font-weight:600;font-size:.92rem;opacity:0;padding-right:18px;transition:opacity .2s}
.qc__item:hover{width:auto;padding-right:4px;background:var(--ink-soft)}
.qc__item:hover span{opacity:1}
.qc__item--wa{background:#25D366}
.qc__item--wa:hover{background:#1eb858}
@media (max-width:840px){
  .qc{right:0;left:0;top:auto;bottom:0;transform:none}
  .qc__panel{flex-direction:row;gap:0;width:100%;box-shadow:0 -8px 24px rgba(0,0,0,.16)}
  .qc__item{width:auto;height:58px;flex:1 1 0;border-radius:0;flex-direction:column;gap:2px;justify-content:center;box-shadow:none;
    border-right:1px solid rgba(255,255,255,.14)}
  .qc__item:last-child{border-right:0}
  .qc__item svg{flex:0 0 auto;width:22px;height:22px;margin:0}
  .qc__item span{opacity:1;font-size:.74rem;padding:0}
  .qc__item:hover{width:auto;padding:0}
  /* Sicherheitsabstand, damit die fixierte Bottom-Bar nichts überdeckt */
  body{padding-bottom:58px}
}

/* ============ CARDS / PILLS / BADGES ============ */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,2.6vw,34px);box-shadow:var(--sh-sm);transition:transform .35s var(--ease),box-shadow .35s}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.card__icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--fl-soft);color:var(--fl);margin-bottom:18px}
.card__icon svg{width:26px;height:26px}
[data-accent="pm"] .card__icon{background:var(--pm-soft);color:var(--pm)}
.card h3{margin-bottom:10px}
.card p{color:var(--muted);font-size:.98rem}

.pill{display:inline-flex;align-items:center;gap:.5em;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-pill);padding:.5rem 1rem;font-size:.86rem;font-weight:600;color:var(--ink-soft);box-shadow:var(--sh-sm)}
.pill svg{width:1.05em;height:1.05em;color:var(--fl)}
[data-accent="pm"] .pill svg{color:var(--pm)}

.trust-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* Stat */
.stat{text-align:center}
.stat__num{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:700;color:var(--fl);line-height:1;letter-spacing:-.03em}
[data-accent="pm"] .stat__num{color:var(--pm)}
.stat__label{margin-top:10px;font-size:.92rem;color:var(--muted);font-weight:500}

/* ============ FORMS ============ */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px;text-align:left}
.field label{font-weight:600;font-size:.92rem;color:var(--ink-soft)}
.field .req{color:var(--fl)}
.field input,.field textarea,.field select{
  width:100%;padding:.95rem 1.1rem;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:#fff;font-size:1rem;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--fl);box-shadow:0 0 0 4px var(--fl-tint)}
[data-accent="pm"] .field input:focus,[data-accent="pm"] .field textarea:focus,[data-accent="pm"] .field select:focus{border-color:var(--pm);box-shadow:0 0 0 4px var(--pm-soft)}
.field textarea{min-height:120px;resize:vertical}
.field--error input,.field--error textarea{border-color:var(--fl)}
.field__err{color:var(--fl);font-size:.84rem;font-weight:600;min-height:0;display:none}
.field--error .field__err{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

.checkbox{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--muted);line-height:1.5;cursor:pointer}
.checkbox input{width:20px;height:20px;flex:0 0 auto;margin-top:2px;accent-color:var(--fl)}
[data-accent="pm"] .checkbox input{accent-color:var(--pm)}
.checkbox a{text-decoration:underline;color:var(--ink-soft)}

.form-note{font-size:.82rem;color:var(--muted-2);display:flex;gap:8px;align-items:center}
.form-note svg{width:1.1em;height:1.1em;flex:0 0 auto}

/* Form-Erfolg / Fehler */
.form-status{display:none;border-radius:var(--r);padding:18px 20px;font-weight:500;margin-top:8px}
.form-status.is-ok{display:block;background:#EAF7EE;color:#1E7A3D;border:1px solid #BFE6CC}
.form-status.is-bad{display:block;background:var(--fl-soft);color:var(--fl-deep);border:1px solid var(--fl-tint)}

/* ============ FOOTER ============ */
.footer{background:var(--ink);color:rgba(255,255,255,.78)}
.footer__cta{border-bottom:1px solid rgba(255,255,255,.1)}
.footer__cta-grid{max-width:var(--container);margin-inline:auto;display:grid;grid-template-columns:1fr 1fr}
@media (max-width:720px){.footer__cta-grid{grid-template-columns:1fr}}
.footer__door{position:relative;padding:clamp(32px,5vw,56px) clamp(24px,5vw,48px);display:flex;flex-direction:column;gap:8px;
  overflow:hidden;transition:background .3s}
.footer__door--fl:hover{background:rgba(226,0,26,.16)}
.footer__door--pm:hover{background:rgba(0,97,176,.18)}
.footer__door--fl{border-right:1px solid rgba(255,255,255,.1)}
@media (max-width:720px){.footer__door--fl{border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}}
.footer__door-eyebrow{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.footer__door--fl .footer__door-eyebrow{color:#ff5e6e}
.footer__door--pm .footer__door-eyebrow{color:#5aa6e8}
.footer__door-title{font-family:var(--font-display);font-size:clamp(1.3rem,2.2vw,1.9rem);color:#fff;max-width:18ch}
.footer__door-arrow{font-size:1.5rem;color:#fff;transition:transform .3s var(--ease)}
.footer__door:hover .footer__door-arrow{transform:translateX(8px)}

.footer__main{max-width:var(--container);margin-inline:auto;padding:clamp(48px,6vw,80px) clamp(20px,5vw,48px) 40px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
@media (max-width:860px){.footer__main{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer__main{grid-template-columns:1fr}}
.footer__logo{height:40px;width:auto;margin-bottom:18px}
.footer__claim{font-family:var(--font-display);font-style:italic;color:#fff;font-size:1.15rem;margin-bottom:14px}
.footer__about{font-size:.92rem;line-height:1.6;max-width:42ch}
.footer__h{font-family:var(--font-sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px;font-weight:700}
.footer__col a{display:block;padding:6px 0;color:rgba(255,255,255,.78);font-size:.96rem;transition:color .2s}
.footer__col a:hover{color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px clamp(20px,5vw,48px);
  max-width:var(--container);margin-inline:auto;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center}
.footer__copy{font-size:.82rem;color:rgba(255,255,255,.55)}
.footer__legal{display:flex;gap:20px;flex-wrap:wrap}
.footer__legal a{font-size:.82rem;color:rgba(255,255,255,.55);transition:color .2s}
.footer__legal a:hover{color:#fff}
/* Kontakt-Spalte mit Icons */
.footer__col--contact a{display:flex;align-items:center;gap:11px}
.footer__col--contact svg{width:18px;height:18px;flex:0 0 auto;color:#ff6675;transition:color .2s}
.footer__col--contact a:hover svg{color:#fff}
