/* ========== BASE: Farben, Typo, Grundlayout, Header/Hero/Footer ========== */

/* Lokale Fonts */
@font-face { font-family:'Montserrat'; src:url('../assets/fonts/montserrat-v30-latin-regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../assets/fonts/montserrat-v30-latin-600.woff2') format('woff2'); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../assets/fonts/montserrat-v30-latin-700.woff2') format('woff2'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Open Sans'; src:url('../assets/fonts/open-sans-v43-latin-regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Open Sans'; src:url('../assets/fonts/open-sans-v43-latin-600.woff2') format('woff2'); font-weight:600; font-style:normal; font-display:swap; }

/* Design-Tokens */
:root{
  --radius: 12px;
  --gap: 12px;
  --label-fs: 14px;
  --input-fs: 15px;
  --input-pad-y: 10px;
  --input-pad-x: 12px;
  
  --primary:#1377bd; --primary-600:#0f5f98; --accent:#13a4d8;
  --text:#0f172a; --muted:#57616f;
  --border:#d6dde6; --border-strong:#b9c3cf;
  --card-bg:#fff; --bg-subtle:#f7fbfe;

  --hero-bg:url('../assets/images/istanbul.jpg');

  --brand-logo-h:52px; --footer-logo-h:70px;
  --banner:#13a4d8; --brandbar-name:#13a4d8; --brandbar-border:#e6edf3;
  --footer:#0b2133; --footer-link:#cfefff;

  --card-width:1040px; --topbar-h:32px;
  --icon-o:28px; --icon-u:28px;
  --footer-gap:3px; --footer-link-fs:14px;
  --panel-min:440px;
  --pay-offset: 24px

  /* Tabs Theme (Business Blau) */
  --tab-bg:#fff; --tab-color:#0f172a; --tab-border:#d6dde6;
  --tab-hover-border:#1377bd; --tab-focus-ring: color-mix(in srgb, #1377bd 20%, transparent);
  --tab-active-bg:#13a4d8; --tab-active-color:#fff; --tab-active-border:#1377bd;

  /* Pills */
  --pill-bg:#fff; --pill-border:var(--border); --pill-color:var(--text);
  --pill-hover-border:var(--primary); --pill-focus-ring: color-mix(in srgb, var(--accent) 15%, transparent);
  --pill-bg-active:var(--primary); --pill-color-active:#fff; --pill-border-active:var(--primary);
  --pill-size:26px; --trav-row-gap:140px; --pill-gap:8px; --label-mb:6px;

  /* Tabs sizing */
  --tab-fs:15px; --tab-pad-y:8px; --tab-pad-x:20px; --tab-radius:8px; --tab-gap:12px;

  /* Trip tabs */
  --trip-fs:15px; --trip-pad-y:4px; --trip-pad-x:14px; --trip-radius:8px;
  --trip-bg:#fff; --trip-color:var(--text); --trip-border:var(--border);
  --trip-hover-border:var(--primary); --trip-focus-ring: color-mix(in srgb, var(--accent) 15%, transparent);
  --trip-active-bg:var(--primary); --trip-active-color:#fff; --trip-active-border:var(--primary);

  /* Buttons */
  --btn-fs:15px; --btn-h:40px;
  --btn-primary-bg:var(--primary); --btn-primary-text:#fff; --btn-primary-border:var(--primary); --btn-primary-hover:var(--primary-600);
  --btn-ghost-bg:#fff; --btn-ghost-text:var(--text); --btn-ghost-border:var(--border);
  --btn-ghost-hover-bg:#f7fbfe; --btn-ghost-hover-bor:var(--primary);
}

/* Base */
*{ box-sizing:border-box }
html{ scroll-behavior:smooth; }
html, body { height: 100%; }
/* PATCH: Sticky-Footer – Body wird Flex-Container */
body{
  margin:0;
  font-family:'Montserrat','Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial,sans-serif;
  font-size:16px;
  line-height:1.6;
  color:#111;

  /* Sticky-Mechanik */
  min-height: 100dvh;
  display: flex;
  flex-direction: column;

  /* Hintergrund für leere Bereiche (kein weißes Band) */
  background: var(--bg-subtle, #f7fbfe);

  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
/* PATCH: Sticky-Footer – Content wächst, Footer bleibt unten */
main{ flex: 1 0 auto; }
footer{ flex-shrink: 0; }
.wrap{ max-width:var(--card-width); margin:0 auto; padding:20px }
h1,h2,h3{ margin:0 }

/* Brandbar/Topbar */
.topbar{ height:var(--topbar-h); background:var(--banner); width:100%; }
.brandbar{ background:#fff; border-bottom:2px solid var(--brandbar-border); position:relative; z-index:50; }
.brandbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:10px 0; }
.brandbar-left{ display:flex; align-items:center; gap:10px; min-width:0; }
.brandbar-logo{ height:var(--brand-logo-h); width:auto; display:block; }
.brandbar-name{
  font-family:'Montserrat','Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Noto Sans',Helvetica,Arial,sans-serif;
  font-weight:800; letter-spacing:.2px; color:var(--brandbar-name); font-size:18px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.brandbar-right{ display:flex; align-items:center; gap:14px; }
.brandbar-right img{ width:var(--icon-o); height:var(--icon-o); display:block; opacity:.95; transition:transform .12s, opacity .12s; }
.brandbar-right a:hover img{ transform:translateY(-1px); opacity:1; }

/* Hero ohne 'fixed' – zoombeständig */
.hero{
  background: var(--hero-bg) center/cover no-repeat; /* 'fixed' entfernt */
  position: relative;
  margin-top: 0;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.18) 35%, rgba(0,0,0,0) 65%);
  pointer-events:none;
}

/* Card (Basis) */
.card{ background:#fff; border:1px solid var(--border); border-radius:12px; padding:16px; box-shadow:0 2px 12px rgba(0,0,0,.1) }
.card--glass{
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(120%) blur(6px); -webkit-backdrop-filter:saturate(120%) blur(6px);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 24px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.06);
}

/* Footer */
footer{ background:var(--footer); color:#e7f6fd }
.footer-wrap{ max-width:1100px; margin:0 auto; padding:18px 16px }
.footer-grid{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:16px }
.footer-left{ display:flex; flex-direction:column; gap:10px; align-items:flex-start }
.footer-logo{ height:var(--footer-logo-h); width:auto; display:block }
.footer-tagline{ color:#e7f6fd; opacity:.95 }
.footer-social{ display:flex; gap:10px; align-items:center }
.footer-social img{ width:var(--icon-u); height:var(--icon-u); display:block; filter:brightness(1.2); transition:transform .12s, opacity .12s; }
.footer-social a:hover img{ transform:translateY(-1px); opacity:1; }
.footer-bottom{ margin-top:6px; font-size:14px; color:#cfefff }

/* Footer-Links mittig/untereinander */
.footer-links{
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  gap:var(--footer-gap); min-height:44px; text-align:center;
}
.footer-links a{ color:var(--footer-link); text-decoration:none; font-size:var(--footer-link-fs); opacity:.9; }
.footer-links a:hover{ text-decoration:underline; opacity:1; }

/* Zahlungslogos Grid (Footer) */
.pay-strip{ display:flex; flex-direction:column; align-items:flex-end; gap:8px }
.pay-title{ font-weight:700 }
.pay-list{ display:grid; grid-template-columns:repeat(3,auto); gap:14px 22px; justify-content:center; align-items:center; margin-top:10px }
.pay-list img{ height:22px; transition:transform .12s }
.pay-list img:hover{ transform:translateY(-1px) }
@media (max-width:420px){ .pay-list{ grid-template-columns:repeat(2,auto) } }

/* Typo-Feinschliff */
h1,h2,h3{ font-family:'Montserrat','Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Noto Sans',Helvetica,Arial,sans-serif; font-weight:700; letter-spacing:.2px; }
.brand-name{ font-family:'Montserrat','Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Noto Sans',Helvetica,Arial,sans-serif; font-weight:800 }

/* Medien-Defaults: Bilder skalieren nie über ihr Eltern-Element */
img{ max-width:100%; height:auto; }

/* Besseres Scroll-Verhalten & System-Zoom */
html{ -webkit-text-size-adjust:100%; text-size-adjust:100%; }

/* Tablet-Optimierung */
@media (max-width: 900px){
  :root{
    --brand-logo-h: 46px;
    --footer-logo-h: 64px;
    --tab-fs: 14px;
  }
  .wrap{ padding:16px; }
}

/* Phone-Optimierung */
@media (max-width: 560px){
  :root{
    --brand-logo-h: 40px;
    --footer-logo-h: 56px;
    --label-fs: 13px;   /* Labels minimal kleiner */
    --tab-fs: 13.5px;
    --trip-fs: 14px;
  }
  .wrap{ padding:12px; }
}

@media (prefers-reduced-motion: reduce){
  /* Keine globalen Hard-Stops, nur sanfter */
  *{ scroll-behavior: auto; }
}


