/* =========================================================================
   INconnect GmbH — standalone document pages (Impressum · Datenschutz ·
   Bewerbung). Shares the one-pager's palette + type, but is a calm, fully
   static, screen-reader-friendly document layout (no WebGL / scroll rig).
   ========================================================================= */

:root{
  --bg:      #05070d;
  --bg-2:    #0a1320;
  --blue:    #2781bc;
  --blue-hi: #5cb4ec;
  --cyan:    #5cb4ec;
  --warm:    #ff8f4a;
  --ink:     #eef4ff;
  --text:    #c3d0e4;   /* comfortable long-form body color */
  --muted:   #93a6c2;
  --faint:   #5d6f8c;
  --line:    rgba(120,165,215,.16);
  --line-2:  rgba(120,165,215,.08);
  --glass:   rgba(10,16,28,.55);

  --ff-disp: "Archivo", "Arial Narrow", sans-serif;
  --ff-mono: "JetBrains Mono", ui-monospace, monospace;
  --ease: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--ff-disp);
  font-weight:400;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}
/* ---- live WebGL backdrop — identical to the homepage --------------------- */
/* The scene itself is booted by background.js (src/app.js). These are the exact
   background layers from the one-pager: the WebGL canvas + scrim + cinematic
   vignette + film grain, in the same z-order. */
#webgl{ position:fixed; inset:0; width:100vw; height:100vh; z-index:0; display:block; }
.scrim{ position:fixed; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 30%, transparent 40%, rgba(2,4,9,.55) 100%); }
.vignette-cine{ position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(2,4,9,.55) 0%, transparent 12%, transparent 88%, rgba(2,4,9,.6) 100%),
    radial-gradient(130% 100% at 50% 50%, transparent 58%, rgba(2,4,9,.5) 100%);
  mix-blend-mode:multiply; animation:vigBreathe 14s var(--ease) infinite; }
@keyframes vigBreathe{ 0%,100%{ opacity:.85; } 50%{ opacity:1; } }
.grain{ position:fixed; inset:-50%; z-index:6; pointer-events:none;
  width:200%; height:200%; opacity:.05; mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite; }
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-4%,2%)}
  40%{transform:translate(3%,-3%)} 60%{transform:translate(-2%,4%)}
  80%{transform:translate(4%,1%)} 100%{transform:translate(0,0)}
}
a{ color:var(--cyan); text-decoration:none; transition:color .25s; }
a:hover{ color:var(--ink); }
::selection{ background:var(--cyan); color:#021018; }
:focus-visible{ outline:2px solid var(--cyan); outline-offset:3px; border-radius:4px; }

/* ---- top bar -------------------------------------------------------------- */
.doc-nav{
  position:sticky; top:0; z-index:20;
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:16px clamp(20px,5vw,64px);
  /* transparent at the top — same as the homepage nav */
  background:transparent; border-bottom:1px solid transparent;
  transition:background .4s, backdrop-filter .4s, border-color .4s;
}
/* soft gradient + blur once scrolled (mirrors the homepage .nav--solid) */
.doc-nav.is-solid{
  background:linear-gradient(180deg, rgba(5,7,13,.72), rgba(5,7,13,0));
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-color:var(--line-2);
}
.doc-nav .brand{ display:flex; align-items:center; gap:14px; }
.brand-logo{ height:26px; width:auto; display:block;
  /* the source SVG is dark-on-light; recolor it to the site's white wordmark */
  filter:brightness(0) invert(1); }
.doc-back{
  font-family:var(--ff-mono); font-size:12px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--muted);
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--line); border-radius:100px; padding:9px 16px;
  transition:border-color .3s, color .3s;
}
.doc-back:hover{ color:var(--ink); border-color:var(--blue-hi); }
.doc-back .arr{ transition:transform .3s var(--ease); }
.doc-back:hover .arr{ transform:translateX(-4px); }

/* ---- document shell ------------------------------------------------------- */
.doc-wrap{ max-width:880px; margin:0 auto; padding:clamp(40px,7vw,84px) clamp(20px,5vw,40px) 40px; }
.doc-kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-mono); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--cyan); margin-bottom:18px;
}
.doc-kicker::before{ content:""; width:30px; height:1px; background:var(--cyan); opacity:.7; }
.doc-title{
  font-size:clamp(34px,6vw,64px); font-weight:800; letter-spacing:-.025em;
  line-height:1.02; color:var(--ink); margin-bottom:18px; text-wrap:balance;
}
.doc-intro{ font-size:clamp(16px,1.5vw,19px); color:var(--muted); max-width:62ch; }
.doc-rule{ height:1px; background:var(--line); border:0; margin:clamp(28px,4vw,44px) 0; }

/* ---- long-form typography ------------------------------------------------- */
.doc-body h2{
  font-size:clamp(22px,2.6vw,30px); font-weight:800; color:var(--ink);
  letter-spacing:-.02em; line-height:1.18; margin:42px 0 14px; scroll-margin-top:90px;
}
.doc-body h3{
  font-size:clamp(17px,1.7vw,20px); font-weight:600; color:var(--blue-hi);
  margin:26px 0 8px; letter-spacing:-.01em;
}
.doc-body p{ margin:0 0 14px; }
.doc-body strong{ color:var(--ink); font-weight:600; }
.doc-body ul, .doc-body ol{ margin:0 0 16px; padding-left:1.4em; }
.doc-body li{ margin:0 0 8px; }
.doc-body ul li::marker{ color:var(--blue); }
.doc-body a{ word-break:break-word; }
.doc-body address{ font-style:normal; }

/* highlighted contact / responsible-party block */
.callout{
  border:1px solid var(--line); border-radius:16px; padding:22px 26px;
  background:var(--glass); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  margin:8px 0 22px; line-height:1.65;
}
.callout strong{ color:var(--ink); }
.callout .lbl{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--cyan); display:block; margin-bottom:8px; }

/* small two-column key/value list (Impressum facts) */
.facts{ display:grid; grid-template-columns:max-content 1fr; gap:8px 28px; margin:6px 0 20px; }
.facts dt{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--faint); align-self:baseline; }
.facts dd{ color:var(--text); }
@media (max-width:560px){ .facts{ grid-template-columns:1fr; gap:2px 0; }
  .facts dd{ margin-bottom:12px; } }

/* ---- forms (Bewerbung) ---------------------------------------------------- */
.form{ margin-top:8px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:600px){ .form-row{ grid-template-columns:1fr; } }
.field{ margin-bottom:20px; display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted); }
.field label .req{ color:var(--warm); margin-left:3px; }
.field input, .field textarea{
  font-family:var(--ff-disp); font-size:16px; color:var(--ink);
  background:rgba(8,13,22,.6); border:1px solid var(--line); border-radius:12px;
  padding:13px 15px; width:100%; transition:border-color .25s, background .25s;
}
.field textarea{ resize:vertical; min-height:120px; line-height:1.6; }
.field input::placeholder, .field textarea::placeholder{ color:var(--faint); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--blue-hi);
  background:rgba(10,18,32,.8); }
.field input:user-invalid, .field textarea:user-invalid{ border-color:#e0644a; }

/* file input */
.file-drop{ position:relative; border:1px dashed var(--line); border-radius:12px;
  padding:18px 16px; background:rgba(8,13,22,.4); cursor:pointer;
  display:flex; align-items:center; gap:14px; transition:border-color .25s, background .25s; }
.file-drop:hover{ border-color:var(--blue-hi); background:rgba(10,18,32,.6); }
.file-drop input[type=file]{ position:absolute; inset:0; opacity:0; cursor:pointer; }
.file-drop .ic{ font-size:20px; color:var(--cyan); }
.file-drop .file-txt{ font-size:14px; color:var(--muted); }
.file-drop .file-txt b{ color:var(--ink); font-weight:600; }
.file-hint{ font-size:12px; color:var(--faint); margin-top:6px; }

/* consent checkbox */
.consent{ display:flex; gap:12px; align-items:flex-start; margin:6px 0 26px;
  font-size:14px; color:var(--muted); line-height:1.55; }
.consent input{ flex:0 0 auto; width:20px; height:20px; margin-top:1px; accent-color:var(--blue); }

/* submit button */
.btn{
  font-family:var(--ff-mono); font-size:13px; letter-spacing:.12em; text-transform:uppercase;
  font-weight:500; color:#04101a; background:var(--blue-hi); border:0; border-radius:100px;
  padding:15px 32px; cursor:pointer; display:inline-flex; align-items:center; gap:10px;
  transition:transform .3s var(--ease), box-shadow .3s, background .3s;
  box-shadow:0 14px 40px -18px var(--blue-hi);
}
.btn:hover{ transform:translateY(-2px); background:#7cc4f7;
  box-shadow:0 18px 50px -16px var(--blue-hi); }
.btn:disabled{ opacity:.55; cursor:not-allowed; transform:none; }
.btn .arrow{ transition:transform .3s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

.form-note{ font-size:13px; color:var(--faint); margin-top:18px; line-height:1.6; }

/* form result banner */
.form-status{ display:none; border-radius:14px; padding:18px 22px; margin:4px 0 26px;
  font-size:15px; line-height:1.6; }
.form-status.is-ok{ display:block; border:1px solid rgba(63,220,146,.4);
  background:rgba(20,60,40,.4); color:#bff3d6; }
.form-status.is-err{ display:block; border:1px solid rgba(224,100,74,.4);
  background:rgba(60,24,18,.4); color:#f4c7bc; }

/* ---- footer --------------------------------------------------------------- */
.doc-foot{ border-top:1px solid var(--line-2); margin-top:60px;
  padding:34px clamp(20px,5vw,64px); }
.doc-foot-inner{ max-width:880px; margin:0 auto; display:flex; flex-wrap:wrap;
  gap:10px 24px; align-items:center; justify-content:space-between;
  font-family:var(--ff-mono); font-size:12px; letter-spacing:.04em; color:var(--faint); }
.doc-foot-links{ display:flex; flex-wrap:wrap; gap:8px 22px; }
.doc-foot-links a{ color:var(--muted); }
.doc-foot-links a:hover{ color:var(--cyan); }

/* lift the document above the scrim/vignette (z-index:1) — same as <main> on the homepage */
.doc-wrap, .doc-foot{ position:relative; z-index:2; }

/* ---- open-position cards (Bewerbung) ------------------------------------- */
.jobs-group-label{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--faint); margin:30px 0 14px; }
.jobs{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media (max-width:640px){ .jobs{ grid-template-columns:1fr; } }
.job-card{ border:1px solid var(--line); border-radius:16px; padding:22px 24px;
  background:var(--glass); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  display:flex; flex-direction:column; gap:9px; color:inherit;
  transition:border-color .3s, transform .4s var(--ease), background .3s; }
.job-card:hover{ border-color:var(--blue-hi); transform:translateY(-4px);
  background:rgba(13,22,42,.62); }
.job-card .job-tag{ font-family:var(--ff-mono); font-size:10.5px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--cyan); }
.job-card h3{ font-size:18px; font-weight:700; color:var(--ink); line-height:1.28;
  letter-spacing:-.01em; }
.job-card .job-loc{ font-size:13px; color:var(--muted); line-height:1.5;
  display:flex; gap:8px; }
.job-card .job-loc::before{ content:""; flex:0 0 auto; width:7px; height:7px;
  margin-top:6px; border-radius:50%; background:var(--blue); box-shadow:0 0 10px var(--cyan); }
.job-card .job-go{ margin-top:auto; padding-top:4px; font-family:var(--ff-mono);
  font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--cyan);
  display:inline-flex; gap:8px; align-items:center; }
.job-card .job-go .arrow{ transition:transform .3s var(--ease); }
.job-card:hover .job-go .arrow{ transform:translateX(4px); }
/* aufklappbare Stellenbeschreibung */
.job-card .job-details{ margin-top:2px; }
.job-card .job-details summary{ cursor:pointer; list-style:none; display:inline-flex;
  align-items:center; gap:7px; padding:2px 0; font-family:var(--ff-mono); font-size:11px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--muted); transition:color .3s; }
.job-card .job-details summary::-webkit-details-marker{ display:none; }
.job-card .job-details summary::before{ content:"+"; color:var(--cyan); font-size:14px; line-height:1; }
.job-card .job-details[open] summary::before{ content:"\2013"; }
.job-card .job-details summary:hover{ color:var(--ink); }
.job-card .job-desc{ margin-top:10px; font-size:13.5px; line-height:1.6; color:var(--text); }
.job-card .job-desc p{ margin:0; }

/* "you are applying for …" banner above the form */
.chosen-banner{ border:1px solid color-mix(in oklab, var(--blue-hi) 35%, var(--line));
  background:rgba(13,22,42,.5); border-radius:14px; padding:14px 18px; margin-bottom:24px;
  font-size:15px; color:var(--text); }
.chosen-banner b{ color:var(--ink); }
