:root{
  --bg:#ffffff;
  --ink:#0B1220;
  --muted:#6E7480;
  --line:#E2E5EB;
  --card:#0B1220;
  --shadow: 0 20px 60px rgba(11,18,32,.12);
  --radius: 22px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
a{color:inherit}
.hidden{display:none}

.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px;
  background:rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(226,229,235,.6);
}
.brand{display:flex; gap:12px; align-items:center; text-decoration:none}
.brand img{height:34px; width:auto}
.brand span{font-size:12px; letter-spacing:.22em; text-transform:uppercase}
.brand em{font-style:normal; opacity:.7}

.navlinks{display:flex; gap:34px; align-items:center}
.navlinks a{font-size:13px; text-decoration:none; opacity:.78}
.navlinks a:hover{opacity:1}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  height:44px; padding:0 18px;
  background:var(--ink); color:#fff;
  border-radius:999px; text-decoration:none;
  font-size:13px; letter-spacing:.02em;
  box-shadow:0 10px 30px rgba(11,18,32,.18);
}
.btn:hover{transform:translateY(-1px)}
.btn--ghost{background:transparent; color:var(--ink); border:1px solid var(--line); box-shadow:none}
.btn--ghost:hover{background:#f6f7fb}

.link{font-size:13px; opacity:.78; text-decoration:none}
.link:hover{opacity:1; text-decoration:underline}

.hero{
  min-height:auto;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:0;
  padding-top:74px;
}
.hero__bg{
  min-height:520px;

  background:
    linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.10) 45%, rgba(0,0,0,.0) 60%),
    linear-gradient(0deg, rgba(11,18,32,.40) 0%, rgba(0,0,0,0) 55%),
    url('/assets/hero.jpg') center/cover no-repeat;
}
.hero__content{
  padding:44px 40px 40px 40px;
  display:flex; flex-direction:column; justify-content:center;
}
.hero h1{
  font-family:"Playfair Display", Georgia, serif;
  font-weight:600;
  font-size:clamp(42px, 4.6vw, 56px);
  line-height:1.04;
  margin:0 0 14px 0;
}
.hero p{margin:0 0 18px 0; color:var(--muted); max-width:42ch; font-size:15px; line-height:1.6}
.hero__cta{display:flex; gap:16px; align-items:center; margin-top:8px}
.hero__trust{
  margin-top:14px;
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  font-size:12px;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:rgba(11,18,32,.62);
}
.hero__trust i{font-style:normal; opacity:.55}
.hero__note{margin-top:28px; font-size:14px; line-height:1.55; color:rgba(11,18,32,.58); max-width:760px; margin-left:auto; margin-right:auto; text-align:center}

.section{padding:46px 40px}
.section--alt{background:#FBFCFF; border-top:1px solid rgba(226,229,235,.7); border-bottom:1px solid rgba(226,229,235,.7)}
.section__head{max-width:860px}
.section__head{margin-left:auto; margin-right:auto}
.section__head h2{
  font-family:"Playfair Display", Georgia, serif;
  font-weight:600;
  font-size:40px; margin:0 0 10px 0;
}
.section__head p{margin:0 0 18px 0; color:var(--muted); line-height:1.7}

.grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
  align-items:stretch;
}
.card{
  border:0; padding:0; text-align:left; cursor:pointer;
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  background: var(--ink);
  box-shadow: var(--shadow);
  transform: translateZ(0);
  height:auto;
  aspect-ratio: 3 / 4;
  min-height:360px;
}
.card::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(0deg, rgba(11,18,32,.72) 0%, rgba(0,0,0,0) 55%),
    var(--bg) center/cover no-repeat;
  transform:scale(1.02);
  transition:transform .5s ease;
}

.card h3{
  font-family:"Playfair Display", Georgia, serif;
  font-weight:600;
  font-size:clamp(44px, 4.2vw, 56px);
  line-height:1.05;
  margin:0 0 10px 0;
}
.card p{
  margin:0;
  opacity:.92;
  font-size:clamp(14px, 1.6vw, 16px);
  letter-spacing:.06em;
}
.card__brand{
  position:absolute; left:0; right:0; bottom:18px;
  text-align:center;
  color:rgba(255,255,255,.62);
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  transform:none;
  transition:none;
}

.card:hover::before{transform:scale(1.06)}
.card__overlay{
  position:absolute; left:22px; right:22px; bottom:86px;
  color:#fff;
}

.card__overlay h3{
  font-family:"Playfair Display", Georgia, serif;
  font-size:42px; margin:0 0 6px 0; letter-spacing:.01em;
}
.card__overlay p{margin:0; opacity:.92; font-size:14px; letter-spacing:.08em; text-transform:none}
.card__brand{
  position:absolute; left:0; right:0; bottom:18px;
  text-align:center;
  color:rgba(255,255,255,.62);
  font-size:12px; letter-spacing:.28em; text-transform:uppercase;
  transform:translateY(58px);
  transition:transform .35s ease;
}
.card__brand span{opacity:.8}
.card:hover .card__brand{transform:translateY(0)}

.micro{margin-top:12px; color:var(--muted); font-size:12px}

.steps{
  list-style:none;
  margin:18px 0 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
}
.steps li{
  background:#fff; border:1px solid rgba(226,229,235,.8);
  border-radius:18px; padding:18px;
  display:flex; gap:14px;
}
.k{font-size:12px; letter-spacing:.24em; opacity:.6}
.steps h4{margin:0 0 6px 0; font-size:15px}
.steps p{margin:0; color:var(--muted); font-size:13px; line-height:1.6}

.disclaimer{
  margin-top:18px;
  border:1px solid rgba(226,229,235,.9);
  background:#fff;
  border-radius:18px;
  padding:18px;
  max-width:860px;
}
.disclaimer h5{margin:0 0 6px 0}
.disclaimer p{margin:0; color:var(--muted); line-height:1.7}

.contact{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:34px;
  align-items:start;
}
form{
  background:#fff; border:1px solid rgba(226,229,235,.8);
  border-radius:18px; padding:18px;
}
label{display:block; font-size:12px; letter-spacing:.06em; color:rgba(11,18,32,.8); margin-bottom:12px}
input,select,textarea{
  width:100%;
  margin-top:8px;
  padding:12px 12px;
  border:1px solid rgba(226,229,235,.9);
  border-radius:12px;
  font-size:14px;
  outline:none;
}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(11,18,32,.35)}
.row{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:12px}
.check{display:flex; gap:10px; align-items:flex-start}
.check input{width:auto; margin-top:2px}
.check span{font-size:12px; color:var(--muted); letter-spacing:0}

.contact__aside{display:grid; gap:12px}
.asidebox{
  border:1px solid rgba(226,229,235,.8);
  border-radius:18px;
  padding:18px;
  background: #0B1220;
  color:#fff;
  box-shadow: var(--shadow);
}
.asidebox h3{
  font-family:"Playfair Display", Georgia, serif;
  margin:0 0 8px 0;
  font-size:22px;
}
.asidebox p{margin:0 0 10px 0; opacity:.9}
.asidebox ul{margin:0; padding-left:16px; opacity:.9}
.asidebox--light{background:#fff; color:var(--ink); box-shadow:none}
.asidebox--light p{color:var(--muted)}

.footer{
  padding:32px 56px;
  display:flex; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(226,229,235,.8);
}
.footer__brand{letter-spacing:.26em; text-transform:uppercase; font-size:12px}
.footer__brand span{opacity:.75}
.footer__links a{font-size:12px; color:var(--muted); text-decoration:none}
.footer__links a:hover{text-decoration:underline}

/* Minimal, centered footer variant */
.footer.footer--center{
  justify-content:center;
  padding-left:0;
  padding-right:0;
}
.footer__centerLink{
  font-size:12px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:none;
  border-bottom:1px solid rgba(0,0,0,.16);
  padding-bottom:3px;
}
.footer__centerLink:hover{border-bottom-color: rgba(0,0,0,.30);}

.modal::backdrop{background:rgba(11,18,32,.62)}
.modal{
  border:0;
  border-radius:22px;
  padding:0;
  width:min(720px, 92vw);
  box-shadow: var(--shadow);
}
.modal__inner{padding:22px 22px 18px 22px}
.modal__x{
  position:absolute; top:14px; right:14px;
  width:40px; height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.55);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  cursor:pointer;
  font-size:20px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  color:#0f172a;
  z-index: 50;
}
.modal h3{font-family:"Playfair Display", Georgia, serif; margin:0 0 10px 0; font-size:34px}
.modal p{margin:0 0 12px 0; color:var(--muted); line-height:1.7}
.modal ul{margin:0 0 14px 0; padding-left:18px; color:var(--ink)}
.modal__actions{display:flex; gap:10px; justify-content:flex-end}

@media (max-width: 980px){
  .hero{grid-template-columns:1fr}
  .hero__bg{
  min-height:520px;
min-height:56vh}
  .hero__content{padding:34px 22px 28px 22px}
  .section{padding:46px 40px}
  .grid{grid-template-columns:1fr}
  .card{height:auto;}
  .steps{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .footer{padding:26px 22px}
  .footer.footer--center{padding-left:0; padding-right:0;}
  .navlinks{gap:14px}
}

@media (min-width: 1100px){
  .grid{ grid-template-columns:repeat(4, minmax(0,1fr)); gap:20px; }
}
@media (max-width: 640px){
  .grid{ grid-template-columns:1fr; }
  .card{ min-height:340px; aspect-ratio: 3 / 4; }
}

.hero.hero--center{
  min-height:unset;
  padding:84px 0 22px;
  display:block;
  grid-template-columns:none;
}
.hero__content--center{
  max-width:980px;
  margin:0 auto;
  text-align:center;
}
.hero__content--center .hero__cta{
  justify-content:center;
}

.standard__lockup{
  margin-top:22px;
  text-align:center;
  letter-spacing:.32em;
  font-size:12px;
  color:rgba(0,0,0,.55);
}
.standard__lockup span{
  display:block;
  letter-spacing:.44em;
  font-size:11px;
  margin-top:6px;
  opacity:.7;
}


@media (max-width: 980px){
  .section{padding:34px 20px}
  .hero{grid-template-columns:1fr; padding-top:68px}
  .hero__bg{min-height:420px}
  .hero__content{padding:28px 20px}
  .section__head h2{font-size:32px}
}




/* --- v7: screenshot-match (tight, centered, 4-up) --- */
:root{
  --container: 1180px;
  --bg: #f5f2ee;
  --ink: #1b1b1b;
  --muted: rgba(27,27,27,.65);
  --line: rgba(27,27,27,.14);
  --radius: 26px;
}

body{
  background: var(--bg);
  color: var(--ink);
}

/* subtle paper grain */

/* layout */
.section{ padding: 52px 0; }
.wrap{ max-width: var(--container); margin: 0 auto; padding: 0 26px; }

.hero{ padding: 34px 0 34px; }
.hero__inner{ text-align:center; padding: 18px 0 26px; }

.h1{
  font-size: clamp(40px, 4.1vw, 62px);
  letter-spacing: -0.02em;
  margin: 0 0 10px;
}

.lead{
  margin: 0 auto 16px;
  max-width: 820px;
  color: var(--muted);
  font-size: 16px;
}

.ctaRow{
  display:flex;
  gap:14px;
  justify-content:center;
  align-items:center;
  margin-top: 14px;
}

.btn{
  border-radius: 999px;
  padding: 10px 16px;
  border: 1px solid var(--line);
  text-decoration:none;
  font-size: 14px;
}

.btn--primary{
  background:#222;
  color:#fff;
  border-color: transparent;
}

.btn--link{
  background: transparent;
  color: var(--muted);
}

.cardgrid{
  display:grid;
  gap: 18px;
  margin-top: 18px;
}

.cardgrid--4{
  grid-template-columns: repeat(4, minmax(0,1fr));
}

.card{
  position:relative;
  border: 1px solid rgba(27,27,27,.10);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.35);
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  cursor:pointer;
  padding:0;
}

.card img{
  width:100%;
  height:100%;
  display:block;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.brandCenter{
  text-align:center;
  margin-top: 18px;
  opacity:.75;
}

.brandWord{
  letter-spacing: .28em;
  font-size: 18px;
}

.brandSub{
  letter-spacing: .55em;
  font-size: 12px;
  margin-top: 6px;
}

/* (Footer layout handled via .footer / .footer--center) */

@media (max-width: 980px){
  .cardgrid--4{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .hero__inner{ padding-bottom: 18px; }
}

@media (max-width: 560px){
  .cardgrid--4{ grid-template-columns: 1fr; }
  .wrap{ padding: 0 16px; }
}

/* --- v8 adjustments: no background image, centered header brand, overlay text --- */
header .nav{ justify-content: center; }
header .nav__left{ position:absolute; left:26px; }
header .nav__right{ position:absolute; right:26px; }
@media (max-width: 760px){
  header .nav{ justify-content: space-between; }
  header .nav__left, header .nav__right{ position:static; }
}

.card{ position:relative; }
.card .overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:22px;
  text-align:left;
  color:#fff;
  background: linear-gradient(to top, rgba(0,0,0,.52), rgba(0,0,0,0) 58%);
}
.card .overlay .t{
  font-size: 40px;
  line-height:1.0;
  letter-spacing:-0.01em;
  margin:0 0 8px;
}
.card .overlay .s{
  font-size: 14px;
  opacity:.92;
  margin:0;
}
.card .overlay .b{
  margin-top:18px;
  font-size: 10px;
  letter-spacing:.28em;
  opacity:.78;
}

/* --- v10: hero exact centering only --- */
.hero, .hero * { box-sizing: border-box; }
.hero{ text-align:center; }
.hero .heroInner, .hero .inner, .hero .wrap{
  margin-left:auto !important;
  margin-right:auto !important;
}
.hero .heroInner{
  max-width: 980px;
  padding-left: 24px;
  padding-right: 24px;
}
.hero .ctaRow, .hero .actions, .hero .buttons{
  justify-content:center !important;
}

/* --- v11: center hero paragraph + note (only hero) --- */
.hero--center .hero__content--center{
  text-align:center !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
.hero--center .hero__content--center > p,
.hero--center .hero__content--center .hero__note{
  margin-left:auto !important;
  margin-right:auto !important;
  text-align:center !important;
  max-width: 860px;
}

/* --- v12: compact hero + bring tiles up (only spacing/sizing) --- */
.hero{
  padding-top: 64px !important;
  padding-bottom: 28px !important;
}
.hero h1, .hero .headline{
  margin-bottom: 10px !important;
}
.hero .subline, .hero p.lead, .hero .lead, .hero .tagline{
  margin-top: 0 !important;
  margin-bottom: 14px !important;
}
.hero .actions, .hero .ctaRow, .hero .buttons{
  margin-top: 0 !important;
  margin-bottom: 10px !important;
}
.hero .disclaimer, .hero .hint, .hero .note{
  margin-top: 18px !important;
  margin-bottom: 0 !important;
  line-height: 1.4 !important;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.section{
  padding-top: 44px !important;
  padding-bottom: 44px !important;
}
.tiles{
  margin-top: 18px !important;
}
.tileGrid, .tilesGrid, .gridTiles{
  gap: 18px !important;
}
.tile, .tileCard{
  max-width: none;
  width: 100%;
}
.tile img, .tileCard img{
  height: 300px !important;
  object-fit: cover !important;
}
@media (min-width: 980px){
  .tile img, .tileCard img{ height: 310px !important; }
}

/* --- v13: more side breathing room (calmer), keep compactness --- */
:root{
  --pagePad: 34px;
  /* A touch wider on desktop so the layout doesn't feel too narrow on laptops */
  --contentMax: 1180px;
}
body{
  padding-left: var(--pagePad) !important;
  padding-right: var(--pagePad) !important;
}
header, main, footer, .hero, .section{
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.container, .wrap, .inner, .heroInner, .sectionInner, .content, .page{
  max-width: var(--contentMax) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.tiles, .tileGrid, .tilesGrid, .gridTiles{
  max-width: var(--contentMax) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
/* Make the 4-tile row span the same width as the page content,
   so the header can align cleanly to the tile edges. */
.tileGrid, .tilesGrid, .gridTiles{
  justify-content: stretch !important;
  width: 100%;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}
@media (max-width: 980px){
  .tileGrid, .tilesGrid, .gridTiles{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px){
  .tileGrid, .tilesGrid, .gridTiles{
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 740px){
  :root{ --pagePad: 18px; }
}

/* --- Legal page polish (align + premium card) --- */
.section--legal .wrap{ width:100%; }
.legal__card{
  max-width: 920px;
  margin: 20px auto 0;
  padding: 28px 28px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(226,229,235,.85);
  border-radius: 22px;
  box-shadow: 0 18px 44px rgba(18,16,14,.08);
  color: var(--muted);
  line-height: 1.85;
}
.legal__card h3{
  color: var(--ink);
  margin: 18px 0 8px;
  font-size: 16px;
  letter-spacing: .02em;
}
.legal__card p{ margin: 0 0 14px; }
.legal__actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}
@media (max-width: 560px){
  .legal__card{ padding: 22px 18px; }
}

/* --- v27: NAV align EXACTLY to tile edges (no extra inner padding) --- */
.nav{ padding-left: 0 !important; padding-right: 0 !important; }
.nav__inner{
  max-width: var(--contentMax) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* --- v27: HERO note lower + wraps nicer on 2 lines --- */
.hero__note, .hero .disclaimer, .hero .hint, .hero .note{
  margin-top: 30px !important;
  max-width: 720px !important;
}

/* --- v28: restore baseline layout (left-aligned heads + wider page on desktop) --- */
:root{
  /* Wider on laptops to avoid excessive empty margins */
  --contentMax: 1380px;
  --pagePad: 26px;
}

/* The section heads must be left-aligned (not centered) */
.section__head{
  margin-left: 0 !important;
  margin-right: 0 !important;
  text-align: left !important;
}
.section__head h2,
.section__head p{ text-align: left !important; }

/* Undo any global hero-centering overrides from older iterations */
.hero{ text-align: left !important; }
.hero__note{ text-align: center; } /* keep the small note calm/centered */

@media (max-width: 740px){
  :root{ --pagePad: 18px; }
}

/* --- v28: tiles – reserve 2 text lines so all titles sit on the same height --- */
.card__overlay p{
  min-height: 2.8em; /* ~2 lines */
}


/* Premium modal */
.modal{
  width: min(820px, calc(100% - 2.4rem));
  border: none;
  padding: 0;
  background: transparent;
}
.modal::backdrop{
  background: rgba(20,18,16,.55);
  backdrop-filter: blur(6px);
}
.modal__inner{
  background: rgba(246,243,238,.98);
  border: 1px solid rgba(40,34,30,.10);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 28px 90px rgba(0,0,0,.28);
  position: relative;
}
.modal__x{
  position:absolute; top:14px; right:14px;
  width:40px; height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.55);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  cursor:pointer;
  font-size:20px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  color:#0f172a;
  z-index: 50;
}
.modal__hero{
  height: 220px;
  background-image: var(--hero);
  background-size: cover;
  background-position: center;
  position: relative;
  z-index: 0;
}
.modal__heroShade{
  position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,.08), rgba(0,0,0,.55));
  z-index: 1;
}
.modal__heroBrand{
  position:absolute; left: 22px; bottom: 18px;
  z-index: 2;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.92);
}
.modal__heroBrand span{ opacity:.78; font-weight:600; }
.modal__content{
  padding: 22px 24px 26px;
}
.modal__eyebrow{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(40,34,30,.55);
}
.modal__title{
  margin: 10px 0 6px;
  font-size: 40px;
  line-height: 1.02;
}
.modal__lead{
  margin: 0 0 16px;
  color: rgba(40,34,30,.72);
}
.modal__grid{
  display: grid;
  grid-template-columns: 1.2fr .9fr;
  gap: 14px;
  margin-top: 14px;
}
.modal__box{
  border: 1px solid rgba(40,34,30,.10);
  background: rgba(255,255,255,.55);
  border-radius: 18px;
  padding: 14px 14px 12px;
}
.modal__box--soft{
  background: rgba(238,233,226,.65);
}
.modal__boxTitle{
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(40,34,30,.62);
  margin-bottom: 10px;
}
.modal__list{
  margin: 0;
  padding-left: 18px;
}
.modal__list li{ margin: 7px 0; color: rgba(40,34,30,.78); }
.modal__micro{
  margin: 0 0 12px;
  color: rgba(40,34,30,.72);
}
.modal__pills{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.pill{
  border: 1px solid rgba(40,34,30,.16);
  background: rgba(255,255,255,.55);
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 12px;
  color: rgba(40,34,30,.78);
}
.modal__actions{
  display:flex;
  gap: 10px;
  margin-top: 18px;
}
@media (max-width: 680px){
  .modal__hero{ height: 180px; }
  .modal__title{ font-size: 34px; }
  .modal__grid{ grid-template-columns: 1fr; }
  .modal__actions{ flex-direction: column; }
}



/* --- v16: Ablauf cards + Transparenz premium polish --- */
.section--alt{
  background: rgba(255,255,255,.35) !important;
}

.steps{
  list-style:none;
  margin: 18px 0 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}

.steps > li{
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(40,34,30,.10);
  border-radius: 26px;
  padding: 22px 22px;
  display:flex;
  gap: 14px;
  box-shadow: 0 14px 40px rgba(0,0,0,.06);
}

.steps > li .k{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(40,34,30,.12);
  background: rgba(255,255,255,.55);
  color: rgba(40,34,30,.70);
  font-size: 12px;
  letter-spacing: .16em;
}

.steps > li h4{
  margin: 2px 0 6px;
}

.steps > li p{
  margin: 0;
  color: rgba(40,34,30,.72);
}

.disclaimer{
  margin-top: 18px;
  border: 1px solid rgba(40,34,30,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.80), rgba(246,243,238,.92));
  border-radius: 28px;
  padding: 22px 22px;
  max-width: 860px;
  box-shadow: 0 18px 55px rgba(0,0,0,.07);
  position: relative;
  overflow:hidden;
}

.disclaimer:before{
  content:"";
  position:absolute;
  inset:-40px -40px auto -40px;
  height: 90px;
  background: radial-gradient(closest-side, rgba(0,0,0,.06), rgba(0,0,0,0));
}

.disclaimer h5{
  margin: 0 0 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(40,34,30,.62);
}

.disclaimer p{
  margin: 0;
  color: rgba(40,34,30,.72);
  line-height: 1.55;
}

@media (max-width: 820px){
  .steps{ grid-template-columns: 1fr; }
}

/* --- v17: Transparenz card integrated (full width, aligned with steps grid) --- */
.disclaimer{
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-top: 16px !important; /* aligns with grid rhythm */
  border: 1px solid rgba(40,34,30,.08) !important;
  box-shadow: 0 16px 46px rgba(0,0,0,.065) !important;
}


/* --- Direct links (legacy; kept neutral) --- */
.navsocial{display:inline-flex; gap:8px; margin-left:10px; align-items:center}
.navicon{display:inline-flex; align-items:center; justify-content:center; color:var(--ink); text-decoration:none}

.btn--soft{background:#f6f7fb; border:1px solid var(--line); color:var(--ink); box-shadow:none}
.btn--soft:hover{background:#eef0f7}

/* Premium icon actions (WhatsApp / Formular / Instagram) */
.contactActions{display:flex; align-items:stretch; justify-content:space-between; gap:34px; margin-top:18px; padding:6px 8px; width:100%}
.actionBtn{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:14px 10px; border-radius:18px; border:0; background:transparent; color:var(--ink); text-decoration:none; box-shadow:none; transition:transform .15s ease, background .15s ease, border-color .15s ease}
.actionBtn:hover{transform:translateY(-1px); background:rgba(17,24,39,.04)}
.actionBtn--primary{background:rgba(255,124,42,.10); box-shadow:0 0 0 1px rgba(255,124,42,.20) inset}
.actionBtn--primary:hover{background:rgba(255,124,42,.14)}
.actionBtn svg{width:44px; height:44px; fill:currentColor; opacity:.92}
.actionBtn span{font-size:12px; letter-spacing:.06em; text-transform:uppercase; opacity:.8}

/* === v21: Nav refinement (alignment + underline) === */
.nav{
  display:block;
  padding: 14px 0;
}
.nav__inner{
  /* Align header edges to the same container as the 4-tile grid */
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 40px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 20px;
}
.navlinks{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 18px;
  flex-wrap:wrap;
}

.navlink{ /* semantic hook (same as .navlinks a) */ }

/* unify link style */
.navlinks a{
  position:relative;
  text-decoration:none;
  padding: 10px 2px;
  border-radius: 0;
}

/* underline on hover/focus */
.navlinks a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:6px;
  height:1px;
  background: rgba(15,15,18,.55);
  transform: scaleX(0);
  transform-origin: 0 50%;
  transition: transform .18s ease, opacity .18s ease;
  opacity:.9;
}
.navlinks a:hover::after,
.navlinks a:focus-visible::after{
  transform: scaleX(1);
}

/* nav icons (WA / IG / Form) */
.navicons{
  display:flex;
  align-items:center;
  gap: 14px;
  margin-left: 6px;
}
.navicon{
  width: 34px;
  height: 34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  opacity: .92;
}
.navicon::after{ display:none; }
.navicon svg{ width:18px; height:18px; fill: rgba(17,20,24,.72); }
.navicon:hover svg, .navicon:focus-visible svg{ fill: rgba(17,20,24,.95); }
.navicon:hover{ opacity: 1; }

/* ensure header right edge aligns with page content */
@media (max-width: 720px){
  .nav{ padding: 12px 0; }
  .navlinks{
    display:grid;
    grid-template-columns: repeat(3, auto);
    grid-auto-rows:auto;
    justify-content:end;
    gap: 10px 18px;
  }
  .navicons{
    grid-column: 1 / -1;
    justify-content:end;
    margin-left: 0;
  }
  .navlinks a{ padding: 8px 0; }
}


/* ===== FINAL OVERRIDES (v28) ===== */
:root{
  --contentMax: 1120px !important;
  --pagePad: 26px !important;
}

html, body{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.wrap{
  max-width: var(--contentMax) !important;
  padding-left: var(--pagePad) !important;
  padding-right: var(--pagePad) !important;
}

/* Header alignment: match tile edges */
header.nav{
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.nav__inner{
  max-width: var(--contentMax) !important;
  padding-left: var(--pagePad) !important;
  padding-right: var(--pagePad) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Make sure hero + cards use the same content width */
.hero, .section{
  max-width: var(--contentMax) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--pagePad) !important;
  padding-right: var(--pagePad) !important;
}

/* Hero needs extra top room because the nav is fixed (and on mobile becomes taller). */
.hero{padding-top: 72px !important;}
@media (max-width: 720px){
  .hero{padding-top: 132px !important;}
}

.hero .disclaimer{margin-top: 26px !important;}

/* Hinweis: move lower + 2-line comfortable */
.hero .note, .hero .hero-note, .hero .hint{
  margin-top: 18px !important;
  max-width: 720px !important;
  line-height: 1.55 !important;
}

/* Card images: never stretch */
.card{
  background-size: cover !important;
  background-position: center !important;
}

