/* =========================================================
   EasyFix — Design Tokens
   Palette aus dem Logo abgeleitet:
   Orange #FF7A1A · Rot #E8352F · Magenta #B6308C · Violett #6A2FBE · Blau #2E45C7
   Hintergrund: #07070C (fast schwarz, wie das Logo)
   ========================================================= */
:root{
  --bg: #07070c;
  --bg-elev: #0d0d16;
  --bg-elev-2: #12121d;
  --line: rgba(255,255,255,0.09);
  --text: #f3f3f7;
  --text-dim: #a8a8b8;
  --text-faint: #6f6f80;

  --orange: #ff7a1a;
  --red: #e8352f;
  --magenta: #b6308c;
  --violet: #6a2fbe;
  --blue: #3450d6;

  --grad-brand: linear-gradient(95deg, var(--orange) 0%, var(--red) 32%, var(--magenta) 60%, var(--violet) 82%, var(--blue) 100%);
  --grad-brand-soft: linear-gradient(95deg, rgba(255,122,26,0.18), rgba(232,53,47,0.18), rgba(182,48,140,0.18), rgba(106,47,190,0.18), rgba(52,80,214,0.18));

  --radius: 16px;
  --radius-sm: 10px;
  --shadow-soft: 0 20px 60px -20px rgba(0,0,0,0.6);

  --font-display: 'Sora', sans-serif;
  --font-body: 'Inter', sans-serif;

  --ease: cubic-bezier(.16,.8,.24,1);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

body{
  margin:0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img{ max-width: 100%; display:block; }
a{ color: inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family: inherit; }

.container{ width: 100%; max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.container-narrow{ max-width: 760px; }

.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--bg-elev); color:var(--text);
  padding:10px 16px; border-radius:8px; z-index:200;
}
.skip-link:focus{ left:16px; top:16px; }

:focus-visible{ outline: 2px solid var(--orange); outline-offset: 3px; border-radius: 4px; }

/* ---------- Loader ---------- */
#loader{
  position:fixed; inset:0; background:var(--bg); z-index:999;
  display:flex; align-items:center; justify-content:center;
  transition: opacity .6s var(--ease), visibility .6s var(--ease);
}
#loader.is-hidden{ opacity:0; visibility:hidden; }
.loader-mark{
  width:84px; height:84px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  animation: loaderPulse 1.4s ease-in-out infinite;
}
.loader-logo{ width:64px; height:64px; object-fit:contain; filter: drop-shadow(0 0 24px rgba(255,122,26,0.45)); }
@keyframes loaderPulse{
  0%,100%{ transform: scale(1); opacity:1; }
  50%{ transform: scale(0.88); opacity:0.7; }
}

/* ---------- Glass ---------- */
.glass{
  background: linear-gradient(160deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015));
  border: 1px solid var(--line);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: var(--radius);
}

/* ---------- Typography ---------- */
h1,h2,h3{ font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; margin: 0; color: var(--text); }
h1{ font-size: clamp(2.4rem, 5.4vw, 3.8rem); line-height: 1.08; }
h2{ font-size: clamp(1.9rem, 3.6vw, 2.6rem); line-height: 1.15; }
h3{ font-size: 1.15rem; }
p{ margin:0; color: var(--text-dim); }

.gradient-text{
  background: var(--grad-brand);
  -webkit-background-clip: text; background-clip:text;
  -webkit-text-fill-color: transparent; color: transparent;
}

.eyebrow{
  font-family: var(--font-display); font-size: 0.78rem; font-weight:600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--orange);
  margin:0 0 14px;
}
.eyebrow.center{ text-align:center; }

.section-title{ margin-bottom: 18px; }
.section-title.center{ text-align:center; }
.section-lead{ max-width: 620px; margin: 0 auto 56px; font-size: 1.05rem; }
.section-lead.center{ text-align:center; }

.section{ padding: 110px 0; position:relative; }
.section-alt{ background: var(--bg-elev); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 15px 30px; border-radius: 999px; font-weight:600; font-size: 0.98rem;
  border: 1px solid transparent; cursor:pointer; transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  font-family: var(--font-display);
}
.btn-primary{
  background: var(--grad-brand); color:#fff;
  box-shadow: 0 12px 30px -8px rgba(232,53,47,0.45);
}
.btn-primary:hover{ transform: translateY(-2px); box-shadow: 0 18px 40px -8px rgba(182,48,140,0.55); }
.btn-ghost{
  background: rgba(255,255,255,0.04); color: var(--text); border-color: var(--line);
}
.btn-ghost:hover{ background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.2); transform: translateY(-2px); }
.btn-full{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position: fixed; top:0; left:0; right:0; z-index:100;
  padding: 18px 0; transition: background .35s var(--ease), padding .35s var(--ease), border-color .35s var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled{
  background: rgba(7,7,12,0.78); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  padding: 12px 0; border-color: var(--line);
}
.nav-wrap{ max-width:1180px; margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; align-items:center; }
.brand-logo{ height: 42px; width:auto; }

.nav-menu{ display:flex; align-items:center; gap: 34px; }
.nav-link{ font-size:0.95rem; font-weight:500; color: var(--text-dim); transition: color .2s; position:relative; }
.nav-link:hover{ color: var(--text); }
.nav-link::after{
  content:''; position:absolute; left:0; bottom:-6px; width:0; height:2px;
  background: var(--grad-brand); transition: width .25s var(--ease);
}
.nav-link:hover::after{ width:100%; }
.nav-cta{
  background: var(--grad-brand); color:#fff !important; padding:10px 20px; border-radius:999px;
  font-weight:600;
}
.nav-cta::after{ display:none; }

.nav-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:120;
}
.nav-toggle span{ width:24px; height:2px; background: var(--text); border-radius:2px; transition: transform .3s var(--ease), opacity .3s var(--ease); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height: 100vh; display:flex; align-items:center;
  padding-top: 110px; overflow:hidden;
}
.hero-bg{ position:absolute; inset:0; z-index:0; }
#circuitCanvas{ position:absolute; inset:0; width:100%; height:100%; opacity:0.55; }
.hero-glow{ position:absolute; border-radius:50%; filter: blur(90px); opacity:0.5; }
.hero-glow--warm{ width:480px; height:480px; background: radial-gradient(circle, var(--orange), transparent 70%); top:-120px; left:-120px; }
.hero-glow--cool{ width:520px; height:520px; background: radial-gradient(circle, var(--violet), transparent 70%); bottom:-160px; right:-160px; }

.hero-inner{
  position:relative; z-index:1; display:grid; grid-template-columns: 1.2fr 0.8fr; gap: 50px; align-items:center;
  padding: 60px 24px 100px;
}
.hero-sub{ font-size: 1.15rem; max-width: 540px; margin-top: 18px; }
.hero-actions{ display:flex; gap:16px; margin-top: 36px; flex-wrap:wrap; }

.hero-visual{ display:flex; justify-content:center; }
.hero-card{
  padding: 36px; border-radius: 28px; display:flex; align-items:center; justify-content:center;
  box-shadow: var(--shadow-soft);
}
.hero-logo{ width: min(280px, 60vw); animation: floatLogo 6s ease-in-out infinite; }
@keyframes floatLogo{ 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-14px); } }

.scroll-cue{
  position:absolute; left:50%; bottom:32px; transform: translateX(-50%); z-index:1;
  width:26px; height:42px; border-radius:14px; border: 2px solid rgba(255,255,255,0.25);
}
.scroll-cue span{
  position:absolute; top:8px; left:50%; width:4px; height:8px; margin-left:-2px; border-radius:2px;
  background: var(--orange); animation: cueDrop 1.8s ease-in-out infinite;
}
@keyframes cueDrop{ 0%{ opacity:1; top:8px; } 80%{ opacity:0; top:22px; } 100%{ opacity:0; top:8px; } }

/* ---------- Benefits ---------- */
.benefits-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 8px; }
.benefit-card{ padding: 32px 26px; transition: transform .3s var(--ease), border-color .3s var(--ease); }
.benefit-card:hover{ transform: translateY(-6px); border-color: rgba(255,255,255,0.18); }
.benefit-icon{
  width:52px; height:52px; border-radius: 14px; margin-bottom:18px;
  display:flex; align-items:center; justify-content:center;
  background: var(--grad-brand-soft); color: var(--orange);
}
.benefit-icon svg{ width:24px; height:24px; }
.benefit-card h3{ margin-bottom:8px; font-size:1.08rem; }
.benefit-card p{ font-size:0.94rem; }

/* ---------- Services ---------- */
.services-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.service-card{ padding: 32px; transition: transform .3s var(--ease), border-color .3s var(--ease); }
.service-card:hover{ transform: translateY(-6px); border-color: rgba(255,255,255,0.18); }
.service-icon{
  width:54px; height:54px; border-radius: 14px; margin-bottom:20px;
  display:flex; align-items:center; justify-content:center;
  background: var(--grad-brand); color:#fff;
}
.service-icon svg{ width:26px; height:26px; }
.service-card h3{ margin-bottom: 14px; }
.service-sub{ font-size: 0.86rem; color: var(--text-faint); margin: -8px 0 16px; }
.service-card ul{ display:flex; flex-direction:column; gap:9px; }
.service-card li{
  font-size: 0.92rem; color: var(--text-dim); padding-left: 18px; position:relative;
}
.service-card li::before{
  content:''; position:absolute; left:0; top:8px; width:7px; height:7px; border-radius:50%;
  background: var(--grad-brand);
}
.service-card--wide{ grid-column: span 1; }
.service-list--row{ flex-direction:row; flex-wrap:wrap; gap: 10px 22px; }

/* ---------- Ablauf / Steps ---------- */
.steps{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 28px; counter-reset: step; }
.step{ position:relative; padding: 30px 24px 24px; border-top: 2px solid var(--line); }
.step-num{
  font-family: var(--font-display); font-weight:800; font-size: 2.2rem;
  background: var(--grad-brand); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  margin-bottom: 14px;
}
.step h3{ margin-bottom: 10px; }
.step p{ font-size: 0.94rem; }

/* ---------- FAQ ---------- */
.faq-list{ display:flex; flex-direction:column; gap: 14px; }
.faq-item{
  border: 1px solid var(--line); border-radius: var(--radius-sm); overflow:hidden;
  background: rgba(255,255,255,0.02);
}
.faq-q{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px;
  background:none; border:none; color: var(--text); padding: 20px 24px; text-align:left;
  font-family: var(--font-display); font-weight:600; font-size: 1rem; cursor:pointer;
}
.faq-icon{ font-size:1.4rem; color: var(--orange); transition: transform .3s var(--ease); flex-shrink:0; }
.faq-item.is-open .faq-icon{ transform: rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition: max-height .35s var(--ease); }
.faq-a p{ padding: 0 24px 20px; font-size: 0.96rem; }

/* ---------- Kontakt ---------- */
.contact-grid{ display:grid; grid-template-columns: 1.5fr 1fr; gap: 32px; align-items:start; }
.contact-form{ padding: 36px; }
.form-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field{ margin-bottom: 18px; display:flex; flex-direction:column; gap:8px; }
.field label{ font-size: 0.85rem; font-weight:600; color: var(--text-dim); }
.field input, .field textarea{
  background: rgba(255,255,255,0.04); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 13px 16px; color: var(--text); font-family: var(--font-body); font-size: 0.96rem;
  transition: border-color .2s, background .2s;
}
.field input:focus, .field textarea:focus{ border-color: var(--orange); background: rgba(255,255,255,0.06); }
.field textarea{ resize: vertical; min-height: 110px; }
.field-checkbox{ flex-direction:row; align-items:flex-start; gap:10px; }
.field-checkbox input{ margin-top:4px; width:16px; height:16px; accent-color: var(--orange); }
.field-checkbox label{ font-weight:400; font-size: 0.88rem; }
.field-checkbox a{ color: var(--orange); text-decoration: underline; }
.form-status{ margin-top:14px; font-size:0.9rem; min-height: 1.2em; }
.form-status.ok{ color: #4dd58a; }
.form-status.err{ color: var(--red); }

.contact-info{ display:flex; flex-direction:column; gap: 20px; }
.info-card{ padding: 28px; }
.info-card h3{ margin-bottom: 16px; }
.info-link{
  display:flex; align-items:center; gap:12px; padding: 10px 0; font-size:0.96rem; color: var(--text-dim);
  transition: color .2s;
}
.info-link:hover{ color: var(--orange); }
.info-link svg{ width:20px; height:20px; flex-shrink:0; }
.info-card p{ font-size: 0.94rem; }

/* ---------- Footer ---------- */
.site-footer{ background: var(--bg-elev-2); border-top: 1px solid var(--line); padding: 56px 0 0; }
.footer-grid{ display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap: 24px; padding-bottom: 36px; }
.footer-logo{ height: 38px; margin-bottom: 12px; }
.footer-brand p{ font-size: 0.88rem; max-width: 280px; }
.footer-links{ display:flex; gap: 26px; }
.footer-links a{ font-size:0.9rem; color: var(--text-dim); transition: color .2s; }
.footer-links a:hover{ color: var(--orange); }
.footer-bottom{ border-top: 1px solid var(--line); padding: 20px 0; }
.footer-bottom p{ font-size: 0.82rem; color: var(--text-faint); text-align:center; }

/* ---------- Scroll Animations ---------- */
[data-animate]{ opacity:0; transform: translateY(28px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
[data-animate="fade-in"]{ transform: none; }
[data-animate].is-visible{ opacity:1; transform: translateY(0); }
[data-delay="1"]{ transition-delay: .05s; }
[data-delay="2"]{ transition-delay: .15s; }
[data-delay="3"]{ transition-delay: .25s; }
[data-delay="4"]{ transition-delay: .35s; }
[data-delay="5"]{ transition-delay: .45s; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero-inner{ grid-template-columns: 1fr; text-align:center; padding-top:30px; }
  .hero-sub{ margin-inline:auto; }
  .hero-actions{ justify-content:center; }
  .hero-visual{ order:-1; margin-bottom: 10px; }
  .benefits-grid{ grid-template-columns: repeat(2,1fr); }
  .services-grid{ grid-template-columns: repeat(2,1fr); }
  .service-card--wide{ grid-column: span 2; }
  .steps{ grid-template-columns: repeat(2,1fr); }
  .contact-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 720px){
  .nav-menu{
    position: fixed; top:0; right:0; height:100vh; width: min(78vw, 320px);
    background: rgba(10,10,16,0.97); backdrop-filter: blur(20px);
    flex-direction:column; justify-content:center; align-items:flex-start; gap: 28px;
    padding: 0 40px; transform: translateX(100%); transition: transform .4s var(--ease);
    border-left: 1px solid var(--line);
  }
  .nav-menu.is-open{ transform: translateX(0); }
  .nav-toggle{ display:flex; }
  .nav-link{ font-size:1.1rem; }

  .benefits-grid{ grid-template-columns: 1fr; }
  .services-grid{ grid-template-columns: 1fr; }
  .service-card--wide{ grid-column: span 1; }
  .steps{ grid-template-columns: 1fr; }
  .form-row{ grid-template-columns: 1fr; }
  .section{ padding: 76px 0; }
  h1{ font-size: clamp(2rem, 9vw, 2.6rem); }
}
