/* ============================================================
   MOLLOGISTIC — Überführungs-Kalkulator
   Premium automotive: white page, black panel, gold accents
   ============================================================ */

.calc{
  background:#fff;
  color:#000;
  padding:clamp(64px,8vw,120px) 40px clamp(72px,9vw,128px);
}
.calc__inner{max-width:1320px;margin:0 auto}

.calc__head{text-align:center;margin-bottom:clamp(40px,4.5vw,64px)}
.calc__title{
  font-size:clamp(30px,3.6vw,50px);
  font-weight:800;letter-spacing:-.02em;line-height:1.08;color:#000;
}
.calc__title .it{
  font-family:"Playfair Display",Georgia,serif;
  font-style:italic;font-weight:700;
}
.calc__sub{
  margin:18px auto 0;max-width:560px;
  font-size:clamp(15px,1.2vw,17px);line-height:1.6;color:#6b7280;text-wrap:pretty;
}

/* ---------- TWO-COLUMN GRID ---------- */
.calc__grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.15fr);
  gap:clamp(18px,1.8vw,26px);
  align-items:stretch;
}

/* ---------- LEFT: BLACK FORM PANEL ---------- */
.calc__panel{
  background:#000;
  border-radius:24px;
  padding:clamp(26px,2.4vw,40px);
  display:flex;flex-direction:column;gap:clamp(16px,1.6vw,22px);
  box-shadow:0 24px 60px rgba(16,24,40,.16);
}
.calc__panel-eyebrow{
  display:flex;align-items:center;gap:13px;
  color:var(--gold);
  font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
}
.calc__panel-eyebrow::before{
  content:"";display:block;width:26px;height:2px;background:var(--gold);opacity:.6;
}

.field{display:flex;flex-direction:column;gap:9px;position:relative}
.field__label{
  font-size:13px;font-weight:700;letter-spacing:.04em;color:#cfd4dc;
  text-transform:uppercase;
}
.field__wrap{position:relative;display:flex;align-items:center}
.field__icon{
  position:absolute;left:18px;top:50%;transform:translateY(-50%);
  color:var(--gold);pointer-events:none;display:flex;
}
.field__input,
.field__select{
  width:100%;
  font-family:inherit;font-size:16px;font-weight:500;color:#fff;
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:18px 18px 18px 50px;
  outline:none;
  transition:border-color .18s,background .18s,box-shadow .18s;
  -webkit-appearance:none;appearance:none;
}
.field__input::placeholder{color:#7c8597}
.field__input:focus,
.field__select:focus{
  border-color:var(--gold);
  background:rgba(255,255,255,.08);
  box-shadow:0 0 0 4px rgba(200,144,47,.18);
}
.field__select{
  cursor:pointer;color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23c8902f' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 18px center;
  padding-right:48px;
}
.field__select option{color:#000;background:#fff}

/* swap row between Von / Nach */
.field__route{position:relative}
.calc__swap{
  position:absolute;right:16px;top:-29px;z-index:3;
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#fff;color:#000;border:none;cursor:pointer;
  box-shadow:0 6px 16px rgba(0,0,0,.34);
  transition:transform .25s,background .18s,color .18s;
}
.calc__swap:hover{background:var(--gold);color:#fff;transform:rotate(180deg)}

/* autocomplete dropdown */
.ac{
  position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:20;
  list-style:none;margin:0;padding:6px;
  background:#fff;color:#000;border-radius:16px;
  box-shadow:0 18px 44px rgba(16,24,40,.28);
  max-height:264px;overflow-y:auto;
  display:none;
}
.ac.open{display:block}
.ac li{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:11px;cursor:pointer;
  font-size:14.5px;line-height:1.35;color:#1a1d23;
  transition:background .12s;
}
.ac li:hover,.ac li.active{background:#f4f1ea}
.ac li .ac__pin{color:var(--gold);flex-shrink:0;display:flex}
.ac li .ac__name{font-weight:600}
.ac li .ac__meta{color:#8a909c;font-weight:500}
.ac__empty{padding:14px;color:#8a909c;font-size:14px;text-align:center}

/* ---------- RIGHT: MAP ---------- */
.calc__map-wrap{
  position:relative;
  border-radius:24px;overflow:hidden;
  min-height:480px;
  background:#eef0f2;
  box-shadow:0 24px 60px rgba(16,24,40,.12);
  border:1px solid #e7e9ec;
}
#calcMap{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.leaflet-container{background:#eef0f2;font-family:inherit}

/* distance badge over the map */
.calc__dist{
  position:absolute;left:18px;top:18px;z-index:600;
  display:flex;align-items:center;gap:14px;
  background:rgba(0,0,0,.86);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  color:#fff;border-radius:16px;padding:14px 20px;
  box-shadow:0 10px 30px rgba(0,0,0,.3);
  transform:translateY(-8px);opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s;
}
.calc__dist.show{opacity:1;transform:translateY(0)}
.calc__dist .ico{color:var(--gold);display:flex}
.calc__dist .calc__dist-val{font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1}
.calc__dist .calc__dist-val .u{font-size:14px;font-weight:600;color:#c8902f;margin-left:3px}
.calc__dist .calc__dist-lbl{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#9aa1ad;margin-top:4px}

/* map empty / loading hint */
.calc__map-hint{
  position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:600;
  background:rgba(255,255,255,.94);color:#1a1d23;
  border-radius:999px;padding:11px 20px;
  font-size:13.5px;font-weight:600;
  box-shadow:0 8px 22px rgba(16,24,40,.16);
  display:flex;align-items:center;gap:10px;
  transition:opacity .25s;
}
.calc__map-hint .spin{
  width:15px;height:15px;border-radius:50%;
  border:2px solid rgba(0,0,0,.15);border-top-color:var(--gold);
  animation:calcSpin .7s linear infinite;display:none;
}
.calc__map-hint.loading .spin{display:block}
.calc__map-hint.hidden{opacity:0;pointer-events:none}
@keyframes calcSpin{to{transform:rotate(360deg)}}

/* custom map pins */
.calc-pin{display:flex;align-items:center;justify-content:center}
.calc-pin span{
  width:18px;height:18px;border-radius:50%;
  border:3px solid #fff;box-shadow:0 3px 10px rgba(0,0,0,.4);
}
.calc-pin--from span{background:#000}
.calc-pin--to span{background:var(--gold)}

/* clickable city quick-pick markers */
.calc-city{
  display:flex;align-items:center;gap:6px;cursor:pointer;
  white-space:nowrap;transform:translateX(-3px);
}
.calc-city__dot{
  width:9px;height:9px;border-radius:50%;flex:0 0 auto;
  background:#000;border:2px solid #fff;
  box-shadow:0 1px 5px rgba(0,0,0,.45);
  transition:background .15s,transform .15s;
}
.calc-city__lbl{
  font-size:11px;font-weight:700;letter-spacing:.01em;color:#1a1d23;
  text-shadow:0 0 3px #fff,0 0 3px #fff,0 1px 2px rgba(255,255,255,.95);
  transition:color .15s;
}
.calc-city:hover .calc-city__dot{background:var(--gold);transform:scale(1.3)}
.calc-city:hover .calc-city__lbl{color:var(--gold)}

/* static, non-clickable federal-state labels */
.calc-state{
  display:flex;align-items:center;justify-content:center;
  transform:translate(-50%,-50%);pointer-events:none;
}
.calc-state__lbl{
  font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(60,66,78,.42);white-space:nowrap;pointer-events:none;
  text-shadow:0 0 2px rgba(255,255,255,.85),0 0 2px rgba(255,255,255,.85);
}

/* flowing dashes travelling along the route */
.route-flow{
  stroke-dashoffset:0;
  animation:routeFlow 1s linear infinite;
}
@keyframes routeFlow{to{stroke-dashoffset:-34}}

/* the vehicle marker driving the route */
.calc-car{
  position:relative;width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  transition:transform .12s linear;
}
.calc-car__body{
  position:relative;z-index:2;
  width:26px;height:26px;border-radius:50%;
  background:var(--gold);border:3px solid #fff;
  box-shadow:0 3px 10px rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;
}
.calc-car__pulse{
  position:absolute;left:50%;top:50%;width:26px;height:26px;
  margin:-13px 0 0 -13px;border-radius:50%;
  background:var(--gold);opacity:.55;
  animation:carPulse 1.6s ease-out infinite;
}
@keyframes carPulse{
  0%{transform:scale(1);opacity:.5}
  70%{transform:scale(2.4);opacity:0}
  100%{opacity:0}
}
@media (prefers-reduced-motion:reduce){
  .route-flow{animation:none}
  .calc-car__pulse{animation:none;opacity:0}
}

/* ---------- STYLE / PRICE CARDS ---------- */
.calc__styles{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,1.6vw,22px);
  margin-top:clamp(20px,2vw,28px);
}
.styc{
  position:relative;text-align:left;cursor:pointer;
  background:#fff;border:1.5px solid #e7e9ec;border-radius:20px;
  padding:clamp(22px,1.8vw,28px);
  display:flex;flex-direction:column;gap:6px;
  transition:transform .2s,box-shadow .2s,border-color .2s;
  font-family:inherit;color:#000;
}
.styc:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(16,24,40,.1)}
.styc.selected{
  border-color:var(--gold);
  box-shadow:0 0 0 1.5px var(--gold),0 20px 44px rgba(200,144,47,.18);
}
.styc__check{
  position:absolute;top:18px;right:18px;
  width:24px;height:24px;border-radius:50%;
  border:2px solid #d7dae0;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,background .2s;
}
.styc__check svg{opacity:0;transform:scale(.5);transition:opacity .2s,transform .2s;color:#fff}
.styc.selected .styc__check{background:var(--gold);border-color:var(--gold)}
.styc.selected .styc__check svg{opacity:1;transform:scale(1)}
.styc__tag{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);
}
.styc__name{font-size:clamp(19px,1.5vw,23px);font-weight:800;letter-spacing:-.01em;color:#000}
.styc__desc{font-size:14px;line-height:1.55;color:#6b7280;text-wrap:pretty;min-height:43px}
.styc__price{
  margin-top:10px;display:flex;align-items:baseline;gap:6px;
  font-weight:800;letter-spacing:-.02em;color:#000;
}
.styc__price .pre{font-size:13px;font-weight:600;color:#8a909c;letter-spacing:0}
.styc__price .num{font-size:clamp(26px,2.2vw,32px)}
.styc__price .cur{font-size:18px}
.styc__price.empty{color:#aeb3bd}
.styc__price.empty .num{font-size:16px;font-weight:600}
.styc__eta{font-size:12.5px;color:#9aa1ad;font-weight:600;margin-top:2px}

/* ---------- CTA ROW ---------- */
.calc__cta-row{
  margin-top:clamp(22px,2.2vw,32px);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;
  background:#faf8f3;border:1px solid #efe8d9;border-radius:20px;
  padding:clamp(20px,1.8vw,26px) clamp(24px,2vw,32px);
}
.calc__summary{display:flex;flex-direction:column;gap:3px;min-width:0}
.calc__summary-route{
  font-size:clamp(17px,1.5vw,21px);font-weight:800;letter-spacing:-.01em;color:#000;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.calc__summary-route .arr{color:var(--gold)}
.calc__summary-route .muted{color:#aeb3bd;font-weight:600}
.calc__summary-meta{font-size:14px;color:#6b7280;font-weight:500}
.calc__summary-meta b{color:#000;font-weight:700}

.calc__cta{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:13px;
  background:#000;color:#fff;
  font-size:16px;font-weight:700;letter-spacing:0;
  padding:19px 32px;border-radius:999px;
  border:2px solid transparent;cursor:pointer;text-decoration:none;
  box-shadow:0 7px 18px rgba(0,0,0,.28);
  transition:transform .18s,background .18s,color .18s,border-color .18s;
  font-family:inherit;
}
.calc__cta:hover{background:var(--gold);color:#fff;transform:translateY(-2px)}
.calc__cta svg{transition:transform .18s}
.calc__cta:hover svg{transform:translateX(4px)}
.calc__cta[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .calc{padding:64px 20px 72px}
  .calc__grid{grid-template-columns:1fr}
  .calc__map-wrap{min-height:380px;order:2}
  .calc__panel{order:1}
  .calc__styles{grid-template-columns:1fr}
  .calc__cta-row{flex-direction:column;align-items:stretch}
  .calc__cta{justify-content:center}
}
@media (max-width:560px){
  .calc__panel{padding:24px 20px}
  .styc__desc{min-height:0}
}
@media (max-width:480px){
  .calc{padding:54px 16px 60px}
  .calc__map-wrap{min-height:320px}
  .calc__dist{left:12px;top:12px;padding:10px 14px;gap:10px}
  .calc__dist .calc__dist-val{font-size:20px}
  .contact{padding:56px 16px 64px}
}

/* ============================================================
   KONTAKTBEREICH
   ============================================================ */
.contact{
  position:relative;overflow:hidden;
  background:#0a0a0a;color:#fff;
  padding:clamp(64px,8vw,116px) 40px clamp(72px,9vw,120px);
}
.contact__bg{
  position:absolute;left:50%;top:50%;
  width:min(165%,1500px);aspect-ratio:1/1;
  transform:translate(-50%,-50%);
  background:url("logo-bg.jpeg") center/contain no-repeat;
  filter:blur(20px) saturate(1.25);
  opacity:.62;
  pointer-events:none;z-index:0;
}
.contact::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(10,10,10,.1) 0%,rgba(10,10,10,.55) 68%,#0a0a0a 100%);
}
.contact__inner{position:relative;z-index:2;max-width:1180px;margin:0 auto}
.contact__head{text-align:center;margin-bottom:clamp(40px,4.5vw,60px)}
.contact__eyebrow{
  display:inline-flex;align-items:center;gap:13px;
  color:var(--gold);font-size:12px;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;margin-bottom:20px;
}
.contact__eyebrow::before,.contact__eyebrow::after{
  content:"";display:block;width:30px;height:1.5px;background:var(--gold);opacity:.55;
}
.contact__title{
  font-size:clamp(30px,3.6vw,50px);font-weight:800;letter-spacing:-.02em;
  line-height:1.08;color:#fff;
}
.contact__title .it{font-family:"Playfair Display",Georgia,serif;font-style:italic;font-weight:700;color:var(--gold)}
.contact__sub{
  margin:18px auto 0;max-width:540px;
  font-size:clamp(15px,1.2vw,17px);line-height:1.6;color:#9aa1ad;text-wrap:pretty;
}

.contact__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,1.6vw,22px);
}
.ccard{
  position:relative;text-decoration:none;
  background:rgba(20,20,20,.72);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:22px;padding:clamp(26px,2.2vw,34px);
  display:flex;flex-direction:column;gap:9px;
  transition:transform .22s,border-color .22s,background .22s,box-shadow .22s;
}
.ccard:hover{
  transform:translateY(-5px);
  border-color:var(--gold);
  background:rgba(26,23,20,.82);
  box-shadow:0 22px 48px rgba(0,0,0,.5);
}
.ccard__icon{
  width:56px;height:56px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(200,144,47,.12);color:var(--gold);
  margin-bottom:8px;transition:background .22s,color .22s;
}
.ccard:hover .ccard__icon{background:var(--gold);color:#0a0a0a}
.ccard--wa:hover .ccard__icon{background:#25d366;color:#0a0a0a}
.ccard__label{
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#8a909c;
}
.ccard__value{
  font-size:clamp(17px,1.5vw,21px);font-weight:800;letter-spacing:-.01em;color:#fff;
  word-break:break-word;line-height:1.25;
}
.ccard__hint{
  margin-top:6px;display:flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:600;color:#7c8597;
}
.ccard__arrow{color:var(--gold);transition:transform .2s}
.ccard:hover .ccard__arrow{transform:translateX(4px)}

@media (max-width:880px){
  .contact{padding:64px 20px 72px}
  .contact__grid{grid-template-columns:1fr}
}
