/* DM Sans (selbst gehostet, DSGVO-konform) */
@font-face{font-family:"DM Sans";font-style:normal;font-display:swap;font-weight:100 1000;
  src:url("../fonts/dm-sans-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"DM Sans";font-style:normal;font-display:swap;font-weight:100 1000;
  src:url("../fonts/dm-sans-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}

:root{
    --purple:#6B46C1; --purple-dk:#553398; --purple-lt:#f1ecfb;
    --gold:#FBB040; --gold-dk:#e09a23;
    --mint:#10B981; --mint-dk:#0c9a6c;
    --graphit:#1F2937; --ink:#2a2f3a; --muted:#6b7280;
    --crm:#0EA5E9; --ept:#EF4444; --msg:#805AD5; --support:#10B981; --wbw:#F59E0B; --aio:#6B46C1;
    --cream:#FFFCF6; --card:#ffffff; --line:#ece7df;
    --shadow:0 10px 30px rgba(31,41,55,.08); --shadow-lg:0 24px 60px rgba(85,51,152,.16);
    --r:18px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:"DM Sans",system-ui,sans-serif;color:var(--ink);background:var(--cream);
    line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  .wrap{width:min(1180px,92vw);margin:0 auto}
  section{padding:84px 0}
  h1,h2,h3{line-height:1.12;letter-spacing:-.02em;color:var(--graphit)}
  .eyebrow{font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--purple)}

  /* NAV */
  header{position:sticky;top:0;z-index:50;background:rgba(255,252,246,.82);
    backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:.25s}
  header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(31,41,55,.05)}
  nav{display:flex;align-items:center;gap:18px;height:74px}
  .logo{display:flex;align-items:center;gap:10px;font-weight:800}
  .logo img{height:42px;width:42px;border-radius:11px;box-shadow:0 4px 12px rgba(224,154,35,.35)}
  .logo b{font-size:19px;color:var(--graphit)}
  .logo b span{color:var(--purple)}
  .navlinks{display:flex;gap:6px;margin-left:auto}
  .navlinks a{padding:9px 13px;border-radius:10px;font-weight:500;font-size:15px;color:var(--ink);transition:.18s}
  .navlinks a:hover{background:var(--purple-lt);color:var(--purple)}
  .navtools{display:flex;align-items:center;gap:10px}
  .lang{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
  .lang button{border:0;background:none;font:inherit;font-size:13px;font-weight:700;padding:7px 9px;cursor:pointer;color:var(--muted)}
  .lang button.active{background:var(--purple);color:#fff}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-weight:700;
    border:0;border-radius:12px;padding:12px 20px;cursor:pointer;font-size:15px;transition:.2s;white-space:nowrap}
  .btn-purple{background:var(--purple);color:#fff;box-shadow:0 8px 22px rgba(107,70,193,.28)}
  .btn-purple:hover{background:var(--purple-dk);transform:translateY(-2px)}
  .btn-gold{background:var(--gold);color:#3a2a08;box-shadow:0 8px 22px rgba(251,176,64,.34)}
  .btn-gold:hover{background:var(--gold-dk);transform:translateY(-2px)}
  .btn-mint{background:var(--mint);color:#fff;box-shadow:0 8px 22px rgba(16,185,129,.28)}
  .btn-mint:hover{background:var(--mint-dk);transform:translateY(-2px)}
  .btn-ghost{background:#fff;color:var(--purple);border:1.5px solid var(--purple-lt)}
  .btn-ghost:hover{border-color:var(--purple)}
  .burger{display:none;border:1px solid var(--line);background:#fff;border-radius:10px;width:44px;height:44px;cursor:pointer;align-items:center;justify-content:center}
  .burger svg{width:22px;height:22px;stroke:var(--graphit)}

  /* HERO */
  .hero{position:relative;padding:64px 0 72px;
    background:
      radial-gradient(900px 460px at 78% -8%, rgba(251,176,64,.55), transparent 60%),
      radial-gradient(700px 520px at 6% 110%, rgba(107,70,193,.10), transparent 60%),
      var(--cream);
    overflow:hidden}
  .hero .grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
  .hero h1{font-size:clamp(34px,5.2vw,60px);font-weight:800;margin:18px 0 18px}
  .hero h1 .g{color:var(--gold-dk)} .hero h1 .m{color:var(--mint)}
  .hero p.lead{font-size:clamp(17px,2vw,21px);color:var(--ink);max-width:520px;margin-bottom:28px}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
  .hero-note{margin-top:18px;font-size:14px;color:var(--muted);display:flex;gap:18px;flex-wrap:wrap}
  .hero-note span{display:inline-flex;align-items:center;gap:7px}
  .hero-note svg{width:16px;height:16px;stroke:var(--mint);stroke-width:2.5;fill:none}
  .hero-art{position:relative;display:flex;justify-content:center}
  .hero-card{background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);padding:22px;width:100%;max-width:380px;border:1px solid var(--line)}
  .hero-card .badge{display:inline-block;background:var(--purple-lt);color:var(--purple);font-weight:700;font-size:12px;padding:5px 11px;border-radius:999px;letter-spacing:.04em}
  .hero-card .mini{display:flex;align-items:center;gap:12px;padding:13px;border-radius:14px;background:var(--cream);margin-top:12px}
  .hero-card .dot{width:38px;height:38px;border-radius:11px;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}
  .hero-card .mini b{display:block;font-size:15px;color:var(--graphit)}
  .hero-card .mini small{color:var(--muted);font-size:13px}
  .float{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
    padding:10px 14px;font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
  .float.one{top:-14px;left:-6px;color:var(--mint)} .float.two{bottom:-16px;right:6px;color:var(--gold-dk)}

  /* USP STRIP */
  .usp{background:var(--purple);color:#fff;padding:30px 0}
  .usp .row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
  .usp .item{display:flex;gap:11px;align-items:flex-start;font-size:14px;font-weight:500}
  .usp .item svg{width:22px;height:22px;flex:none;stroke:var(--gold);stroke-width:2.4;fill:none;margin-top:1px}

  /* SECTION HEAD */
  .shead{text-align:center;max-width:680px;margin:0 auto 52px}
  .shead h2{font-size:clamp(28px,3.6vw,42px);font-weight:800;margin:12px 0}
  .shead p{color:var(--muted);font-size:18px}

  /* MODULES */
  .mods{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .mod{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;
    position:relative;overflow:hidden;transition:.22s}
  .mod::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:var(--c)}
  .mod:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
  .mod .ic{width:50px;height:50px;border-radius:14px;background:var(--c);display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 8px 18px color-mix(in srgb,var(--c) 40%,transparent)}
  .mod .ic svg{width:26px;height:26px;stroke:#fff;stroke-width:2.2;fill:none}
  .mod h3{font-size:21px;font-weight:800;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
  .mod .tag{font-weight:600;color:var(--c);font-size:15px;margin:6px 0 14px}
  .mod ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:16px}
  .mod li{display:flex;gap:9px;font-size:14.5px;color:var(--ink)}
  .mod li svg{width:17px;height:17px;flex:none;stroke:var(--c);stroke-width:2.6;fill:none;margin-top:3px}
  .pill{font-size:11.5px;font-weight:800;letter-spacing:.04em;padding:4px 10px;border-radius:999px;text-transform:uppercase}
  .pill.live{background:#e7f9f1;color:var(--mint-dk)}
  .pill.soon{background:#fff3df;color:var(--gold-dk)}

  /* PRICING */
  .pricing{background:linear-gradient(180deg,#fff,var(--cream))}
  .toggle{display:flex;justify-content:center;margin-bottom:14px}
  .toggle .box{display:flex;background:#fff;border:1px solid var(--line);border-radius:14px;padding:5px;box-shadow:var(--shadow)}
  .toggle button{border:0;background:none;font:inherit;font-weight:700;font-size:15px;padding:11px 24px;border-radius:10px;cursor:pointer;color:var(--muted);transition:.2s}
  .toggle button.active.abo{background:var(--mint);color:#fff}
  .toggle button.active.kauf{background:var(--gold);color:#3a2a08}
  .pricenote{text-align:center;color:var(--muted);font-size:13.5px;margin-bottom:40px}
  .plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .plan{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:.22s}
  .plan:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
  .plan .ph{display:flex;align-items:center;gap:11px;margin-bottom:6px}
  .plan .ph .dot{width:34px;height:34px;border-radius:10px;background:var(--c);flex:none}
  .plan h3{font-size:19px;font-weight:800}
  .plan .sub{color:var(--muted);font-size:14px;margin-bottom:18px}
  .tier{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-top:1px dashed var(--line)}
  .tier .nm{font-weight:600;font-size:15px}
  .tier .pr{font-weight:800;font-size:19px;color:var(--graphit)}
  .tier .pr small{font-weight:600;font-size:13px;color:var(--muted)}
  .plan .foot{margin-top:18px}
  .plan.soon{opacity:.92;background:repeating-linear-gradient(135deg,#fff,#fff 12px,#fffaf0 12px,#fffaf0 24px)}
  .plan.soon .big{font-weight:800;font-size:17px;color:var(--gold-dk);margin:10px 0}

  /* VALUES */
  .values{background:var(--graphit);color:#fff}
  .values .shead h2{color:#fff} .values .shead p{color:#c8cdd6}
  .vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .vcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:24px}
  .vcard .ic{width:44px;height:44px;border-radius:12px;background:var(--purple);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
  .vcard .ic svg{width:23px;height:23px;stroke:var(--gold);stroke-width:2.2;fill:none}
  .vcard h3{color:#fff;font-size:18px;margin-bottom:6px}
  .vcard p{color:#aeb4bf;font-size:14.5px}


  /* CRAAS */
  .craas{background:radial-gradient(1000px 500px at 80% -10%,rgba(107,70,193,.45),transparent 60%),linear-gradient(180deg,#161f37,#1F2937);color:#fff;position:relative;overflow:hidden}
  .craas::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(600px 400px at 80% 0,#000,transparent 70%);pointer-events:none}
  .craas .wrap{position:relative;z-index:1}
  .craas-head{text-align:center;max-width:780px;margin:0 auto 40px}
  .craas-head .eyebrow{color:var(--gold)}
  .craas-head h2{color:#fff;font-size:clamp(28px,4.4vw,48px);margin:12px 0}
  .clead{color:#c6ccd8;font-size:18px;max-width:660px;margin:0 auto}
  .cpartner{margin-top:18px;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(251,176,64,.5);color:var(--gold);font-weight:700;font-size:13.5px;padding:7px 14px;border-radius:999px}
  .cbadges{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:0 0 40px}
  .cbadge{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:18px 14px;text-align:center}
  .cbadge .ic{font-size:26px;line-height:1}
  .cbadge .big{font-size:21px;font-weight:800;color:var(--gold);margin:7px 0 3px}
  .cbadge small{color:#aab0bd;font-size:12.5px}
  .cpillars{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:50px}
  .cpillar{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:22px}
  .cpillar .pic{font-size:24px;margin-bottom:10px}
  .cpillar h4{color:#fff;font-size:16px;margin-bottom:7px}
  .cpillar p{color:#a9afbb;font-size:13.5px;line-height:1.5}
  .ctiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
  .ctier{background:#fff;color:var(--ink);border-radius:20px;padding:28px 24px;position:relative;border:2px solid transparent;transition:.22s}
  .ctier:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
  .ctier.pop{border-color:var(--gold);box-shadow:0 24px 60px rgba(251,176,64,.28)}
  .ctier .pop-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:#3a2a08;font-weight:800;font-size:12px;padding:6px 16px;border-radius:999px;white-space:nowrap;letter-spacing:.03em}
  .ctier .cicon{font-size:32px;line-height:1}
  .ctier h3{font-size:23px;font-weight:800;margin:8px 0 2px}
  .ctier .aud{color:var(--muted);font-size:14px;margin-bottom:14px}
  .ctier .setup{font-size:14px;color:var(--ink)}
  .ctier .price{font-size:16px;color:var(--graphit);margin:6px 0 14px;line-height:1.4}
  .ctier .price b{font-size:24px}
  .ctier .price small{font-weight:600;font-size:13px;color:var(--muted)}
  .ctier ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin:6px 0 0}
  .ctier li{display:flex;gap:9px;font-size:14px}
  .ctier li svg{width:16px;height:16px;flex:none;stroke:var(--mint);stroke-width:2.8;fill:none;margin-top:3px}
  .ctier .forwhom{margin-top:16px;border-top:1px solid var(--line);padding-top:13px;font-size:12.5px;color:var(--muted)}
  .ceur{text-align:center;color:#9aa1ae;font-size:13px;margin:30px auto 0;max-width:640px}
  .caddons-h{color:#fff;text-align:center;font-size:24px;margin:64px 0 24px;font-weight:800}
  .caddons{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .caddon{display:flex;justify-content:space-between;gap:14px;align-items:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:15px 18px}
  .caddon .ca-main b{display:block;color:#fff;font-size:15px}
  .caddon .ca-main span{color:#a9afbb;font-size:13px}
  .caddon .ca-price{text-align:right;font-weight:800;color:var(--gold);font-size:14.5px;white-space:nowrap}
  .caddon .ca-price small{display:block;color:#8e95a2;font-weight:600;font-size:12px}
  .craas-cta{text-align:center;margin-top:40px}

  /* CTA */
  .final{text-align:center}
  .final .panel{background:radial-gradient(700px 300px at 50% -40%,rgba(251,176,64,.5),transparent 60%),var(--purple);
    border-radius:28px;padding:60px 32px;color:#fff;box-shadow:var(--shadow-lg)}
  .final h2{color:#fff;font-size:clamp(26px,3.4vw,40px);margin-bottom:14px}
  .final p{color:rgba(255,255,255,.88);font-size:18px;max-width:540px;margin:0 auto 28px}
  .final .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

  /* FOOTER */
  footer{background:#fff;border-top:1px solid var(--line);padding:46px 0 30px;font-size:14.5px}
  .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
  footer h4{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--purple);margin-bottom:14px}
  footer a{color:var(--muted);display:block;padding:4px 0;transition:.15s}
  footer a:hover{color:var(--purple)}
  .fbrand p{color:var(--muted);max-width:280px;margin:12px 0}
  .fbot{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--muted)}
  .heart{color:var(--purple)}

  .reveal{opacity:0;transform:translateY(22px);transition:.6s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  @media(max-width:980px){
    .hero .grid{grid-template-columns:1fr;gap:36px}
    .hero-art{order:-1}
    .mods,.plans,.vgrid{grid-template-columns:1fr 1fr}
    .usp .row{grid-template-columns:1fr 1fr 1fr}
    .fgrid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:680px){
    section{padding:60px 0}
    .navlinks{display:none}
    .burger{display:flex}
    .navtools .btn-purple{display:none}
    .mobile-menu{display:none;flex-direction:column;gap:4px;padding:10px 0 16px}
    .mobile-menu.open{display:flex}
    .mobile-menu a{padding:12px 8px;border-radius:10px;font-weight:600}
    .mobile-menu a:hover{background:var(--purple-lt)}
    .mods,.plans,.vgrid,.fgrid{grid-template-columns:1fr}
    .usp .row{grid-template-columns:1fr;gap:12px}
    .hero-cta .btn{flex:1}
  }

/* Lead-Formular */
.fpw-form{margin-top:26px;text-align:left;max-width:640px;margin-left:auto;margin-right:auto}
.fpw-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fpw-form label{display:block;font-size:14px;font-weight:600;color:#fff}
.fpw-form label.full{margin-top:14px}
.fpw-form input,.fpw-form select,.fpw-form textarea{width:100%;margin-top:6px;font:inherit;font-size:16px;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.96);color:var(--ink)}
.fpw-form textarea{resize:vertical}
.fpw-form .fpw-consent{display:flex;gap:10px;align-items:flex-start;margin-top:16px;font-weight:500;font-size:13.5px;color:rgba(255,255,255,.92)}
.fpw-form .fpw-consent input{width:auto;margin-top:3px}
.fpw-form .fpw-consent a{color:var(--gold);text-decoration:underline}
.fpw-form button[type=submit]{margin-top:18px}
.fpw-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.fpw-form-msg{margin-top:16px;padding:13px 16px;border-radius:12px;font-weight:600;font-size:14.5px}
.fpw-form-msg.is-ok{background:rgba(16,185,129,.18);border:1px solid var(--mint);color:#d7fff0}
.fpw-form-msg.is-err{background:rgba(239,68,68,.18);border:1px solid #ef4444;color:#ffe2e2}
.final .secondary-link{display:block;margin-top:18px;color:rgba(255,255,255,.82);text-decoration:underline;font-size:14px}
@media(max-width:680px){ .fpw-grid{grid-template-columns:1fr} }

/* CRaaS – mobile: Pakete als seitliches Swipe-Carousel, Rest reflow */
@media(max-width:680px){
  .cbadges{grid-template-columns:1fr 1fr}
  .cpillars{grid-template-columns:1fr}
  .caddons{grid-template-columns:1fr}
  .ctiers{display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:14px;padding:18px 2px 14px}
  .ctiers>.ctier{flex:0 0 85%;scroll-snap-align:center}
  .ctiers::-webkit-scrollbar{height:6px}
  .ctiers::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:999px}
}

/* Module + Preise - mobile: seitliches Swipe-Carousel */
@media(max-width:680px){
  .mods,.plans{display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px;padding:6px 2px 14px}
  .mods>.mod,.plans>.plan{flex:0 0 85%;scroll-snap-align:center}
  .mods::-webkit-scrollbar,.plans::-webkit-scrollbar{height:6px}
  .mods::-webkit-scrollbar-thumb,.plans::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}
}

/* EWT-Skin (Markt = ewt): East-West-Tours Genossenschaft, ohne CRaaS */
.fpw-root{background:var(--cream)}
.fpw-market-ewt{
  --purple:#3A7BC8; --purple-dk:#2f63a3; --purple-lt:#e8f0fa;
  --gold:#FF8C42; --gold-dk:#e6742a;
  --mint:#5FB574; --mint-dk:#4a9c60;
  --graphit:#2D3748; --ink:#2D3748;
  --cream:#F7F9FC;
}
.fpw-market-ewt .logo img{box-shadow:0 4px 12px rgba(58,123,200,.28)}
.fpw-market-ewt .logo b{display:none}
.fpw-market-ewt .hero{background:radial-gradient(900px 460px at 78% -8%,rgba(255,140,66,.26),transparent 60%),radial-gradient(700px 520px at 6% 110%,rgba(58,123,200,.12),transparent 60%),var(--cream)}
.fpw-market-ewt .final .panel{background:radial-gradient(700px 300px at 50% -40%,rgba(255,140,66,.5),transparent 60%),var(--purple)}
