/* ============================================================
   DoWell UG — Design System
   Edel-minimal · Beratungs-Premium
   Display: Fraunces · Body: Outfit · Daten/Index: JetBrains Mono
   ============================================================ */

:root{
  --paper:    #ECEBE5;   /* kühles Off-White, bewusst nicht "cream" */
  --paper-2:  #F4F3EE;   /* leicht gehobene Flächen */
  --ink:      #16171B;   /* near-black, Text + dunkle Bänder */
  --ink-soft: #43454C;   /* Sekundärtext */
  --ink-dim:  #8C8E94;   /* Tertiär / Captions */
  --line:     #D4D3CB;   /* Haarlinien */
  --line-2:   #C2C1B8;
  --accent:   #D9691E;   /* Safran — warmes, volles Buddhisten-Orange (Mikrodosen) */
  --accent-ink:#B25410;  /* tiefer für Akzent-TEXT auf hellem Grund (Kontrast) */
  --on-ink:   #E7E6E0;   /* Text auf dunklem Band */
  --on-ink-dim:#9B9DA3;

  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:  'Outfit', system-ui, -apple-system, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, Menlo, monospace;

  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing: border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

::selection{ background:var(--accent); color:#fff; }

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

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }

/* ---------- type helpers ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-dim);
  font-weight:500;
}
.serif{ font-family:var(--serif); font-weight:340; }
.rule{ height:1px; background:var(--line); border:0; margin:0; }

/* ============================================================
   HEADER
   ============================================================ */
.site-head{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:68px;
}
.brand{
  font-family:var(--mono);
  font-weight:600;
  font-size:15px;
  letter-spacing:.04em;
  display:inline-flex; align-items:center; gap:10px;
}
.brand .mark{ width:8px;height:8px;border-radius:50%;background:var(--accent); display:inline-block; }
.nav{ display:flex; align-items:center; gap:clamp(14px,2.4vw,30px); }
.nav a{
  font-family:var(--mono); font-size:12.5px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink-soft);
  padding:4px 0; position:relative;
}
.nav a:hover{ color:var(--ink); }
.nav a[aria-current="page"]{ color:var(--ink); }
.nav a[aria-current="page"]::after{
  content:''; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:var(--accent);
}

.langtoggle{ display:inline-flex; border:1px solid var(--line-2); border-radius:2px; overflow:hidden; }
.langtoggle button{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.08em;
  background:transparent; color:var(--ink-dim); border:0; cursor:pointer;
  padding:6px 9px; line-height:1;
}
.langtoggle button[aria-pressed="true"]{ background:var(--ink); color:var(--paper); }
.langtoggle button:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; }

.nav-toggle{ display:none; }

/* ============================================================
   HERO (Startseite)
   ============================================================ */
.hero{ padding:clamp(56px,11vw,140px) 0 clamp(40px,7vw,80px); }
.hero .wrap{ display:grid; grid-template-columns:1fr; gap:38px; }
.hero-kicker{ margin:0 0 26px; }
.hero-title{
  font-family:var(--serif);
  font-weight:330;
  font-size:clamp(40px, 7.6vw, 92px);
  line-height:1.02;
  letter-spacing:-0.012em;
  margin:0;
  max-width:16ch;
}
.hero-title em{ font-style:italic; color:var(--accent); font-weight:340; }
.hero-sub{
  margin:30px 0 0;
  font-size:clamp(18px,2.1vw,21px);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:62ch;
}
.hero-meta{
  margin-top:40px; display:flex; flex-wrap:wrap; gap:10px 28px;
  font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-dim);
}
.hero-meta span{ display:inline-flex; align-items:center; gap:8px; }
.hero-meta span::before{ content:''; width:5px;height:5px;border-radius:50%;background:var(--line-2); }

/* connective mark (SVG = No-JS / reduced-motion Fallback) */
.hero-mark{ width:100%; max-width:360px; height:auto; color:var(--ink); }
.hero-mark .edge{ stroke:var(--line-2); stroke-width:1; }
.hero-mark .node{ fill:var(--paper); stroke:var(--ink-soft); stroke-width:1.2; }
.hero-mark .node.accent{ fill:var(--accent); stroke:var(--accent); }

/* animierter Knowledge-Graph (canvas) — von graph.js aktiviert */
.hero-graph{ display:none; width:100%; max-width:480px; height:230px; }

/* ============================================================
   DOCTRINE BAND (dunkel)
   ============================================================ */
.band{ background:var(--ink); color:var(--on-ink); padding:clamp(60px,9vw,108px) 0; }
.band .eyebrow{ color:var(--on-ink-dim); }
.doctrine-lines{
  font-family:var(--serif); font-weight:320;
  font-size:clamp(26px,4.4vw,50px); line-height:1.18; letter-spacing:-0.01em;
  margin:26px 0 0; max-width:20ch;
}
.doctrine-lines b{ font-weight:320; color:#fff; }
.doctrine-lines .dot{ color:var(--accent); }
.trust{
  margin-top:44px; max-width:64ch; color:var(--on-ink);
  font-size:clamp(17px,2vw,20px); line-height:1.6;
}
.trust .q{ font-family:var(--serif); font-style:italic; }

/* ============================================================
   REGISTER (Signature)
   ============================================================ */
.section{ padding:clamp(60px,9vw,110px) 0; }
.section-head{ display:flex; align-items:baseline; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:14px; }
.section-title{
  font-family:var(--serif); font-weight:340;
  font-size:clamp(26px,3.6vw,40px); line-height:1.1; letter-spacing:-0.01em; margin:0;
}

.register{ position:relative; margin-top:30px; }
.register::before{
  content:''; position:absolute; left:6px; top:46px; bottom:46px; width:1px; background:var(--line);
}
.reg-row{
  position:relative; display:grid;
  grid-template-columns:72px minmax(0,1fr) 132px;
  gap:clamp(16px,3vw,40px); align-items:baseline;
  padding:32px 0 30px; border-top:1px solid var(--line);
  color:inherit; transition:background .25s ease;
}
.register .reg-row:last-child{ border-bottom:1px solid var(--line); }
.reg-row:hover{ background:linear-gradient(90deg, color-mix(in srgb,var(--accent) 6%, transparent), transparent 60%); }
.reg-dot{
  position:absolute; left:2px; top:38px; width:9px; height:9px; border-radius:50%;
  background:var(--paper); border:1.4px solid var(--ink-dim); transition:all .25s ease;
}
.reg-row:hover .reg-dot, .reg-row:focus-visible .reg-dot{ background:var(--accent); border-color:var(--accent); transform:scale(1.15); }
.reg-num{ font-family:var(--mono); font-size:13px; color:var(--ink-dim); padding-left:26px; letter-spacing:.04em; }
.reg-title{
  font-family:var(--serif); font-weight:380; font-size:clamp(21px,2.7vw,28px);
  line-height:1.15; letter-spacing:-0.01em; margin:0 0 7px;
}
.reg-title .arrow{ font-family:var(--sans); color:var(--ink-dim); font-size:.7em; margin-left:.5em; transition:transform .25s ease, color .25s ease; display:inline-block; }
.reg-row:hover .reg-title .arrow{ color:var(--accent-ink); transform:translateX(4px); }
.reg-essence{ margin:0; color:var(--ink-soft); font-size:15.5px; line-height:1.55; max-width:52ch; }
.reg-status{
  justify-self:start; align-self:center;
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft); border:1px solid var(--line-2); border-radius:2px; padding:5px 9px; white-space:nowrap;
}
.reg-status[data-tone="live"]{ color:var(--ink); border-color:var(--ink-soft); }
.reg-status[data-tone="soon"]{ color:var(--ink-dim); }
.reg-status[data-tone="req"]{ color:var(--accent-ink); border-color:color-mix(in srgb,var(--accent) 45%, var(--line-2)); }

/* ============================================================
   FOUNDERS
   ============================================================ */
.founders{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(24px,4vw,56px); margin-top:36px; }
.founder{ border-top:1px solid var(--line); padding-top:26px; }
.founder .mono-id{
  display:inline-flex; align-items:center; justify-content:center;
  width:46px; height:46px; border:1px solid var(--line-2); border-radius:3px;
  font-family:var(--mono); font-weight:600; font-size:15px; letter-spacing:.04em; margin-bottom:18px;
}
.founder h3{ font-family:var(--serif); font-weight:380; font-size:24px; margin:0 0 4px; letter-spacing:-0.01em; }
.founder .role{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent-ink); margin:0 0 14px; }
.founder p{ margin:0; color:var(--ink-soft); font-size:15.5px; line-height:1.6; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{ background:var(--paper-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cta .wrap{ padding-block:clamp(54px,8vw,92px); display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.cta-title{ font-family:var(--serif); font-weight:340; font-size:clamp(26px,4vw,42px); line-height:1.1; letter-spacing:-0.01em; margin:0; max-width:18ch; }
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  background:var(--ink); color:var(--paper); padding:15px 24px; border-radius:2px;
  transition:background .2s ease, transform .2s ease;
}
.btn:hover{ background:var(--accent-ink); transform:translateY(-1px); }
.btn:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }
.btn.ghost{ background:transparent; color:var(--ink); border:1px solid var(--ink-soft); }
.btn.ghost:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* ============================================================
   PRODUCT PAGE
   ============================================================ */
.phero{ padding:clamp(48px,9vw,108px) 0 clamp(30px,5vw,54px); }
.phero .reg-index{ font-family:var(--mono); font-size:13px; letter-spacing:.12em; color:var(--ink-dim); }
.phero .pstatus{
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  border:1px solid var(--line-2); border-radius:2px; padding:5px 9px; color:var(--ink-soft); margin-left:14px;
}
.phero h1{
  font-family:var(--serif); font-weight:330;
  font-size:clamp(38px,6.4vw,76px); line-height:1.04; letter-spacing:-0.012em;
  margin:24px 0 0; max-width:15ch;
}
.phero .essence{
  margin:28px 0 0; font-size:clamp(18px,2.2vw,22px); line-height:1.5; color:var(--ink-soft); max-width:58ch;
  font-family:var(--serif); font-weight:330; font-style:italic;
}

.pbody{ display:grid; grid-template-columns:1fr; gap:0; }
.prose{ max-width:64ch; }
.prose p{ margin:0 0 20px; font-size:17px; line-height:1.65; color:var(--ink-soft); }
.prose p strong{ color:var(--ink); font-weight:600; }

.points{ list-style:none; margin:8px 0 0; padding:0; border-top:1px solid var(--line); }
.points li{ display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start; padding:22px 0; border-bottom:1px solid var(--line); }
.points .k{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-dim); padding-top:3px; white-space:nowrap; }
.points .v{ color:var(--ink-soft); font-size:16px; line-height:1.55; }
.points .v b{ color:var(--ink); font-weight:600; }

.split{ display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(28px,5vw,64px); align-items:start; }

.back{ font-family:var(--mono); font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-dim); display:inline-flex; gap:9px; align-items:center; }
.back:hover{ color:var(--accent-ink); }

/* einblick cards */
.cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:34px; }
.card{ background:var(--paper); padding:clamp(24px,3vw,34px); }
.card .ix{ font-family:var(--mono); font-size:12px; color:var(--ink-dim); letter-spacing:.1em; }
.card h3{ font-family:var(--serif); font-weight:380; font-size:22px; margin:12px 0 8px; letter-spacing:-0.01em; }
.card p{ margin:0; color:var(--ink-soft); font-size:15px; line-height:1.55; }
.card .tag{ display:inline-block; margin-top:14px; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot{ background:var(--ink); color:var(--on-ink); padding:clamp(48px,7vw,84px) 0 40px; }
.site-foot .wrap{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; }
.site-foot .brand{ color:var(--on-ink); }
.site-foot h4{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--on-ink-dim); margin:0 0 16px; font-weight:500; }
.site-foot a{ color:var(--on-ink); display:block; padding:5px 0; font-size:14.5px; }
.site-foot a:hover{ color:var(--accent); }
.foot-tag{ margin-top:18px; color:var(--on-ink-dim); font-size:14px; line-height:1.6; max-width:38ch; }
.foot-legal{ margin-top:48px; padding-top:22px; border-top:1px solid #2a2b30; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--on-ink-dim); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 880px){
  .founders{ grid-template-columns:1fr; }
  .cards{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .site-foot .wrap{ grid-template-columns:1fr 1fr; }
  .hero .wrap{ gap:18px; }
}
@media (max-width: 680px){
  body{ font-size:16px; }
  .nav{ gap:14px; }
  .nav .nav-link{ display:none; }
  .reg-row{ grid-template-columns:1fr; gap:6px; padding:24px 0 24px 26px; }
  .register::before{ left:6px; top:30px; bottom:30px; }
  .reg-dot{ top:30px; left:2px; }
  .reg-num{ padding-left:0; }
  .reg-status{ margin-top:8px; }
  .cta .wrap{ flex-direction:column; align-items:flex-start; }
  .site-foot .wrap{ grid-template-columns:1fr; }
}

/* ============================================================
   MOTION
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .js .reveal{ opacity:0; transform:translateY(14px); transition:opacity .7s ease, transform .7s ease; }
  .js .reveal.in{ opacity:1; transform:none; }
  .hero-mark .draw{ stroke-dasharray:1; stroke-dashoffset:1; animation:draw 1.4s ease forwards .2s; }
  @keyframes draw{ to{ stroke-dashoffset:0; } }
  .hero-mark .pop{ opacity:0; animation:pop .5s ease forwards; }
  @keyframes pop{ to{ opacity:1; } }
}

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