/* =========================================================
   BohleVision – PREMIUM Layer (Homepage)
   Umsetzung des "Premium Website Redesign Brief" (v1.0).
   Scope: nur Seiten mit <body class="prem-page"> (aktuell Homepage).
   Tokens aus Brief 2.1 · Typografie 2.2 · Motion 2.4.
   Neutral: keine Fremdmarken; nur neutraler Bezug auf manuelle
   Tabellenlisten.
========================================================= */

:root {
  --premium-bg: #f7f4ef;
  --premium-surface: #ffffff;
  --premium-surface-soft: #fbfaf7;
  --premium-text: #141414;
  --premium-muted: #66635f;
  --premium-border: #e4ddd4;
  --premium-accent: #6f1d2a;
  --premium-accent-dark: #3a0d16;
  --premium-gold: #b08a4a;
  --premium-radius-sm: 14px;
  --premium-radius-md: 24px;
  --premium-radius-lg: 36px;
  --premium-shadow-soft: 0 18px 50px rgba(30, 20, 12, .08);
  --premium-shadow-lift: 0 28px 80px rgba(30, 20, 12, .13);
  --premium-max: 1180px;
  --premium-section-y: clamp(72px, 9vw, 132px);
}

/* ---------- Grundlayout ---------- */
.prem-page {
  background: var(--premium-bg);
  color: var(--premium-text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.prem-page main { background: var(--premium-bg); }
.prem-wrap { width: min(var(--premium-max), 92%); margin-inline: auto; }

.prem-section { padding-block: var(--premium-section-y); position: relative; }
.prem-section--soft { background: var(--premium-surface-soft); border-block: 1px solid var(--premium-border); }

.prem-kicker {
  display: inline-block; text-transform: uppercase; font-size: 12px; font-weight: 800;
  letter-spacing: .14em; color: var(--premium-accent);
}
.prem-kicker--gold { color: var(--premium-gold); }

.prem-head { max-width: 860px; margin: 0 auto clamp(34px, 4vw, 56px); text-align: center; }
.prem-head--left { margin-inline: 0; text-align: left; }
.prem-head h2 {
  margin: 12px 0 0; font-size: clamp(30px, 4.5vw, 56px); line-height: 1.05;
  letter-spacing: -0.03em; font-weight: 800;
}
.prem-head p { margin: 16px auto 0; max-width: 720px; font-size: clamp(16px, 1.5vw, 18px); line-height: 1.55; color: var(--premium-muted); }
.prem-head--left p { margin-inline: 0; }

/* ---------- Buttons (premium pills, homepage-weit konsistent) ---------- */
.prem-page .btn {
  border-radius: 999px; min-height: 48px; padding: 0 22px;
  display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  font-weight: 700; font-size: 15px; line-height: 1; border: 1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
}
.prem-page .btn-lg { min-height: 56px; padding: 0 30px; font-size: 16px; }
.prem-page .btn-primary { background: var(--premium-accent); color: #fff; box-shadow: 0 10px 26px rgba(111, 29, 42, .22); }
.prem-page .btn-primary:hover { background: var(--premium-accent-dark); transform: translateY(-1px); box-shadow: 0 16px 34px rgba(111, 29, 42, .26); }
.prem-page .btn-ghost { background: transparent; color: var(--premium-text); border-color: var(--premium-border); }
.prem-page .btn-ghost:hover { background: var(--premium-surface); border-color: var(--premium-accent); transform: translateY(-1px); }
.prem-page .btn:focus-visible { outline: 3px solid rgba(111, 29, 42, .35); outline-offset: 2px; }

/* ---------- Calm Launch-Bar (Brief 3.1) ---------- */
.prem-launchbar {
  background: var(--premium-accent-dark); color: #f4ece9;
  font-size: 13.5px; line-height: 1.4; text-align: center;
}
.prem-launchbar .prem-wrap { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 9px 0; }
.prem-launchbar strong { color: #fff; font-weight: 800; }
.prem-launchbar .prem-code { font-weight: 800; color: var(--premium-gold); letter-spacing: .04em; }

/* ---------- Header-Feinschliff (scoped) ---------- */
.prem-page .site-header { background: rgba(247, 244, 239, .82); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--premium-border); }

/* ---------- HERO (Brief 4.1 / 4.2) ---------- */
.prem-hero { padding-top: clamp(48px, 7vw, 96px); padding-bottom: var(--premium-section-y); overflow: hidden; }
.prem-hero-grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(28px, 5vw, 72px); align-items: center; }
.prem-hero h1 {
  margin: 16px 0 0; font-size: clamp(34px, 4.8vw, 60px); line-height: 1.06;
  letter-spacing: -0.03em; font-weight: 800;
}
.prem-hero .prem-subline { margin: 22px 0 0; max-width: 560px; font-size: clamp(17px, 1.6vw, 20px); line-height: 1.55; color: var(--premium-muted); }
.prem-cta-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.prem-trustline { margin: 22px 0 0; font-size: 13.5px; color: var(--premium-muted); display: flex; flex-wrap: wrap; gap: 6px 14px; }
.prem-trustline span { white-space: nowrap; }
.prem-microcopy { margin: 14px 0 0; font-size: 13.5px; color: var(--premium-muted); font-style: italic; max-width: 520px; }

/* Device-/Glass-Showcase */
.prem-showcase { position: relative; }
.prem-showcase figure {
  margin: 0; border-radius: var(--premium-radius-lg); background: var(--premium-surface);
  border: 1px solid var(--premium-border); box-shadow: var(--premium-shadow-lift);
  padding: 14px; overflow: hidden;
}
.prem-showcase img { width: 100%; height: auto; display: block; border-radius: var(--premium-radius-md); }
.prem-showcase figcaption { margin-top: 12px; text-align: center; font-size: 13px; color: var(--premium-muted); }
.prem-showcase::after {
  content: ""; position: absolute; inset: auto -8% -12% -8%; height: 60%; z-index: -1;
  background: radial-gradient(60% 100% at 50% 0%, rgba(176, 138, 74, .18), transparent 70%);
  filter: blur(8px);
}

/* ---------- HERO Visual: produktgeführte Komposition (Brief 4.1 / 4.2) ----------
   Foto = ruhige, hochwertige Atmosphäre im Hintergrund · Produkt-Screenshot als
   Mockup-Card im Vordergrund · dezente Glass-Chips. Kein vollflächiges Stockfoto. */
.prem-hero-visual { position: relative; isolation: isolate; }
.prem-hero-visual::after { /* weicher, langsam atmender Boden-Glow (bewegliches Element) */
  content: ""; position: absolute; inset: auto 2% -12% 2%; height: 60%; z-index: -1;
  background: radial-gradient(60% 100% at 50% 0%, rgba(176, 138, 74, .20), transparent 72%);
  filter: blur(12px); animation: prem-glow 7s ease-in-out infinite;
}

/* Foto-Hintergrund zeigt den Workspace (Laptop + Schreibtisch), kaum Wand.
   Panel-Verhältnis = Crop-Verhältnis, damit das Bild 1:1 sichtbar bleibt. */
.prem-hero-photo {
  position: relative; margin: 0; border-radius: var(--premium-radius-lg);
  overflow: hidden; aspect-ratio: 3 / 2; background: #efeae3;
  box-shadow: var(--premium-shadow-lift);
}
.prem-hero-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 50%; display: block; }
/* sehr dezentes Ruhe-Overlay, kein hartes Abdunkeln */
.prem-hero-photo::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(28,20,14,0) 56%, rgba(28,20,14,.14) 100%);
}
/* feine Premium-Innenkante */
.prem-hero-photo::before {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  border-radius: inherit; box-shadow: inset 0 0 0 1px rgba(255,255,255,.22);
}

/* Produkt-Mockup-Card: kompakt, unten links auf dem Schreibtisch –
   der Laptop rechts bleibt sichtbar. */
.prem-hero-mockup {
  position: absolute; left: 1%; width: 57%; bottom: 8%; z-index: 3; margin: 0;
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: 14px; box-shadow: var(--premium-shadow-lift); overflow: hidden;
  transform: rotate(-1.6deg); transform-origin: bottom left;
}
.prem-hero-mockup-bar {
  display: flex; align-items: center; gap: 8px; padding: 8px 11px;
  border-bottom: 1px solid var(--premium-border); background: var(--premium-surface-soft);
}
.prem-hero-mockup-icon { width: 19px; height: 19px; border-radius: 6px; display: block; flex: 0 0 auto; }
.prem-hero-mockup-dots { display: inline-flex; gap: 5px; }
.prem-hero-mockup-dots i { width: 7px; height: 7px; border-radius: 50%; background: var(--premium-border); }
.prem-hero-mockup .prem-hero-mockup-label { margin-left: auto; font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--premium-muted); }
.prem-hero-mockup picture { display: block; }
.prem-hero-mockup img.prem-hero-mockup-shot { width: 100%; height: auto; display: block; }

/* Floating Icon-Chips – sanft schwebend (bewegliche Elemente) */
.prem-hero-chip {
  position: absolute; z-index: 4; display: inline-flex; align-items: center; gap: 9px;
  padding: 8px 15px 8px 8px; border-radius: 999px; font-size: 13px; font-weight: 700; letter-spacing: -0.01em;
  color: var(--premium-text); white-space: nowrap;
  background: rgba(255,255,255,.80); border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 14px 32px rgba(30,20,12,.18);
  -webkit-backdrop-filter: blur(11px) saturate(1.15); backdrop-filter: blur(11px) saturate(1.15);
  animation: prem-float 5.4s ease-in-out infinite;
}
.prem-hero-chip-ic { width: 26px; height: 26px; border-radius: 8px; display: grid; place-items: center; color: #fff; flex: 0 0 auto; }
.prem-hero-chip-ic svg { width: 15px; height: 15px; }
.prem-hero-chip--focus   { top: 5%;   left: -4%; animation-delay: -0.4s; }
.prem-hero-chip--focus   .prem-hero-chip-ic { background: var(--premium-accent); }
.prem-hero-chip--habit   { top: 30%;  right: -4%; animation-duration: 6.3s; animation-delay: -1.7s; }
.prem-hero-chip--habit   .prem-hero-chip-ic { background: var(--premium-gold); }
.prem-hero-chip--finance { bottom: 6%; right: 2%; animation-duration: 5.8s; animation-delay: -1.0s; }
.prem-hero-chip--finance .prem-hero-chip-ic { background: #3f7d57; }

@keyframes prem-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes prem-glow  { 0%, 100% { opacity: .65; } 50% { opacity: 1; } }

/* ---------- Problem (Brief 4.4) ---------- */
.prem-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.prem-card {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-md); padding: 28px; box-shadow: var(--premium-shadow-soft);
}
.prem-card h3 { margin: 0; font-size: 19px; letter-spacing: -0.01em; }
.prem-card p { margin: 10px 0 0; font-size: 15.5px; line-height: 1.55; color: var(--premium-muted); }

/* ---------- Product Story (3 Schritte) ---------- */
.prem-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.prem-story-card {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-md); padding: 28px; box-shadow: var(--premium-shadow-soft);
  display: flex; flex-direction: column; gap: 12px;
}
.prem-story-step { font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--premium-gold); }
.prem-story-card h3 { margin: 0; font-size: 20px; letter-spacing: -0.01em; }
.prem-story-card p { margin: 0; font-size: 15.5px; line-height: 1.55; color: var(--premium-muted); }

/* ---------- Feature Experience ---------- */
.prem-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.prem-feature {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-md); padding: 26px; box-shadow: var(--premium-shadow-soft);
  display: flex; flex-direction: column; gap: 12px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.prem-feature:hover { transform: translateY(-3px); box-shadow: var(--premium-shadow-lift); }
.prem-ic {
  width: 50px; height: 50px; border-radius: 16px; display: grid; place-items: center; flex: 0 0 auto;
  background: linear-gradient(135deg, rgba(111, 29, 42, .10), rgba(176, 138, 74, .14));
  color: var(--premium-accent); border: 1px solid var(--premium-border);
}
.prem-ic svg { width: 26px; height: 26px; }
.prem-feature h3 { margin: 0; font-size: 19px; letter-spacing: -0.01em; }
.prem-feature p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--premium-muted); }

/* Device-Galerie */
.prem-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 26px; }
.prem-gallery figure {
  margin: 0; border-radius: var(--premium-radius-md); overflow: hidden; background: var(--premium-surface);
  border: 1px solid var(--premium-border); box-shadow: var(--premium-shadow-soft);
}
.prem-gallery img { width: 100%; height: auto; display: block; }
.prem-gallery figcaption { padding: 12px 16px; font-size: 13px; color: var(--premium-muted); border-top: 1px solid var(--premium-border); }

/* ---------- Trust Panel (Datenhoheit & Lizenzruhe) ---------- */
.prem-trust {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-lg); box-shadow: var(--premium-shadow-soft);
  padding: clamp(28px, 4vw, 48px);
}
.prem-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin-top: 26px; }
.prem-trust-item h3 { margin: 0 0 6px; font-size: 16px; }
.prem-trust-item p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--premium-muted); }
.prem-trust-cta { margin-top: 28px; }

/* ---------- Zwei Produkte ---------- */
.prem-products { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 22px; align-items: stretch; }
.prem-product {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-lg); padding: clamp(26px, 3vw, 40px); box-shadow: var(--premium-shadow-soft);
  display: flex; flex-direction: column; gap: 16px;
}
.prem-product--primary { border-color: rgba(111, 29, 42, .35); box-shadow: var(--premium-shadow-lift); }
.prem-product-tag { font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--premium-gold); }
.prem-product h3 { margin: 0; font-size: clamp(22px, 2.4vw, 30px); letter-spacing: -0.02em; }
.prem-product p { margin: 0; color: var(--premium-muted); line-height: 1.55; font-size: 15.5px; }
.prem-list { list-style: none; padding: 0; margin: 4px 0 0; display: grid; gap: 10px; }
.prem-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 15px; line-height: 1.45; }
.prem-list svg { width: 18px; height: 18px; flex: 0 0 auto; color: var(--premium-accent); margin-top: 2px; }
.prem-product-cta { margin-top: auto; display: flex; gap: 12px; flex-wrap: wrap; padding-top: 8px; }

/* ---------- Demo Stepper ---------- */
.prem-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.prem-step {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-md); padding: 28px; box-shadow: var(--premium-shadow-soft);
  display: grid; gap: 10px;
}
.prem-step .n {
  width: 40px; height: 40px; border-radius: 999px; display: grid; place-items: center; font-weight: 800; color: #fff;
  background: linear-gradient(135deg, var(--premium-accent), var(--premium-accent-dark));
}
.prem-step h3 { margin: 6px 0 0; font-size: 18px; }
.prem-step p { margin: 0; font-size: 15px; color: var(--premium-muted); line-height: 1.5; }
.prem-steps-cta { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; margin-top: 30px; }

/* ---------- FAQ Accordion ---------- */
.prem-faq { max-width: 820px; margin: 0 auto; display: grid; gap: 14px; }
.prem-faq-item {
  background: var(--premium-surface); border: 1px solid var(--premium-border);
  border-radius: var(--premium-radius-md); box-shadow: var(--premium-shadow-soft); padding: 6px 24px;
  transition: border-color .18s ease, box-shadow .18s ease;
}
.prem-faq-item[open] { border-color: rgba(111, 29, 42, .28); box-shadow: var(--premium-shadow-lift); }
.prem-faq-item summary {
  list-style: none; cursor: pointer; padding: 18px 30px 18px 0; position: relative;
  font-weight: 700; font-size: 17px; letter-spacing: -0.01em;
}
.prem-faq-item summary::-webkit-details-marker { display: none; }
.prem-faq-item summary::after {
  content: "+"; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
  font-size: 24px; font-weight: 600; color: var(--premium-accent); transition: transform .2s ease;
}
.prem-faq-item[open] summary::after { content: "\2212"; }
.prem-faq-item p { margin: 0 0 18px; color: var(--premium-muted); font-size: 15.5px; line-height: 1.6; }

/* ---------- Final CTA ---------- */
.prem-final-card {
  position: relative; overflow: hidden; border-radius: var(--premium-radius-lg);
  padding: clamp(40px, 6vw, 80px); text-align: center; color: #f4ece9;
  background:
    radial-gradient(700px 280px at 18% 0%, rgba(176, 138, 74, .22), transparent 60%),
    linear-gradient(135deg, var(--premium-accent-dark) 0%, var(--premium-accent) 120%);
  box-shadow: var(--premium-shadow-lift);
}
.prem-final-card h2 { margin: 0; color: #fff; font-size: clamp(28px, 4vw, 48px); letter-spacing: -0.03em; line-height: 1.05; }
.prem-final-card p { margin: 18px auto 0; max-width: 620px; color: rgba(244, 236, 233, .85); line-height: 1.6; font-size: 17px; }
.prem-final-card .prem-cta-row { justify-content: center; margin-top: 30px; }
.prem-final-card .btn-ghost { color: #fff; border-color: rgba(255, 255, 255, .4); background: rgba(255, 255, 255, .08); }
.prem-final-card .btn-ghost:hover { background: rgba(255, 255, 255, .16); border-color: #fff; }

/* ---------- Premium Footer (Brief 3.3) ---------- */
.prem-footer { background: var(--premium-surface-soft); border-top: 1px solid var(--premium-border); padding-block: clamp(48px, 6vw, 80px) 28px; }
.prem-footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 28px; }
.prem-footer-brand { font-weight: 800; font-size: 20px; letter-spacing: -0.01em; }
.prem-footer-claim { margin: 10px 0 0; color: var(--premium-muted); font-size: 14px; line-height: 1.55; max-width: 280px; }
.prem-footer-col h4 { margin: 0 0 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .12em; color: var(--premium-muted); }
.prem-footer-col a { display: block; color: var(--premium-text); text-decoration: none; font-size: 14.5px; padding: 5px 0; }
.prem-footer-col a:hover { color: var(--premium-accent); }
.prem-footer-bottom { margin-top: 34px; padding-top: 20px; border-top: 1px solid var(--premium-border); display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; color: var(--premium-muted); font-size: 13px; }
.prem-footer-bottom a { color: var(--premium-muted); }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .prem-hero-grid { grid-template-columns: 1fr; }
  .prem-hero .prem-subline, .prem-microcopy { max-width: none; }
  .prem-features, .prem-gallery, .prem-grid-3, .prem-steps, .prem-trust-grid { grid-template-columns: 1fr 1fr; }
  .prem-products { grid-template-columns: 1fr; }
  .prem-footer-grid { grid-template-columns: 1fr 1fr; }
  /* Hero einspaltig: Visual zentriert, Foto 4:3 (= Tablet-Crop) */
  .prem-hero-visual { width: 100%; max-width: 680px; margin-inline: auto; margin-top: 8px; }
  .prem-hero-photo { aspect-ratio: 4 / 3; }
}
@media (max-width: 620px) {
  .prem-grid-2, .prem-features, .prem-gallery, .prem-grid-3, .prem-steps, .prem-trust-grid, .prem-footer-grid { grid-template-columns: 1fr; }
  /* Mobile: weniger Abstand zwischen Launchbar/Werbebanner und Hero */
  .prem-hero { padding-top: 16px; }
  /* Mobile: Hero-Visual ÜBER der H1/Text (Landing-Hero flex-column + Produkt lp-hero-grid einspaltig) */
  .prem-hero-grid { display: flex; flex-direction: column; }
  .prem-hero .prem-showcase { order: 3; }
  .prem-hero .prem-hero-visual, .lp-hero-grid .prem-hero-visual { order: -1; }
  .prem-hero-visual { max-width: 440px; margin-top: 0; }
  .prem-hero-photo { aspect-ratio: 4 / 5; }
  /* Hochformat: Mockup kleiner, leicht nach links gekippt, oben an der linken
     Kante – der angeschnittene Laptop im Foto konkurriert nicht mehr mit der Karte */
  .prem-hero-mockup { left: 2%; width: 73%; right: auto; top: 6%; bottom: auto; transform: rotate(-2.3deg); transform-origin: top left; }
  .prem-hero-chip { font-size: 12px; padding: 6px 12px 6px 6px; gap: 7px; }
  .prem-hero-chip-ic { width: 22px; height: 22px; border-radius: 7px; }
  .prem-hero-chip-ic svg { width: 13px; height: 13px; }
  .prem-hero-chip--focus   { top: 5%;  right: 3%; left: auto; }
  .prem-hero-chip--habit   { display: none; }
  .prem-hero-chip--finance { bottom: 6%; right: 4%; }

  /* Nur Produktseiten: Screenshot tiefer ins Bild, schwebende Chips weg von Laptop/Screenshot */
  .product-page .prem-hero-mockup { top: 18%; }
  .product-page .prem-hero-chip--focus   { top: 10%; right: 4%; left: auto; }
  .product-page .prem-hero-chip--finance { bottom: 5%; left: 6%; right: auto; }
}

@media (prefers-reduced-motion: reduce) {
  .prem-page .btn, .prem-feature, .prem-faq-item { transition: none; }
  .prem-hero-chip, .prem-hero-visual::after { animation: none; }
}
