:root{
  --bw-black:#1A1A1A; --text:#1A1A1A; --muted:#86868B; --yellow:#FFD600;
  --yellow-light:#FFF8E1; --yellow-dark:#E6C200;
  --accent-blue:#2D74FF;
  --bg:#FFFFFF; --bg-secondary:#FFF8E1; --bg-tertiary:#F1F3F5;
  --border:rgba(0,0,0,.08); --border-light:rgba(0,0,0,.04);
  --container-max:1280px; --header-h:75px; --radius:24px;
  --container-padding: 5vw;
  --shadow-xs:0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:0 2px 8px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.06);
  --shadow-lg:0 8px 32px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.08);
  --shadow-xl:0 16px 48px rgba(0,0,0,.16), 0 8px 16px rgba(0,0,0,.1);
  --shadow-yellow:0 8px 24px rgba(255,214,0,.25), 0 4px 8px rgba(255,214,0,.15);
  --gradient-hero:linear-gradient(135deg, rgba(255,214,0,.12) 0%, rgba(255,214,0,.08) 50%, rgba(255,255,0,.08) 100%);
  --gradient-card:linear-gradient(135deg, rgba(255,255,255,.95) 0%, rgba(255,255,255,.98) 100%);
}
*{box-sizing:border-box; -ms-overflow-style: none; scrollbar-width: none;}
*::-webkit-scrollbar { display: none; }
html,body{margin:0;height:100%} html{max-width:100%; overflow-x:hidden; -ms-overflow-style: none; scrollbar-width: none;}
html::-webkit-scrollbar { display: none; }
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text",system-ui,ui-sans-serif,Segoe UI,Roboto,Helvetica,Arial;line-height:1.47059;font-weight:400;letter-spacing:-.022em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale; -ms-overflow-style: none; scrollbar-width: none;}
body::-webkit-scrollbar { display: none; }
img,svg{max-width:100%;height:auto;display:block}
.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-padding);box-sizing:border-box;overflow-x:hidden}

/* Mobile Logo - Hidden by default (Desktop) */
.mobile-logo { display: none; }

.body{
  overflow-x:hidden;
  padding:0 20px;
}
/* Header */
.site-header{position:sticky;top:0;z-index:1000;border-bottom:1px solid transparent;transition:all .5s cubic-bezier(.28,.11,.32,1);overflow:visible}
.site-header.is-top{background:rgba(255,255,255,.4);border-bottom-color:transparent;backdrop-filter:saturate(200%) blur(24px);-webkit-backdrop-filter:saturate(200%) blur(24px)}
.site-header:not(.is-top){background:rgba(255,255,255,.5);border-bottom-color:var(--border-light);backdrop-filter:saturate(200%) blur(24px);-webkit-backdrop-filter:saturate(200%) blur(24px);box-shadow:0 1px 0 0 rgba(0,0,0,.06), var(--shadow-sm)}

.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);padding:0 var(--container-padding);max-width:100%}

.logo{display:flex;align-items:center;gap:0;text-decoration:none;transition:all .3s cubic-bezier(.28,.11,.32,1);z-index:1001;margin-left:0}
.logo:hover{opacity:.85;transform:translateY(-1px)}

.site-header .brand-img{height:72px;width:auto;margin:10px 0 0px;transition:all .3s cubic-bezier(.28,.11,.32,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.04))}
@media(min-width:768px){
  :root { --header-h: 75px; }
  .site-header .brand-img{height:90px;margin:8px 0 3px}
  
  /* Add margin above hero content on desktop and iPad */
  .hero {
    padding-top: 70px;
  }
  .hero-copy {
    margin-top: 30px;
    text-align: left;
  }
  .hero-copy h1 {
    text-align: left;
    margin-left: 0;
    margin-right: auto;
    max-width: 12ch;
    display: block;
  }
  .hero-copy .sub {
    text-align: left;
    margin-left: 0;
    margin-right: auto;
  }
  .hero-copy .cta-row {
    justify-content: flex-start;
  }
  .hero-visual {
    margin-top: 40px;
  }
}

/* More transparent header on map page (desktop and iPad) */
@media(min-width:768px){
  body.map-page-body .site-header.is-top {
    background: rgba(255, 255, 255, 0.15) !important;
    backdrop-filter: saturate(150%) blur(16px) !important;
    -webkit-backdrop-filter: saturate(150%) blur(16px) !important;
  }
  body.map-page-body .site-header:not(.is-top) {
    background: rgba(255, 255, 255, 0.2) !important;
    backdrop-filter: saturate(150%) blur(16px) !important;
    -webkit-backdrop-filter: saturate(150%) blur(16px) !important;
  }
}

.nav{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.nav a{color:var(--muted);text-decoration:none;padding:10px 18px;border-radius:22px;transition:all .3s cubic-bezier(.28,.11,.32,1);font-size:.9375rem;font-weight:500;position:relative;overflow:hidden}
.nav a:hover{background:rgba(0,0,0,.05);color:var(--text);transform:translateY(-1px);box-shadow:var(--shadow-xs)}
.nav a.active{color:#111;background:var(--yellow);box-shadow:0 4px 12px rgba(255,214,0,0.25)}

/* Mobile Menu Toggle */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  padding: 8px;
  cursor: pointer;
  z-index: 1001;
  color: var(--text);
}

@media (max-width: 767px) {
  /* Organized App Shell - Mobile Only (phones, not tablets) */
  :root { 
    --header-h: 72px;
    --nav-h: 62px;
    --container-padding: 20px;
    --radius: 20px;
  }
  
  body { 
    padding-bottom: var(--nav-h);
    padding-top: 0;
  }
  
  html {
    scroll-padding-top: 0;
  }
  
  main {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
  }
  main.map-page {
    padding-left: 0;
    padding-right: 0;
  }
  main.legal-page {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    padding-top: 120px;
    padding-bottom: 20px;
  }
  .legal-page .page-title {
    margin-bottom: 40px;
  }
  .legal-page h2 {
    margin-bottom: 60px !important;
    margin-top: 0 !important;
  }
  
  .container, .b2b-inner, .header-inner {
    padding-inline: 0px;
    max-width: 100%;
  }
  
  /* Ensure all sections have side margins */
  .hero, .section, .features, .b2b-section, .support-section, .site-footer {
    padding-left: 10px;
    padding-right: 10px;
  }
  
  /* Header - Hidden on Mobile */
  .site-header { 
    display: none !important;
  }

  /* Bottom Navigation */
  .mobile-bottom-nav {
    display: flex !important;
    position: fixed;
    bottom: -7px;
    left: 0;
    right: 0;
    height: var(--nav-h);
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-top: 1px solid var(--border-light);
    z-index: 2000;
    padding: 4px 10px 0;
    padding-bottom: env(safe-area-inset-bottom);
    margin-bottom: 0;
    justify-content: space-around;
    align-items: flex-start;
    visibility: visible !important;
    opacity: 1 !important;
  }
  
  .nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 1px;
    text-decoration: none;
    color: var(--muted);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    flex: 1;
    transition: all 0.2s ease;
    padding-top: 6px;
  }
  
  .nav-item.active { color: var(--accent-blue); }
  .nav-item svg { width: 22px; height: 22px; stroke-width: 2; }
  .nav-item.active svg { stroke: var(--accent-blue); }

  /* Mobile Logo in Hero */
  .mobile-logo {
    display: block !important;
    text-align: left;
    padding: 0;
    margin-top: -45px;
    margin-bottom: 5px;
    margin-left: 0;
  }
  .mobile-logo-img {
    height: 100px;
    width: auto;
    margin: 0;
  }
  
  /* Hero - Keep Images Big */
  .hero { 
    padding: 0 0 8px;
    margin: 0;
    background: var(--bg);
  }
  .hero-stripe::before {
    display: none;
  }
  .hero .hero-grid { 
    grid-template-columns: 1fr !important; 
    gap: 12px;
    text-align: left;
  }
  .hero-copy { order: 1; }
  .hero-visual { 
    display: none !important;
  }
  .hero-copy {
    text-align: left !important;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    margin-top: -20px;
    padding-left: 10px;
    padding-right: 10px;
  }
  .hero-copy h1 { 
    font-size: 1.875rem; 
    margin: -14px 0 8px;
    max-width: 12ch;
    line-height: 1.15;
    text-align: left;
    width: auto;
    display: block;
  }
  .sub { 
    font-size: 1rem; 
    margin: 0 auto 12px;
    max-width: 100%;
    line-height: 1.5;
    text-align: left;
    width: 100%;
  }
  .hero-illustration { 
    max-width: 100%;
    width: 85%;
    margin: 0 auto 0;
  }
  .cta-row { 
    grid-template-columns: 1fr !important;
    gap: 0px;
    margin: 0 auto 0;
  }
  
  .btn { 
    height: 50px; 
    border-radius: 14px; 
    font-size: 1rem; 
    font-weight: 600;
    padding: 0 24px;
    width: 100%;
    margin-bottom: -10px;
  }
  
  /* Sections - Organized Spacing */
  .section, .features { 
    padding: 0;
    margin: -100px 0 0;
    margin-bottom: 80px;
  }
  .features h2, .section h2 { 
    font-size: 1.5rem; 
    margin: 0 auto 4px;
    max-width: 100%;
    text-align: left;
  }
  .features h2::after, .section h2::after { 
    bottom: -16px; 
    width: 50px; 
  }
  
  /* Cards - Organized Grid */
  .cards.three { 
    grid-template-columns: 1fr !important; 
    gap: 0px;
    padding: 0;
  }
  .card.step {
    padding: 4px 12px;
    border-radius: 14px;
    margin: 0;
    max-width: 100%;
    box-sizing: border-box;
    transform: none !important;
    box-shadow: none !important;
    border: none !important;
    background: var(--bg) !important;
  }
  .card.step::before { display: none !important; }
  .card.step:hover .step-image img { transform: none !important; }
  .card.step .step-image { 
    height: 30px; 
    margin-bottom: 2px;
    margin-top: -70px;
  }
  .card.step h3 { 
    font-size: 0.8125rem; 
    margin-bottom: 4px;
    line-height: 1.3;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;

  }
  .card.step p { 
    font-size: 0.6875rem; 
    line-height: 1.4;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
    margin: 0;
  }
  
  /* Features cable notice - centered on mobile with proper margins */
  .features-cable-notice {
    text-align: center;
    margin-top: 32px;
    margin-left: auto;
    margin-right: auto;
    font-size: 1rem;
    padding: 0 var(--container-padding);
    max-width: 100%;
    box-sizing: border-box;
  }
  
  /* Ensure sections have proper margins on mobile */
  .features,
  .section,
  .support-section {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    box-sizing: border-box;
  }
  
  .price-notice {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    box-sizing: border-box;
  }
  
  /* Pricing - Organized Layout */
  .price-overview-grid { 
    grid-template-columns: 1fr !important;
    gap: 16px; 
    margin: 0 auto 28px;
    max-width: 100%;
    padding: 0;
  }
  .price-overview-item {
    padding: 20px;
    border-radius: 16px;
    margin: 0;
    text-align: center;
  }
  .price-overview-item .label { 
    font-size: 0.9375rem; 
    margin-bottom: 8px;
  }
  .price-overview-item .value { 
    font-size: 1.875rem; 
  }
  .price-notice {
    font-size: 0.9375rem;
    margin-top: 24px;
    padding: 0;
    text-align: center;
  }
  
  /* Support Banner */
  .support-section { 
    padding: 0; 
    margin-top: 0;
  }
  .support-banner { 
    flex-direction: column;
    padding: 28px var(--container-padding); 
    border-radius: 18px; 
    gap: 20px;
    text-align: left;
  }
  .support-content h2 { 
    font-size: 1.375rem; 
    margin-bottom: 8px;
    text-align: left;
  }
  .support-content p { 
    font-size: 0.9375rem;
    margin: 0;
  }
  .support-actions { 
    width: 100%;
    flex-direction: column; 
    gap: 12px;
  }
  .support-actions .btn { 
    width: 100%;
    height: 50px;
    margin-bottom: 1px;
  }

  /* B2B - Completely Redesigned for Mobile */
  .b2b-section { 
    padding: 5px 0; 
    margin-top: 5px;
    background: none;
    border: none;
    margin-left: calc(var(--container-padding) * -1);
    margin-right: calc(var(--container-padding) * -1);
  }
  .b2b-inner {
    background: var(--bg-tertiary);
    padding: 16px var(--container-padding);
    border-radius: 0;
    margin: 0;
  }
  .b2b-grid { 
    display: flex !important;
    flex-direction: column;
    gap: 12px;
    text-align: left;
  }
  .b2b-copy { 
    text-align: left; 
    order: 1;
  }
  .b2b-title { 
    font-size: 1.15rem; 
    margin-bottom: 6px;
    line-height: 1.2;
    font-weight: 700;
  }
  .b2b-title::after { display: none; }
  .b2b-subtitle { 
    font-size: 0.8125rem; 
    margin: 0 auto 16px;
    max-width: 100%;
    line-height: 1.4;
    color: var(--muted);
  }
  .b2b-cta-wrapper { 
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-bottom: 0;
    order: 3;
    padding-left: 10px;
    padding-right: 10px;
  }
  .b2b-cta-wrapper .btn {
    width: 100%;
    height: 46px;
    font-size: 0.9375rem;
    margin: 0;
  }
  .b2b-cta-wrapper .muted.tiny {
    font-size: 0.875rem;
    margin: 0;
    opacity: 0.8;
    margin-bottom: -50px;
  }
  .b2b-features {
    order: 2;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px;
  }
  .b2b-feature-card { 
    padding: 12px; 
    gap: 10px; 
    border-radius: 12px;
    margin: 0;
    border: none;
    background: rgba(255,255,255,0.6);
    text-align: left;
    align-items: center;
  }
  .feature-icon { 
    width: 32px; 
    height: 32px; 
    font-size: 0.875rem; 
    border-radius: 8px;
    background: var(--yellow);
    color: #111;
  }
  .feature-text h3 { 
    font-size: 0.875rem; 
    margin: 0;
    font-weight: 600;
  }
  .feature-text p { 
    font-size: 0.75rem;
    line-height: 1.3;
    margin: 2px 0 0;
    opacity: 0.8;
  }

  /* Footer - Compact */
  .site-footer { 
    margin-top: 0px; 
    padding: 16px var(--container-padding) 12px;
    background: var(--bg-tertiary);
  }
  .site-footer .container { 
    padding-left: var(--container-padding) !important;
    padding-right: var(--container-padding) !important;
    margin: 0;
  }
  .footer-grid { 
    grid-template-columns: 1fr !important;
    gap: 0; 
    text-align: left;
    padding: 0;
    margin: 0;
    margin-left: 0;
  }
  .foot-brand { 
    align-items: flex-start;
    text-align: left;
    margin-bottom: -40px;
  }
  .site-footer .brand-img { 
    height: 50px; 
    margin: 0 0 8px;
  }
  .foot-brand p {
    font-size: 0.8125rem;
    line-height: 1.4;
    margin: 0;
  }
  .foot-links { 
    margin-top: 0;
  }
  .footer-grid nav:nth-of-type(1),
  .footer-grid nav:nth-of-type(2) {
    display: none;
  }
  .footer-grid h4 { 
    font-size: 0.8125rem; 
    margin-bottom: 8px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--text);
  }
  .footer-grid a { 
    font-size: 0.8125rem; 
    padding: 3px 0;
    line-height: 1.4;
  }
  .footer-grid ul {
    padding-left: 0;
    gap: 6px;
  }
  .footer-bottom { 
    flex-direction: column; 
    gap: 6px; 
    padding: 16px var(--container-padding) 0 !important;
    margin-top: 16px;
    text-align: left;
    font-size: 0.75rem;
    border-top: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .footer-bottom .foot-copy,
  .footer-bottom .foot-tax {
    margin: 0 !important;
  }
  .footer-bottom .sep { display: none; }
  
  /* Standorte Map - Mobile Optimized (App-like) */
  .map-page .locations-section {
    position: fixed;
    top: calc(-1 * env(safe-area-inset-top, 0px));
    left: 0;
    right: 0;
    bottom: var(--nav-h);
    height: calc(100vh - var(--nav-h) + env(safe-area-inset-top, 0px));
    z-index: 1;
  }
  .map-page .locations-grid {
    height: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
  }
  .map-page .locations-map { 
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  .map-page .partners-list-wrap {
    position: absolute;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 350px;
    max-height: 85vh;
    min-height: 115px;
    background: var(--bg);
    border-radius: 24px 24px 0 0;
    box-shadow: 0 -10px 30px rgba(0,0,0,0.15);
    z-index: 10;
    padding: 0px 20px 0px;
    margin-top: 0;
    border: none;
    border-top: 1px solid var(--border-light);
    display: flex;
    flex-direction: column;
    gap: 0;
    transition: height 0.3s cubic-bezier(0.25, 0.1, 0.25, 1);
    touch-action: none; /* Prevent browser scrolling while dragging */
  }
  .map-page .partners-list-wrap.dragging {
    transition: none;
  }
  .partner-list {
    touch-action: pan-y; /* Allow list scrolling */
    margin-top: -1px;
    padding-top: 0;
    margin-bottom: 0;
  }
  .drag-handle {
    display: block;
    width: 45px;
    height: 5px;
    background: rgba(0,0,0,0.2);
    border-radius: 10px;
    margin: 18px auto 12px;
    flex-shrink: 0;
    cursor: grab;
    touch-action: none;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    -webkit-user-select: none;
    position: relative;
    z-index: 20;
  }
  .drag-handle::before {
    content: '';
    position: absolute;
    top: -15px;
    left: -10px;
    right: -10px;
    bottom: -15px;
    z-index: -1;
  }
  .drag-handle:active {
    cursor: grabbing;
  }
  .partners-list-title {
    font-size: 1.25rem;
    margin-bottom: 0;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-light);
    cursor: grab;
    touch-action: none;
    user-select: none;
    -webkit-user-select: none;
    -webkit-tap-highlight-color: transparent;
  }
  .partners-list-title:active {
    cursor: grabbing;
  }
  .partner-list {
    margin-top: 0;
    padding-top: 0;
  }
  .partner-item {
    padding: 14px;
    border-radius: 12px;
  }
  .partner-name {
    font-size: 1rem;
  }
  .partner-address {
    font-size: 0.8125rem;
  }
}

/* iPad/Tablet Optimizations (768px - 1024px) */
@media (min-width: 768px) and (max-width: 1024px) {
  /* Add 10px padding to the whole page for iPad */
  body {
    padding: 0 20px;
    box-sizing: border-box;
  }
  
  html {
    box-sizing: border-box;
  }
  
  /* Ensure proper container padding for iPad - increased for better margins */
  :root {
    --container-padding: min(5vw, 48px);
  }
  
  /* Hero section adjustments for iPad */
  .hero {
    padding-top: 60px;
  }
  .hero-copy {
    text-align: left;
    width: 100%;
    margin-top: 20px;
  }
  .hero-copy h1 {
    font-size: clamp(1.5rem, 3.5vw, 2rem);
    text-align: left;
    margin-left: 0;
    margin-right: auto;
    max-width: 100%;
    display: block;
    line-height: 1.2;
    word-break: normal;
    white-space: normal;
  }
  .sub {
    font-size: 1.15rem;
    text-align: left;
    margin-left: 0;
    margin-right: auto;
  }
  
  /* Adjust hero grid for iPad */
  .hero .hero-grid {
    gap: 40px;
  }
  
  /* Card adjustments for iPad - remove border and background like mobile, but keep horizontal layout */
  .cards.three {
    gap: 24px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .card.step {
    padding: 20px 16px;
    border: none !important;
    background: var(--bg) !important;
    box-shadow: none !important;
    transform: none !important;
  }
  .card.step::before {
    display: none !important;
  }
  .card.step:hover {
    transform: none !important;
    box-shadow: none !important;
    border: none !important;
    background: var(--bg) !important;
  }
  .card.step:hover .step-image img {
    transform: none !important;
  }
  .card.step .step-image {
    height: 120px;
    margin-bottom: 16px;
  }
  .card.step h3 {
    font-size: 1rem;
    margin-bottom: 8px;
    white-space: nowrap;
    line-height: 1.2;
  }
  .card.step p {
    font-size: 0.9375rem;
  }
  
  /* Price grid adjustments */
  .price-overview-grid {
    gap: 20px;
  }
  
  /* B2B section adjustments */
  .b2b-grid {
    gap: 50px;
  }
  
  /* Support banner adjustments */
  .support-banner {
    padding: 50px 40px;
    gap: 35px;
  }
  
  /* Ensure both notice texts are centered on iPad with proper margins */
  .features-cable-notice {
    text-align: center;
    margin-top: 48px;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    font-size: 1.15rem;
    max-width: 100%;
    box-sizing: border-box;
  }
  
  .price-notice {
    text-align: center;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    box-sizing: border-box;
  }
  
  /* Ensure sections have proper margins on iPad */
  .features {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    box-sizing: border-box;
  }
  
  .section {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    box-sizing: border-box;
  }
  
  .support-section {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    box-sizing: border-box;
  }
  
  .support-banner {
    margin-left: auto;
    margin-right: auto;
    max-width: 100%;
    box-sizing: border-box;
  }
  
  /* Ensure cards container respects container padding */
  .features .cards.three {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
  }
  
  /* Map page optimizations for iPad */
  .partners-list-wrap {
    width: 320px;
    padding: 20px;
  }
  
  /* Better touch targets for iPad */
  .btn {
    min-height: 48px;
    padding: 14px 28px;
  }
  
  /* Navigation adjustments */
  .nav a {
    padding: 12px 20px;
    font-size: 1rem;
  }
}

/* Hide bottom nav on tablet/iPad and desktop */
@media (min-width: 768px) {
  .mobile-bottom-nav { display: none; }
  .drag-handle { display: none; }
}

/* Map Footer Legal */
.map-footer-legal {
  position: absolute;
  bottom: 0;
  right: 0;
  background: rgba(255, 255, 255, 0.85);
  padding: 4px 12px;
  font-size: 13px;
  color: var(--text);
  z-index: 1000;
  display: flex;
  gap: 8px;
  align-items: center;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border-top-left-radius: 4px;
  white-space: nowrap;
  flex-wrap: nowrap;
}
.map-footer-legal a {
  color: var(--text);
  text-decoration: none;
  font-weight: 500;
}
.map-footer-legal a:hover {
  text-decoration: underline;
}
.map-footer-legal .sep {
  opacity: 0.3;
}

@media (max-width: 767px) {
  .map-footer-legal {
    font-size: 12px;
    padding: 6px 12px;
    top: env(safe-area-inset-top, 0px);
    bottom: auto;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
    z-index: 2000;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
    white-space: nowrap;
    flex-wrap: nowrap;
  }
  .map-footer-legal a {
    font-weight: 600;
    color: var(--text);
  }
  .map-footer-legal .foot-copy {
    font-weight: 500;
    color: var(--text);
  }
  .map-footer-legal .sep {
    opacity: 0.3;
  }
  .map-footer-legal.satellite-mode a {
    color: rgba(255, 255, 255, 0.95);
  }
  .map-footer-legal.satellite-mode .foot-copy {
    color: rgba(255, 255, 255, 0.95);
  }
  .map-footer-legal.satellite-mode .sep {
    color: rgba(255, 255, 255, 0.6);
    opacity: 1;
  }
  .map-type-selector {
    top: calc(26px + env(safe-area-inset-top, 0px));
  }
  .map-controls {
    top: calc(90px + env(safe-area-inset-top, 0px));
  }
}

/* Hero */
.hero{padding:40px 0 20px;position:relative;overflow:hidden;background:var(--bg)}
.hero-stripe::before{content:"";position:absolute;inset:-160px -12vw auto -12vw;height:400px;background:
  radial-gradient(1200px 280px at 10% 0%, rgba(255,214,0,.25), transparent 60%),
  radial-gradient(1200px 280px at 90% 0%, rgba(255,214,0,.12), transparent 60%),
  radial-gradient(1200px 280px at 50% -10%, rgba(255,255,0,.12), transparent 60%);
  transform:skewY(-8deg);opacity:1;z-index:0}
.hero .hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-copy{text-align:left}
.hero-copy h1{font-weight:700;font-size:clamp(2.5rem,7vw,4.2rem);line-height:1.2;letter-spacing:-.03em;text-wrap:balance;max-width:12ch;margin:40px 0 32px;color:var(--text);text-align:left;display:block;word-break:normal;overflow-wrap:normal}
.sub{color:var(--muted);margin:0 0 56px;max-width:42ch;font-size:1.25rem;line-height:1.6;font-weight:400;text-align:left}
.accent{color:var(--yellow);font-weight:700}
.accent-blue{color:var(--accent-blue);font-weight:700;text-decoration:underline;text-underline-offset:8px;text-decoration-thickness:3px}
.cta-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;margin-bottom:32px}
.btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:14px 28px;border-radius:999px;text-decoration:none;font-weight:500;border:none;transition:all .3s cubic-bezier(.28,.11,.32,1);cursor:pointer;font-size:1.0625rem;line-height:1.47059;letter-spacing:-.011em;position:relative;overflow:hidden}
.btn::before{content:"";position:absolute;inset:0;background:rgba(255,255,255,.2);opacity:0;transition:opacity .3s ease}
.btn:hover::before{opacity:1}
.btn-primary{background:var(--yellow);color:#111;box-shadow:0 4px 12px rgba(255,214,0,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,214,0,.4);background:var(--yellow);color:#111}
.btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px rgba(255,214,0,.3)}
.btn-ghost{background:var(--bg);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{background:var(--bg-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-ghost:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.chev{display:inline-block;margin-left:6px;transition:transform .3s cubic-bezier(.28,.11,.32,1);font-size:1.2em;line-height:0;font-weight:600}
.btn:hover .chev{transform:translateX(4px)}
.checks{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:24px 0 0}
.checks li{padding:10px 18px 10px 38px;border:1px solid var(--border);border-radius:999px;position:relative;background:var(--bg-secondary);font-size:.9375rem;font-weight:400;transition:all .3s cubic-bezier(.28,.11,.32,1);box-shadow:var(--shadow-xs)}
.checks li:hover{background:var(--bg);transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--border)}
.checks li::before{content:"✓";position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--accent-blue);font-weight:700;font-size:1.1em}
.hero-visual{display:grid;place-items:end;justify-items:end;align-items:start;padding:0;position:relative;margin-top:20px;min-height:400px}
.hero-illustration{max-width:600px;width:93%;height:auto;display:block;object-fit:contain;background:transparent;padding:0;margin-bottom:10px;visibility:visible;opacity:1;mix-blend-mode:multiply}

/* Sections */
.section{padding:40px 0 30px;position:relative;box-sizing:border-box}
.features{padding:160px 0 30px;position:relative;box-sizing:border-box}
.features h2,.section h2{margin:0 0 64px;text-wrap:balance;font-size:clamp(2.25rem,6vw,3.5rem);font-weight:600;letter-spacing:-.04em;line-height:1.05;text-align:center;color:var(--text);position:relative}
.features-cable-notice{text-align:center;margin-top:48px;margin-left:auto;margin-right:auto;padding-left:var(--container-padding);padding-right:var(--container-padding);font-size:1.15rem;color:var(--text);max-width:100%;display:block;box-sizing:border-box;word-wrap:break-word;overflow-wrap:break-word}
.features .hero-visual,.features .hero-illustration{display:none !important}
.section .hero-visual,.section .hero-illustration{display:none !important}
.features h2::after,.section h2::after{content:"";position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:linear-gradient(90deg, transparent, var(--yellow), transparent);border-radius:2px}
.page-title{margin:0 0 16px;text-wrap:balance;font-size:clamp(2.5rem,6vw,4rem);font-weight:600;letter-spacing:-.04em;line-height:1.05;text-align:center;color:var(--text);position:relative}
.contact-page-title{margin-bottom:30px}
.page-title::after{content:"";position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:linear-gradient(90deg, transparent, var(--yellow), transparent);border-radius:2px}
.b2b-title{position:relative}
.cards{display:grid;gap:24px}
.cards.three{grid-template-columns:repeat(3,minmax(0,1fr));gap:40px}
.card.step{padding:48px 36px;border-radius:var(--radius);border:none;background:var(--bg);box-shadow:none;transition:none;position:relative;text-align:center}
.card.step::before{display:none}
.card.step:hover{transform:none;box-shadow:none;border:none;background:var(--bg)}
.card.step:hover::before{opacity:0}
.card.step .step-image{width:100%;height:180px;margin-bottom:24px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.card.step .step-image img{max-height:100%;object-fit:contain;transition:none}
.card.step:hover .step-image img{transform:none}
.card.step h3{margin:0 0 16px;font-size:1.375rem;font-weight:600;letter-spacing:-.02em;line-height:1.3;color:var(--text)}
.card.step p{margin:0;color:var(--muted);font-size:1.0625rem;line-height:1.7;font-weight:400}

/* Preise */
#preise { padding-top: 80px; }
.price-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 900px;
  margin: 0 auto 64px;
  text-align: center;
}

.price-overview-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.price-overview-item .label {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--muted);
}

.price-overview-item .value {
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.02em;
  text-decoration: none;
  line-height: 1.1;
}

.price-overview-item .value.accent-blue {
  color: var(--accent-blue);
}

@media (max-width: 760px) {
  .price-overview-grid { grid-template-columns: 1fr; gap: 32px; margin-bottom: 48px; }
}

.price-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;max-width:900px;margin:0 auto}
.price-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 20px;border:1px solid var(--border);border-radius:20px;background:var(--bg);box-shadow:var(--shadow-sm);transition:all .4s cubic-bezier(.28,.11,.32,1);cursor:pointer;position:relative;overflow:hidden}
.price-item::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(255,214,0,.06), rgba(0,122,255,.03));opacity:0;transition:opacity .4s ease}
.price-item:hover:not(.notice){transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border);background:var(--bg-secondary)}
.price-item:hover:not(.notice)::before{opacity:1}
.price-item .time{font-weight:500;font-size:.9375rem;letter-spacing:.01em;color:var(--muted);margin-bottom:8px;text-transform:uppercase;opacity:.8}
.price-item .amount{font-weight:700;font-size:1.75rem;letter-spacing:-.03em;color:var(--accent-blue);line-height:1.2;font-variant-numeric:tabular-nums}
.price-item.highlight{border:2px solid var(--yellow);background:linear-gradient(135deg, rgba(255,214,0,.08), rgba(255,214,0,.03));box-shadow:0 4px 16px rgba(255,214,0,.2), var(--shadow-sm);position:relative}
.price-item.highlight::after{content:"";position:absolute;top:12px;right:12px;width:8px;height:8px;background:var(--yellow);border-radius:50%;box-shadow:0 0 8px rgba(255,214,0,.6)}
.price-item.highlight .amount{color:var(--text);font-size:1.875rem}
.price-item.notice{grid-column:1/-1;flex-direction:row;justify-content:center;border-style:dashed;border-width:1.5px;background:var(--bg-secondary);color:var(--muted);gap:8px;cursor:default;font-size:.9375rem;padding:20px 24px;margin-top:8px}
.price-item.notice .time{font-weight:500;margin:0;text-transform:none;opacity:1}
.price-item.notice .amount{font-weight:600;font-size:1rem;opacity:1}

/* Map */
.map{height:700px;border-radius:0;border:1.5px solid var(--border);overflow:hidden;box-shadow:var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.6);background:var(--bg-secondary);transition:all .4s cubic-bezier(.28,.11,.32,1);position:relative}
.map-full{height:calc(100vh - 120px);min-height:700px;max-height:900px;border-radius:0}
.map:hover{box-shadow:var(--shadow-xl), inset 0 1px 0 rgba(255,255,255,.7);border-color:rgba(255,214,0,.2)}

/* Leaflet Custom Controls */
.leaflet-container{font-family:inherit;background:var(--bg-secondary);border-radius:0}
.leaflet-popup-content-wrapper{border-radius:16px;box-shadow:var(--shadow-md);padding:0;background:var(--bg);border:1px solid var(--border)}
.leaflet-popup-content{margin:16px 20px;font-size:.9375rem;line-height:1.5}
.leaflet-popup-content strong{font-weight:600;color:var(--text);display:block;margin-bottom:4px}
.leaflet-popup-tip{background:var(--bg);box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.leaflet-popup-close-button{color:var(--muted);font-size:20px;padding:8px;transition:color .2s ease}
.leaflet-popup-close-button:hover{color:var(--text)}
.custom-marker{background:transparent;border:none}

/* Floating Map Controls */
.map-controls{position:absolute;top:90px;left:16px;z-index:400;display:flex;flex-direction:column;gap:8px}
.map-control-btn{width:48px;height:48px;border-radius:12px;background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.28,.11,.32,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.map-control-btn:hover{background:var(--bg-secondary);transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border)}
.map-control-btn.active{background:var(--yellow);border-color:var(--yellow);box-shadow:0 4px 12px rgba(255,214,0,.3)}
.map-control-btn svg{width:20px;height:20px;stroke:var(--text);fill:none;stroke-width:2}
.map-control-btn.active svg{stroke:#111}

.map-type-selector{position:absolute;top:26px;left:16px;z-index:400;display:flex;gap:4px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:4px;box-shadow:var(--shadow-md);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.map-type-btn{padding:8px 14px;border-radius:8px;background:transparent;border:none;font-size:.875rem;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s ease;white-space:nowrap;line-height:1.2}
.map-type-btn:hover{color:var(--text);background:var(--bg-secondary)}
.map-type-btn.active{background:var(--yellow);color:#111;font-weight:600;box-shadow:0 2px 4px rgba(255,214,0,.2)}

/* Locations layout */
.locations-section {
  position: relative;
  padding: 0;
  height: calc(100vh - var(--header-h));
  max-height: calc(100vh - var(--header-h));
  overflow: hidden;
}
.locations-grid { 
  display: block; 
  position: relative;
  width: 100%;
  height: 100%;
}

.locations-map { 
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0; 
  overflow: hidden; 
  box-shadow: none; 
  background: var(--bg-tertiary); 
  border: none;
  z-index: 1;
}
.locations-map .map { height: 100%; width: 100%; }

.partners-list-wrap {
  position: absolute;
  top: 12px;
  right: 24px;
  width: 360px;
  background: var(--bg); 
  border: 1px solid var(--border); 
  border-radius: 24px; 
  padding: 24px; 
  box-shadow: var(--shadow-lg); 
  display: flex; 
  flex-direction: column; 
  gap: 20px; 
  overflow: hidden;
  height: calc(100% - 48px);
  z-index: 10;
}
.partners-list-title { 
  margin: 0 0 16px; 
  font-size: 1.75rem; 
  font-weight: 700; 
  letter-spacing: -0.04em; 
  color: var(--text); 
  border-bottom: 1px solid var(--border);
  padding-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.partners-list-title::after { 
  content: "1 Station"; 
  font-size: 0.8125rem; 
  font-weight: 600; 
  color: var(--muted); 
  background: var(--bg-tertiary); 
  padding: 4px 12px; 
  border-radius: 8px;
}
.partners-list-title::before {
  content: "";
  width: 8px;
  height: 8px;
  background: #34C759;
  border-radius: 50%;
  position: absolute;
  right: 90px;
  top: 50%;
  transform: translateY(-50%);
  box-shadow: 0 0 0 rgba(52, 199, 89, 0.4);
  animation: pulse-dot 2s infinite;
  display: none; /* Hidden for now, can be enabled if wanted */
}
@keyframes pulse-dot {
  0% { box-shadow: 0 0 0 0 rgba(52, 199, 89, 0.7); }
  70% { box-shadow: 0 0 0 10px rgba(52, 199, 89, 0); }
  100% { box-shadow: 0 0 0 0 rgba(52, 199, 89, 0); }
}

.partner-list { 
  list-style: none; 
  margin: 0; 
  padding: 0; 
  display: flex; 
  flex-direction: column; 
  gap: 16px; 
  overflow-y: auto; 
  flex: 1; 
  padding-right: 4px;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.partner-list::-webkit-scrollbar { display: none; }

.partner-item { 
  border: 1.5px solid var(--border); 
  border-radius: 20px; 
  padding: 20px; 
  background: var(--bg); 
  transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1); 
  cursor: pointer; 
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: visible;
}
.partner-item.active { border-color: var(--accent-blue); background: rgba(45, 116, 255, 0.02); box-shadow: var(--shadow-md); }

.partner-name { margin: 0; font-size: 1.15rem; font-weight: 700; color: var(--text); letter-spacing: -0.01em; }
.partner-address { margin: 0; font-size: 0.9375rem; color: var(--muted); line-height: 1.5; }

.partner-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; align-items: flex-start; }
.partner-tag { 
  padding: 6px 14px; 
  border-radius: 999px; 
  background: var(--bg-tertiary); 
  font-size: 0.75rem; 
  font-weight: 700; 
  color: var(--text); 
  text-transform: uppercase; 
  letter-spacing: 0.05em; 
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s ease;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Custom Dropdown Styling */
.custom-dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-trigger {
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--bg-tertiary);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: 999px;
  transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  outline: none;
  color: var(--text);
}

.custom-dropdown.active .dropdown-trigger {
  background: var(--bg);
  border-color: var(--yellow);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.dropdown-trigger .chevron {
  transition: transform 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
}

.custom-dropdown.active .chevron {
  transform: rotate(180deg);
}

.dropdown-menu {
  position: absolute;
  top: calc(100% + 12px);
  left: 0;
  z-index: 1000;
  width: max-content;
  min-width: 180px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1), 0 4px 8px rgba(0,0,0,0.04);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px) scale(0.98);
  transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  overflow: hidden;
}

.custom-dropdown.active .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.dropdown-content {
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dropdown-item {
  padding: 8px 12px;
  font-size: 0.8125rem;
  color: var(--text);
  font-weight: 500;
  border-radius: 8px;
  transition: all 0.2s ease;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.dropdown-item:not(:last-child) {
  border-bottom: none;
}

.dropdown-item:hover {
  background: var(--bg-tertiary);
  color: var(--accent-blue);
}

@media (max-width: 1023px) {
  .locations-grid { grid-template-columns: 1fr; height: calc(100vh - var(--nav-h)); min-height: calc(100vh - var(--nav-h)); }
  .locations-map { height: 500px; order: 1; }
  .partners-list-wrap {height: auto; max-height: calc(100vh - var(--header-h) - 100px); order: 2; }
}

@media (min-width: 1024px) {
  .locations-grid { grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); }
}

/* B2B Section Redesign */
.b2b-section {
  padding: 30px 0;
  margin-top: 30px;
  position: relative;
  background: var(--bg-tertiary);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.b2b-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.b2b-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.b2b-copy {
  text-align: left;
}

.b2b-title {
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--text);
  margin-bottom: 24px;
  line-height: 1.1;

}

.b2b-subtitle {
  font-size: 1.25rem;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 40px;
  max-width: 500px;
}

.b2b-cta-wrapper {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 50px
}

.b2b-features {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.b2b-feature-card {
  background: var(--bg);
  padding: 24px;
  border-radius: 20px;
  border: 1px solid var(--border);
  display: flex;
  gap: 20px;
  align-items: flex-start;
  transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
}

.b2b-feature-card:hover {
  transform: translateX(10px);
  border-color: var(--yellow);
  box-shadow: var(--shadow-md);
}

.feature-icon {
  width: 48px;
  height: 48px;
  background: var(--yellow-light);
  color: var(--yellow-dark);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  flex-shrink: 0;
}

.feature-text h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}

.feature-text p {
  font-size: 0.9375rem;
  color: var(--muted);
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 1024px) {
  .b2b-grid { grid-template-columns: 1fr; gap: 60px; }
  .b2b-copy { text-align: left; }
  .b2b-subtitle { margin-inline: auto; }
  .b2b-cta-wrapper { align-items: center; }
  .b2b-feature-card:hover { transform: translateY(-5px); }
}

/* Support Banner Section */
.support-section {
  padding-top: 100px;
  padding-bottom: 0px;
}
.support-section h2::after { display: none; }


.support-banner {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 32px;
  padding: 60px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  box-shadow: var(--shadow-sm);
  margin-left: auto;
  margin-right: auto;
  max-width: 100%;
  box-sizing: border-box;
}

.support-content h2 {
  margin: 0 0 12px;
  text-align: left;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.support-content p {
  margin: 0;
  color: var(--muted);
  font-size: 1.125rem;
  max-width: 500px;
}

.support-actions {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .support-banner {
    flex-direction: column;
    text-align: left;
    padding: 40px 24px;
  }
  .support-content h2 { text-align: left; }
  .support-actions { flex-direction: column; width: 100%; }
  .support-actions .btn { width: 100%; }
}

/* Legal Pages */
.legal-section {
  padding: 80px 0;
  max-width: 800px;
  margin: 0 auto;
}

.legal-section .page-title {
  margin-bottom: 80px;
  font-size: clamp(2rem, 5vw, 2.75rem);
}

.legal-content {
  text-align: left;
  line-height: 1.7;
  color: var(--text);
  font-size: 1.0625rem;
}

.legal-content h3 {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 40px 0 2px;
  letter-spacing: -0.02em;
  color: var(--text);
}
.legal-content h3:first-child {
  margin-top: 0;
}

.legal-content p {
  margin-bottom: 24px;
  color: var(--muted);
}

.legal-content strong {
  color: var(--text);
  font-weight: 600;
}

.legal-content a {
  color: var(--accent-blue);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  transition: opacity 0.2s;
}

.legal-content a:hover {
  opacity: 0.7;
}

/* Footer */
.site-footer{margin-top:120px;border-top:1.5px solid var(--border);background:linear-gradient(180deg, #F8F9FA 0%, var(--bg-tertiary) 100%);padding:0px 0 30px;position:relative;overflow:hidden}
.footer-grid{display:grid;gap:48px;grid-template-columns:1.5fr 1fr 1fr 1fr;padding:0;position:relative;z-index:1}
.foot-brand{display:flex;flex-direction:column;gap:0;margin-left:0}
@media(min-width:768px){.foot-brand{margin-left:0}}
.foot-brand .logo{display:inline-block}
.site-footer .brand-img{height:99px;width:auto;margin:10px 0 5px;opacity:.85;transition:all .3s cubic-bezier(.28,.11,.32,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.06))}
@media(min-width:768px){.site-footer .brand-img{height:132px;margin:15px 0 10px}}
.site-footer .brand-img:hover{opacity:1;transform:translateY(-1px);filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}
.foot-brand p{margin:0;font-size:.9375rem;line-height:1.6;color:var(--muted);max-width:280px;margin-top:0}
.foot-links{display:flex;flex-direction:column;margin-top:40px}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer-grid h4{margin:0 0 16px;font-size:1.0625rem;font-weight:600;letter-spacing:-.016em;color:var(--text)}
.footer-grid a{color:var(--muted);text-decoration:none;font-size:.9375rem;transition:all .3s cubic-bezier(.28,.11,.32,1);font-weight:400;padding:2px 0;position:relative;display:inline-block}
.footer-grid a::before{content:"";position:absolute;bottom:2px;left:0;width:0;height:1.5px;background:linear-gradient(90deg, var(--yellow), rgba(255,214,0,.6));transition:width .3s cubic-bezier(.28,.11,.32,1)}
.footer-grid a:hover{color:var(--text);transform:translateX(4px)}
.footer-grid a:hover::before{width:100%;background:var(--yellow)}
.footer-bottom{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;padding:32px 0 0;margin-top:32px;color:var(--muted);font-size:.875rem;border-top:none;font-weight:400;position:relative;z-index:1}
.footer-bottom .foot-copy { margin-left: 90px; }
.footer-bottom .foot-tax { margin-right: 90px; }


/* Feature icons */
.card.step .icon svg{ width:100%; height:100%; stroke:var(--text); fill:none; stroke-width:1.8; vector-effect:non-scaling-stroke; }
.card.step .icon svg rect, .card.step .icon svg path, .card.step .icon svg line, .card.step .icon svg circle{ stroke:var(--text); fill:none }

/* Price section enhancements */
#preise { padding-top: 80px; }
#preise h2{ margin-bottom:48px; text-wrap:balance }
.price-notice {
  text-align: center;
  color: var(--muted);
  font-size: 1.15rem;
  max-width: 800px;
  margin: 32px auto 40px;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
  line-height: 1.6;
  font-weight: 450;
  box-sizing: border-box;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.help-cta { text-align: center; padding: 60px 40px; background: linear-gradient(135deg, rgba(255,214,0,.08), rgba(255,214,0,.03)); border: 1px solid var(--border); border-radius: var(--radius); margin: 40px auto; max-width: 900px; }
.help-cta h3 { margin: 0 0 16px; font-size: 1.5rem; font-weight: 600; color: var(--text); }
.help-cta p { margin: 0 0 24px; color: var(--muted); }

/* No horizontal scroll */
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 20px)}
html, body { overflow-x: hidden; }
main, .hero { max-width: 100vw; overflow-x: hidden; }
.hero-stripe::before { max-width: 120vw; }
.logo-marquee { overflow-x: hidden; }

/* Contact Form */
.section-intro {
  text-align: left;
  color: var(--muted);
  font-size: 1.125rem;
  max-width: 600px;
  margin: 0 auto 0px;
}

/* Legal Page Base Padding */
main.legal-page {
  padding-top: 120px;
  padding-bottom: 100px;
}

@media (min-width: 901px) {
  main.legal-page.contact-page,
  main.legal-page.faq-page {
    padding-top: 40px;
  }
}

.contact-grid {
  max-width: 1100px;
  margin: 100px auto 60px;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  grid-template-areas: "form info";
  gap: 100px;
  align-items: start;
}

@media (max-width: 1024px) {
  .contact-grid {
    grid-template-columns: 1fr 1fr;
    gap: 60px;
  }
}

@media (max-width: 760px) {
  .contact-grid { 
    grid-template-columns: 1fr; 
    grid-template-areas: "info" "form";
    gap: 0; 
    padding: 0 20px; 
    margin-top: 0;
    margin-bottom: 0;
  }
  .contact-form-wrapper { margin-top: 40px; }
  .faq-list { padding: 0; }
}

.contact-grid h2 { margin: 0 0 32px; font-size: 1.5rem; font-weight: 600; letter-spacing: -.02em; color: var(--text); }

.contact-info {
  padding: 0;
  background: transparent;
  border: none;
  margin-top: 34px;
  margin-bottom: 40px;
}

.contact-info .card.step { 
  display: flex;
  gap: 24px;
  align-items: flex-start;
  text-align: left; 
  padding: 0; 
  margin-bottom: 40px; 
  background: transparent;
  border: none;
  box-shadow: none;
  transform: none !important;
}
.contact-info .card.step:last-child { margin-bottom: 0; }
.contact-info .card.step::before { display: none; }
.contact-info .card.step:hover { transform: none; box-shadow: none; border: none; background: transparent; }

.info-icon {
  width: 24px;
  height: 24px;
  color: var(--accent-blue);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 4px;
}
.info-icon svg { width: 24px; height: 24px; stroke-width: 1.5; }

.info-text h3 { margin: 0 0 8px; font-size: 1.125rem; font-weight: 600; color: var(--text); }
.info-text p { margin: 0; color: var(--muted); line-height: 1.6; font-size: 1rem; }
.info-text a { color: var(--text); font-weight: 500; text-decoration: none; border-bottom: 1px solid var(--border); transition: border-color 0.2s; }
.info-text a:hover { border-bottom-color: var(--accent-blue); }

.contact-form-wrapper { grid-area: form; }
.contact-info { grid-area: info; }

@media (max-width: 760px) {
  .contact-info .card.step {
    gap: 20px;
    margin-bottom: 32px;
  }
  .info-icon {
    width: 20px;
    height: 20px;
    margin-top: 3px;
  }
  .info-icon svg { width: 20px; height: 20px; }
  .info-text h3 { font-size: 1rem; }
  .info-text p { font-size: 0.9375rem; }
}

.contact-form-wrapper,.contact-info{display:flex;flex-direction:column}
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group label{font-size:.9375rem;font-weight:500;color:var(--text);letter-spacing:-.01em}
.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  padding: 14px 18px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #F9F9F9;
  color: var(--text);
  font-size: 1rem;
  font-family: inherit;
  transition: all 0.2s ease;
  font-weight: 400;
  line-height: 1.5;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none;
  background: var(--bg);
  border-color: var(--yellow);
  box-shadow: 0 0 0 4px rgba(255, 214, 0, 0.1);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted);opacity:.6}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2386868B' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;padding-right:40px}
.form-group textarea{resize:vertical;min-height:120px}
@media(max-width:760px){
  .contact-form-wrapper,.contact-info{grid-column:1/-1}
  div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important;gap:32px}
}

@media (min-width:1024px){
  .locations-section {
    position: relative;
    padding: 0;
    height: calc(100vh - var(--header-h));
    max-height: calc(100vh - var(--header-h));
    overflow: hidden;
  }
  .locations-grid { 
    display: block; 
    position: relative;
    width: 100%;
    height: 100%;
  }
  .locations-map { 
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 0; 
    overflow: hidden; 
    box-shadow: none; 
    background: var(--bg-tertiary); 
    border: none;
    z-index: 1;
  }
  .partners-list-wrap {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 350px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 24px;
    padding: 20px;
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    gap: 20px;
    overflow: hidden;
    height: auto;
    max-height: calc(100vh - var(--header-h) - 100px);
    z-index: 10;
  }
  .partner-list {
    max-height: calc(100vh - var(--header-h) - 180px);
    min-height: 120px;
  }
  .partners-list-wrap {
    min-height: calc(100vh - var(--header-h) - 48px);
  }
}

/* Legal Sections */
.legal-section { padding: 60px 0; }
.legal-content { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 24px; }
.legal-content .card.step { text-align: left; padding: 32px; }
.legal-content h3 { margin-top: 40px; margin-bottom: 2px; font-size: 1.25rem; font-weight: 600; }
.legal-content p { margin: 0; line-height: 1.7; }
.legal-content a { color: var(--text); text-decoration: underline; }

/* FAQ Accordion */
.faq-list{display:flex;flex-direction:column;gap:16px;max-width:960px;margin:0 auto}
.faq-section { padding-top: 20px; padding-bottom: 100px; }
.faq-item{border:1px solid var(--border);border-radius:14px;background:var(--bg);overflow:hidden;transition:all .3s cubic-bezier(.28,.11,.32,1);box-shadow:none;position:relative}
.faq-item:hover{border-color:var(--yellow);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 22px;background:none;border:none;text-align:left;cursor:pointer;font-size:1.15rem;font-weight:600;color:var(--text);letter-spacing:-.012em;transition:color .3s cubic-bezier(.28,.11,.32,1);gap:12px}
.faq-question:hover{color:var(--text)}
.faq-question span{flex:1}
.faq-icon{width:22px;height:22px;flex-shrink:0;transition:transform .3s cubic-bezier(.28,.11,.32,1);color:var(--muted)}
.faq-question[aria-expanded="true"] .faq-icon{transform:rotate(180deg);color:var(--yellow)}
.faq-item[aria-expanded="true"] .faq-question .faq-icon{transform:rotate(180deg);color:var(--yellow)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.28,.11,.32,1),padding .35s cubic-bezier(.28,.11,.32,1);padding:0 22px}
.faq-item[aria-expanded="true"] .faq-answer{max-height:360px;padding:0 22px 20px}
.faq-answer p{margin:0;color:var(--muted);line-height:1.68;font-size:1.02rem}
.faq-answer p:not(:last-child){margin-bottom:12px}
