:root{
  --color-bg:#F2F0EB;
  --color-black:#1C1C1C;
  --color-orange:#E85D04;
  --color-mid:#C9C5BC;
  --color-text:#444444;
  --color-text-light:#777777;
  --color-white:#FFFFFF;
  --color-green:#2D7D46;
}

*{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}

body{
  background:var(--color-bg);
  color:var(--color-text);
  font-family:'Inter',sans-serif;
  font-size:15px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img,svg{display:block;max-width:100%;}

a{color:inherit;text-decoration:none;}

.container{
  max-width:1100px;
  margin:0 auto;
  padding:0 24px;
}

section{
  padding:100px 0;
  scroll-margin-top:150px;
}

@media (max-width:768px){
  section{padding:64px 0;}
}

h1,h2,h3{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  text-transform:uppercase;
  color:var(--color-black);
}

h1{
  font-size:72px;
  letter-spacing:-0.01em;
  line-height:0.93;
}

h2{
  font-size:48px;
  line-height:1.02;
}

h3{
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:16px;
  text-transform:none;
  color:var(--color-black);
}

@media (max-width:768px){
  h1{font-size:44px;}
  h2{font-size:32px;}
}

.eyebrow{
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:var(--color-orange);
  margin-bottom:16px;
  display:block;
}

.caption{
  font-size:12px;
  color:var(--color-text-light);
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--color-orange);
  color:#fff;
  padding:12px 24px;
  border-radius:2px;
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:13px;
  border:none;
  cursor:pointer;
  transition:transform 0.15s ease, opacity 0.15s ease, box-shadow 0.15s ease;
}

.btn:hover{opacity:0.92;transform:translateY(-1px);}

.btn .arrow{display:inline-block;transition:transform 0.2s ease;}
.btn:hover .arrow{transform:translateX(3px);}

.btn-white{
  background:#fff;
  color:var(--color-orange);
}

.link-secondary{
  color:var(--color-black);
  text-decoration:underline;
  font-weight:500;
  font-size:14px;
  transition:color 0.15s ease;
}

.link-secondary:hover{color:var(--color-orange);}

.accent{
  color:var(--color-orange);
}

.cta-block .accent{color:#fff;}

/* ---------- NAV ---------- */
header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--color-bg);
  border-bottom:1px solid transparent;
  transition:border-color 0.2s ease;
}

header.scrolled{
  border-bottom:1px solid var(--color-mid);
}

nav{
  max-width:1100px;
  margin:0 auto;
  padding:20px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.logo{
  display:block;
  height:100px;
  width:auto;
}

/* ---------- HERO ---------- */
.hero{
  padding:50px 0 0;
  overflow:hidden;
}

.hero-grid{
  display:grid;
  grid-template-columns:55% 45%;
  gap:40px;
  align-items:start;
}

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

.hero-subline{
  margin:24px 0 32px;
  max-width:440px;
  font-size:16px;
  color:var(--color-text);
}

.hero-cta{
  display:flex;
  align-items:center;
  gap:28px;
  flex-wrap:wrap;
}

/* ---------- HERO MASCOT ---------- */
.hero-mascot{
  width:100%;
  max-width:360px;
  margin:0 auto;
  opacity:0;
  transform:translateX(60px);
}

.hero-mascot img{
  width:100%;
  height:auto;
}

@media (max-width:900px){
  .hero-mascot{margin:40px auto 0;max-width:280px;}
}

/* ---------- LV DOCUMENT ---------- */
.lv-doc{
  position:relative;
  background:#fff;
  border:1px solid var(--color-mid);
  border-radius:6px;
  box-shadow:none;
  padding:28px 24px;
  opacity:0;
  transform:translateY(40px);
  max-width:480px;
  margin:0 auto;
}

@media (max-width:900px){
  .lv-doc{max-width:100%;}
}

.lv-stamp{
  position:absolute;
  top:-18px;
  right:-16px;
  width:64px;
  height:64px;
  border-radius:50%;
  border:1.5px dashed var(--color-orange);
  background:var(--color-bg);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  transform:rotate(-10deg);
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:9px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:var(--color-orange);
  line-height:1.2;
  opacity:0;
}

@media (max-width:900px){
  .lv-stamp{width:54px;height:54px;font-size:8px;top:-14px;right:-10px;}
}

.lv-doc-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:18px;
  text-transform:uppercase;
  color:var(--color-black);
  letter-spacing:0.02em;
}

.lv-doc-sub{
  font-size:13px;
  color:var(--color-text-light);
  margin-top:4px;
}

.lv-doc-divider{
  border-top:1px solid var(--color-mid);
  margin:14px 0;
}

.lv-doc-header-row{
  display:grid;
  grid-template-columns:28px 1fr 64px 76px;
  font-size:11px;
  font-weight:600;
  color:var(--color-text-light);
  text-transform:uppercase;
  letter-spacing:0.04em;
  padding-bottom:8px;
  gap:6px;
}

.lv-row{
  display:grid;
  grid-template-columns:28px 1fr 64px 76px;
  align-items:start;
  padding:10px 4px;
  border-radius:3px;
  transition:background 0.4s ease;
  gap:6px;
}

.lv-row.active{
  background:rgba(232,93,4,0.08);
}

.lv-pos{
  font-size:13px;
  font-weight:600;
  color:var(--color-black);
}

.lv-desc{
  font-size:13px;
  color:var(--color-text);
  line-height:1.4;
}

.lv-price{
  font-family:'Courier New',monospace;
  font-size:13px;
  font-weight:600;
  text-align:right;
  color:var(--color-text-light);
  white-space:nowrap;
}

.lv-price.ep-done{
  color:var(--color-black);
}

.lv-price.done{
  color:var(--color-green);
}

.lv-cursor{
  display:inline-block;
  width:7px;
  background:var(--color-orange);
  margin-left:1px;
  animation:blink 0.8s steps(1) infinite;
}

@keyframes blink{
  50%{opacity:0;}
}

.lv-total-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:8px;
  padding-top:14px;
  border-top:1px solid var(--color-mid);
}

.lv-total-label{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:14px;
  text-transform:uppercase;
  color:var(--color-black);
}

.lv-total-price{
  font-family:'Courier New',monospace;
  font-size:20px;
  font-weight:700;
  color:var(--color-text-light);
  transition:color 0.3s ease;
}

.lv-total-price.done{
  color:var(--color-green);
}

/* ---------- TRUST BAR ---------- */
.trust-bar{
  background:var(--color-black);
  padding:36px 0;
}

.trust-bar .caption{
  color:var(--color-mid);
  margin-bottom:14px;
  font-size:12px;
}

.trust-tags{
  color:var(--color-mid);
  font-size:15px;
  line-height:1.8;
}

.trust-tags .sep{
  color:var(--color-orange);
  margin:0 10px;
}

.trust-rotator{
  position:relative;
  height:60px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.trust-word{
  position:absolute;
  left:0;
  right:0;
  text-align:center;
  color:#FFFFFF;
  font-weight:700;
  font-size:50px;
  white-space:nowrap;
}

/* ---------- PROBLEM + LÖSUNG ---------- */
.ps-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:start;
}

@media (max-width:900px){
  .ps-grid{grid-template-columns:1fr;gap:64px;}
}

.ps-sub{
  margin-top:14px;
  margin-bottom:32px;
  font-size:16px;
  color:var(--color-text);
}

.problem-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

@media (max-width:900px){
  .problem-cards{grid-template-columns:1fr;}
}

.solution-tiles{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.card{
  background:#fff;
  border:1px solid var(--color-mid);
  border-radius:6px;
  padding:24px;
  transition:transform 0.2s ease, border-color 0.2s ease;
}

.card:hover{
  transform:translateY(-4px);
  border-color:var(--color-orange);
}

.card-icon{
  font-size:26px;
  color:var(--color-orange);
  margin-bottom:12px;
  line-height:1;
  display:inline-block;
  transition:transform 0.2s ease;
}

.card:hover .card-icon{
  transform:scale(1.1);
}

.card h3{
  margin-bottom:6px;
}

.card p{
  font-size:14px;
  color:var(--color-text);
}

.section-head{
  text-align:center;
  margin-bottom:56px;
}

.section-head p{
  margin-top:14px;
  font-size:17px;
  color:var(--color-text);
}

.tile{
  background:var(--color-bg);
  border:1px solid var(--color-mid);
  border-radius:6px;
  padding:24px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  transition:transform 0.2s ease, border-color 0.2s ease;
}

.tile:hover{
  transform:translateY(-4px);
  border-color:var(--color-orange);
}

.tile-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:36px;
  color:var(--color-orange);
  line-height:1;
  flex-shrink:0;
}

.tile h3{
  font-size:16px;
  margin-bottom:6px;
}

.tile p{
  font-size:14px;
}

.ps-col .eyebrow{
  text-align:left;
  margin-bottom:14px;
}

/* ---------- HOW IT WORKS ---------- */
.steps{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
  margin-top:56px;
}

.steps::before{
  content:'';
  position:absolute;
  top:5px;
  left:0;
  right:0;
  height:1px;
  background:var(--color-mid);
}

@media (max-width:900px){
  .steps{grid-template-columns:1fr;}
  .steps::before{display:none;}
}

.step{
  position:relative;
  padding-top:28px;
}

.step::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--color-orange);
  box-shadow:0 0 0 0 rgba(232,93,4,0.4);
  transition:box-shadow 0.3s ease;
}

.step:hover::before{
  box-shadow:0 0 0 6px rgba(232,93,4,0.15);
}

@media (max-width:900px){
  .step::before{display:none;}
}

.step-label{
  color:var(--color-orange);
  font-weight:600;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin-bottom:10px;
  display:block;
}

.step h3{
  font-size:18px;
  margin-bottom:8px;
}

.step p{
  font-size:14px;
}

/* ---------- WAITLIST ---------- */
.waitlist-card{
  max-width:600px;
  margin:0 auto;
  text-align:center;
  background:#fff;
  border:1px solid var(--color-mid);
  border-radius:6px;
  padding:56px 48px;
}

.waitlist-card .eyebrow{
  text-align:center;
}

.waitlist-card .ps-sub{
  margin-bottom:28px;
}

.waitlist-card .caption{
  margin-top:16px;
}

@media (max-width:768px){
  .waitlist-card{padding:40px 28px;}
}

/* ---------- METRICS ---------- */
.metrics{
  background:var(--color-black);
  text-align:center;
}

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

@media (max-width:768px){
  .metrics-grid{grid-template-columns:1fr;gap:48px;}
}

.metric-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:64px;
  color:var(--color-orange);
  line-height:1;
}

.metric-label{
  margin-top:10px;
  font-size:13px;
  color:var(--color-mid);
}

/* ---------- PRIVACY / HOSTING ---------- */
.forwhom-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}

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

.trust-badges{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.trust-badge{
  display:flex;
  gap:18px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--color-mid);
  border-radius:6px;
  padding:22px 24px;
  transition:transform 0.2s ease, border-color 0.2s ease;
}

.trust-badge:hover{
  transform:translateY(-4px);
  border-color:var(--color-orange);
}

.trust-badge-icon{
  font-size:26px;
  line-height:1;
  flex-shrink:0;
}

.trust-badge-flag{
  width:28px;
  height:28px;
  border-radius:4px;
  background:var(--color-black);
  color:#fff;
  font-family:'Inter',sans-serif;
  font-weight:700;
  font-size:11px;
  letter-spacing:0.02em;
  display:flex;
  align-items:center;
  justify-content:center;
}

.trust-badge h3{
  font-size:15px;
  margin-bottom:4px;
}

.trust-badge p{
  font-size:13px;
  color:var(--color-text);
  margin:0;
}

/* ---------- TESTIMONIALS ---------- */
.testimonial-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

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

.quote-card{
  background:#fff;
  border:1px solid var(--color-mid);
  border-radius:6px;
  padding:36px 28px;
  position:relative;
  transition:transform 0.2s ease, border-color 0.2s ease;
}

.quote-card:hover{
  transform:translateY(-4px);
  border-color:var(--color-orange);
}

.quote-mark{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:64px;
  color:var(--color-orange);
  line-height:1;
  margin-bottom:8px;
}

.quote-text{
  font-size:17px;
  color:var(--color-black);
  margin-bottom:20px;
  line-height:1.4;
}

.quote-name{
  font-weight:600;
  font-size:14px;
  color:var(--color-black);
}

.quote-role{
  font-size:13px;
  color:var(--color-text-light);
}

/* ---------- CTA BLOCK ---------- */
.cta-block{
  background:var(--color-orange);
  text-align:center;
}

.cta-block h2{
  color:#fff;
}

.cta-block p{
  color:#fff;
  margin:20px 0 32px;
  font-size:17px;
  opacity:0.95;
}

/* ---------- FOOTER ---------- */
footer{
  background:var(--color-black);
  padding:48px 0;
}

.footer-grid{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:24px;
}

.footer-logo{
  display:block;
  height:36px;
  width:auto;
  margin-bottom:8px;
}

.footer-grid .caption{
  color:var(--color-mid);
}

.footer-links{
  color:#fff;
  font-size:14px;
}

.footer-links a{
  text-decoration:none;
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0% 1px;
  background-repeat:no-repeat;
  background-position:0 100%;
  transition:background-size 0.2s ease;
}

.footer-links a:hover{
  background-size:100% 1px;
}

.footer-links .sep{
  color:var(--color-mid);
  margin:0 8px;
}

/* ---------- LEGAL PAGES ---------- */
.legal-hero{
  padding:64px 0 0;
}

#datenschutz{
  border-top:1px solid var(--color-mid);
}

.legal-content{
  max-width:720px;
  margin:0 auto;
}

.legal-back{
  display:inline-block;
  margin-bottom:32px;
}

.legal-updated{
  margin-bottom:40px;
}

.legal-content h3{
  margin-top:32px;
  margin-bottom:10px;
  font-size:16px;
}

.legal-content p{
  margin-bottom:16px;
}

.legal-content ul{
  margin:0 0 16px 20px;
}

.legal-content li{
  margin-bottom:6px;
}

.legal-content a{
  color:var(--color-orange);
  text-decoration:underline;
}

/* ---------- GSAP reveal base state ---------- */
.reveal{
  opacity:0;
  transform:translateY(40px);
}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1 !important;transform:none !important;}
  .lv-doc{opacity:1 !important;transform:none !important;}
  *{animation-duration:0.001ms !important; transition-duration:0.001ms !important;}
}
