/* =========================================================
   Clavis — Landing Page
   Palette derived from the product UI (navy / emerald / amber)
   ========================================================= */

/* Self-hosted fonts — no external CDN call (data sovereignty / DSGVO).
   Files live in ../fonts and are served from the same origin. */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/space-grotesk-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/space-grotesk-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/space-grotesk-latin-600-normal.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/space-grotesk-latin-700-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/ibm-plex-sans-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/ibm-plex-sans-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/ibm-plex-sans-latin-600-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/ibm-plex-sans-latin-700-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/ibm-plex-mono-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/ibm-plex-mono-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/ibm-plex-mono-latin-600-normal.woff2') format('woff2');}

:root{
  /* brand */
  --navy-950:#0f1b30;
  --navy-900:#142339;
  --navy-800:#1b2e49;
  --navy-700:#26395a;
  --ink:#16223a;
  --slate-600:#4d5a72;
  --slate-500:#697892;
  --slate-400:#93a0b5;

  --bg:#f5f7fb;
  --bg-2:#eef2f8;
  --surface:#ffffff;
  --border:#e4e8f0;
  --border-strong:#d4dae6;

  --emerald-700:#127049;
  --emerald-600:#15835660;
  --emerald:#178a55;
  --emerald-500:#1f9d63;
  --emerald-100:#e4f3ea;
  --emerald-50:#f0f8f3;

  --teal:#1f9b86;

  --amber:#d6a23a;
  --amber-deep:#b07e1d;
  --amber-bg:#fbf3df;

  --danger:#c2533f;
  --danger-bg:#fbeae6;

  /* accent is tweakable */
  --accent:var(--emerald);
  --accent-600:var(--emerald-700);
  --accent-100:var(--emerald-100);
  --accent-50:var(--emerald-50);

  --radius:14px;
  --radius-sm:10px;
  --radius-lg:20px;

  --shadow-sm:0 1px 2px rgba(20,35,57,.05), 0 1px 3px rgba(20,35,57,.06);
  --shadow:0 4px 14px rgba(20,35,57,.07), 0 1px 3px rgba(20,35,57,.05);
  --shadow-lg:0 18px 50px rgba(15,27,48,.14), 0 6px 18px rgba(15,27,48,.08);

  --display:'Space Grotesk', system-ui, sans-serif;
  --sans:'IBM Plex Sans', system-ui, sans-serif;
  --mono:'IBM Plex Mono', ui-monospace, monospace;

  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.6;
}
h1,h2,h3,h4{font-family:var(--display); font-weight:600; line-height:1.08; margin:0; color:var(--ink); letter-spacing:-.02em;}
p{margin:0;}
a{color:inherit; text-decoration:none;}
code,pre,.mono{font-family:var(--mono);}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 32px;}
.section{padding:96px 0;}
.section.tight{padding:64px 0;}

/* ---------- eyebrow / labels ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent-600); font-weight:500;
  display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{
  content:''; width:18px; height:1.5px; background:var(--accent); display:inline-block;
}
.eyebrow.on-dark{color:#7fd2a8;}
.eyebrow.on-dark::before{background:#7fd2a8;}

.section-intro{max-width:680px; margin-bottom:52px;}
.section-intro h2{font-size:clamp(30px, 3.6vw, 44px); margin-top:18px;}
.section-intro p{margin-top:18px; font-size:18px; color:var(--slate-600);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans); font-weight:600; font-size:15.5px;
  padding:14px 24px; border-radius:11px; cursor:pointer;
  border:1.5px solid transparent; transition:.18s ease;
  white-space:nowrap;
}
.btn .ic{width:17px; height:17px; display:inline-flex;}
.btn-primary{background:var(--accent); color:#fff; box-shadow:0 6px 16px color-mix(in srgb, var(--accent) 32%, transparent);}
.btn-primary:hover{filter:brightness(1.05); transform:translateY(-1px);}
.btn-dark{background:var(--navy-900); color:#fff;}
.btn-dark:hover{background:var(--navy-800); transform:translateY(-1px);}
.btn-outline{background:var(--surface); color:var(--ink); border-color:var(--border-strong);}
.btn-outline:hover{border-color:var(--slate-400); background:var(--bg);}
.btn-ghost-light{background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.22);}
.btn-ghost-light:hover{background:rgba(255,255,255,.16);}
.btn-lg{padding:16px 28px; font-size:16.5px;}
.btn-sm{padding:9px 16px; font-size:14px; border-radius:9px;}

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:40;
  background:rgba(245,247,251,.82);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:14px 32px;
  display:flex; align-items:center; gap:14px;
}
.brand{display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:600; font-size:20px; letter-spacing:-.01em;}
.brand-mark{
  width:34px; height:34px; border-radius:9px;
  background:linear-gradient(150deg, var(--teal), var(--emerald));
  display:grid; place-items:center; color:#fff; font-weight:700; font-size:19px;
  box-shadow:0 3px 8px rgba(31,155,134,.32);
}
.nav-links{display:flex; gap:6px; margin-left:24px;}
.nav-links a{
  font-size:15px; color:var(--slate-600); padding:8px 13px; border-radius:8px; font-weight:500;
  transition:.15s;
}
.nav-links a:hover{color:var(--ink); background:var(--bg-2);}
.nav-right{margin-left:auto; display:flex; align-items:center; gap:10px;}
.nav-login{font-size:15px; font-weight:600; color:var(--slate-600); padding:8px 6px;}
.nav-login:hover{color:var(--ink);}

/* ---------- hero ---------- */
.hero{position:relative; overflow:hidden; padding:88px 0 56px;}
.hero::before{
  content:''; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(900px 500px at 78% -8%, color-mix(in srgb, var(--accent) 9%, transparent), transparent 60%),
    radial-gradient(700px 460px at 8% 12%, rgba(31,155,134,.07), transparent 60%);
  pointer-events:none;
}
.hero-inner{position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; padding:0 32px;
  display:grid; grid-template-columns:1.08fr .92fr; gap:56px; align-items:center;}
.hero h1{font-size:clamp(40px, 5.2vw, 64px); letter-spacing:-.03em;}
.hero h1 .hl{position:relative; white-space:nowrap; color:var(--accent-600);}
.hero h1 .hl::after{
  content:''; position:absolute; left:-2px; right:-2px; bottom:.06em; height:.34em; z-index:-1;
  background:color-mix(in srgb, var(--accent) 22%, transparent); border-radius:3px;
}
.hero-lede{margin-top:26px; font-size:19px; color:var(--slate-600); max-width:560px;}
.hero-lede code{font-family:var(--mono); font-size:.86em; background:var(--bg-2); padding:2px 7px; border-radius:6px; color:var(--navy-800); border:1px solid var(--border);}
.hero-cta{display:flex; gap:13px; margin-top:34px; flex-wrap:wrap; align-items:center;}
.hero-note{font-size:13.5px; color:var(--slate-500); margin-top:16px; display:flex; align-items:center; gap:8px;}
.hero-note .dot{width:6px; height:6px; border-radius:50%; background:var(--accent); flex:none;}

.trustline{
  margin-top:40px; padding-top:26px; border-top:1px solid var(--border);
  display:flex; flex-wrap:wrap; gap:10px 26px;
}
.trustline .ti{
  font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--slate-500);
  display:inline-flex; align-items:center; gap:8px;
}
.trustline .ti svg{width:15px; height:15px; color:var(--accent);}

/* hero side card -> dashboard preview */
.hero-card{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); overflow:hidden;
  transform:perspective(1600px) rotateY(-7deg) rotateX(2.5deg);
  transform-origin:center right;
}

/* ---------- generic card ---------- */
.card{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}

/* ---------- pain ---------- */
.pain{background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border);}
.pain-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.pain-card{padding:34px 30px; border-radius:var(--radius); border:1px solid var(--border); background:var(--bg); position:relative; overflow:hidden;}
.pain-card .pc-ic{
  width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:var(--danger-bg); color:var(--danger); margin-bottom:20px;
}
.pain-card .pc-ic svg{width:23px; height:23px;}
.pain-card h3{font-size:21px; margin-bottom:10px;}
.pain-card p{font-size:15px; color:var(--slate-600);}
.pain-card .pc-tag{margin-top:18px; font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--danger); text-transform:uppercase;}

/* ---------- answer / docker steps ---------- */
.answer{background:var(--bg-2);}
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.step{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column;}
.step-head{display:flex; align-items:center; gap:12px; margin-bottom:16px;}
.step-num{width:30px; height:30px; border-radius:8px; background:var(--accent-100); color:var(--accent-600); font-family:var(--mono); font-weight:600; display:grid; place-items:center; font-size:14px;}
.step h3{font-size:18px;}
.step p{font-size:14.5px; color:var(--slate-600); margin-top:auto;}
.term{
  background:var(--navy-950); border-radius:11px; padding:16px 17px; margin:4px 0 16px;
  font-family:var(--mono); font-size:13px; line-height:1.85; color:#cdd8e8; overflow-x:auto;
}
.term .pr{color:var(--teal);}
.term .ok{color:#5fd197;}
.term .cm{color:#6b7c96;}
.term .fl{color:#e7c980;}

/* ---------- modules ---------- */
.mod-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px;}
.mod{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:18px 18px 16px; transition:.16s; position:relative; min-height:128px;
  display:flex; flex-direction:column;
}
.mod:hover{border-color:var(--accent); box-shadow:var(--shadow); transform:translateY(-2px);}
.mod-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:13px;}
.mod-ic{width:34px; height:34px; border-radius:9px; background:var(--accent-50); color:var(--accent-600); display:grid; place-items:center;}
.mod-ic svg{width:18px; height:18px;}
.mod-art{font-family:var(--mono); font-size:10.5px; letter-spacing:.03em; color:var(--slate-400); background:var(--bg); border:1px solid var(--border); padding:3px 7px; border-radius:6px;}
.mod h4{font-family:var(--sans); font-weight:600; font-size:15.5px; letter-spacing:0; margin-bottom:4px;}
.mod p{font-size:12.8px; color:var(--slate-500); line-height:1.45;}
.mod.cross{background:var(--bg); border-style:dashed;}
.mod.cross .mod-ic{background:var(--navy-900); color:#fff;}

.mod-foot{margin-top:26px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; font-size:14px; color:var(--slate-500);}
.mod-foot .lg{display:inline-flex; align-items:center; gap:8px;}
.mod-foot .sw{width:13px; height:13px; border-radius:4px; border:1px solid var(--border-strong);}

/* ---------- comparison ---------- */
.compare{background:var(--navy-900);}
.compare .section-intro h2, .compare .section-intro p{color:#fff;}
.compare .section-intro p{color:#aeb9cc;}
.ctable{
  background:var(--navy-950); border:1px solid rgba(255,255,255,.09); border-radius:var(--radius-lg);
  overflow:hidden;
}
.crow{display:grid; grid-template-columns:1.3fr 1fr 1fr;}
.crow > div{padding:18px 24px; border-bottom:1px solid rgba(255,255,255,.07);}
.crow > div + div{border-left:1px solid rgba(255,255,255,.07);}
.crow:last-child > div{border-bottom:none;}
.chead > div{padding:20px 24px;}
.chead .h-crit{color:#8b97ad; font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase;}
.chead .h-clavis{background:var(--accent); color:#fff; font-family:var(--display); font-weight:600; font-size:18px; display:flex; align-items:center; gap:9px;}
.chead .h-clavis .bm{width:24px; height:24px; border-radius:7px; background:rgba(255,255,255,.18); display:grid; place-items:center; font-size:14px;}
.chead .h-saas{color:#cdd6e4; font-family:var(--display); font-weight:600; font-size:18px;}
.crit{color:#e6ebf3; font-weight:500; font-size:15px;}
.crow .clavis{background:color-mix(in srgb, var(--accent) 12%, var(--navy-950));}
.cell-yes{color:#fff; font-size:14.5px; display:flex; gap:10px; align-items:flex-start;}
.cell-yes .mk{color:#73e2a8; flex:none; margin-top:2px;}
.cell-no{color:#c5cee0; font-size:14.5px; display:flex; gap:10px; align-items:flex-start;}
.cell-no .mk{color:#e0846f; flex:none; margin-top:2px;}
.cell-neu{color:#aab4c8; font-size:14.5px; display:flex; gap:10px; align-items:flex-start;}
.cell-neu .mk{color:#8b97ad; flex:none; margin-top:2px;}
.cell-detail{display:block; color:#8b97ad; font-size:12.5px; margin-top:4px;}
.cell-yes .cell-detail{color:#9fd9b8;}

/* ---------- dashboard showcase ---------- */
.showcase{background:var(--surface); border-top:1px solid var(--border);}
.showcase-grid{display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:center;}
.showcase ul{list-style:none; padding:0; margin:24px 0 0; display:flex; flex-direction:column; gap:14px;}
.showcase li{display:flex; gap:13px; font-size:15.5px; color:var(--slate-600);}
.showcase li .li-ic{width:24px; height:24px; border-radius:7px; background:var(--accent-100); color:var(--accent-600); display:grid; place-items:center; flex:none; margin-top:1px;}
.showcase li .li-ic svg{width:14px; height:14px;}
.showcase li b{color:var(--ink); font-weight:600;}

/* product dashboard mock */
.pd{
  border:1px solid var(--border); border-radius:16px; overflow:hidden; background:#fbfcfe;
  box-shadow:var(--shadow-lg);
}
.pd-bar{display:flex; align-items:center; gap:7px; padding:11px 15px; background:var(--surface); border-bottom:1px solid var(--border);}
.pd-bar .dot{width:10px; height:10px; border-radius:50%;}
.pd-bar .tt{margin-left:10px; font-family:var(--mono); font-size:11.5px; color:var(--slate-400);}
.pd-body{display:grid; grid-template-columns:148px 1fr;}
.pd-side{background:var(--navy-900); padding:16px 12px; display:flex; flex-direction:column; gap:3px;}
.pd-side .s-brand{display:flex; align-items:center; gap:8px; color:#fff; font-family:var(--display); font-weight:600; font-size:15px; padding:4px 6px 14px;}
.pd-side .s-brand .bm{width:22px; height:22px; border-radius:6px; background:linear-gradient(150deg,var(--teal),var(--emerald)); display:grid; place-items:center; font-size:12px;}
.pd-side .s-grp{font-family:var(--mono); font-size:8.5px; letter-spacing:.12em; color:#5b6b86; margin:12px 6px 4px;}
.pd-side .s-item{display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:7px; color:#9fadc6; font-size:12px;}
.pd-side .s-item svg{width:13px; height:13px;}
.pd-side .s-item.active{background:rgba(255,255,255,.1); color:#fff;}
.pd-main{padding:20px; background:#f7f9fc;}
.pd-h{display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:16px;}
.pd-h h4{font-family:var(--display); font-size:19px;}
.pd-h .sub{font-size:11.5px; color:var(--slate-500); margin-top:3px;}
.pd-h .mini-btn{background:var(--navy-900); color:#fff; font-size:11px; font-weight:600; padding:7px 11px; border-radius:8px; display:inline-flex; gap:6px; align-items:center;}
.pd-kpis{display:grid; grid-template-columns:repeat(5,1fr); gap:9px; margin-bottom:14px;}
.pd-kpi{background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:11px;}
.pd-kpi .k-top{display:flex; justify-content:space-between; align-items:center;}
.pd-kpi .k-lbl{font-size:9.5px; color:var(--slate-500); line-height:1.3;}
.pd-kpi .k-ic{width:18px; height:18px; color:var(--slate-400);}
.pd-kpi .k-ic svg{width:15px; height:15px;}
.pd-kpi .k-val{font-family:var(--display); font-weight:600; font-size:23px; margin-top:7px;}
.pd-kpi .k-meta{font-size:9px; color:var(--slate-400); margin-top:1px;}
.pd-kpi.alert{background:#fdf6ee; border-color:#f0d9b8;}
.pd-kpi.alert .k-ic, .pd-kpi.alert .k-val{color:var(--amber-deep);}
.pd-kpi.alert .k-lbl{color:var(--amber-deep);}
.pd-cols{display:grid; grid-template-columns:1.25fr 1fr; gap:12px;}
.pd-score{background:var(--surface); border:1px solid var(--border); border-radius:11px; padding:16px;}
.pd-score-h{display:flex; justify-content:space-between; align-items:center; margin-bottom:12px;}
.pd-score-h .t{font-family:var(--display); font-weight:600; font-size:15px;}
.pd-score-h .badge{font-family:var(--display); font-weight:600; font-size:12px; color:var(--amber-deep); background:var(--amber-bg); padding:3px 11px; border-radius:999px;}
.pd-mainbar{height:8px; border-radius:5px; background:var(--bg-2); overflow:hidden; margin-bottom:16px;}
.pd-mainbar > div{height:100%; background:var(--amber); border-radius:5px;}
.pd-srow{display:flex; align-items:center; gap:10px; margin-bottom:8px;}
.pd-srow .nm{width:118px; font-size:10.5px; color:var(--slate-600); flex:none;}
.pd-srow .tr{flex:1; height:6px; border-radius:4px; background:var(--bg-2); overflow:hidden;}
.pd-srow .tr > div{height:100%; border-radius:4px;}
.pd-srow .pc{width:30px; text-align:right; font-family:var(--mono); font-size:10px; font-weight:500; color:var(--slate-600);}
.pd-tasks{background:var(--surface); border:1px solid var(--border); border-radius:11px; padding:16px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;}
.pd-tasks .t{font-family:var(--display); font-weight:600; font-size:14px; align-self:flex-start; margin-bottom:auto;}
.pd-tasks .check{width:34px; height:34px; border-radius:50%; background:var(--emerald-50); color:var(--emerald); display:grid; place-items:center; margin:18px 0 9px;}
.pd-tasks .msg{font-size:11px; color:var(--slate-500);}

/* ---------- trust ---------- */
.trust{background:var(--bg-2);}
.trust-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.trust-card{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:26px 24px;}
.trust-card .tc-ic{width:42px; height:42px; border-radius:11px; background:var(--accent-50); color:var(--accent-600); display:grid; place-items:center; margin-bottom:16px;}
.trust-card .tc-ic svg{width:21px; height:21px;}
.trust-card h4{font-family:var(--display); font-size:17px; margin-bottom:7px;}
.trust-card p{font-size:14px; color:var(--slate-600);}
.trust-flag{display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); font-size:12px; letter-spacing:.05em; color:var(--slate-500); margin-top:6px;}
.trust-flag .fl{width:22px; height:15px; border-radius:2px; overflow:hidden; display:inline-grid; grid-template-rows:1fr 1fr 1fr; border:1px solid var(--border);}
.trust-flag .fl i{display:block;}

/* ---------- pricing ---------- */
.pricing{background:var(--bg);}
.price-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch;}
.price-card{
  position:relative; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:32px 28px; display:flex; flex-direction:column; box-shadow:var(--shadow-sm);
}
.price-card.featured{
  border:1.5px solid var(--accent); box-shadow:0 18px 44px color-mix(in srgb, var(--accent) 16%, transparent);
  transform:translateY(-6px);
}
.pc-flag{
  position:absolute; top:-13px; left:28px; background:var(--accent); color:#fff;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  padding:5px 12px; border-radius:999px; font-weight:500;
}
.pc-tier{font-family:var(--mono); font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--slate-500);}
.pc-price{display:flex; align-items:baseline; gap:8px; margin-top:16px;}
.pc-price .amt{font-family:var(--display); font-weight:600; font-size:46px; letter-spacing:-.03em; color:var(--ink);}
.pc-price .per{font-size:16px; color:var(--slate-500); font-weight:500;}
.pc-cycle{font-size:13.5px; color:var(--slate-500); margin-top:4px;}
.pc-desc{font-size:14.5px; color:var(--slate-600); margin-top:18px;}
.pc-feat{list-style:none; padding:0; margin:20px 0 26px; display:flex; flex-direction:column; gap:11px;}
.pc-feat li{position:relative; padding-left:28px; font-size:14.5px; color:var(--ink);}
.pc-feat li::before{
  content:''; position:absolute; left:0; top:2px; width:18px; height:18px; border-radius:50%;
  background:var(--accent-100);
}
.pc-feat li::after{
  content:''; position:absolute; left:5px; top:7px; width:8px; height:5px;
  border-left:2px solid var(--accent-600); border-bottom:2px solid var(--accent-600);
  transform:rotate(-45deg);
}
.pc-cta{margin-top:auto; justify-content:center;}
.pc-feat code{font-family:var(--mono); font-size:.86em; background:var(--bg-2); padding:1px 6px; border-radius:5px; border:1px solid var(--border);}

.price-addon{
  margin-top:24px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:24px 28px; display:flex; align-items:center; gap:22px; box-shadow:var(--shadow-sm);
}
.price-addon .pa-ic{
  width:48px; height:48px; border-radius:12px; background:var(--accent-50); color:var(--accent-600);
  display:grid; place-items:center; flex:none;
}
.price-addon .pa-ic svg{width:24px; height:24px;}
.price-addon .pa-body{flex:1;}
.price-addon h4{font-family:var(--display); font-size:17px; margin-bottom:5px;}
.price-addon .pa-amt{color:var(--accent-600);}
.price-addon p{font-size:14px; color:var(--slate-600);}
.price-addon p a{color:var(--accent-600); font-weight:600; text-decoration:underline; text-underline-offset:2px;}
.price-addon .pc-cta{flex:none; margin:0;}

/* ---------- final cta ---------- */
.final{background:var(--navy-900); position:relative; overflow:hidden;}
.final::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(800px 400px at 85% 0%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 55%);
}
.final-inner{position:relative; z-index:1; display:grid; grid-template-columns:1.3fr .7fr; gap:48px; align-items:center;}
.final h2{color:#fff; font-size:clamp(30px,3.8vw,46px);}
.final p{color:#aeb9cc; font-size:17px; margin-top:18px; max-width:560px;}
.final-cta{display:flex; flex-direction:column; gap:12px;}
.final .btn{justify-content:center;}

/* =========================================================
   Clavis — "Jetzt starten" page only
   ========================================================= */
.start-hero{padding:64px 0 56px; position:relative; overflow:hidden;}
.start-hero::before{
  content:''; position:absolute; inset:0; z-index:0;
  background:radial-gradient(800px 460px at 82% -10%, color-mix(in srgb, var(--accent) 9%, transparent), transparent 60%);
  pointer-events:none;
}
.start-hero-inner{position:relative; z-index:1; display:grid; grid-template-columns:1fr .92fr; gap:52px; align-items:center;}
.start-hero h1{font-size:clamp(34px,4.4vw,52px); letter-spacing:-.03em; margin-top:20px;}
.start-hero .lede{font-size:18px; color:var(--slate-600); margin-top:22px; max-width:520px;}
.crumb{font-size:14px; color:var(--slate-500);}
.crumb a{color:var(--accent-600); font-weight:600;}
.crumb a:hover{text-decoration:underline;}

.facts{display:flex; gap:14px; margin-top:30px; flex-wrap:wrap;}
.fact{background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:14px 18px; box-shadow:var(--shadow-sm);}
.fact .fv{font-family:var(--display); font-weight:600; font-size:22px; color:var(--ink);}
.fact .fl{font-size:12.5px; color:var(--slate-500); margin-top:2px;}

/* download card */
.dl-card{
  background:var(--navy-900); border-radius:var(--radius-lg); padding:28px; color:#fff;
  box-shadow:var(--shadow-lg); position:relative; overflow:hidden;
}
.dl-card::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(420px 220px at 90% 0%, color-mix(in srgb, var(--accent) 28%, transparent), transparent 60%);
  pointer-events:none;
}
.dl-card .dl-h{position:relative; display:flex; align-items:center; gap:14px; margin-bottom:20px;}
.dl-card .dl-fileic{width:52px; height:52px; border-radius:13px; background:rgba(255,255,255,.1); display:grid; place-items:center; flex:none;}
.dl-card .dl-fileic svg{width:26px; height:26px; color:#7fd2a8;}
.dl-card .dl-name{font-family:var(--mono); font-size:15px; font-weight:500; word-break:break-all;}
.dl-card .dl-tag{font-size:12.5px; color:#9fb4cf; margin-top:2px;}
.dl-meta{position:relative; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:rgba(255,255,255,.08); border-radius:10px; overflow:hidden; margin-bottom:20px;}
.dl-meta div{background:var(--navy-900); padding:11px 14px;}
.dl-meta .ml{font-size:11px; color:#8b9cb6; letter-spacing:.04em;}
.dl-meta .mv{font-family:var(--mono); font-size:13px; color:#e6edf6; margin-top:2px;}
.dl-card .btn{position:relative; width:100%; justify-content:center;}
.dl-sha{position:relative; margin-top:14px; font-family:var(--mono); font-size:11px; color:#7e90ab; word-break:break-all; line-height:1.6;}
.dl-sha b{color:#9fb4cf; font-weight:500;}

/* install steps */
.install-list{position:relative; margin-top:8px;}
.istep{position:relative; display:grid; grid-template-columns:54px 1fr; gap:20px; padding-bottom:36px;}
.istep:last-child{padding-bottom:0;}
.istep::before{
  content:''; position:absolute; left:26px; top:46px; bottom:-6px; width:2px; background:var(--border-strong);
}
.istep:last-child::before{display:none;}
.istep .inum{
  width:52px; height:52px; border-radius:14px; background:var(--surface); border:1.5px solid var(--accent);
  color:var(--accent-600); font-family:var(--display); font-weight:600; font-size:22px;
  display:grid; place-items:center; z-index:1; box-shadow:var(--shadow-sm);
}
.istep .ibody{padding-top:4px;}
.istep h3{font-family:var(--display); font-size:20px; margin-bottom:8px;}
.istep p{font-size:15px; color:var(--slate-600); max-width:620px;}
.istep p code, .istep .ibody > code{font-family:var(--mono); font-size:.86em; background:var(--bg-2); padding:2px 7px; border-radius:6px; border:1px solid var(--border); color:var(--navy-800);}
.istep .term{max-width:620px; margin:14px 0 0;}
.istep .hint{font-size:13px; color:var(--slate-500); margin-top:10px; display:flex; gap:8px; align-items:flex-start;}
.istep .hint svg{width:16px; height:16px; color:var(--accent-600); flex:none; margin-top:2px;}

/* requirements */
.req{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm);}
.req-row{display:grid; grid-template-columns:1fr 2fr; border-bottom:1px solid var(--border);}
.req-row:last-child{border-bottom:none;}
.req-row > div{padding:15px 22px;}
.req-row .rk{font-weight:600; font-size:14.5px; color:var(--ink); background:var(--bg);}
.req-row .rv{font-size:13.5px; color:var(--slate-600); font-family:var(--mono);}

/* help callout */
.help{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px; display:grid; grid-template-columns:1fr auto; gap:28px; align-items:center; box-shadow:var(--shadow-sm);}
.help h3{font-family:var(--display); font-size:22px; margin-bottom:8px;}
.help p{font-size:15px; color:var(--slate-600); max-width:620px;}
.help .help-cta{display:flex; gap:12px; flex-wrap:wrap;}

@media (max-width:1080px){
  .start-hero-inner{grid-template-columns:1fr;}
  .help{grid-template-columns:1fr;}
}

/* ---------- footer ---------- */
.footer{background:var(--navy-950); color:#9fadc6; padding:64px 0 36px;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px;}
.footer .brand{color:#fff; margin-bottom:14px;}
.footer p{font-size:14px; max-width:300px;}
.footer h5{font-family:var(--display); font-weight:600; font-size:14px; color:#fff; margin-bottom:14px; letter-spacing:0;}
.footer ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px;}
.footer ul a{font-size:14px; color:#9fadc6;}
.footer ul a:hover{color:#fff;}
.footer-base{border-top:1px solid rgba(255,255,255,.08); margin-top:48px; padding-top:24px; display:flex; justify-content:space-between; align-items:center; font-size:13px; color:#6b7c96;}
.footer-base .mono{font-family:var(--mono); letter-spacing:.04em;}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .hero-inner, .showcase-grid, .final-inner{grid-template-columns:1fr;}
  .hero-card{transform:none; margin-top:12px;}
  .mod-grid{grid-template-columns:repeat(3,1fr);}
  .final-cta{flex-direction:row; flex-wrap:wrap;}
  .price-grid{grid-template-columns:1fr;}
  .price-card.featured{transform:none;}
  .price-addon{flex-direction:column; align-items:flex-start;}
}
@media (max-width:820px){
  .pain-grid, .steps, .trust-grid{grid-template-columns:1fr;}
  .mod-grid{grid-template-columns:repeat(2,1fr);}
  .pd-kpis{grid-template-columns:repeat(3,1fr);}
  .pd-cols{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .crow{grid-template-columns:1fr;}
  .crow > div + div{border-left:none;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}

/* ---------- legal / prose pages ---------- */
.legal{padding:56px 0 84px; position:relative; overflow:hidden;}
.legal::before{
  content:''; position:absolute; inset:0; z-index:0;
  background:radial-gradient(760px 380px at 85% -12%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 60%);
  pointer-events:none;
}
.legal .wrap{position:relative; z-index:1; max-width:820px;}
.legal h1{font-size:clamp(30px,3.6vw,42px); margin-top:14px;}
.legal .updated{font-size:13px; color:var(--slate-500); margin-top:16px; font-family:var(--mono);}
.prose{margin-top:34px;}
.prose h2{font-size:22px; margin-top:36px;}
.prose h3{font-family:var(--display); font-size:17px; margin-top:24px;}
.prose p, .prose li{font-size:15.5px; color:var(--slate-600); line-height:1.7;}
.prose p{margin-top:12px;}
.prose ul{margin-top:12px; padding-left:22px;}
.prose li{margin-top:6px;}
.prose a{color:var(--accent-600); font-weight:600; text-decoration:underline; text-underline-offset:2px;}
.prose code{font-family:var(--mono); font-size:.88em; background:var(--bg-2); padding:2px 6px; border-radius:6px; border:1px solid var(--border); color:var(--navy-800);}
.prose .todo{
  background:var(--amber-bg); border:1px solid #f0d9b8; color:var(--amber-deep);
  border-radius:12px; padding:14px 18px; font-size:14px; margin-top:20px; line-height:1.6;
}
.prose .todo b{color:var(--amber-deep);}
