/* Scoped IMPark module styles. All selectors are prefixed with .impark- to
   avoid global theme conflicts. Design tokens follow the IMPark concept:
   dark navy base, bright accent for CTAs. */

:root {
  --impark-color-bg: #0b1220;
  --impark-color-surface: #ffffff;
  --impark-color-text: #0f172a;
  --impark-color-muted: #6b7280;
  --impark-color-accent: #0c1428; /* IMPark brand navy — consistent CTA color (P4-002) */
  --impark-color-accent-hover: #0c2a4f;
  --impark-color-accent-2: #16a34a;
  --impark-color-border: rgba(15, 23, 42, 0.12);
  --impark-radius: 14px;
  --impark-radius-sm: 10px;
}

.impark-disabled-notice {
  margin: 1rem 0;
  padding: 0.6rem 0.85rem;
  border: 1px dashed rgba(220, 38, 38, 0.6);
  background: #fef2f2;
  color: #991b1b;
  border-radius: var(--impark-radius-sm);
  font-size: 0.9rem;
}

.impark-cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.7rem 1.2rem;
  border-radius: 999px;
  background: var(--impark-color-accent);
  color: #fff !important;
  text-decoration: none;
  font-weight: 600;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.impark-cta-button:hover,
.impark-cta-button:focus {
  background: var(--impark-color-accent-hover);
  color: #fff !important;
  transform: translateY(-1px);
}

.impark-cta-button--ghost {
  background: transparent;
  color: var(--impark-color-accent) !important;
  border: 1px solid var(--impark-color-accent);
}

.impark-cta-button--ghost:hover,
.impark-cta-button--ghost:focus {
  background: rgba(15, 52, 96, 0.08);
  color: var(--impark-color-accent) !important;
}

/* Hero search */
.impark-hero-search {
  margin: 1.5rem 0;
  padding: 1rem 1.1rem;
  background: var(--impark-color-bg);
  color: #f8fafc;
  border-radius: var(--impark-radius);
}

.impark-hero-search__label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.impark-hero-search__field {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.impark-hero-search__input {
  flex: 1;
  min-height: 2.75rem;
  padding: 0.55rem 0.9rem;
  border-radius: var(--impark-radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.06);
  color: #f8fafc;
  font-size: 1rem;
}

.impark-hero-search__input::placeholder {
  color: rgba(248, 250, 252, 0.65);
}

.impark-hero-search__hint {
  font-size: 0.9rem;
  color: rgba(248, 250, 252, 0.75);
}

/* B2B teaser */
.impark-b2b-teaser {
  margin: 2rem 0;
  padding: 1.5rem 1.6rem;
  border-radius: var(--impark-radius);
  border: 1px solid var(--impark-color-border);
  background: #fff;
}

.impark-b2b-teaser__title {
  margin: 0 0 0.5rem;
  font-size: 1.4rem;
  color: var(--impark-color-text);
}

.impark-b2b-teaser__subtitle {
  margin: 0 0 0.9rem;
  color: var(--impark-color-muted);
}

.impark-b2b-teaser__list {
  margin: 0 0 1rem;
  padding-left: 1.2rem;
}

.impark-b2b-teaser__list li {
  margin: 0.25rem 0;
}

.impark-b2b-teaser__cta {
  margin: 0.8rem 0 0.4rem;
}

.impark-b2b-teaser__note {
  margin: 0.5rem 0 0;
  color: var(--impark-color-muted);
}

/* Dauermiete steps */
.impark-dauermiete-steps {
  margin: 2rem 0;
}

.impark-dauermiete-steps__title {
  margin: 0 0 1rem;
  font-size: 1.5rem;
}

.impark-dauermiete-steps__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.85rem;
}

@media (min-width: 768px) {
  .impark-dauermiete-steps__list {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

.impark-dauermiete-step {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--impark-color-border);
  border-radius: var(--impark-radius-sm);
  background: #fff;
}

.impark-dauermiete-step__num {
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--impark-color-bg);
  color: #fff;
  border-radius: 999px;
  font-weight: 700;
}

.impark-dauermiete-step__title {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
}

.impark-dauermiete-step__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  background: #fef3c7;
  color: #92400e;
  font-size: 0.75rem;
  font-weight: 600;
}

.impark-dauermiete-step__text {
  margin: 0;
  font-size: 0.92rem;
  color: var(--impark-color-muted);
}

.impark-dauermiete-steps__cta,
.impark-dauermiete-steps__note {
  margin-top: 1rem;
}

.impark-dauermiete-steps__note {
  color: var(--impark-color-muted);
}

/* FAQ – an das Mockup angeglichen: schmale, ZENTRIERTE Spalte, Mono-Kicker als
   Gruppentitel (Bernstein), Einträge als feine Trennlinien (keine Karten), blauer
   Chevron, Archivo-Titel. Diese Datei wird vom Shortcode spät (Footer) geladen und
   ist damit die maßgebliche Quelle – daher hier die endgültige Optik. */
.impark-faq { max-width: 780px; margin: 0 auto; padding: .5rem 24px 2.5rem;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif; color: #1f2733; }
.impark-faq__title { font-family: 'Archivo', system-ui, sans-serif; font-size: clamp(1.6rem,3.4vw,2rem);
  font-weight: 800; color: #0c1428; margin: 0 0 1.7rem; text-align: center; letter-spacing: -.02em; }
.impark-faq__group { margin: 0 0 1.9rem; }
.impark-faq__group-title { font-family: 'Spline Sans Mono', ui-monospace, monospace; font-size: .74rem;
  font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: #d98a16; margin: 0 0 .35rem; padding: 0; border: 0; }
.impark-faq__list { display: block; }
.impark-faq__item { border: 0; border-bottom: 1px solid rgba(12,20,40,.12); border-radius: 0;
  background: transparent; padding: 0; overflow: hidden; box-shadow: none; }
.impark-faq__item[open] { box-shadow: none; border-color: rgba(12,20,40,.12); }
.impark-faq__question { cursor: pointer; list-style: none; display: flex; align-items: center;
  justify-content: space-between; gap: 1rem; padding: 16px 8px 16px 0; font-size: 1rem; font-weight: 600; color: #0c1428; outline: 0; }
.impark-faq__question::-webkit-details-marker { display: none; }
.impark-faq__question::after { content: ""; flex: 0 0 auto; width: .6rem; height: .6rem;
  border-right: 2px solid #2b7fe2; border-bottom: 2px solid #2b7fe2; transform: rotate(45deg);
  transition: transform .2s ease; margin-top: -3px; }
.impark-faq__item[open] .impark-faq__question::after { transform: rotate(-135deg); border-color: #1f63c0; }
.impark-faq__item:hover .impark-faq__question { color: #1f63c0; }
.impark-faq__question:focus-visible { outline: 2px solid #2b7fe2; outline-offset: 2px; border-radius: 6px; }
.impark-faq__answer { margin: 0; padding: 0 0 18px; color: #3f4654; line-height: 1.65; font-size: .95rem; }

/* Owner trust */
.impark-owner-trust {
  margin: 2rem 0;
  padding: 1.5rem 1.6rem;
  border-radius: var(--impark-radius);
  background: linear-gradient(180deg, #0b1220 0%, #111c33 100%);
  color: #e2e8f0;
}

.impark-owner-trust__title {
  margin: 0 0 0.5rem;
  font-size: 1.5rem;
  color: #f8fafc;
}

.impark-owner-trust__subtitle {
  margin: 0 0 1rem;
  color: rgba(226, 232, 240, 0.85);
}

.impark-owner-trust__kpis {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.impark-owner-trust__kpi {
  background: rgba(255, 255, 255, 0.06);
  border-radius: var(--impark-radius-sm);
  padding: 0.85rem 1rem;
}

.impark-owner-trust__kpi-value {
  display: block;
  font-size: 1.5rem;
  font-weight: 700;
  color: #f8fafc;
}

.impark-owner-trust__kpi-label {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.85rem;
  color: rgba(226, 232, 240, 0.8);
}

.impark-owner-trust__cta { margin: 0.5rem 0 0; }
.impark-owner-trust .impark-cta-button--ghost {
  border-color: rgba(248, 250, 252, 0.6);
  color: #f8fafc !important;
}

/* ===== IMPark Profile hub (v3.7.0) ===== */
.impark-profile__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin:1.4rem 0}
.impark-profile__card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.2rem 1.3rem;box-shadow:0 12px 26px -22px rgba(15,52,96,.45)}
.impark-profile__card-h{margin:0 0 .55rem;font-size:1.12rem;color:#0c1428}
.impark-profile__safe,.impark-profile__empty{margin:0 0 .8rem;color:#475569;font-size:.98rem;line-height:1.55}
.impark-profile__empty{color:#64748b}
.impark-profile__status{margin:1.6rem 0}
.impark-profile__continue{display:flex;flex-wrap:wrap;gap:.7rem;margin:1.4rem 0 .4rem}
@media(max-width:680px){.impark-profile__grid{grid-template-columns:1fr}}
/* ===== /IMPark Profile hub ===== */

/* ===== IMPark Profile hub — v3.12.1 read-only visual polish ===== */
/* Contained dark gradient hero (the profile reused .impark-mv__hero, which was
   only styled under .impark-mein-vertrag, so on /profil/ it rendered unstyled). */
.impark-profile .impark-mv__hero{ margin:-1.75rem -1.75rem 1.6rem; padding:clamp(2rem,4vw,3rem) clamp(1.4rem,3vw,2.4rem);
  border-radius:14px 14px 0 0; position:relative; overflow:hidden; isolation:isolate; color:#eef4ff;
  background:radial-gradient(140% 120% at 100% 0%, rgba(16,185,129,.28) 0%, transparent 46%),
    radial-gradient(130% 150% at -8% 0%, rgba(59,130,246,.5) 0%, transparent 52%),
    linear-gradient(135deg,#060e1d 0%,#0e2039 55%,#060e1d 100%); }
.impark-profile .impark-mv__hero::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:5px;
  background:linear-gradient(90deg,#10b981 0%,#3b82f6 55%,#10b981 100%); }
.impark-profile .impark-spl__hero-eyebrow{ display:inline-flex; align-items:center; gap:.5rem; margin:0 0 .85rem;
  padding:.32rem .8rem; border-radius:999px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16);
  color:#a5f3e0; font-weight:700; font-size:.72rem; letter-spacing:.07em; text-transform:uppercase; }
.impark-profile .impark-spl__hero-eyebrow::before{ content:""; width:.5rem; height:.5rem; border-radius:50%;
  background:#10b981; box-shadow:0 0 0 4px rgba(16,185,129,.25); }
.impark-profile .impark-spl__hero-title{ margin:.1rem 0 .5rem; font-size:clamp(1.8rem,3.4vw,2.6rem); font-weight:800; color:#fff; line-height:1.12; }
.impark-profile .impark-spl__hero-sub{ margin:0; color:rgba(238,244,255,.85); font-size:clamp(1rem,1.4vw,1.18rem); }

/* Richer cards: accent dot title, hover lift, responsive auto-fit grid. */
.impark-profile__grid{ grid-template-columns:repeat(auto-fit,minmax(280px,1fr)) !important; gap:1.1rem !important; }
.impark-profile__card{ border:1px solid #e6ebf3 !important; border-radius:16px !important; padding:1.4rem 1.45rem !important;
  box-shadow:0 1px 2px rgba(15,23,42,.05),0 14px 30px -24px rgba(15,52,96,.5) !important;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.impark-profile__card:hover{ transform:translateY(-2px); border-color:#cdd9ee !important;
  box-shadow:0 2px 4px rgba(15,23,42,.06),0 20px 40px -24px rgba(15,52,96,.6) !important; }
.impark-profile__card-h{ display:flex; align-items:center; gap:.55rem; font-weight:800; }
.impark-profile__card-h::before{ content:""; width:.7rem; height:.7rem; border-radius:3px; flex:0 0 auto;
  background:linear-gradient(135deg,#10b981,#3b82f6); }
.impark-profile__safe,.impark-profile__empty{ font-size:.96rem; line-height:1.6; }

/* Status + continue sections framed cleanly. */
.impark-profile__status{ margin:1.8rem 0 0; }
.impark-profile__status > .impark-profile__card-h{ margin-bottom:.85rem; }
.impark-profile__continue{ gap:.7rem !important; margin-top:1.7rem !important; padding-top:1.4rem; border-top:1px solid #eef2f7; }
.impark-profile .impark-spl__small{ color:#94a3b8; margin-top:1rem; }

/* Two working cards side by side (Meine Stellplätze + Anfragen-Status). */
.impark-profile__cols{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; align-items:start; margin:1.4rem 0; }
@media(max-width:820px){ .impark-profile__cols{ grid-template-columns:1fr; } }
.impark-profile__cols .impark-profile__status{ margin:0; }
.impark-profile__cols .impark-profile__status .impark-status-view{ margin:0; box-shadow:none; border:0; padding:0; }
.impark-profile__cols .impark-profile__card{ display:flex; flex-direction:column; }
/* ===== /IMPark Profile hub v3.12.1 ===== */

/* ===== Availability status chips (P4-004) — colour + text, accessible ===== */
.impark-standort-availability { margin: 0.45rem 0; }
.impark-status-chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.25rem 0.65rem; border-radius: 999px;
  font-size: 0.85rem; font-weight: 600; line-height: 1.2;
  border: 1px solid transparent;
}
.impark-status-chip__dot { width: 0.55rem; height: 0.55rem; border-radius: 50%; background: currentColor; flex: 0 0 auto; }
.impark-status-chip--available { background: #e7f6ec; color: #15803d; border-color: #b6e3c4; }
.impark-status-chip--none { background: #f1f3f5; color: #4b5563; border-color: #d7dee8; }
.impark-status-chip--ev { background: #e8f1fe; color: #2b7fe2; border-color: #bcd4fb; }
