/* =========================================================================
   Taxi Planer – Marketing-Website
   Design-System (Picktime-inspiriert: luftig, Pastell-Lavendel, Pills)
   Anbieter: Ipsom GmbH (Österreich)
   ========================================================================= */

/* ------------------------------ Tokens ------------------------------ */
:root {
  /* Brand */
  --brand:        #6C5CE7;   /* soft indigo */
  --brand-600:    #5B4BD6;
  --brand-700:    #4B3CC4;
  --brand-soft:   #EFEDFC;   /* light lavender wash */

  /* Ink / text */
  --ink:          #1B1C39;   /* deep indigo-navy */
  --ink-2:        #3A3B57;
  --muted:        #6B6C84;
  --muted-2:      #9799AD;

  /* Surfaces */
  --bg:           #ffffff;
  --bg-soft:      #F6F6FC;   /* page soft sections */
  --bg-lav:       #F1EFFB;   /* lavender section */
  --border:       #ECECF4;
  --border-2:     #E2E2EE;

  /* Pastel card tints */
  --tint-lav:     #EFEEFB;
  --tint-blue:    #E9F1FC;
  --tint-pink:    #FBEDF4;
  --tint-mint:    #E9F6F0;
  --tint-peach:   #FCF1E8;
  --tint-sky:     #E8F4FB;

  /* Effects */
  --radius:       18px;
  --radius-lg:    26px;
  --radius-sm:    12px;
  --radius-pill:  999px;
  --shadow-sm:    0 2px 8px rgba(27,28,57,.05);
  --shadow:       0 12px 34px rgba(27,28,57,.08);
  --shadow-lg:    0 30px 70px rgba(27,28,57,.14);
  --ring:         0 0 0 4px rgba(108,92,231,.18);

  /* Type */
  --font-head: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Layout */
  --maxw: 1140px;
  --gut: 24px;
}

/* ------------------------------ Reset ------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink-2);
  background: var(--bg);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { max-width: 100%; display: block; }
a { color: var(--brand-600); text-decoration: none; }
a:hover { color: var(--brand-700); }
h1, h2, h3, h4 { font-family: var(--font-head); color: var(--ink); line-height: 1.15; margin: 0 0 .5em; font-weight: 800; letter-spacing: -.02em; }
h1 { font-size: clamp(2.2rem, 5vw, 3.4rem); }
h2 { font-size: clamp(1.7rem, 3.4vw, 2.5rem); }
h3 { font-size: 1.25rem; }
p  { margin: 0 0 1rem; }
ul { margin: 0; padding: 0; }

/* ------------------------------ Layout ------------------------------ */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.section { padding: 88px 0; }
.section--soft { background: var(--bg-soft); }
.section--lav  { background: linear-gradient(180deg, #F4F2FD 0%, #FAFAFE 100%); }
.section-head { max-width: 660px; margin: 0 auto 52px; text-align: center; }
.section-head p { color: var(--muted); font-size: 1.05rem; margin: 0; }
.eyebrow {
  display: inline-block; font-family: var(--font-head); font-weight: 700;
  font-size: .78rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--brand-600); background: var(--brand-soft);
  padding: 6px 14px; border-radius: var(--radius-pill); margin-bottom: 18px;
}
.lead { font-size: 1.15rem; color: var(--muted); }

/* ------------------------------ Buttons ------------------------------ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-head); font-weight: 700; font-size: .98rem;
  padding: 13px 26px; border-radius: var(--radius-pill);
  border: 1px solid transparent; cursor: pointer; transition: .18s ease;
  white-space: nowrap;
}
.btn-primary { background: var(--brand); color: #fff; box-shadow: 0 10px 24px rgba(108,92,231,.32); }
.btn-primary:hover { background: var(--brand-600); color: #fff; transform: translateY(-2px); box-shadow: 0 16px 30px rgba(108,92,231,.38); }
.btn-ghost { background: #fff; color: var(--ink); border-color: var(--border-2); }
.btn-ghost:hover { border-color: var(--brand); color: var(--brand-700); transform: translateY(-2px); }
.btn-light { background: rgba(255,255,255,.16); color: #fff; border-color: rgba(255,255,255,.4); }
.btn-light:hover { background: rgba(255,255,255,.26); color: #fff; }
.btn-lg { padding: 16px 32px; font-size: 1.05rem; }
.btn-block { width: 100%; }

/* ------------------------------ Navbar ------------------------------ */
.nav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,.82); backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav__inner { display: flex; align-items: center; gap: 28px; height: 72px; }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-head); font-weight: 800; font-size: 1.18rem; color: var(--ink); letter-spacing: -.02em; }
.brand:hover { color: var(--ink); }
.brand__logo { width: 34px; height: 34px; }
.nav__links { display: flex; gap: 26px; margin-left: 14px; list-style: none; }
.nav__links a { color: var(--ink-2); font-weight: 600; font-size: .96rem; }
.nav__links a:hover, .nav__links a.is-active { color: var(--brand-700); }
.nav__right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.lang { display: inline-flex; align-items: center; gap: 2px; background: var(--bg-soft); border-radius: var(--radius-pill); padding: 4px; }
.lang a { font-size: .82rem; font-weight: 700; padding: 5px 11px; border-radius: var(--radius-pill); color: var(--muted); }
.lang a.is-active { background: #fff; color: var(--brand-700); box-shadow: var(--shadow-sm); }
.nav__toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav__toggle span { display: block; width: 22px; height: 2px; background: var(--ink); margin: 4px 0; border-radius: 2px; transition: .2s; }

/* ------------------------------ Hero ------------------------------ */
.hero {
  position: relative; text-align: center; overflow: hidden;
  padding: 70px 0 0;
  background:
    radial-gradient(60% 70% at 50% 0%, #ECE8FB 0%, rgba(236,232,251,0) 60%),
    linear-gradient(180deg, #F3F1FD 0%, #FBFBFE 70%);
}
.hero__inner { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; }
.hero h1 { margin-bottom: 18px; }
.hero h1 .hl { color: var(--brand); }
.hero__sub { font-size: 1.18rem; color: var(--muted); max-width: 560px; margin: 0 auto 28px; }
.hero__cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 12px; }
.hero__note { font-size: .9rem; color: var(--muted-2); }
.hero__stage { position: relative; margin-top: 54px; padding-bottom: 90px; }

/* floating decorative chips */
.float { position: absolute; z-index: 2; background: #fff; border-radius: 14px; box-shadow: var(--shadow); padding: 10px 14px; display: flex; align-items: center; gap: 9px; font-family: var(--font-head); font-weight: 700; font-size: .8rem; color: var(--ink); animation: bob 6s ease-in-out infinite; }
.float .dot { width: 26px; height: 26px; border-radius: 8px; display: grid; place-items: center; font-size: .9rem; }
.float--1 { top: 6%;  left: 4%;  animation-delay: .0s; }
.float--2 { top: 22%; right: 3%; animation-delay: .8s; }
.float--3 { bottom: 30%; left: 1%; animation-delay: 1.6s; }
.float--4 { bottom: 18%; right: 6%; animation-delay: 1.2s; }
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

/* ------------------------------ App mockups (CSS) ------------------------------ */
.mockwin {
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); overflow: hidden; text-align: left;
}
.mockwin__bar { display: flex; align-items: center; gap: 7px; padding: 12px 16px; background: #FAFAFE; border-bottom: 1px solid var(--border); }
.mockwin__bar i { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.mockwin__bar i:nth-child(1){ background:#FF6058; } .mockwin__bar i:nth-child(2){ background:#FFBD2E; } .mockwin__bar i:nth-child(3){ background:#28C840; }
.mockwin__url { margin-left: 12px; font-size: .72rem; color: var(--muted-2); background:#fff; border:1px solid var(--border); border-radius: 8px; padding: 3px 12px; font-family: var(--font-body); }

/* hero overlapping stage */
.stage-cards { position: relative; max-width: 920px; margin: 0 auto; z-index: 1; }
.stage-cards .mockwin { position: relative; }
.stage-cards .card-main { z-index: 3; }
.stage-cards .card-side { position: absolute; top: 40px; width: 300px; z-index: 1; }
.stage-cards .card-left  { left: -90px; transform: rotate(-6deg); }
.stage-cards .card-right { right: -90px; transform: rotate(6deg); }

/* generic faux-ui pieces */
.ui-pad { padding: 18px; }
.ui-row { display: flex; align-items: center; gap: 12px; }
.ui-title { font-family: var(--font-head); font-weight: 800; color: var(--ink); font-size: 1rem; }
.ui-sub { font-size: .78rem; color: var(--muted-2); }
.ui-bar { height: 9px; border-radius: 6px; background: var(--bg-soft); }
.ui-bar.w70{width:70%} .ui-bar.w50{width:50%} .ui-bar.w90{width:90%} .ui-bar.w40{width:40%} .ui-bar.w60{width:60%}
.ui-chip { font-size: .7rem; font-weight: 700; padding: 4px 10px; border-radius: var(--radius-pill); font-family: var(--font-head); }
.chip-green { background: var(--tint-mint); color: #1B8A5A; }
.chip-amber { background: var(--tint-peach); color: #B26B12; }
.chip-blue  { background: var(--tint-blue); color: var(--brand-700); }
.ui-step { display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--border); border-radius:12px; margin-bottom:8px; }
.ui-step .n { width:24px;height:24px;border-radius:50%;background:var(--brand-soft);color:var(--brand-700);font-weight:800;font-size:.78rem;display:grid;place-items:center;font-family:var(--font-head); }
.ui-step.is-done .n { background: var(--brand); color:#fff; }
.ui-price { font-family: var(--font-head); font-weight:800; color: var(--ink); font-size:1.5rem; }
.ui-avatars { display:flex; }
.ui-avatars span { width:28px;height:28px;border-radius:50%;border:2px solid #fff;margin-left:-8px;background:var(--brand-soft); display:grid;place-items:center;font-size:.7rem;font-weight:700;color:var(--brand-700); }
.ui-avatars span:first-child{margin-left:0}

/* ------------------------------ Feature cards (pastel grid) ------------------------------ */
.grid { display: grid; gap: 22px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.fcard {
  border-radius: var(--radius-lg); padding: 28px; border: 1px solid rgba(27,28,57,.04);
  position: relative; overflow: hidden; transition: .2s ease;
}
.fcard:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.fcard .ic { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; background: #fff; box-shadow: var(--shadow-sm); margin-bottom: 18px; }
.fcard h3 { margin-bottom: 8px; }
.fcard p { color: var(--muted); font-size: .96rem; margin: 0; }
.t-lav{background:var(--tint-lav)} .t-blue{background:var(--tint-blue)} .t-pink{background:var(--tint-pink)}
.t-mint{background:var(--tint-mint)} .t-peach{background:var(--tint-peach)} .t-sky{background:var(--tint-sky)}

/* small feature pill row */
.pill-feats { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.pill-feat { display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--border); border-radius:var(--radius-pill); padding:9px 18px; font-weight:600; font-size:.92rem; color:var(--ink-2); box-shadow:var(--shadow-sm); }

/* ------------------------------ Stats ------------------------------ */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.stat .num { font-family: var(--font-head); font-weight: 800; font-size: clamp(2rem,4vw,2.8rem); color: var(--brand); letter-spacing: -.03em; }
.stat .lbl { color: var(--muted); font-size: .95rem; }

/* ------------------------------ Steps (So funktioniert's) ------------------------------ */
.steps { counter-reset: step; display: grid; gap: 20px; }
.step { display: grid; grid-template-columns: 56px 1fr; gap: 18px; align-items: start; background:#fff; border:1px solid var(--border); border-radius: var(--radius); padding: 22px 24px; }
.step__n { width: 46px; height: 46px; border-radius: 14px; background: var(--brand-soft); color: var(--brand-700); display: grid; place-items: center; font-family: var(--font-head); font-weight: 800; font-size: 1.25rem; }
.step h3 { margin-bottom: 4px; }
.step p { margin: 0; color: var(--muted); font-size: .96rem; }

/* split (text + mockup) */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split--rev .split__media { order: -1; }
.split__media { position: relative; }
.split ul.checks { list-style: none; margin: 18px 0 0; }
.checks li { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 12px; color: var(--ink-2); }
.checks li svg { flex: 0 0 22px; margin-top: 3px; }

/* ------------------------------ Phone mockup ------------------------------ */
.phone {
  width: 270px; border-radius: 38px; background: #11122B; padding: 12px;
  box-shadow: var(--shadow-lg); position: relative;
}
.phone::before { content:""; position:absolute; top:18px; left:50%; transform:translateX(-50%); width:120px; height:24px; background:#11122B; border-radius:0 0 16px 16px; z-index:3; }
.phone__screen { background: #F6F6FC; border-radius: 28px; overflow: hidden; }
.phone__top { background: var(--brand); color:#fff; padding: 34px 18px 18px; }
.phone__top .ui-title { color:#fff; }
.phone__top .ui-sub { color: rgba(255,255,255,.8); }
.phone__body { padding: 16px; }
.app-card { background:#fff; border-radius:14px; box-shadow:var(--shadow-sm); padding:14px; margin-bottom:12px; }
.app-btns { display:flex; gap:8px; }
.app-btns .b { flex:1; text-align:center; font-family:var(--font-head); font-weight:700; font-size:.74rem; padding:9px; border-radius:10px; }
.b-call{ background:var(--tint-mint); color:#1B8A5A; } .b-nav{ background:var(--tint-blue); color:var(--brand-700); } .b-wa{ background:var(--tint-peach); color:#B26B12; }

.phones { display:flex; justify-content:center; gap:32px; flex-wrap:wrap; }
.phone--back { transform: translateY(28px) rotate(-4deg) scale(.92); opacity:.96; }
.phone--front { transform: rotate(3deg); z-index:2; }

/* ------------------------------ Audience cards ------------------------------ */
.aud { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.aud__card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:28px; text-align:center; transition:.2s; }
.aud__card:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.aud__ic { width:64px;height:64px;border-radius:18px;margin:0 auto 16px;display:grid;place-items:center;font-size:1.7rem; }

/* ------------------------------ 1-Klick Flow (Annehmen/Ablehnen) ------------------------------ */
.oneclick { background: linear-gradient(135deg, #F4F2FD 0%, #FBF7FB 100%); border:1px solid var(--border); border-radius: var(--radius-lg); padding: 44px; }
.flow { display:grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items:center; margin-top: 8px; }
.flow__arrow { color: var(--brand); display:grid; place-items:center; }
.flow__arrow svg { width: 44px; height: 44px; }
.req-card { background:#fff; border:1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); padding: 20px; }
.req-card__top { display:flex; align-items:center; justify-content:space-between; margin-bottom: 14px; }
.bigbtns { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:16px; }
.bigbtn { display:flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-head); font-weight:800; font-size:.95rem; padding:13px; border-radius:12px; border:1px solid transparent; }
.bigbtn--yes { background:#1FAE6B; color:#fff; box-shadow:0 8px 18px rgba(31,174,107,.3); }
.bigbtn--no { background:#fff; color:var(--muted); border-color:var(--border-2); }
.mailout { background:#fff; border:1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); padding: 20px; }
.mailout__hd { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.mailout__hd .ic-mail { width:38px;height:38px;border-radius:11px;background:var(--tint-mint);display:grid;place-items:center;font-size:1.1rem; }
@media (max-width: 760px){
  .oneclick { padding: 28px 20px; }
  .flow { grid-template-columns: 1fr; }
  .flow__arrow { transform: rotate(90deg); }
}

/* ------------------------------ CTA band ------------------------------ */
.cta-band { background: linear-gradient(135deg, #6C5CE7 0%, #8B5CF6 55%, #A855F7 100%); border-radius: var(--radius-lg); padding: 60px; text-align: center; color:#fff; position: relative; overflow: hidden; }
.cta-band::after { content:""; position:absolute; inset:0; background: radial-gradient(40% 60% at 80% 20%, rgba(255,255,255,.18), transparent 60%); }
.cta-band > * { position: relative; z-index:1; }
.cta-band h2 { color:#fff; }
.cta-band p { color: rgba(255,255,255,.9); max-width: 520px; margin: 0 auto 26px; }

/* ------------------------------ Forms ------------------------------ */
.form { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding: 34px; box-shadow: var(--shadow-sm); }
.field { margin-bottom: 18px; }
.field label { display:block; font-family:var(--font-head); font-weight:700; font-size:.86rem; color:var(--ink); margin-bottom:7px; }
.field .req { color: var(--brand); }
.input, .textarea, .select {
  width:100%; font-family:var(--font-body); font-size:1rem; color:var(--ink);
  border:1px solid var(--border-2); border-radius:12px; padding:12px 14px; background:#fff; transition:.15s;
}
.input:focus, .textarea:focus, .select:focus { outline:none; border-color:var(--brand); box-shadow: var(--ring); }
.textarea { min-height: 120px; resize: vertical; }
.row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.hp { position:absolute; left:-9999px; top:-9999px; }
.form__ok { display:none; background:var(--tint-mint); color:#1B7A50; border-radius:12px; padding:14px 16px; font-weight:600; margin-bottom:18px; }
.consent { font-size:.84rem; color:var(--muted); display:flex; gap:10px; align-items:flex-start; }
.consent input { margin-top:5px; }

.contact-grid { display:grid; grid-template-columns: 1fr 1.2fr; gap:44px; align-items:start; }
.contact-info .ci { display:flex; gap:14px; align-items:flex-start; margin-bottom:22px; }
.contact-info .ci__ic { width:46px;height:46px;border-radius:13px;background:var(--brand-soft);display:grid;place-items:center;flex:0 0 46px; }
.contact-info .ci__t { font-family:var(--font-head);font-weight:700;color:var(--ink); }
.contact-info .ci__v { color:var(--muted); font-size:.95rem; }

/* ------------------------------ Logos / trust ------------------------------ */
.trust { text-align:center; }
.trust__row { display:flex; flex-wrap:wrap; justify-content:center; gap:34px; align-items:center; margin-top:10px; opacity:.7; }
.trust__row span { font-family:var(--font-head); font-weight:800; color:var(--muted-2); font-size:1.25rem; letter-spacing:-.02em; }

/* ------------------------------ Legal / prose ------------------------------ */
.prose { max-width: 780px; margin: 0 auto; }
.prose h2 { font-size: 1.5rem; margin-top: 2em; }
.prose h3 { margin-top: 1.6em; }
.prose p, .prose li { color: var(--ink-2); }
.prose ul { padding-left: 1.2em; margin-bottom: 1rem; list-style: disc; }
.page-head { background: linear-gradient(180deg,#F3F1FD,#FBFBFE); text-align:center; padding: 64px 0 40px; }
.page-head h1 { margin-bottom: 10px; }
.page-head p { color: var(--muted); max-width: 580px; margin: 0 auto; }

/* ------------------------------ Footer ------------------------------ */
.footer { background: #14152E; color: #C9CAE0; padding: 64px 0 30px; }
.footer a { color:#C9CAE0; } .footer a:hover { color:#fff; }
.footer__top { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; padding-bottom: 40px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer .brand { color:#fff; margin-bottom: 14px; }
.footer__about { font-size:.92rem; color:#9A9CBE; max-width: 280px; }
.footer h4 { color:#fff; font-size:.95rem; margin-bottom: 14px; }
.footer ul { list-style:none; }
.footer ul li { margin-bottom: 9px; font-size:.92rem; }
.footer__bottom { display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding-top: 22px; font-size:.85rem; color:#8284A6; }
.footer__bottom a { color:#8284A6; }

/* ------------------------------ Utilities ------------------------------ */
.text-center { text-align:center; }
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-32{margin-top:32px}.mt-40{margin-top:40px}
.reveal { opacity:0; transform: translateY(18px); transition: .6s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity:1; transform:none; }

/* ------------------------------ Responsive ------------------------------ */
@media (max-width: 960px) {
  .split { grid-template-columns: 1fr; gap: 36px; }
  .split--rev .split__media { order: 0; }
  .grid-4 { grid-template-columns: repeat(2,1fr); }
  .stats { grid-template-columns: repeat(2,1fr); }
  .aud { grid-template-columns: repeat(2,1fr); }
  .footer__top { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .stage-cards .card-side { display:none; }
}
@media (max-width: 760px) {
  .section { padding: 60px 0; }
  .nav__links, .nav__right .btn { display: none; }
  .nav__toggle { display: block; }
  .nav.open .nav__links { display: flex; position: absolute; top: 72px; left:0; right:0; flex-direction: column; background:#fff; padding: 18px 24px; gap: 16px; border-bottom:1px solid var(--border); box-shadow: var(--shadow); }
  .nav.open .nav__links { margin: 0; }
  .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .row-2 { grid-template-columns: 1fr; }
  .cta-band { padding: 40px 24px; }
  .footer__top { grid-template-columns: 1fr; }
}
@media (max-width: 460px) {
  .grid-4, .stats, .aud { grid-template-columns: 1fr; }
}
