/* Infraschild · Clarity — shared stylesheet for the website */
:root{
  --paper:#F7F6F2; --card:#FFFFFF; --ink:#15171C; --muted:#6B6E76;
  --accent:#1F3DFF; --accent-soft:#E9ECFF; --hair:#E5E3DB;
  --crit:#E0392B; --high:#E8862B; --med:#C9A227; --ok:#1E8E5A;
  --font-display:"Schibsted Grotesk",sans-serif;
  --font-body:"Hanken Grotesk",sans-serif;
  --font-mono:"IBM Plex Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--font-body);line-height:1.5}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px}
.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-size:12px}

/* nav */
nav{position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--paper) 86%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--hair)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em}
.brand svg{width:22px;height:26px;display:block}
.nav-links{display:flex;align-items:center;gap:34px;margin-right:auto;margin-left:14px}
.nav-links a{font-size:15px;color:var(--muted);font-weight:500;transition:color .15s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-26px;height:2px;background:var(--accent)}
.nav-right{display:flex;align-items:center;gap:14px}
.lang{display:flex;border:1px solid var(--hair);border-radius:8px;overflow:hidden;font-family:var(--font-mono);font-size:12px;font-weight:500}
.lang button{background:transparent;border:none;padding:7px 11px;cursor:pointer;color:var(--muted);font:inherit;transition:background .15s,color .15s}
.lang button.active{background:var(--ink);color:#fff}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:46px;padding:0 22px;border-radius:9px;font-family:var(--font-display);font-weight:600;font-size:15px;cursor:pointer;border:1px solid transparent;white-space:nowrap;transition:transform .12s,background .15s,box-shadow .15s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(31,61,255,.25)}
.btn-primary:hover{background:#1733e6}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--hair)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:#eee}
.nav .btn{height:42px}

/* landing hero */
.hero{padding:84px 0 76px;border-bottom:1px solid var(--hair)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.eyebrow{color:var(--accent);margin-bottom:22px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent)}
h1{font-family:var(--font-display);font-weight:800;font-size:clamp(40px,5vw,62px);line-height:1.02;letter-spacing:-.025em;margin-bottom:24px}
h1 em{font-style:normal;color:var(--accent)}
.lede{font-size:19px;color:var(--muted);max-width:34ch;margin-bottom:34px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.meta-strip{display:flex;gap:30px;margin-top:46px;padding-top:26px;border-top:1px solid var(--hair)}
.meta-strip .m{display:flex;flex-direction:column;gap:3px}
.meta-strip b{font-family:var(--font-display);font-size:22px;font-weight:700}
.meta-strip span{font-size:13px;color:var(--muted)}

/* report card */
.report{background:var(--card);border:1px solid var(--hair);border-radius:16px;box-shadow:0 24px 60px -28px rgba(20,30,80,.22);overflow:hidden}
.rep-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--hair)}
.rep-head .t{font-family:var(--font-display);font-weight:600;font-size:15px}
.rep-head .d{color:var(--muted)}
.rep-body{display:grid;grid-template-columns:auto 1fr;gap:26px;padding:24px 22px;align-items:center}
.ring{--p:72;position:relative;width:132px;height:132px;border-radius:50%;
  background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--hair) 0);display:grid;place-items:center}
.ring::after{content:"";position:absolute;inset:13px;background:var(--card);border-radius:50%}
.ring .v{position:relative;text-align:center}
.ring .v b{font-family:var(--font-display);font-size:34px;font-weight:800;letter-spacing:-.02em}
.ring .v span{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.find{display:flex;flex-direction:column;gap:13px}
.row{display:flex;align-items:center;gap:11px;font-size:14px}
.dot{width:8px;height:8px;border-radius:50%;flex:none}
.row .lbl{flex:1;color:var(--ink)}
.sev{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;padding:3px 7px;border-radius:5px;font-weight:500}
.rep-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid var(--hair);color:var(--muted)}
.rep-foot a{color:var(--accent);font-weight:600;font-family:var(--font-display)}

/* subpage hero */
.subhero{padding:70px 0 54px;border-bottom:1px solid var(--hair)}
.subhero .eyebrow{margin-bottom:20px}
.subhero h1{font-size:clamp(36px,4.4vw,54px);max-width:18ch}
.subhero .lede{font-size:19px;max-width:56ch;margin-bottom:0;margin-top:18px}

/* section heads */
.features{padding:90px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:54px;gap:30px;flex-wrap:wrap}
.sec-head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3.4vw,40px);letter-spacing:-.02em;line-height:1.05;max-width:20ch}
.sec-head p{color:var(--muted);font-size:16px;max-width:34ch}

/* feature grid (home) */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--hair)}
.feat{padding:38px 38px 38px 0;border-bottom:1px solid var(--hair)}
.feat:nth-child(odd){padding-right:48px;border-right:1px solid var(--hair)}
.feat:nth-child(even){padding-left:48px}
.feat .n{font-family:var(--font-mono);color:var(--accent);font-size:13px;margin-bottom:18px}
.feat h3{font-family:var(--font-display);font-weight:600;font-size:21px;letter-spacing:-.01em;margin-bottom:10px}
.feat p{color:var(--muted);font-size:15.5px;max-width:42ch}

/* steps (produkt) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;padding:30px;border:1px solid var(--hair);border-radius:16px;background:var(--card)}
.step .sn{font-family:var(--font-mono);font-size:13px;color:var(--accent);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.step .sn::after{content:"";flex:1;height:1px;background:var(--hair)}
.step h3{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.01em;margin-bottom:9px}
.step p{color:var(--muted);font-size:15px}

/* flow rows (produkt) */
.flow{display:flex;flex-direction:column;gap:0;margin-top:8px}
.flow-row{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:26px 0;border-top:1px solid var(--hair);align-items:start}
.flow-row .fn{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--accent);letter-spacing:-.02em;line-height:1}
.flow-row h3{font-family:var(--font-display);font-weight:600;font-size:19px;margin-bottom:7px}
.flow-row p{color:var(--muted);font-size:15.5px;max-width:62ch}
.flow-row code{font-family:var(--font-mono);font-size:.86em;background:#EFEDE6;padding:1px 6px;border-radius:4px}

/* coverage grid (abdeckung) */
.cov-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.cov{border:1px solid var(--hair);border-radius:16px;padding:28px;background:var(--card)}
.cov .ic{width:34px;height:34px;border-radius:9px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:16px}
.cov .ic svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:1.7}
.cov h3{font-family:var(--font-display);font-weight:600;font-size:18px;margin-bottom:6px}
.cov .desc{color:var(--muted);font-size:14px;margin-bottom:16px}
.cov ul{list-style:none;display:flex;flex-wrap:wrap;gap:7px}
.cov ul li{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.02em;color:var(--ink);background:#F2F1EB;border:1px solid var(--hair);padding:4px 9px;border-radius:6px}

/* framework strip */
.fw{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:26px 30px;border:1px solid var(--hair);border-radius:14px;background:var(--card);margin-top:24px}
.fw .lab{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.fw .items{display:flex;gap:10px;flex-wrap:wrap}
.fw .items span{font-family:var(--font-display);font-weight:600;font-size:15px;padding:6px 14px;border:1px solid var(--hair);border-radius:30px}

/* pricing tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.tier{border:1px solid var(--hair);border-radius:18px;background:var(--card);padding:30px 28px;display:flex;flex-direction:column;gap:18px}
.tier.feature{border-color:var(--accent);box-shadow:0 24px 60px -34px rgba(31,61,255,.4);position:relative}
.tier .badge{position:absolute;top:-12px;left:28px;background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:30px}
.tier .tname{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.01em}
.tier .ttag{color:var(--muted);font-size:14px;margin-top:-10px}
.tier .price{font-family:var(--font-display);font-weight:800;font-size:30px;letter-spacing:-.02em;line-height:1.1}
.tier .price small{display:block;font-family:var(--font-body);font-weight:500;font-size:13px;color:var(--muted);letter-spacing:0;margin-top:5px}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:11px;border-top:1px solid var(--hair);padding-top:18px}
.tier ul li{display:flex;gap:10px;font-size:14.5px;color:#33363d;line-height:1.45}
.tier ul li::before{content:"";flex:none;width:16px;height:16px;margin-top:2px;border-radius:50%;background:var(--accent-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4 8.4 6.7 11l5.3-6' stroke='%231F3DFF' stroke-width='1.7' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.tier .btn{width:100%;margin-top:auto}
.price-note{text-align:center;color:var(--muted);font-size:13px;margin-top:22px}

/* contact */
.contact{background:var(--ink);color:#fff;border-radius:20px;padding:54px 50px;display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;position:relative;overflow:hidden}
.contact::after{content:"";position:absolute;right:-90px;top:-90px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(31,61,255,.5),transparent 65%)}
.contact h2{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3vw,38px);letter-spacing:-.02em;line-height:1.05;position:relative}
.contact p{color:#c4c7cf;margin-top:14px;position:relative;max-width:42ch}
.contact .cbox{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:24px}
.contact .cbox .k{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9fb0ff;margin-bottom:6px}
.contact .cbox .v{font-family:var(--font-display);font-weight:600;font-size:18px;margin-bottom:18px;word-break:break-word}
.contact .cbox .btn{width:100%}

/* cta band */
.cta{padding:88px 0}
.cta-card{background:var(--ink);color:#fff;border-radius:20px;padding:64px 56px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-card::after{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(31,61,255,.55),transparent 65%)}
.cta-card h2{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,3.6vw,42px);letter-spacing:-.02em;line-height:1.05;max-width:18ch;position:relative}
.cta-card .btn-light{position:relative}

/* generic section divider */
.sec{padding:84px 0;border-top:1px solid var(--hair)}
.sec-title{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,3.2vw,38px);letter-spacing:-.02em;margin-bottom:14px;max-width:22ch}
.sec-intro{color:var(--muted);font-size:17px;max-width:60ch;margin-bottom:44px}

footer{border-top:1px solid var(--hair);padding:46px 0 40px}
.foot-in{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-links{display:flex;gap:28px;flex-wrap:wrap}
.foot-links a{font-size:14px;color:var(--muted)}
.foot-links a:hover{color:var(--ink)}
.foot-meta{color:var(--muted);font-size:13px;text-align:right}

@media(max-width:880px){
  .wrap{padding:0 24px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .nav-links{display:none}
  .feat-grid{grid-template-columns:1fr}
  .feat,.feat:nth-child(odd){padding:30px 0;border-right:none}
  .feat:nth-child(even){padding:30px 0}
  .steps{grid-template-columns:1fr}
  .cov-grid{grid-template-columns:1fr}
  .tiers{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr;padding:40px 28px}
  .cta-card{padding:44px 30px}
}
