/* FRAMETOOL — Site-Design (Landing, Features, Login, Legal)
   Kino-Ästhetik: Schwarz, Amber, Frameline-Brackets, Filmkorn, Bebas-Neue-Headlines. */
@font-face{
  font-family:'Source Sans 3';
  src:url('fonts/source-sans-3-latin.woff2') format('woff2');
  font-weight:400 700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'JetBrains Mono';
  src:url('fonts/jetbrains-mono-latin.woff2') format('woff2');
  font-weight:400 700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Bebas Neue';
  src:url('fonts/bebas-neue-latin.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;
}

:root{
  --bg:#0a0a0b;
  --bg2:#101012;
  --panel:#141416;
  --line:#232326;
  --line2:#3a3a3e;
  --ink:#d9d9d4;
  --bright:#f2f1ec;
  --dim:#8f8f89;
  --faint:#7a7a76;
  --amber:#e8a33d;
  --amber-hi:#ffc55c;
  --grn:#6fce7e;
  --red:#e5544a;
  --display:'Bebas Neue',Impact,sans-serif;
  --ui:'Source Sans 3',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--ui);font-size:16px;line-height:1.55}
::selection{background:#6a4d1e;color:#fff}
:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
img{max-width:100%;display:block}
a{color:var(--amber);text-decoration:none}
a:hover{color:var(--amber-hi)}

/* Filmkorn + Vignette über allem (dezent) */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(ellipse 130% 110% at 50% 40%, transparent 60%, rgba(0,0,0,.5) 100%);
}
main,header.site,footer.site{position:relative;z-index:2}

/* ---------- Typo-Bausteine ---------- */
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);margin:0 0 14px}
h1.display{font-family:var(--display);font-weight:400;font-size:clamp(52px,8.5vw,110px);line-height:.95;letter-spacing:.015em;color:var(--bright);margin:0 0 18px;text-wrap:balance}
h2.display{font-family:var(--display);font-weight:400;font-size:clamp(34px,4.6vw,56px);line-height:1;letter-spacing:.02em;color:var(--bright);margin:0 0 12px}
h3{font-size:19px;color:var(--bright);margin:0 0 6px}
.lead{font-size:clamp(17px,2vw,20px);color:var(--ink);max-width:56ch;margin:0 0 28px}
.mono{font-family:var(--mono)}
.dim{color:var(--dim)}

/* ---------- Layout ---------- */
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
section{padding:84px 0}
section.tight{padding:56px 0}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:10;background:rgba(10,10,11,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;gap:26px;height:58px}
.logo{font-family:var(--ui);font-weight:700;font-size:17px;letter-spacing:.04em;color:var(--bright);white-space:nowrap}
.logo b{color:var(--amber)}
header.site nav{display:flex;gap:20px;margin-left:8px}
header.site nav a{color:var(--dim);font-size:14.5px;font-weight:600}
header.site nav a:hover,header.site nav a.on{color:var(--bright)}
header.site .sp{flex:1}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:var(--ui);font-weight:700;font-size:15px;padding:11px 22px;border-radius:3px;border:1px solid var(--line2);color:var(--bright);background:transparent;cursor:pointer;transition:all .15s;letter-spacing:.01em}
.btn:hover{border-color:var(--amber);color:var(--amber-hi)}
.btn.primary{background:var(--amber);border-color:var(--amber);color:#140d02}
.btn.primary:hover{background:var(--amber-hi);color:#140d02}
.btn.big{font-size:17px;padding:14px 30px}
.btn.small{font-size:13px;padding:7px 14px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- Frameline-Brackets (Kamera-Klammern) ---------- */
.brackets{position:relative}
.brackets::before,.brackets::after,
.brackets .bk::before,.brackets .bk::after{
  content:'';position:absolute;width:22px;height:22px;border:2px solid var(--amber);z-index:3;pointer-events:none
}
.brackets::before{top:-2px;left:-2px;border-right:0;border-bottom:0}
.brackets::after{bottom:-2px;right:-2px;border-left:0;border-top:0}
.brackets .bk::before{top:-2px;right:-2px;border-left:0;border-bottom:0}
.brackets .bk::after{bottom:-2px;left:-2px;border-right:0;border-top:0}

/* ---------- Hero ---------- */
.hero{padding:92px 0 70px;position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-sub{font-family:var(--mono);font-size:12px;color:var(--faint);margin-top:16px}
.demo-box{background:#000;border:1px solid var(--line);padding:0}
.demo-box canvas{display:block;width:100%;height:auto;background:#000}
.demo-ui{display:flex;align-items:center;gap:12px;padding:10px 12px;border-top:1px solid var(--line);background:var(--panel)}
.demo-ui label{font-family:var(--mono);font-size:11px;color:var(--dim);white-space:nowrap}
.demo-ui .val{font-family:var(--mono);font-size:12px;color:var(--amber);min-width:88px;text-align:right}
.demo-ui input[type=range]{-webkit-appearance:none;appearance:none;flex:1;height:14px;background:transparent}
.demo-ui input[type=range]::-webkit-slider-runnable-track{height:3px;background:#0a0a0a;border:1px solid #000;border-radius:1px}
.demo-ui input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:8px;height:14px;margin-top:-6px;border-radius:1px;background:var(--amber);border:1px solid #000;cursor:ew-resize}
.demo-ui input[type=range]::-moz-range-track{height:3px;background:#0a0a0a;border:1px solid #000}
.demo-ui input[type=range]::-moz-range-thumb{width:8px;height:14px;border-radius:1px;background:var(--amber);border:1px solid #000}
.demo-note{font-family:var(--mono);font-size:10.5px;color:var(--faint);padding:6px 12px 10px;background:var(--panel)}

/* ---------- Stats-Leiste ---------- */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg2)}
.stats .wrap{display:flex;flex-wrap:wrap;gap:0;padding-top:26px;padding-bottom:26px}
.stat{flex:1;min-width:150px;text-align:center;padding:6px 12px;border-left:1px solid var(--line)}
.stat:first-child{border-left:0}
.stat b{display:block;font-family:var(--display);font-size:42px;color:var(--amber);letter-spacing:.02em;line-height:1}
.stat span{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase}

/* ---------- Feature-Karten ---------- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px;margin-top:44px}
.fcard{background:var(--panel);border:1px solid var(--line);padding:0;display:flex;flex-direction:column}
.fcard img{border-bottom:1px solid var(--line);aspect-ratio:16/9;object-fit:cover;object-position:top left;width:100%}
.fcard .body{padding:18px 20px 22px}
.fcard .tag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);display:block;margin-bottom:8px}
.fcard p{margin:0;color:var(--dim);font-size:15px}

/* ---------- Screenshot-Bühne (große Bilder) ---------- */
.stage{margin-top:44px}
.stage img{border:1px solid var(--line);width:100%}
.stage figcaption{font-family:var(--mono);font-size:11px;color:var(--faint);padding-top:10px;text-align:center;letter-spacing:.06em}

/* ---------- Split-Sektionen ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-top:20px}
.split.rev>.txt{order:2}
.split ul{list-style:none;padding:0;margin:18px 0 0}
.split li{padding:7px 0 7px 26px;position:relative;color:var(--ink)}
.split li::before{content:'▸';position:absolute;left:2px;color:var(--amber);font-size:12px;top:11px}

/* ---------- Workflow-Schritte ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px;margin-top:44px;counter-reset:step}
.step{border:1px solid var(--line);background:var(--panel);padding:22px;position:relative}
.step::before{counter-increment:step;content:'0' counter(step);font-family:var(--display);font-size:52px;color:#2c2c2f;position:absolute;top:8px;right:14px;line-height:1}
.step h3{font-size:17px;padding-right:50px}
.step p{margin:6px 0 0;color:var(--dim);font-size:14.5px}

/* ---------- Vergleich ---------- */
.vs-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:38px}
table.vs{width:100%;border-collapse:collapse;font-size:15px;min-width:520px}
table.vs th{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);text-align:left;padding:12px 14px;border-bottom:1px solid var(--line2)}
table.vs th.ft{color:var(--amber)}
table.vs td{padding:11px 14px;border-bottom:1px solid var(--line);color:var(--ink)}
table.vs td.y{color:var(--grn);font-family:var(--mono)}
table.vs td.n{color:var(--faint);font-family:var(--mono)}
table.vs tr td:first-child{color:var(--dim)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:40px auto 0}
.faq details{border:1px solid var(--line);background:var(--panel);margin-bottom:10px}
.faq summary{list-style:none;cursor:pointer;padding:16px 20px;font-weight:700;color:var(--bright);display:flex;gap:12px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:'▸';color:var(--amber);font-size:12px;transition:transform .12s}
.faq details[open] summary::before{transform:rotate(90deg)}
.faq .a{padding:0 20px 18px 42px;color:var(--dim)}

/* ---------- CTA-Block ---------- */
.cta-block{text-align:center;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel),var(--bg2));padding:70px 30px;margin:20px 0}

/* ---------- Footer ---------- */
footer.site{border-top:1px solid var(--line);background:var(--bg2);padding:34px 0;margin-top:40px}
footer.site .wrap{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
footer.site .mono{font-size:11px;color:var(--faint)}
footer.site nav{display:flex;gap:18px;margin-left:auto}
footer.site nav a{color:var(--dim);font-size:13px}

/* ---------- Auth-Seite (Login/Registrieren) ---------- */
.auth-body{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.auth-visual{position:relative;background:#000;overflow:hidden;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--line)}
.auth-visual canvas{width:100%;height:100%;display:block;position:absolute;inset:0}
.auth-visual .overlay{position:relative;z-index:2;text-align:center;padding:40px}
.auth-visual .overlay .mono{font-size:11px;letter-spacing:.2em;color:var(--dim)}
.auth-panel{display:flex;flex-direction:column;justify-content:center;padding:48px clamp(28px,6vw,84px);position:relative;z-index:2}
.auth-card{max-width:400px;width:100%}
.auth-tabs{display:flex;border:1px solid var(--line);margin:26px 0 22px}
.auth-tabs button{flex:1;background:transparent;border:0;color:var(--dim);font-family:var(--ui);font-weight:700;font-size:14.5px;padding:10px;cursor:pointer;border-right:1px solid var(--line)}
.auth-tabs button:last-child{border-right:0}
.auth-tabs button.on{background:var(--panel);color:var(--amber);box-shadow:inset 0 -2px 0 var(--amber)}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:6px}
.field .inwrap{position:relative}
.field input{width:100%;background:#0d0d0e;border:1px solid var(--line2);color:var(--bright);font-family:var(--ui);font-size:16px;padding:11px 42px 11px 13px;border-radius:3px}
.field input:focus{outline:none;border-color:var(--amber)}
.field .toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--dim);font-family:var(--mono);font-size:10.5px;cursor:pointer;padding:6px}
.field .toggle:hover{color:var(--bright)}
.field .hint{font-size:12.5px;color:var(--faint);margin-top:5px}
.auth-err{color:var(--red);font-size:14px;min-height:20px;margin:2px 0 12px}
.auth-note{border:1px solid #3a2f18;background:#191308;color:#c9a86a;font-size:13px;padding:12px 14px;margin-top:20px;line-height:1.5}
.auth-note b{color:var(--amber)}
.auth-back{position:absolute;top:20px;left:24px;z-index:3;font-family:var(--mono);font-size:12px}

@media (max-width:920px){
  .hero .wrap,.split{grid-template-columns:1fr}
  .split.rev>.txt{order:0}
  .auth-body{grid-template-columns:1fr}
  .auth-visual{min-height:240px;border-right:0;border-bottom:1px solid var(--line)}
  header.site nav{display:none}
  section{padding:56px 0}
}
@media (max-width:480px){
  header.site .wrap{gap:8px}
  header.site .btn.small{padding:7px 11px;white-space:nowrap}
  .logo{font-size:15px}
  h1.display{font-size:clamp(40px,11vw,60px)}
  .stat{min-width:120px}
  .stat b{font-size:34px}
}
