/* PAXPOST24 - Modern Forms Layer v2.0 (alle Portale) */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* === HERO-CARDS in Tabs === */
.hero-card {
  background: linear-gradient(135deg, rgba(36,52,71,.7), rgba(26,35,50,.5)) !important;
  border: 1px solid rgba(45,212,191,.18) !important;
  border-radius: 22px !important;
  padding: 28px !important;
  margin-bottom: 18px !important;
  position: relative;
  overflow: hidden;
}
.hero-card::before {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(45,212,191,.18), transparent);
  border-radius: 50%;
}
.hero-card h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  letter-spacing: -.02em !important;
  margin: 0 0 8px !important;
  color: #F0F4F8 !important;
  position: relative;
}
.hero-card h2 i { color: #2DD4BF; font-style: italic; }
.hero-card p {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  color: rgba(240,244,248,.75) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  position: relative;
  max-width: 580px;
}

/* === Portal-Cards (pg-card / tp-card / dc-card) === */
.pg-card, .tp-card, .dc-card, .s2-form-card {
  background: linear-gradient(145deg, rgba(36,52,71,.55), rgba(26,35,50,.45)) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 20px !important;
  padding: 22px !important;
  margin-bottom: 14px !important;
  box-shadow: 0 12px 30px -12px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: all .3s !important;
}
.pg-card:hover, .tp-card:hover, .dc-card:hover {
  border-color: rgba(45,212,191,.18) !important;
}
.pg-card-h, .tp-card-h, .dc-card-h {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  color: #F0F4F8 !important;
  margin-bottom: 16px !important;
  display: flex;
  align-items: center;
  gap: 10px;
}
.pg-card-h .ic, .tp-card-h .ic, .dc-card-h .ic {
  font-size: 22px;
}
.pg-card-h .badge, .tp-card-h .badge, .dc-card-h .badge {
  margin-left: auto;
  background: rgba(45,212,191,.15);
  color: #2DD4BF;
  padding: 4px 12px;
  border-radius: 100px;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .12em;
}

/* === INFO-BANNER === */
.info-banner {
  background: linear-gradient(135deg, rgba(96,165,250,.08), rgba(96,165,250,.03)) !important;
  border: 1px solid rgba(96,165,250,.22) !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
  margin-bottom: 14px !important;
  display: flex !important;
  gap: 12px !important;
  align-items: flex-start !important;
}
.info-banner .ic { font-size: 22px; }
.info-banner b { color: #60A5FA; font-weight: 700; }
.info-banner div {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  color: rgba(240,244,248,.85) !important;
  line-height: 1.55 !important;
}

/* === CUSTOMS / WARNING-BANNER === */
.customs-banner {
  background: linear-gradient(135deg, rgba(251,191,36,.1), rgba(251,191,36,.04)) !important;
  border: 1px solid rgba(251,191,36,.3) !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
  margin: 12px 0 !important;
  display: flex !important;
  gap: 12px !important;
  align-items: flex-start !important;
}
.customs-banner b { color: #FBBF24; font-weight: 700; }
.customs-banner div {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  color: rgba(240,244,248,.85) !important;
  line-height: 1.5 !important;
}

/* === TABS Pill (pg-tab / tp-tab / dc-tab) === */
.pg-tab, .tp-tab, .dc-tab {
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  letter-spacing: .05em !important;
  border-radius: 100px !important;
  padding: 10px 18px !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  color: rgba(240,244,248,.6) !important;
  transition: all .25s !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px;
  cursor: pointer;
}
.pg-tab:hover, .tp-tab:hover, .dc-tab:hover {
  background: rgba(255,255,255,.04) !important;
  color: #F0F4F8 !important;
}
.pg-tab.active, .tp-tab.active, .dc-tab.active {
  background: linear-gradient(135deg, rgba(45,212,191,.18), rgba(45,212,191,.08)) !important;
  border-color: rgba(45,212,191,.35) !important;
  color: #2DD4BF !important;
  box-shadow: 0 4px 16px rgba(45,212,191,.15) !important;
}

/* === STATS Editorial === */
.dc-stat {
  background: linear-gradient(145deg, rgba(36,52,71,.55), rgba(26,35,50,.45)) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 16px !important;
  padding: 18px 20px !important;
  position: relative;
  overflow: hidden;
}
.dc-stat::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(45,212,191,.6), transparent);
}
.dc-stat .val {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 700 !important;
  font-size: 32px !important;
  line-height: 1 !important;
  background: linear-gradient(135deg, #fff, #2DD4BF) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}
.dc-stat .lbl {
  font-family: 'IBM Plex Mono', monospace !important;
  font-weight: 600 !important;
  font-size: 9px !important;
  letter-spacing: .2em !important;
  text-transform: uppercase !important;
  color: rgba(240,244,248,.55) !important;
  margin-top: 6px;
}

/* === INPUTS === */
.input, input.input, textarea.input, select.input {
  font-family: 'Inter', sans-serif !important;
  background: rgba(15,20,25,.55) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: 14px !important;
  padding: 14px 16px !important;
  color: #F0F4F8 !important;
  font-size: 14px !important;
  transition: all .25s !important;
}
.input:focus, input.input:focus, textarea.input:focus, select.input:focus {
  outline: none !important;
  border-color: #2DD4BF !important;
  background: rgba(45,212,191,.06) !important;
  box-shadow: 0 0 0 4px rgba(45,212,191,.12) !important;
}
.input::placeholder { color: rgba(240,244,248,.35) !important; }

.input-label {
  font-family: 'IBM Plex Mono', monospace !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  color: #2DD4BF !important;
  margin-bottom: 8px !important;
  display: flex !important;
  gap: 8px;
  align-items: center;
}
.input-label::before {
  content: '';
  width: 14px; height: 1px;
  background: rgba(45,212,191,.5);
}

select.input.select {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232dd4bf' stroke-width='2.5' stroke-linecap='round'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  background-size: 16px !important;
  padding-right: 40px !important;
  appearance: none !important;
  cursor: pointer;
}

textarea.input { min-height: 100px !important; resize: vertical !important; line-height: 1.55; }

/* === BUTTONS === */
.btn, button.btn {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border-radius: 100px !important;
  padding: 13px 24px !important;
  transition: all .25s !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.btn.primary {
  background: linear-gradient(135deg, #2DD4BF, #14B8A6) !important;
  color: #0F1419 !important;
  box-shadow: 0 6px 20px rgba(45,212,191,.35) !important;
  border: none !important;
}
.btn.primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 30px rgba(45,212,191,.5) !important;
}
.btn.secondary {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: #F0F4F8 !important;
}
.btn.secondary:hover {
  background: rgba(45,212,191,.08) !important;
  border-color: rgba(45,212,191,.3) !important;
  color: #2DD4BF !important;
}
.btn.danger {
  background: linear-gradient(135deg, #EF4444, #DC2626) !important;
  color: #fff !important;
  border: none !important;
}
.btn.success {
  background: linear-gradient(135deg, #22C55E, #15803D) !important;
  color: #fff !important;
  border: none !important;
}
.btn.full { width: 100% !important; justify-content: center; }
.btn.small { padding: 8px 16px !important; font-size: 11px !important; }

/* === EMPTY STATE === */
.empty {
  text-align: center !important;
  padding: 48px 24px !important;
}
.empty .ic {
  font-size: 56px !important;
  margin-bottom: 14px !important;
  opacity: .6;
}
.empty .h {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #F0F4F8 !important;
  margin-bottom: 6px !important;
}
.empty .t {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  color: rgba(240,244,248,.55) !important;
  line-height: 1.55 !important;
  max-width: 420px;
  margin: 0 auto;
}

/* === SHIFT-CARD (Deliver) === */
.shift-card {
  background: linear-gradient(135deg, rgba(45,212,191,.15), rgba(45,212,191,.05)) !important;
  border: 1px solid rgba(45,212,191,.3) !important;
  border-radius: 20px !important;
  padding: 22px !important;
  position: relative;
  overflow: hidden;
}
.shift-card.off {
  background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.01)) !important;
  border-color: rgba(255,255,255,.1) !important;
}
.shift-card .h {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
}
.shift-card .clock {
  font-family: 'IBM Plex Mono', monospace !important;
  font-size: 32px !important;
  font-weight: 600 !important;
  color: #2DD4BF !important;
}

/* === STOP-CARD (Deliver) === */
.stop-card {
  background: linear-gradient(145deg, rgba(36,52,71,.55), rgba(26,35,50,.45)) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 16px !important;
  padding: 16px !important;
  margin-bottom: 10px !important;
  transition: all .25s !important;
}
.stop-card.next {
  border-color: rgba(45,212,191,.4) !important;
  box-shadow: 0 8px 24px rgba(45,212,191,.15) !important;
}

/* === SHOP s2-* Klassen === */
.s2-cat-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
  gap: 12px !important;
}
.s2-cat-grid > * {
  background: linear-gradient(145deg, rgba(36,52,71,.55), rgba(26,35,50,.45)) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 16px !important;
  transition: all .25s !important;
}
.s2-cat-grid > *:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(45,212,191,.3) !important;
}
.s2-checkout-btn {
  background: linear-gradient(135deg, #2DD4BF, #14B8A6) !important;
  color: #0F1419 !important;
  border-radius: 100px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  box-shadow: 0 6px 20px rgba(45,212,191,.35) !important;
}

/* === MODAL === */
.modal-bg {
  background: rgba(15,20,25,.85) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}
.modal {
  background: linear-gradient(180deg, #1A2332, #0F1419) !important;
  border: 1px solid rgba(45,212,191,.25) !important;
  border-radius: 22px !important;
  box-shadow: 0 30px 70px rgba(0,0,0,.6) !important;
  padding: 28px !important;
}
.modal h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 700 !important;
  letter-spacing: -.02em !important;
  color: #F0F4F8 !important;
}

/* === GPS Pill === */
.gps-pill {
  font-family: 'IBM Plex Mono', monospace !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
  font-weight: 600 !important;
  border-radius: 100px !important;
}

/* === Headline pages h1 === */
.dc-title h1, .pg-title h1, .tp-title h1 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 700 !important;
  letter-spacing: -.02em !important;
}

/* === Loader === */
.loader {
  width: 40px; height: 40px;
  border: 3px solid rgba(45,212,191,.15);
  border-top: 3px solid #2DD4BF;
  border-radius: 50%;
  animation: ppLoad 1s linear infinite;
  margin: 30px auto;
}
@keyframes ppLoad { to { transform: rotate(360deg); } }