:root{
  --blue:#1768ff;
  --blue2:#17308f;
  --ink:#071126;
  --muted:#617089;
  --soft:#f3f8ff;
  --line:#e4ecf7;
  --white:#fff;
  --shadow:0 28px 80px rgba(23,48,143,.13);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.55}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
.container{width:min(1180px,calc(100% - 42px));margin:auto}
.narrow{width:min(820px,calc(100% - 42px))}
.skip-link{position:absolute;left:-999px;top:10px;background:#fff;padding:12px 18px;z-index:99;border-radius:12px}.skip-link:focus{left:10px}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:blur(22px);border-bottom:1px solid rgba(228,236,247,.78)}
.nav-container{height:78px;width:min(1320px,calc(100% - 42px));margin:auto;display:flex;align-items:center;gap:30px}
.brand{display:flex;align-items:center;gap:10px;font-size:31px;font-weight:900;letter-spacing:-.05em}.brand span span{color:var(--blue)}
.nav{margin-left:auto;display:flex;gap:34px;font-weight:760;font-size:15px}.nav a{position:relative}.nav a:after{content:"";position:absolute;left:0;right:100%;bottom:-9px;height:2px;background:var(--blue);transition:.25s}.nav a:hover:after{right:0}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:15px;background:linear-gradient(135deg,var(--blue),#0754e9);color:#fff;font-weight:850;padding:15px 24px;box-shadow:0 18px 44px rgba(23,104,255,.24);transition:.25s}.btn:hover{transform:translateY(-2px);box-shadow:0 24px 60px rgba(23,104,255,.32)}.nav-btn{padding:11px 18px;font-size:14px}.btn-xl{padding:18px 27px}.ghost{background:rgba(255,255,255,.82);color:var(--ink);border:1px solid var(--line);box-shadow:0 12px 32px rgba(7,17,38,.08)}.btn-light{background:#fff;color:var(--blue);box-shadow:none}
.menu-toggle{display:none;margin-left:auto;width:48px;height:48px;border:1px solid var(--line);border-radius:14px;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px}.menu-toggle span{width:21px;height:2px;background:var(--ink);border-radius:99px}
.hero{position:relative;min-height:760px;overflow:hidden;display:flex;flex-direction:column;justify-content:center;background:#071126;color:#fff}
.hero-image{position:absolute;inset:0;display:block;overflow:hidden;transform:scale(1.02)}.hero-image img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,17,38,.9) 0%,rgba(7,17,38,.62) 42%,rgba(7,17,38,.14) 100%),radial-gradient(circle at 72% 33%,rgba(23,104,255,.25),transparent 34%)}
.hero-inner{position:relative;display:grid;grid-template-columns:1fr 360px;gap:44px;align-items:center;padding:90px 0 50px}
.badge,.mini{display:inline-flex;align-items:center;border-radius:999px;background:#eaf2ff;color:var(--blue);padding:7px 12px;font-size:12px;font-weight:950;letter-spacing:.09em;text-transform:uppercase}.hero .badge{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);color:#dcebff}
h1,h2,h3,p{margin-top:0}h1{font-size:clamp(47px,6vw,82px);line-height:1.01;letter-spacing:-.07em;max-width:820px;margin:18px 0}h1 span,h2 span{color:#51a0ff}
.hero-copy p{font-size:21px;max-width:690px;color:#d9e6f9}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:34px 0 24px}
.trust-pills{display:flex;gap:10px;flex-wrap:wrap}.trust-pills span{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);padding:10px 13px;border-radius:999px;color:#e8f1ff;font-size:14px}
.hero-panel{align-self:end;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.19);backdrop-filter:blur(22px);border-radius:28px;padding:24px;box-shadow:0 30px 90px rgba(0,0,0,.28)}.panel-top{display:flex;align-items:center;gap:10px;margin-bottom:20px}.pulse{width:10px;height:10px;border-radius:50%;background:#28ff9a;box-shadow:0 0 0 8px rgba(40,255,154,.12)}.metric{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-top:1px solid rgba(255,255,255,.14)}.metric span{color:#d6e3f6}.metric strong{font-size:28px;color:#fff}
.hero-bottom{position:relative;margin-bottom:-38px;background:rgba(255,255,255,.92);color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:24px;padding:18px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.hero-bottom div{display:flex;align-items:center;gap:12px;padding:14px;border-radius:18px}.hero-bottom strong,.hero-bottom span{display:block}.hero-bottom span{color:var(--muted);font-size:13px}
i[data-icon]{width:42px;height:42px;display:inline-grid;place-items:center;border-radius:14px;background:#eaf2ff;color:var(--blue);flex:0 0 auto}
.section{padding:94px 0}.logos{padding-top:72px;padding-bottom:38px;background:#fff;text-align:center}.logos p{color:var(--muted);font-weight:700}.logo-row{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.logo-row span{border:1px solid var(--line);background:#fbfdff;border-radius:999px;padding:10px 16px;color:#64738b;font-weight:800}
.section-head{text-align:center;margin-bottom:38px}.section-head h2{font-size:clamp(31px,4vw,52px);line-height:1.08;letter-spacing:-.055em;max-width:920px;margin:12px auto 0}
.premium-grid{display:grid;grid-template-columns:1.12fr .88fr;grid-template-rows:auto auto;gap:24px}.premium-card{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 18px 60px rgba(7,17,38,.07);min-height:300px;transition:.25s}.premium-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}.premium-card.large{grid-row:span 2;display:flex;flex-direction:column;justify-content:space-between;min-height:624px}.premium-card h3{font-size:29px;line-height:1.12;letter-spacing:-.035em;margin:18px 0 10px}.premium-card p{color:var(--muted);font-size:16px}.premium-card a{color:var(--blue);font-weight:900}.premium-card img{border-radius:20px;margin-top:24px;object-fit:cover;aspect-ratio:16/9;box-shadow:0 18px 50px rgba(7,17,38,.12)}.premium-card:not(.large) img{position:absolute;right:18px;bottom:18px;width:48%;opacity:.95}
.benefits{background:linear-gradient(180deg,#f7fbff,#fff)}.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}.split h2{font-size:clamp(34px,4vw,56px);line-height:1.04;letter-spacing:-.06em;margin:14px 0}.split p{color:var(--muted);font-size:18px}.check-list{display:grid;gap:12px;margin-top:24px}.check-list span{background:#fff;border:1px solid var(--line);border-radius:15px;padding:14px 16px;font-weight:850;box-shadow:0 10px 30px rgba(7,17,38,.04)}
.stats-board{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stats-board div{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px;box-shadow:0 16px 50px rgba(7,17,38,.06)}.stats-board strong{font-size:43px;color:var(--blue);display:block;letter-spacing:-.05em}.stats-board strong[data-count]:after{content:"+"}.stats-board span{color:var(--muted);font-weight:750}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative}.step{text-align:center;background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px 18px;box-shadow:0 14px 44px rgba(7,17,38,.05)}.step b{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:50%;background:var(--blue);color:#fff}.step i{margin:18px auto 12px}.step h3{font-size:21px;margin-bottom:8px}.step p{color:var(--muted);font-size:14px}
.testimonial-section{background:linear-gradient(135deg,#071126,#122553);color:#fff}.quote-card{max-width:820px;margin:auto;text-align:center;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16);border-radius:30px;padding:44px;backdrop-filter:blur(20px)}.quote-mark{font-size:80px;color:#56a3ff;line-height:.7}.quote-card p{font-size:24px;color:#eaf2ff}.stars{color:#ffb400;letter-spacing:5px;margin:18px 0}.quote-card span:last-child{display:block;color:#b9c9e5}
.faq details{background:#fff;border:1px solid var(--line);box-shadow:0 12px 36px rgba(7,17,38,.05);border-radius:18px;padding:20px 24px;margin-bottom:13px}.faq summary{font-weight:900;cursor:pointer}.faq details p{color:var(--muted);margin:12px 0 0}
.final-cta{margin-top:20px;margin-bottom:70px;padding:44px;border-radius:30px;background:linear-gradient(135deg,#1768ff,#0d4bd0);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:0 30px 70px rgba(23,104,255,.26);position:relative;overflow:hidden}.final-cta:after{content:"";position:absolute;right:-10%;bottom:-30%;width:50%;height:140%;background:radial-gradient(circle,rgba(255,255,255,.24),transparent 58%)}.final-cta h2{font-size:clamp(30px,4vw,48px);line-height:1.05;letter-spacing:-.05em;max-width:760px;margin:10px 0}.final-cta p{color:#e6f0ff}.mini.light{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.22)}
.footer{background:#fff;border-top:1px solid var(--line);padding:46px 0 22px}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}.footer p,.footer a{color:#58677f}.footer a{display:block;margin:9px 0}.footer h3{font-size:15px}.copyright{text-align:center;border-top:1px solid var(--line);padding-top:20px;margin-top:26px;color:#697891;font-size:13px}
.whatsapp{position:fixed;right:22px;bottom:86px;z-index:80;background:#25d366;color:white;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-weight:950;box-shadow:0 18px 38px rgba(37,211,102,.28)}.back-top{position:fixed;right:22px;bottom:24px;z-index:80;width:52px;height:52px;border:0;border-radius:50%;background:#071126;color:#fff;font-size:23px;box-shadow:0 18px 38px rgba(7,17,38,.22);opacity:0;pointer-events:none;transition:.25s}.back-top.show{opacity:1;pointer-events:auto}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}.reveal.visible{opacity:1;transform:none}
@media(max-width:980px){
  .nav,.nav-btn{display:none}.menu-toggle{display:flex}.nav.open{display:flex;position:absolute;top:78px;left:21px;right:21px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:12px;flex-direction:column;gap:0}.nav.open a{padding:15px;color:var(--ink)}
  .hero{min-height:auto}.hero-inner{grid-template-columns:1fr;padding-top:74px}.hero-panel{display:none}.hero-bottom,.premium-grid,.split,.process-grid,.footer-grid{grid-template-columns:1fr}.premium-card.large{min-height:auto}.premium-card:not(.large) img{position:relative;right:auto;bottom:auto;width:100%}.stats-board{grid-template-columns:1fr 1fr}.hero-bottom{margin-bottom:0}
}
@media(max-width:620px){
  .container,.nav-container{width:min(100% - 28px,1180px)}.site-header{background:rgba(255,255,255,.94)}.nav-container{height:70px}.brand{font-size:26px}.brand svg{width:32px}
  .hero{background:#f5f9ff;color:var(--ink)}.hero-image{opacity:.38}.hero-overlay{background:linear-gradient(180deg,rgba(255,255,255,.83),rgba(255,255,255,.96))}
  .hero-inner{padding:42px 0 20px}.badge{background:#eaf2ff!important;color:var(--blue)!important;border:0!important}h1{font-size:42px;color:var(--ink)}h1 span{color:var(--blue)}.hero-copy p{font-size:17px;color:#40516a}.hero-actions .btn{width:100%}.trust-pills span{background:#fff;color:#34445c;border-color:var(--line)}
  .hero-bottom{padding:8px}.hero-bottom div{background:#fff;border:1px solid var(--line)}
  .section{padding:58px 0}.section-head h2,.split h2{font-size:34px}.stats-board{grid-template-columns:1fr}.quote-card{padding:28px}.quote-card p{font-size:18px}.final-cta{padding:30px;flex-direction:column;align-items:flex-start}.footer-grid{gap:18px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}


/* ===== Premium Services Section – rebuilt ===== */
.premium-services {
  position: relative;
  padding-top: 105px;
  background:
    radial-gradient(circle at 16% 12%, rgba(23,104,255,.08), transparent 32%),
    linear-gradient(180deg, #ffffff 0%, #f7fbff 58%, #ffffff 100%);
  overflow: hidden;
}

.premium-services::before {
  content: "";
  position: absolute;
  inset: 70px auto auto 50%;
  width: min(920px, 90vw);
  height: 420px;
  transform: translateX(-50%);
  background: radial-gradient(circle, rgba(23,104,255,.10), transparent 68%);
  pointer-events: none;
}

.section-subline {
  max-width: 760px;
  margin: 18px auto 0;
  color: var(--muted);
  font-size: 18px;
}

.service-showcase {
  position: relative;
  display: grid;
  grid-template-columns: 1.12fr .88fr;
  gap: 28px;
  align-items: stretch;
}

.side-stack {
  display: grid;
  gap: 28px;
}

.showcase-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(213, 226, 246, .95);
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,251,255,.92));
  border-radius: 34px;
  box-shadow: 0 24px 70px rgba(7,17,38,.075);
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.showcase-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 22% 10%, rgba(23,104,255,.10), transparent 30%),
    radial-gradient(circle at 82% 90%, rgba(23,104,255,.08), transparent 36%);
  opacity: 0;
  transition: opacity .28s ease;
  pointer-events: none;
}

.showcase-card:hover {
  transform: translateY(-7px);
  border-color: rgba(23,104,255,.25);
  box-shadow: 0 34px 90px rgba(23,104,255,.15);
}

.showcase-card:hover::after {
  opacity: 1;
}

.showcase-card.primary {
  min-height: 680px;
  display: grid;
  grid-template-rows: auto 1fr;
  padding: 34px;
}

.showcase-card.compact {
  min-height: 326px;
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 22px;
  padding: 28px;
  align-items: end;
}

.card-content {
  position: relative;
  z-index: 2;
}

.service-label {
  display: inline-flex;
  align-items: center;
  margin-bottom: 15px;
  padding: 7px 12px;
  border-radius: 999px;
  background: #eaf2ff;
  color: var(--blue);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.showcase-card h3 {
  margin: 18px 0 12px;
  font-size: clamp(28px, 3vw, 43px);
  line-height: 1.07;
  letter-spacing: -.055em;
  max-width: 650px;
}

.showcase-card.compact h3 {
  font-size: 27px;
  max-width: 420px;
}

.showcase-card p {
  color: #50617a;
  font-size: 17px;
  max-width: 610px;
  margin-bottom: 20px;
}

.showcase-card.compact p {
  font-size: 15px;
  max-width: 380px;
}

.service-points {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 22px 0 24px;
  list-style: none;
}

.service-points li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #22324a;
  font-weight: 780;
}

.service-points li::before {
  content: "✓";
  display: grid;
  place-items: center;
  width: 23px;
  height: 23px;
  border-radius: 50%;
  background: #eaf2ff;
  color: var(--blue);
  font-size: 13px;
  font-weight: 950;
}

.text-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--blue);
  font-weight: 950;
}

.text-link span {
  transition: transform .25s ease;
}

.text-link:hover span {
  transform: translateX(4px);
}

.card-media {
  position: relative;
  z-index: 2;
  align-self: end;
  margin-top: 28px;
}

.card-media img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 26px;
  box-shadow: 0 26px 70px rgba(7,17,38,.18);
}

.media-badge {
  position: absolute;
  left: 24px;
  bottom: 24px;
  color: #fff;
  background: rgba(7,17,38,.64);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(16px);
  border-radius: 999px;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 850;
}

.compact-media {
  position: relative;
  z-index: 2;
  align-self: stretch;
  display: flex;
  align-items: flex-end;
}

.compact-media img {
  width: 100%;
  height: 168px;
  object-fit: cover;
  border-radius: 22px;
  box-shadow: 0 18px 48px rgba(7,17,38,.14);
}

.service-proof {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(213, 226, 246, .95);
  border-radius: 28px;
  box-shadow: 0 22px 65px rgba(7,17,38,.06);
  overflow: hidden;
}

.service-proof div {
  padding: 26px 20px;
  text-align: center;
  border-right: 1px solid var(--line);
}

.service-proof div:last-child {
  border-right: 0;
}

.service-proof strong {
  display: block;
  color: var(--blue);
  font-size: 35px;
  line-height: 1;
  letter-spacing: -.05em;
}

.service-proof span {
  display: block;
  color: var(--muted);
  font-weight: 760;
  margin-top: 8px;
  font-size: 14px;
}

@media(max-width: 980px) {
  .premium-services {
    padding-top: 70px;
  }

  .service-showcase {
    grid-template-columns: 1fr;
  }

  .showcase-card.primary {
    min-height: auto;
  }

  .showcase-card.compact {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .compact-media img {
    height: auto;
    aspect-ratio: 16 / 9;
  }

  .service-proof {
    grid-template-columns: 1fr 1fr;
  }

  .service-proof div:nth-child(2) {
    border-right: 0;
  }

  .service-proof div:nth-child(-n+2) {
    border-bottom: 1px solid var(--line);
  }
}

@media(max-width: 620px) {
  .premium-services {
    padding-top: 56px;
  }

  .section-subline {
    font-size: 16px;
  }

  .showcase-card.primary,
  .showcase-card.compact {
    padding: 22px;
    border-radius: 26px;
  }

  .showcase-card h3,
  .showcase-card.compact h3 {
    font-size: 27px;
  }

  .showcase-card p {
    font-size: 15px;
  }

  .media-badge {
    left: 14px;
    bottom: 14px;
    font-size: 12px;
  }

  .service-proof {
    grid-template-columns: 1fr;
  }

  .service-proof div {
    border-right: 0 !important;
    border-bottom: 1px solid var(--line);
  }

  .service-proof div:last-child {
    border-bottom: 0;
  }
}


/* ===== Final responsive polish / desktop + mobile optimization ===== */

html, body {
  max-width: 100%;
  overflow-x: hidden;
}

body {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.container {
  width: min(1240px, calc(100% - 48px));
}

.narrow {
  width: min(840px, calc(100% - 48px));
}

/* Header refinement */
.site-header {
  box-shadow: 0 1px 0 rgba(228,236,247,.9);
}

.nav-container {
  width: min(1360px, calc(100% - 48px));
}

.nav a,
.footer a,
.text-link {
  transition: color .22s ease, opacity .22s ease;
}

.nav a:hover,
.footer a:hover {
  color: var(--blue);
}

/* Hero final layout */
.hero {
  min-height: auto;
  padding: 0;
}

.hero-inner {
  min-height: 760px;
  padding: 115px 0 64px;
}

.hero-copy {
  max-width: 850px;
}

.hero-copy p {
  max-width: 720px;
}

.hero-panel {
  margin-bottom: 30px;
}

/* The floating benefit bar now sits cleanly inside the hero area */
.hero-bottom {
  margin: 0 auto 54px;
  max-width: 1180px;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(22px);
  border-radius: 26px;
  box-shadow: 0 24px 80px rgba(0,0,0,.18);
}

.hero-bottom div {
  min-width: 0;
}

.hero-bottom strong {
  font-size: 15px;
  line-height: 1.25;
}

.hero-bottom span {
  line-height: 1.3;
}

/* Trust/logo separator: cleaner and less empty */
.logos {
  padding-top: 54px;
  padding-bottom: 42px;
}

.logos p {
  margin-bottom: 18px;
}

/* Section spacing consistency */
.section {
  padding: 88px 0;
}

.section-head {
  margin-bottom: 44px;
}

.section-head h2 {
  max-width: 960px;
}

.section-subline {
  max-width: 790px;
}

/* Premium services final card balance */
.premium-services {
  padding-top: 88px;
  padding-bottom: 92px;
}

.service-showcase {
  grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr);
  gap: 30px;
}

.showcase-card {
  isolation: isolate;
}

.showcase-card.primary {
  min-height: 650px;
  padding: 36px;
}

.showcase-card.compact {
  grid-template-columns: minmax(0, 1fr) 210px;
  gap: 22px;
  min-height: 310px;
  align-items: center;
  padding: 28px;
}

.showcase-card.compact .card-content {
  min-width: 0;
}

.showcase-card.compact h3 {
  font-size: clamp(23px, 1.9vw, 29px);
  line-height: 1.12;
  max-width: 100%;
}

.showcase-card.compact p {
  max-width: 100%;
  margin-bottom: 16px;
}

.compact-media {
  align-items: center;
}

.compact-media img {
  height: 174px;
  width: 100%;
}

.card-media img {
  max-height: 360px;
}

/* Proof bar */
.service-proof {
  margin-top: 30px;
}

.service-proof div {
  min-height: 116px;
  display: grid;
  align-content: center;
}

/* Benefits and stats refinement */
.benefits {
  padding-top: 92px;
}

.stats-board div {
  min-height: 160px;
}

/* Process cards equal height */
.process-grid {
  align-items: stretch;
}

.step {
  min-height: 245px;
}

/* CTA refinement */
.final-cta {
  width: min(1240px, calc(100% - 48px));
}

/* Image consistency */
.showcase-card img,
.premium-card img,
.hero-visual img {
  object-position: center;
}

/* Large desktop */
@media (min-width: 1500px) {
  .container,
  .final-cta {
    width: min(1320px, calc(100% - 80px));
  }

  .nav-container {
    width: min(1440px, calc(100% - 80px));
  }

  .hero-inner {
    min-height: 820px;
  }
}

/* Laptop / tablet */
@media (max-width: 1180px) {
  .service-showcase {
    grid-template-columns: 1fr;
  }

  .showcase-card.primary {
    min-height: auto;
  }

  .side-stack {
    grid-template-columns: 1fr 1fr;
  }

  .showcase-card.compact {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .compact-media img {
    height: auto;
    aspect-ratio: 16 / 9;
  }
}

@media (max-width: 980px) {
  .container,
  .narrow,
  .nav-container,
  .final-cta {
    width: min(100% - 36px, 1240px);
  }

  .hero-inner {
    min-height: auto;
    padding: 78px 0 34px;
  }

  .hero-copy {
    max-width: 100%;
  }

  .hero-bottom {
    grid-template-columns: 1fr 1fr;
    margin-bottom: 34px;
  }

  .side-stack {
    grid-template-columns: 1fr;
  }

  .service-proof {
    border-radius: 24px;
  }

  .split {
    gap: 34px;
  }

  .process-grid {
    grid-template-columns: 1fr 1fr;
  }

  .footer-grid {
    grid-template-columns: 1.2fr 1fr 1fr 1fr;
  }
}

/* Mobile premium optimization */
@media (max-width: 720px) {
  .container,
  .narrow,
  .nav-container,
  .final-cta {
    width: min(100% - 28px, 1240px);
  }

  .site-header {
    background: rgba(255,255,255,.96);
  }

  .hero-inner {
    padding: 42px 0 24px;
  }

  .hero-copy {
    padding: 24px 0 0;
  }

  .hero-copy .badge {
    margin-bottom: 12px;
  }

  h1 {
    font-size: clamp(37px, 10.8vw, 46px);
    letter-spacing: -.06em;
  }

  .hero-copy p {
    font-size: 16.5px;
  }

  .hero-actions {
    margin: 26px 0 20px;
  }

  .trust-pills {
    gap: 8px;
  }

  .trust-pills span {
    width: 100%;
    text-align: center;
  }

  .hero-bottom {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 10px;
    margin-bottom: 28px;
    border-radius: 22px;
  }

  .hero-bottom div {
    padding: 14px;
  }

  .logos {
    padding-top: 42px;
    padding-bottom: 34px;
  }

  .logo-row {
    gap: 8px;
  }

  .logo-row span {
    font-size: 13px;
    padding: 8px 12px;
  }

  .section {
    padding: 58px 0;
  }

  .premium-services {
    padding-top: 62px;
    padding-bottom: 62px;
  }

  .section-head {
    margin-bottom: 30px;
  }

  .section-head h2,
  .split h2,
  .final-cta h2 {
    font-size: clamp(30px, 8.8vw, 38px);
    line-height: 1.08;
  }

  .section-subline {
    font-size: 16px;
  }

  .service-showcase {
    gap: 18px;
  }

  .side-stack {
    gap: 18px;
  }

  .showcase-card.primary,
  .showcase-card.compact {
    padding: 22px;
    border-radius: 24px;
  }

  .showcase-card h3,
  .showcase-card.compact h3 {
    font-size: 26px;
    letter-spacing: -.04em;
  }

  .showcase-card p,
  .showcase-card.compact p {
    font-size: 15px;
  }

  .service-points {
    gap: 8px;
    margin: 18px 0 22px;
  }

  .service-points li {
    font-size: 14px;
    align-items: flex-start;
  }

  .card-media {
    margin-top: 22px;
  }

  .card-media img,
  .compact-media img {
    border-radius: 18px;
  }

  .media-badge {
    position: static;
    display: inline-flex;
    margin-top: 12px;
    color: var(--blue);
    background: #eaf2ff;
    border: 1px solid var(--line);
    backdrop-filter: none;
  }

  .service-proof {
    margin-top: 18px;
  }

  .service-proof strong {
    font-size: 31px;
  }

  .stats-board {
    gap: 12px;
  }

  .stats-board div {
    min-height: 126px;
    padding: 22px;
  }

  .process-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .step {
    min-height: auto;
  }

  .quote-card {
    border-radius: 24px;
  }

  .final-cta {
    margin-bottom: 48px;
    border-radius: 24px;
  }

  .footer-grid {
    grid-template-columns: 1fr;
  }
}

/* Very small phones */
@media (max-width: 420px) {
  .brand {
    font-size: 24px;
  }

  .brand svg {
    width: 30px;
    height: 30px;
  }

  .menu-toggle {
    width: 44px;
    height: 44px;
  }

  .btn {
    width: 100%;
    padding-left: 18px;
    padding-right: 18px;
  }

  .showcase-card.primary,
  .showcase-card.compact,
  .final-cta,
  .quote-card {
    padding: 20px;
  }

  .service-label,
  .mini,
  .badge {
    font-size: 11px;
  }

  .service-proof div {
    padding: 22px 14px;
  }

  .whatsapp,
  .back-top {
    right: 14px;
  }
}


/* ===== Subpages matching homepage ===== */
.sub-hero {
  position: relative;
  overflow: hidden;
  padding: 96px 0 74px;
  background:
    radial-gradient(circle at 18% 18%, rgba(23,104,255,.10), transparent 34%),
    linear-gradient(135deg, #f7fbff 0%, #ffffff 58%, #eef6ff 100%);
}

.sub-hero::after {
  content: "";
  position: absolute;
  inset: auto -10% -35% auto;
  width: 620px;
  height: 620px;
  background: radial-gradient(circle, rgba(23,104,255,.14), transparent 64%);
  pointer-events: none;
}

.sub-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr .92fr;
  gap: 48px;
  align-items: center;
}

.sub-hero h1 {
  color: var(--ink);
  font-size: clamp(44px, 5vw, 72px);
  max-width: 760px;
}

.sub-hero h1 span {
  color: var(--blue);
}

.sub-hero p {
  color: #40516a;
  font-size: 20px;
  max-width: 690px;
}

.sub-hero-media {
  position: relative;
}

.sub-hero-media img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 32px;
  box-shadow: 0 30px 90px rgba(23,48,143,.18);
  border: 1px solid rgba(255,255,255,.75);
}

.sub-hero-media::before {
  content: "";
  position: absolute;
  inset: -18px;
  border-radius: 42px;
  background: linear-gradient(135deg, rgba(23,104,255,.18), transparent 55%);
  z-index: -1;
}

.page-section {
  background: #fff;
}

.soft-section {
  background: linear-gradient(180deg, #f7fbff, #fff);
}

.content-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,255,.94));
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 30px;
  box-shadow: 0 20px 60px rgba(7,17,38,.07);
}

.content-card h3 {
  font-size: 25px;
  margin-bottom: 12px;
}

.content-card p {
  color: var(--muted);
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.feature-grid .content-card {
  min-height: 250px;
}

.feature-grid i {
  margin-bottom: 18px;
}

.contact-layout {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 44px;
  align-items: start;
}

.contact-layout h2 {
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.06;
  letter-spacing: -.05em;
}

.contact-layout p {
  color: var(--muted);
  font-size: 18px;
}

.contact-options {
  display: grid;
  gap: 12px;
  margin-top: 26px;
}

.contact-options a {
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(7,17,38,.04);
  font-weight: 850;
  color: var(--blue);
}

.contact-form {
  display: grid;
  gap: 16px;
  padding: 30px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 30px;
  box-shadow: 0 24px 70px rgba(7,17,38,.08);
}

.contact-form label {
  display: grid;
  gap: 8px;
  font-weight: 850;
  color: #22324a;
}

.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 15px;
  padding: 15px 16px;
  font: inherit;
  background: #f8fbff;
  color: var(--ink);
  outline: none;
  transition: border-color .22s ease, box-shadow .22s ease, background .22s ease;
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
  border-color: rgba(23,104,255,.45);
  box-shadow: 0 0 0 4px rgba(23,104,255,.10);
  background: #fff;
}

.legal-content {
  display: grid;
  gap: 20px;
}

.legal-content h2 {
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.08;
  letter-spacing: -.05em;
}

.legal-content > p {
  color: var(--muted);
  font-size: 18px;
  max-width: 780px;
}

@media (max-width: 980px) {
  .sub-hero-grid,
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .sub-hero {
    padding: 70px 0 58px;
  }

  .sub-hero-media {
    order: -1;
  }

  .feature-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .sub-hero {
    padding: 42px 0 42px;
  }

  .sub-hero h1 {
    font-size: clamp(36px, 10vw, 44px);
  }

  .sub-hero p {
    font-size: 16.5px;
  }

  .sub-hero-media img {
    border-radius: 24px;
  }

  .content-card,
  .contact-form {
    padding: 22px;
    border-radius: 24px;
  }

  .contact-options a {
    font-size: 15px;
  }
}


/* ===== SMTP contact + SEO manager ===== */
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.form-message {
  padding: 14px 16px;
  border-radius: 15px;
  font-weight: 850;
  line-height: 1.4;
}

.form-message.success {
  color: #0f7a42;
  background: #eafaf1;
  border: 1px solid #bdeccd;
}

.form-message.error {
  color: #a91f1f;
  background: #fff1f1;
  border: 1px solid #ffd0d0;
}

.seo-admin .content-card {
  margin-bottom: 18px;
}

.seo-admin details summary {
  cursor: pointer;
  font-size: 22px;
  font-weight: 950;
  color: var(--ink);
}

.seo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 22px;
}

.seo-grid label,
.seo-admin-form label {
  display: grid;
  gap: 8px;
  font-weight: 850;
  color: #22324a;
}

.seo-grid input,
.seo-grid textarea,
.seo-grid select,
.seo-admin-form input,
.seo-admin-form textarea,
.seo-admin-form select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 15px;
  padding: 14px 15px;
  font: inherit;
  background: #f8fbff;
  color: var(--ink);
}

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


/* ===== Dynamic SEO landingpages ===== */
.landing-hero .sub-hero-media img {
  box-shadow: 0 34px 95px rgba(23,48,143,.20);
}

.landing-text-grid .content-card {
  min-height: 280px;
}

.seo-landing-head {
  margin-top: 58px;
  padding-top: 44px;
  border-top: 1px solid var(--line);
}

.seo-new-page {
  margin-bottom: 24px;
}

.seo-landing-card summary small {
  color: var(--blue);
  font-size: 14px;
  font-weight: 800;
}

.seo-landing-card h3 {
  margin-top: 28px;
}


/* ===== Free HTML content editor for SEO landingpages ===== */
.html-editor {
  width: 100%;
  min-height: 360px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 14px;
  line-height: 1.6;
  background: #071126;
  color: #eaf2ff;
  resize: vertical;
}

.admin-help {
  color: var(--muted);
  margin-top: -8px;
  margin-bottom: 12px;
}

.custom-html-section {
  background: #fff;
}

.custom-html-content {
  background: linear-gradient(180deg, #ffffff, #f7fbff);
  border: 1px solid var(--line);
  border-radius: 30px;
  padding: clamp(24px, 4vw, 44px);
  box-shadow: 0 24px 70px rgba(7,17,38,.07);
}

.custom-html-content h2 {
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.08;
  letter-spacing: -.05em;
  margin-bottom: 18px;
}

.custom-html-content h3 {
  font-size: clamp(24px, 3vw, 32px);
  margin-top: 30px;
  margin-bottom: 12px;
}

.custom-html-content p {
  color: var(--muted);
  font-size: 18px;
}

.custom-html-content ul,
.custom-html-content ol {
  display: grid;
  gap: 10px;
  margin: 22px 0;
  padding-left: 22px;
  color: #22324a;
  font-weight: 760;
}

.custom-html-content a {
  color: var(--blue);
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.custom-html-content img {
  border-radius: 22px;
  box-shadow: 0 20px 55px rgba(7,17,38,.12);
  margin: 24px 0;
}

.custom-html-content blockquote {
  margin: 28px 0;
  padding: 22px 26px;
  border-left: 4px solid var(--blue);
  background: #eef6ff;
  border-radius: 18px;
  color: #22324a;
  font-weight: 760;
}

@media(max-width: 620px) {
  .html-editor {
    min-height: 280px;
    font-size: 13px;
  }

  .custom-html-content {
    border-radius: 24px;
  }

  .custom-html-content p {
    font-size: 16px;
  }
}


/* ===== Delete SEO landingpage option ===== */
.delete-page-box {
  margin: 20px 0 22px;
  padding: 16px 18px;
  border: 1px solid #ffd0d0;
  background: #fff5f5;
  border-radius: 18px;
}

.delete-page-box label {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #a91f1f;
  font-weight: 950;
}

.delete-page-box input {
  width: 18px;
  height: 18px;
  accent-color: #d92d20;
}

.delete-page-box p {
  margin: 8px 0 0;
  color: #7a3a3a;
  font-size: 14px;
}


/* ===== Content Manager ===== */
.seo-content-card summary {
  color: var(--blue);
}

.seo-content-card textarea {
  min-height: 110px;
}


/* ===== Final security/admin polish ===== */
.backup-info {
  margin-bottom: 22px;
}

.backup-info code {
  display: inline-block;
  padding: 3px 7px;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--blue);
  font-weight: 850;
}


/* ===== Marketing Power Upgrade: tracking/media/internal links ===== */
.media-grid-admin {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 16px;
  margin-top: 22px;
}

.media-item-admin {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 12px;
  background: #f8fbff;
  overflow: hidden;
}

.media-item-admin img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 13px;
  margin-bottom: 10px;
}

.media-item-admin strong {
  display: block;
  font-size: 14px;
  margin-bottom: 8px;
}

.media-item-admin code {
  display: block;
  font-size: 12px;
  word-break: break-all;
  color: var(--blue);
  background: #eaf2ff;
  border-radius: 10px;
  padding: 7px;
}

.related-pages-section {
  background: linear-gradient(180deg, #fff, #f7fbff);
}

.related-page-card {
  display: block;
  transition: transform .25s ease, box-shadow .25s ease;
}

.related-page-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 28px 75px rgba(23,104,255,.13);
}

.related-page-card strong {
  color: var(--blue);
}

.tracking-settings,
.media-manager,
.duplicate-landing {
  margin-bottom: 22px;
}


/* ===== Improved admin dashboard + password hashing UI ===== */
.admin-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 16px;
  margin: 28px 0 10px;
}

.admin-tile {
  display: block;
  text-align: left;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: linear-gradient(180deg, #fff, #f7fbff);
  box-shadow: 0 14px 44px rgba(7,17,38,.06);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.admin-tile:hover {
  transform: translateY(-4px);
  border-color: rgba(23,104,255,.28);
  box-shadow: 0 24px 70px rgba(23,104,255,.12);
}

.admin-tile strong {
  display: block;
  color: var(--blue);
  font-size: 20px;
  margin-bottom: 8px;
}

.admin-tile span {
  display: block;
  color: var(--muted);
  font-size: 14px;
}

.password-change-card {
  margin-bottom: 22px;
  border-color: rgba(23,104,255,.22);
}

.seo-admin .section-head {
  text-align: left;
}

.seo-admin .section-head h1 {
  color: var(--ink);
  font-size: clamp(38px, 5vw, 64px);
}

.seo-admin details.content-card {
  border-left: 4px solid rgba(23,104,255,.22);
}

.seo-admin details.content-card[open] {
  border-left-color: var(--blue);
}

@media(max-width: 620px) {
  .admin-dashboard-grid {
    grid-template-columns: 1fr;
  }

  .admin-tile {
    padding: 18px;
  }
}


/* ===== Premium Admin UI v2 ===== */
.seo-admin-layout {
  min-height: 100vh;
  padding: 46px 0 90px;
  background:
    radial-gradient(circle at 12% 8%, rgba(23,104,255,.10), transparent 28%),
    linear-gradient(180deg, #f7fbff 0%, #ffffff 38%, #f8fbff 100%);
}

.seo-admin-layout > .container {
  width: min(1380px, calc(100% - 48px));
}

.seo-admin-layout .section-head {
  text-align: left;
  margin-bottom: 24px;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  border-radius: 30px;
  padding: 30px;
  box-shadow: 0 18px 55px rgba(7,17,38,.06);
}

.seo-admin-layout .section-head h1 {
  margin-bottom: 8px;
  color: var(--ink);
}

.admin-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 24px;
}

.admin-stats-row div {
  padding: 18px;
  border-radius: 18px;
  background: #f7fbff;
  border: 1px solid var(--line);
}

.admin-stats-row strong {
  display: block;
  color: var(--blue);
  font-size: 30px;
  line-height: 1;
}

.admin-stats-row span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  margin-top: 6px;
  font-weight: 780;
}

.admin-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.admin-sidebar {
  position: sticky;
  top: 96px;
  display: grid;
  gap: 16px;
}

.admin-sidebar-card,
.admin-sidebar-note {
  background: rgba(255,255,255,.92);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 18px;
  box-shadow: 0 16px 48px rgba(7,17,38,.06);
}

.admin-sidebar-label {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.admin-sidebar a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 13px 14px;
  border-radius: 15px;
  color: #22324a;
  font-weight: 850;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.admin-sidebar a::after {
  content: "→";
  color: var(--blue);
  opacity: .75;
}

.admin-sidebar a:hover {
  background: #eaf2ff;
  color: var(--blue);
  transform: translateX(3px);
}

.admin-sidebar-note strong {
  display: block;
  color: var(--blue);
  margin-bottom: 6px;
}

.admin-sidebar-note span {
  color: var(--muted);
  font-size: 14px;
}

.admin-main {
  min-width: 0;
}

.admin-panel {
  scroll-margin-top: 110px;
  margin-bottom: 24px;
}

.admin-panel-head {
  margin-bottom: 16px;
  padding: 24px 26px;
  background: linear-gradient(135deg, #ffffff, #f7fbff);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: 0 12px 38px rgba(7,17,38,.045);
}

.admin-panel-head h2 {
  margin: 12px 0 8px;
  font-size: clamp(27px, 3vw, 40px);
  line-height: 1.08;
  letter-spacing: -.045em;
}

.admin-panel-head p {
  margin: 0;
  color: var(--muted);
}

.seo-admin-layout .content-card {
  border-radius: 24px;
  box-shadow: 0 14px 44px rgba(7,17,38,.055);
}

.seo-admin-layout details.content-card {
  margin-bottom: 14px;
  background: #fff;
}

.seo-admin-layout details.content-card summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 2px 0;
}

.seo-admin-layout details.content-card summary::after {
  content: "öffnen / schließen";
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  background: #eaf2ff;
  border-radius: 999px;
  padding: 6px 10px;
}

.seo-grid {
  align-items: start;
}

.seo-grid label {
  min-width: 0;
}

.seo-grid input,
.seo-grid textarea,
.seo-grid select,
.contact-form input,
.contact-form textarea,
.contact-form select {
  border-radius: 14px;
}

.admin-savebar {
  position: sticky;
  bottom: 18px;
  z-index: 30;
  margin-top: 28px;
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: rgba(7,17,38,.92);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  backdrop-filter: blur(18px);
  box-shadow: 0 24px 70px rgba(7,17,38,.25);
}

.admin-savebar strong,
.admin-savebar span {
  display: block;
}

.admin-savebar span {
  color: #c8d6ec;
  font-size: 13px;
}

.admin-savebar .btn {
  flex: 0 0 auto;
  box-shadow: none;
}

.tracking-settings,
.media-manager,
.duplicate-landing,
.password-change-card,
.backup-info {
  margin-bottom: 0;
}

@media (max-width: 1050px) {
  .admin-shell {
    grid-template-columns: 1fr;
  }

  .admin-sidebar {
    position: static;
  }

  .admin-sidebar-card {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }

  .admin-sidebar-label {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  .seo-admin-layout {
    padding: 24px 0 72px;
  }

  .seo-admin-layout > .container {
    width: min(100% - 28px, 1380px);
  }

  .seo-admin-layout .section-head,
  .admin-panel-head,
  .seo-admin-layout .content-card {
    padding: 20px;
    border-radius: 22px;
  }

  .admin-stats-row {
    grid-template-columns: 1fr 1fr;
  }

  .admin-sidebar-card {
    grid-template-columns: 1fr;
  }

  .seo-grid {
    grid-template-columns: 1fr;
  }

  .admin-savebar {
    left: 14px;
    right: 14px;
    flex-direction: column;
    align-items: stretch;
  }

  .admin-savebar .btn {
    width: 100%;
  }
}


/* ===== FIX: prevent full-width bottom sections ===== */
.seo-admin-layout .container {
  max-width: 1380px;
  margin: 0 auto;
}

.admin-main {
  max-width: 100%;
}

.admin-panel,
.media-manager,
.tracking-settings,
.duplicate-landing,
.password-change-card,
.backup-info {
  width: 100%;
  max-width: 100%;
}



/* ===== Admin UI Clean Rebuild ===== */
body.admin-body {
  margin: 0;
  background: #eef5ff;
  color: #071126;
}

.admin-app {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  background:
    radial-gradient(circle at 20% 0%, rgba(23,104,255,.12), transparent 28%),
    linear-gradient(180deg,#eef5ff,#f8fbff);
}

.admin-aside {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 24px;
  background: rgba(255,255,255,.76);
  border-right: 1px solid #dfe9f7;
  backdrop-filter: blur(20px);
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.admin-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 30px;
  font-weight: 950;
  letter-spacing: -.05em;
  color: #071126;
}

.admin-logo span span {
  color: #1768ff;
}

.admin-menu {
  display: grid;
  gap: 8px;
}

.admin-menu a,
.admin-aside-footer a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 13px 14px;
  border-radius: 14px;
  color: #31425d;
  font-weight: 850;
  transition: .2s ease;
}

.admin-menu a::after {
  content: "→";
  color: #1768ff;
  opacity: .7;
}

.admin-menu a:hover,
.admin-menu a.active {
  background: #e8f1ff;
  color: #1768ff;
  transform: translateX(2px);
}

.admin-aside-footer {
  margin-top: auto;
  display: grid;
  gap: 6px;
  padding-top: 18px;
  border-top: 1px solid #dfe9f7;
}

.admin-workspace {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
  padding: 32px 0 110px;
}

.admin-topbar {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: flex-start;
  padding: 30px;
  border-radius: 30px;
  background: rgba(255,255,255,.92);
  border: 1px solid #dfe9f7;
  box-shadow: 0 20px 70px rgba(7,17,38,.08);
  margin-bottom: 20px;
}

.admin-kicker,
.admin-section-head span {
  display: inline-flex;
  padding: 7px 11px;
  border-radius: 999px;
  background: #e8f1ff;
  color: #1768ff;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.admin-topbar h1 {
  margin: 14px 0 8px;
  font-size: clamp(42px,5vw,70px);
  line-height: .95;
  letter-spacing: -.07em;
  color: #071126;
}

.admin-topbar p,
.admin-section-head p {
  margin: 0;
  color: #60718b;
  max-width: 760px;
}

.admin-topbar-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-message {
  margin: 0 0 20px;
  padding: 16px 18px;
  border-radius: 18px;
  font-weight: 850;
}

.admin-message.success {
  background: #eafaf1;
  color: #08713b;
  border: 1px solid #bfeecd;
}

.admin-message.error {
  background: #fff1f1;
  color: #a91f1f;
  border: 1px solid #ffd0d0;
}

.admin-stats-clean {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}

.admin-stats-clean div {
  background: #fff;
  border: 1px solid #dfe9f7;
  border-radius: 20px;
  padding: 20px;
  box-shadow: 0 12px 38px rgba(7,17,38,.045);
}

.admin-stats-clean strong {
  display: block;
  color: #1768ff;
  font-size: 34px;
  line-height: 1;
}

.admin-stats-clean span {
  display: block;
  margin-top: 7px;
  color: #60718b;
  font-size: 13px;
  font-weight: 800;
}

.admin-section {
  scroll-margin-top: 28px;
  margin-bottom: 24px;
}

.admin-section-head {
  padding: 26px;
  border-radius: 26px 26px 0 0;
  background: linear-gradient(135deg,#fff,#f7fbff);
  border: 1px solid #dfe9f7;
  border-bottom: 0;
}

.admin-section-head h2 {
  margin: 13px 0 8px;
  font-size: clamp(30px,3vw,44px);
  line-height: 1.05;
  letter-spacing: -.055em;
  color: #071126;
}

.admin-card,
.admin-details {
  background: rgba(255,255,255,.96);
  border: 1px solid #dfe9f7;
  border-radius: 0 0 26px 26px;
  padding: 26px;
  box-shadow: 0 18px 55px rgba(7,17,38,.06);
}

.admin-card + .admin-card {
  margin-top: 16px;
  border-radius: 24px;
}

.admin-card h3,
.admin-details h3 {
  margin: 0 0 16px;
  font-size: 23px;
  letter-spacing: -.03em;
}

.admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
}

.admin-grid label {
  display: grid;
  gap: 8px;
  color: #22324a;
  font-weight: 850;
  min-width: 0;
}

.admin-grid input,
.admin-grid textarea,
.admin-grid select,
.html-editor {
  width: 100%;
  border: 1px solid #dfe9f7;
  border-radius: 15px;
  padding: 14px 15px;
  background: #f8fbff;
  color: #071126;
  font: inherit;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.admin-grid input:focus,
.admin-grid textarea:focus,
.admin-grid select:focus,
.html-editor:focus {
  border-color: rgba(23,104,255,.45);
  box-shadow: 0 0 0 4px rgba(23,104,255,.10);
  background: #fff;
}

.admin-details {
  border-radius: 24px;
  margin-bottom: 14px;
}

.admin-details summary {
  cursor: pointer;
  list-style: none;
  font-size: 22px;
  font-weight: 950;
  color: #071126;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.admin-details summary::-webkit-details-marker {
  display: none;
}

.admin-details summary::after {
  content: "öffnen";
  font-size: 12px;
  color: #1768ff;
  background: #e8f1ff;
  padding: 6px 10px;
  border-radius: 999px;
}

.admin-details[open] summary {
  margin-bottom: 22px;
  padding-bottom: 16px;
  border-bottom: 1px solid #dfe9f7;
}

.admin-details[open] summary::after {
  content: "schließen";
}

.admin-landing-details small {
  color: #1768ff;
  font-size: 13px;
}

.admin-delete-box {
  margin-bottom: 20px;
  padding: 16px;
  background: #fff5f5;
  border: 1px solid #ffd0d0;
  border-radius: 18px;
}

.admin-delete-box label {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #a91f1f;
  font-weight: 950;
}

.admin-delete-box p {
  margin: 8px 0 0;
  color: #7a3a3a;
  font-size: 14px;
}

.admin-media-grid {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(190px,1fr));
  gap: 16px;
}

.admin-media-item {
  border: 1px solid #dfe9f7;
  background: #f8fbff;
  border-radius: 18px;
  padding: 12px;
}

.admin-media-item img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  border-radius: 13px;
  margin-bottom: 10px;
}

.admin-media-item strong {
  display: block;
  font-size: 14px;
  margin-bottom: 8px;
}

.admin-media-item code,
.admin-note-card code {
  display: block;
  word-break: break-all;
  background: #e8f1ff;
  color: #1768ff;
  padding: 7px;
  border-radius: 10px;
  font-size: 12px;
}

.html-editor {
  min-height: 340px;
  font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
  background: #071126;
  color: #eaf2ff;
}

.admin-help {
  margin: -5px 0 12px;
  color: #60718b;
}

.admin-savebar-clean {
  position: sticky;
  bottom: 18px;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  padding: 16px;
  border-radius: 22px;
  background: rgba(7,17,38,.94);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 70px rgba(7,17,38,.28);
  backdrop-filter: blur(18px);
}

.admin-savebar-clean strong,
.admin-savebar-clean span {
  display: block;
}

.admin-savebar-clean span {
  color: #c9d7ea;
  font-size: 13px;
}

.admin-savebar-clean .btn {
  flex: 0 0 auto;
  box-shadow: none;
}

@media (max-width: 1100px) {
  .admin-app {
    grid-template-columns: 1fr;
  }

  .admin-aside {
    position: static;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid #dfe9f7;
  }

  .admin-menu {
    grid-template-columns: repeat(2,1fr);
  }

  .admin-aside-footer {
    grid-template-columns: repeat(2,1fr);
  }
}

@media (max-width: 760px) {
  .admin-workspace {
    width: min(100% - 28px,1180px);
    padding: 20px 0 96px;
  }

  .admin-topbar {
    flex-direction: column;
    padding: 22px;
    border-radius: 24px;
  }

  .admin-stats-clean,
  .admin-grid,
  .admin-menu {
    grid-template-columns: 1fr;
  }

  .admin-section-head,
  .admin-card,
  .admin-details {
    padding: 20px;
  }

  .admin-savebar-clean {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-savebar-clean .btn {
    width: 100%;
  }
}


/* ===== Cookie consent, leads, backups, optimized admin ===== */
.cookie-consent {
  position: fixed;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 9999;
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: center;
  padding: 20px;
  background: rgba(255,255,255,.96);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: 0 24px 80px rgba(7,17,38,.18);
  backdrop-filter: blur(18px);
}

.cookie-consent[hidden] {
  display: none;
}

.cookie-consent strong {
  display: block;
  font-size: 20px;
  margin-bottom: 5px;
}

.cookie-consent p {
  margin: 0;
  color: var(--muted);
}

.cookie-actions {
  display: flex;
  gap: 10px;
  flex: 0 0 auto;
}

.lead-list,
.backup-list {
  display: grid;
  gap: 14px;
}

.lead-card,
.backup-item {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 18px;
  align-items: start;
  padding: 18px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background: #f8fbff;
}

.lead-card strong,
.backup-item strong {
  display: block;
  color: #071126;
  font-size: 18px;
}

.lead-card span,
.backup-item span,
.lead-card small {
  display: block;
  color: #60718b;
  font-size: 13px;
  margin-top: 4px;
}

.lead-card p {
  margin: 12px 0;
  color: #22324a;
}

.lead-card label {
  display: grid;
  gap: 8px;
  font-weight: 850;
}

.lead-card select {
  border: 1px solid #dfe9f7;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}

.admin-stats-clean {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

@media(max-width: 720px) {
  .cookie-consent {
    flex-direction: column;
    align-items: stretch;
    left: 14px;
    right: 14px;
    bottom: 14px;
  }

  .cookie-actions {
    flex-direction: column;
  }

  .lead-card,
  .backup-item {
    grid-template-columns: 1fr;
  }
}


/* ===== FIX Cookie Banner + Admin Statistics ===== */
.cookie-consent {
  position: fixed !important;
  left: 24px !important;
  right: 24px !important;
  bottom: 24px !important;
  z-index: 999999 !important;
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: center;
  padding: 20px;
  background: rgba(255,255,255,.98);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: 0 24px 80px rgba(7,17,38,.22);
  backdrop-filter: blur(18px);
}

.cookie-consent[style*="display: none"] {
  display: none !important;
}

.cookie-copy strong {
  display: block;
  font-size: 20px;
  margin-bottom: 5px;
}

.cookie-copy p {
  margin: 0;
  color: var(--muted);
}

.cookie-actions {
  display: flex;
  gap: 10px;
  flex: 0 0 auto;
}

.stats-mini-chart {
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  gap: 10px;
  align-items: end;
  min-height: 160px;
  padding: 18px;
  border: 1px solid #dfe9f7;
  background: #f8fbff;
  border-radius: 18px;
  margin-bottom: 24px;
}

.stats-day {
  display: grid;
  justify-items: center;
  gap: 6px;
  color: #60718b;
  font-size: 12px;
}

.stats-bar {
  width: 100%;
  max-width: 28px;
  border-radius: 999px 999px 6px 6px;
  background: linear-gradient(180deg, #1768ff, #74a8ff);
}

.stats-day strong {
  color: #071126;
  font-size: 13px;
}

.stats-table {
  display: grid;
  gap: 10px;
}

.stats-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid #dfe9f7;
  border-radius: 14px;
  background: #fff;
}

.stats-row span {
  color: #22324a;
  font-weight: 850;
  word-break: break-word;
}

.stats-row strong {
  color: #1768ff;
  white-space: nowrap;
}

@media(max-width: 720px) {
  .cookie-consent {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    flex-direction: column;
    align-items: stretch;
  }

  .cookie-actions {
    flex-direction: column;
  }

  .stats-mini-chart {
    grid-template-columns: repeat(7, 1fr);
    overflow-x: auto;
  }

  .stats-row {
    flex-direction: column;
    align-items: flex-start;
  }
}


/* ===== Performance 100 Upgrade ===== */
.hero-image img {
  content-visibility: visible;
}

.section,
.premium-services,
.benefits,
.process,
.testimonial-section,
.faq,
.footer {
  content-visibility: auto;
  contain-intrinsic-size: 1px 760px;
}

img[loading="lazy"] {
  content-visibility: auto;
}

.cookie-consent {
  transform: translateY(120%);
  opacity: 0;
  transition: transform .35s ease, opacity .35s ease;
}

.cookie-consent.is-visible {
  transform: translateY(0);
  opacity: 1;
}

/* avoid expensive blur on small devices */
@media(max-width: 720px) {
  .site-header,
  .hero-panel,
  .quote-card,
  .cookie-consent {
    backdrop-filter: none !important;
  }
}


/* ===== Logo Manager ===== */
.brand-logo-img {
  display: block;
  width: auto;
  max-width: 190px;
  height: auto;
  max-height: 54px;
  object-fit: contain;
}

.site-header .brand-logo-img {
  max-height: 44px;
}

.footer .brand-logo-img {
  max-height: 52px;
}

.logo-preview-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 26px;
}

.logo-preview-row > div > span {
  display: block;
  color: #60718b;
  font-weight: 850;
  margin-bottom: 8px;
}

.logo-preview-box {
  min-height: 92px;
  display: flex;
  align-items: center;
  padding: 18px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background:
    linear-gradient(45deg, #f8fbff 25%, transparent 25%),
    linear-gradient(-45deg, #f8fbff 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #f8fbff 75%),
    linear-gradient(-45deg, transparent 75%, #f8fbff 75%);
  background-size: 18px 18px;
  background-position: 0 0, 0 9px, 9px -9px, -9px 0px;
  background-color: #fff;
}

.logo-preview-box .brand {
  font-size: 28px;
}

@media(max-width: 720px) {
  .logo-preview-row {
    grid-template-columns: 1fr;
  }

  .brand-logo-img {
    max-width: 150px;
    max-height: 42px;
  }
}


/* ===== Logo Manager FIX ===== */
.brand-logo-img {
  display: block;
  width: auto;
  max-width: 190px;
  height: auto;
  max-height: 54px;
  object-fit: contain;
}

.site-header .brand-logo-img {
  max-height: 44px;
}

.footer .brand-logo-img {
  max-height: 52px;
}

.logo-preview-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 26px;
}

.logo-preview-row > div > span {
  display: block;
  color: #60718b;
  font-weight: 850;
  margin-bottom: 8px;
}

.logo-preview-box {
  min-height: 92px;
  display: flex;
  align-items: center;
  padding: 18px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background-color: #fff;
}

@media(max-width: 720px) {
  .logo-preview-row {
    grid-template-columns: 1fr;
  }
}


/* ===== Logo size + favicon manager fix ===== */
.brand:has(.brand-logo-img) {
  gap: 0;
}

.brand-logo-img {
  display: block;
  width: auto;
  height: auto;
  object-fit: contain;
}

.site-header .brand-logo-img {
  max-width: 240px !important;
  max-height: 64px !important;
  min-height: 46px;
}

.footer .brand-logo-img {
  max-width: 260px !important;
  max-height: 72px !important;
  min-height: 54px;
}

.logo-preview-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.logo-preview-box .brand-logo-img {
  max-width: 240px !important;
  max-height: 72px !important;
}

.favicon-preview img {
  width: 64px;
  height: 64px;
  object-fit: contain;
}

@media(max-width: 980px) {
  .logo-preview-row {
    grid-template-columns: 1fr;
  }
}

@media(max-width: 720px) {
  .site-header .brand-logo-img {
    max-width: 180px !important;
    max-height: 50px !important;
    min-height: 38px;
  }

  .footer .brand-logo-img {
    max-width: 210px !important;
    max-height: 62px !important;
  }
}


/* ===== Referrer Tracking UI ===== */
.source-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px;
  margin: 14px 0 24px;
}

.source-card {
  padding: 18px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  box-shadow: 0 10px 30px rgba(7,17,38,.04);
}

.source-card strong {
  display: block;
  color: #071126;
  font-size: 18px;
  margin-bottom: 6px;
}

.source-card span {
  color: #1768ff;
  font-weight: 900;
}


/* ===== Conversion Tracking UI ===== */
.conversion-kpi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 2fr;
  gap: 14px;
  margin-bottom: 24px;
}

.conversion-kpi-grid div {
  padding: 18px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background: linear-gradient(180deg, #fff, #f8fbff);
}

.conversion-kpi-grid strong {
  display: block;
  color: #1768ff;
  font-size: clamp(22px, 3vw, 34px);
  line-height: 1.1;
  word-break: break-word;
}

.conversion-kpi-grid span {
  display: block;
  margin-top: 7px;
  color: #60718b;
  font-weight: 850;
  font-size: 13px;
}

@media(max-width: 860px) {
  .conversion-kpi-grid {
    grid-template-columns: 1fr;
  }
}


/* ===== Admin Tab Pages ===== */
.admin-dashboard-links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 16px;
}

.admin-dashboard-links a {
  display: block;
  padding: 20px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.admin-dashboard-links a:hover {
  transform: translateY(-3px);
  border-color: rgba(23,104,255,.35);
  box-shadow: 0 18px 48px rgba(23,104,255,.10);
}

.admin-dashboard-links strong {
  display: block;
  color: #1768ff;
  font-size: 18px;
  margin-bottom: 7px;
}

.admin-dashboard-links span {
  display: block;
  color: #60718b;
  font-size: 14px;
}

.admin-menu a.active {
  background: #e8f1ff;
  color: #1768ff;
}


/* ===== Real Admin Pages Fix ===== */
.admin-section[style*="display:none"],
.admin-stats-clean[style*="display:none"],
.admin-savebar-clean[style*="display:none"] {
  display: none !important;
}

.admin-workspace {
  min-height: 100vh;
}

.admin-menu a.active {
  background: #e8f1ff !important;
  color: #1768ff !important;
}


/* ===== Admin Real Pages FINAL FIX ===== */
.admin-section[style*="display:none"],
.admin-stats-clean[style*="display:none"],
.admin-savebar-clean[style*="display:none"] {
  display: none !important;
}

.admin-menu a.active {
  background: #e8f1ff !important;
  color: #1768ff !important;
}

.admin-dashboard-links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 16px;
}

.admin-dashboard-links a {
  display: block;
  padding: 20px;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.admin-dashboard-links a:hover {
  transform: translateY(-3px);
  border-color: rgba(23,104,255,.35);
  box-shadow: 0 18px 48px rgba(23,104,255,.10);
}

.admin-dashboard-links strong {
  display: block;
  color: #1768ff;
  font-size: 18px;
  margin-bottom: 7px;
}

.admin-dashboard-links span {
  display: block;
  color: #60718b;
  font-size: 14px;
}


/* ===== Redirect Manager + Export + Lead Notification ===== */
.redirect-row {
  display: grid;
  grid-template-columns: 1.2fr 1.2fr .55fr .65fr .7fr;
  gap: 14px;
  align-items: end;
  padding: 16px;
  margin: 12px 0;
  border: 1px solid #dfe9f7;
  border-radius: 18px;
  background: #f8fbff;
}

.redirect-row label {
  display: grid;
  gap: 8px;
  font-weight: 850;
}

.redirect-row input,
.redirect-row select {
  width: 100%;
  border: 1px solid #dfe9f7;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}

.admin-message a {
  color: inherit;
  text-decoration: underline;
  font-weight: 950;
}

@media(max-width: 980px) {
  .redirect-row {
    grid-template-columns: 1fr;
  }
}


/* ===== Angebot Rechner ===== */
.offer-hero .sub-hero-media img {
  box-shadow: 0 34px 95px rgba(23,48,143,.18);
}

.offer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 26px;
  align-items: start;
}

.compact-left {
  text-align: left;
  margin-bottom: 24px;
}

.offer-calculator {
  padding: clamp(22px, 4vw, 42px);
}

.offer-field,
.offer-contact label {
  display: grid;
  gap: 8px;
  margin-bottom: 18px;
  font-weight: 850;
  color: #22324a;
}

.offer-field input,
.offer-field select,
.offer-contact input,
.offer-contact textarea,
.offer-contact select {
  width: 100%;
  border: 1px solid #dfe9f7;
  border-radius: 15px;
  padding: 14px 15px;
  background: #f8fbff;
  color: #071126;
  font: inherit;
  outline: none;
}

.offer-field input:focus,
.offer-field select:focus,
.offer-contact input:focus,
.offer-contact textarea:focus {
  border-color: rgba(23,104,255,.45);
  box-shadow: 0 0 0 4px rgba(23,104,255,.10);
  background: #fff;
}

.range-output {
  color: #1768ff;
  font-weight: 950;
}

.range-output small {
  color: #60718b;
}

.offer-options {
  display: grid;
  gap: 12px;
  margin: 22px 0;
}

.offer-options label {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 15px;
  border: 1px solid #dfe9f7;
  border-radius: 16px;
  background: #f8fbff;
  font-weight: 850;
}

.offer-options input {
  width: 18px;
  height: 18px;
  accent-color: #1768ff;
}

.offer-options span {
  margin-left: auto;
  color: #1768ff;
  font-weight: 950;
  white-space: nowrap;
}

.offer-contact {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid #dfe9f7;
}

.offer-contact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}

.offer-summary {
  position: sticky;
  top: 105px;
}

.offer-summary-card {
  padding: 28px;
  border-radius: 28px;
  background: linear-gradient(180deg, #071126, #10254c);
  color: #fff;
  box-shadow: 0 28px 80px rgba(7,17,38,.2);
}

.offer-price {
  font-size: clamp(48px, 6vw, 72px);
  font-weight: 950;
  letter-spacing: -.07em;
  line-height: 1;
  margin: 20px 0 14px;
}

.offer-summary-card p {
  color: #c9d7ea;
}

.offer-breakdown {
  display: grid;
  gap: 9px;
  margin: 22px 0;
}

.offer-breakdown div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.12);
  color: #d9e6f9;
}

.offer-breakdown strong {
  color: #fff;
}

.offer-summary-card .check-list span {
  background: rgba(255,255,255,.08);
  color: #eaf2ff;
}

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

  .offer-summary {
    position: static;
  }
}

@media(max-width: 620px) {
  .offer-contact-grid {
    grid-template-columns: 1fr;
  }

  .offer-options label {
    align-items: flex-start;
    flex-wrap: wrap;
  }
}


/* ===== Angebot Rechner Admin ===== */
.offer-admin-row {
  grid-template-columns: 1.4fr 1fr .7fr .7fr .8fr;
}

.offer-new-box {
  padding: 18px;
  border: 1px dashed #b9cff0;
  border-radius: 18px;
  background: #f8fbff;
  margin: 10px 0 26px;
}

@media(max-width: 980px) {
  .offer-admin-row {
    grid-template-columns: 1fr;
  }
}


/* ===== Login + Logout Fix UI ===== */
.admin-login-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
  background:
    radial-gradient(circle at 18% 0%, rgba(23,104,255,.18), transparent 28%),
    linear-gradient(135deg, #eef5ff 0%, #ffffff 52%, #eaf3ff 100%);
}

.admin-login-card {
  width: min(560px, 100%);
  background: rgba(255,255,255,.94);
  border: 1px solid #dfe9f7;
  border-radius: 32px;
  padding: clamp(28px, 5vw, 46px);
  box-shadow: 0 28px 90px rgba(7,17,38,.13);
}

.admin-login-card .admin-logo {
  margin-bottom: 24px;
}

.admin-login-card h1 {
  margin: 16px 0 10px;
  font-size: clamp(48px, 7vw, 82px);
  line-height: .9;
  letter-spacing: -.075em;
  color: #071126;
}

.admin-login-card p {
  margin: 0;
  color: #60718b;
  line-height: 1.7;
}

.admin-login-form {
  margin-top: 26px;
  display: grid;
  gap: 16px;
}

.admin-login-form label {
  display: grid;
  gap: 8px;
  color: #22324a;
  font-weight: 900;
}

.admin-login-form input {
  width: 100%;
  border: 1px solid #dfe9f7;
  border-radius: 16px;
  padding: 15px 16px;
  background: #f8fbff;
  color: #071126;
  font: inherit;
  outline: none;
}

.admin-login-form input:focus {
  border-color: rgba(23,104,255,.48);
  box-shadow: 0 0 0 4px rgba(23,104,255,.10);
  background: #fff;
}

.admin-login-form .btn {
  width: 100%;
  justify-content: center;
  padding: 16px 22px;
}

@media(max-width: 620px) {
  .admin-login-page {
    padding: 16px;
  }
}


/* ===== Cookie settings footer link ===== */
.footer-cookie-link {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-weight: 850;
  text-decoration: underline;
  cursor: pointer;
  padding: 0;
}

.footer-cookie-link:hover,
.footer-cookie-link:focus-visible {
  color: var(--blue);
}


/* ===== Backup Download + 1-Klick Restore ===== */
.backup-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 22px;
}

.backup-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.btn.danger-soft {
  background: #fff1f1;
  color: #a91f1f;
  border: 1px solid #ffd0d0;
  box-shadow: none;
}

.btn.danger-soft:hover {
  background: #ffe8e8;
  transform: translateY(-1px);
}

@media(max-width: 780px) {
  .backup-actions {
    justify-content: flex-start;
  }
}
