:root{
  --white:#FFFFFF;--ink:#1a1f24;--slate:#5C7C89;--teal:#1F4959;--midnight:#011425;
  --paper:#f5f8f9;--line:#e4eaec;--gold:#c9a96a;
  --serif:'Georgia','Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;justify-content:space-between;align-items:center;padding:22px 48px;transition:background .4s,padding .4s}
nav.scrolled{background:rgba(1,20,37,0.95);padding:14px 48px;backdrop-filter:blur(10px)}
.brand{font-family:var(--serif);color:var(--white);font-size:21px;letter-spacing:2px;font-weight:500;text-decoration:none;z-index:210}
.brand small{display:block;font-size:9px;letter-spacing:5px;color:var(--slate);margin-top:2px}
.nav-right{display:flex;align-items:center;gap:22px;z-index:210}
.lang{display:flex;gap:2px;align-items:center;background:rgba(255,255,255,0.12);border-radius:30px;padding:3px}
.lang button{background:none;border:none;color:var(--white);font-family:var(--sans);font-size:12px;letter-spacing:1px;padding:6px 13px;border-radius:30px;cursor:pointer;opacity:.6;transition:.3s}
.lang button.active{background:var(--white);color:var(--midnight);opacity:1}
.burger{width:42px;height:42px;border:none;background:rgba(255,255,255,0.1);border-radius:50%;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;transition:.3s}
.burger:hover{background:rgba(255,255,255,0.2)}
.burger span{display:block;width:18px;height:1.5px;background:#fff;transition:.35s}
body.menu-open .burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ---------- MENU OVERLAY ---------- */
.menu-overlay{position:fixed;inset:0;z-index:190;background:linear-gradient(165deg,#011425,#06243a 70%,#1F4959);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s}
body.menu-open .menu-overlay{opacity:1;visibility:visible}
.menu-overlay a{font-family:var(--serif);color:#fff;font-size:clamp(30px,6vw,52px);text-decoration:none;font-weight:400;letter-spacing:1px;
  padding:8px 0;position:relative;opacity:0;transform:translateY(20px);transition:color .3s}
body.menu-open .menu-overlay a{opacity:1;transform:translateY(0)}
body.menu-open .menu-overlay a:nth-child(1){transition:opacity .5s .15s,transform .5s .15s,color .3s}
body.menu-open .menu-overlay a:nth-child(2){transition:opacity .5s .22s,transform .5s .22s,color .3s}
body.menu-open .menu-overlay a:nth-child(3){transition:opacity .5s .29s,transform .5s .29s,color .3s}
body.menu-open .menu-overlay a:nth-child(4){transition:opacity .5s .36s,transform .5s .36s,color .3s}
body.menu-open .menu-overlay a:nth-child(5){transition:opacity .5s .43s,transform .5s .43s,color .3s}
body.menu-open .menu-overlay a:nth-child(6){transition:opacity .5s .50s,transform .5s .50s,color .3s}
.menu-overlay a:hover{color:var(--gold)}
.menu-overlay a .idx{font-family:var(--sans);font-size:13px;color:var(--slate);letter-spacing:2px;position:absolute;left:-34px;top:50%;transform:translateY(-50%)}
.menu-foot{position:absolute;bottom:42px;color:rgba(255,255,255,0.5);font-size:13px;letter-spacing:1px;text-align:center}
.menu-foot a{font-size:13px;color:var(--slate);font-family:var(--sans);display:inline;letter-spacing:1px}

/* ---------- HERO (home) ---------- */
.hero{min-height:100vh;background:linear-gradient(165deg,#011425 0%,#06243a 55%,#1F4959 135%);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:120px 24px 90px;position:relative;overflow:hidden}
.arch{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:540px;height:700px;max-width:90vw;border-radius:270px 270px 0 0;border:1px solid rgba(92,124,137,0.22);pointer-events:none}
.arch:before{content:"";position:absolute;top:64px;left:50%;transform:translateX(-50%);width:60%;height:78%;border-radius:170px 170px 0 0;border:1px solid rgba(92,124,137,0.16)}
.hero-content{position:relative;z-index:2;max-width:820px}
.eyebrow{color:var(--slate);font-size:13px;letter-spacing:5px;text-transform:uppercase;margin-bottom:28px;opacity:0;animation:fadeUp .8s .1s forwards}
.hero h1{font-family:var(--serif);color:var(--white);font-weight:400;font-size:clamp(34px,5.6vw,62px);line-height:1.14;letter-spacing:.5px;margin-bottom:26px;opacity:0;animation:fadeUp .8s .25s forwards}
.hero p{color:rgba(255,255,255,0.72);font-size:clamp(16px,2vw,20px);max-width:580px;margin:0 auto 40px;font-weight:300;opacity:0;animation:fadeUp .8s .4s forwards}
.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .8s .55s forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.eyebrow,.hero h1,.hero p,.cta-row{transform:translateY(24px)}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.4);font-size:12px;letter-spacing:2px;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeUp .8s 1s forwards}
.scroll-cue .dot{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,0.5),transparent)}

/* ---------- PAGE HERO (sub-pages) ---------- */
.page-hero{background:linear-gradient(165deg,#011425 0%,#06243a 55%,#1F4959 135%);padding:160px 48px 80px;text-align:center;position:relative;overflow:hidden}
.page-hero .arch{height:400px;width:340px}
.page-hero .hero-content{position:relative;z-index:2}
.page-hero .eyebrow{opacity:0;animation:fadeUp .8s .1s forwards;transform:translateY(24px)}
.page-hero h1{font-family:var(--serif);color:var(--white);font-weight:400;font-size:clamp(28px,4.5vw,48px);line-height:1.18;letter-spacing:.5px;margin-bottom:18px;opacity:0;animation:fadeUp .8s .25s forwards;transform:translateY(24px)}
.page-hero p{color:rgba(255,255,255,0.72);font-size:clamp(15px,1.8vw,19px);max-width:560px;margin:0 auto;font-weight:300;opacity:0;animation:fadeUp .8s .4s forwards;transform:translateY(24px)}

/* ---------- BUTTONS ---------- */
.btn{font-family:var(--sans);font-size:14px;letter-spacing:1px;padding:15px 34px;border-radius:2px;cursor:pointer;text-decoration:none;display:inline-block;transition:.3s;border:1px solid transparent}
.btn-primary{background:var(--white);color:var(--midnight)}
.btn-primary:hover{background:var(--gold);color:var(--midnight)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.4)}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,0.08)}
.btn-teal{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn-teal:hover{background:#17384a}

/* ---------- SECTIONS ---------- */
section{padding:120px 48px}
.wrap{max-width:1100px;margin:0 auto}
.sec-label{color:var(--slate);font-size:12px;letter-spacing:4px;text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:12px}
.sec-label:before{content:"";width:28px;height:1px;background:var(--gold)}
.sec-title{font-family:var(--serif);font-weight:400;font-size:clamp(28px,4vw,44px);color:var(--midnight);line-height:1.18;margin-bottom:24px;max-width:720px}
.sec-lead{font-size:18px;color:#46575f;max-width:640px;font-weight:300}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:translateY(0)}

.intro{text-align:center}
.intro .sec-label{justify-content:center}.intro .sec-label:before{display:none}
.intro .sec-title{margin:0 auto 24px}.intro .sec-lead{margin:0 auto}

/* ---------- SERVICES ---------- */
.services{background:var(--paper)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:36px;transition:transform .35s,box-shadow .35s}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 28px 56px -34px rgba(1,20,37,0.55)}
.svc-card .num{font-family:var(--serif);color:var(--gold);font-size:15px;letter-spacing:2px;margin-bottom:20px}
.svc-card h3{font-size:20px;color:var(--midnight);margin-bottom:12px;font-weight:600}
.svc-card p{font-size:14.5px;color:#62727a;font-weight:300}

/* ---------- SPOTLIGHT / KLARTEXT ---------- */
.spotlight{background:var(--white)}
.spot-badge{display:inline-block;background:var(--teal);color:#fff;font-size:11px;letter-spacing:2px;padding:6px 13px;border-radius:2px;margin-bottom:22px}
.prod-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;margin-top:40px}
.prod-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:34px}
.doc-line{height:9px;background:#dde5e8;border-radius:5px;margin:10px 0}
.doc-line.s{width:60%}.doc-line.m{width:85%}
.arrow-down{text-align:center;color:var(--gold);font-size:22px;margin:14px 0}
.explain{background:#fff;border:1px solid var(--line);border-left:3px solid var(--teal);border-radius:4px;padding:16px 18px;font-size:14px;color:#3a4b53}
.explain b{color:var(--midnight)}
.feature-list{list-style:none}
.feature-list li{padding:16px 0;border-bottom:1px solid var(--line);display:flex;gap:16px;align-items:flex-start}
.feature-list li:last-child{border-bottom:none}
.feature-list .n{font-family:var(--serif);color:var(--gold);font-size:15px;min-width:26px}
.feature-list h4{font-size:16px;color:var(--midnight);margin-bottom:3px}
.feature-list p{font-size:14px;color:#62727a;font-weight:300}

/* ---------- DEMO ---------- */
.demo{background:var(--paper);text-align:center}
.demo .sec-label{justify-content:center}.demo .sec-label:before{display:none}
.demo .sec-title{margin:0 auto 24px}.demo .sec-lead{margin:0 auto 40px}
.demo-box{max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:12px;padding:32px;text-align:left;box-shadow:0 30px 60px -40px rgba(1,20,37,0.4)}
#kl-drop{border:2px dashed #c2ccd1;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:.3s;background:var(--paper)}
#kl-drop:hover{border-color:var(--teal);background:#fafcfc}
#kl-drop .icon{font-size:30px;margin-bottom:10px}
#kl-drop p{font-size:15px;color:var(--midnight);margin-bottom:4px}
#kl-drop span{font-size:13px;color:#7e8c93}
.demo-hint{font-size:13px;color:#7e8c93;text-align:center;margin-top:14px}
#kl-loading{display:none;text-align:center;padding:30px}
.spinner{width:34px;height:34px;border:3px solid #dde4e7;border-top-color:var(--teal);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}
#kl-result{margin-top:4px}
.lang-select{margin-top:16px}
.lang-select select{width:100%;padding:10px;border:1px solid var(--line);border-radius:6px;font-size:14px;font-family:var(--sans)}

/* ---------- APPROACH / STEPS ---------- */
.approach .step-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:46px;margin-top:54px}
.step .num{font-family:var(--serif);font-size:44px;color:var(--line);line-height:1;margin-bottom:16px}
.step h4{font-size:18px;color:var(--midnight);margin-bottom:8px}
.step p{font-size:14px;color:#62727a;font-weight:300}

/* ---------- GRANT BOX ---------- */
.grant-box{max-width:580px;margin:54px auto 0;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:32px;text-align:center}
.grant-box .label{font-size:12px;letter-spacing:3px;color:var(--slate);text-transform:uppercase;margin-bottom:16px}
.grant-nums{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;margin-bottom:16px}
.grant-nums .item .big{font-family:var(--serif);font-size:32px;color:var(--teal);font-weight:400}
.grant-nums .item.gold .big{color:var(--gold)}
.grant-nums .item .sub{font-size:13px;color:var(--slate)}
.grant-box .note{font-size:14px;color:#62727a;font-weight:300}

/* ---------- GRANT TABLE ---------- */
.grant-table{width:100%;border-collapse:collapse;margin-top:40px}
.grant-table th{background:var(--midnight);color:#fff;font-size:13px;letter-spacing:1px;text-transform:uppercase;padding:14px 20px;text-align:left;font-weight:500}
.grant-table td{padding:14px 20px;border-bottom:1px solid var(--line);font-size:15px;color:#3a4b53}
.grant-table tr:nth-child(even) td{background:var(--paper)}
.grant-table .check{color:#2d7d5a;font-weight:700}
.grant-table .cross{color:#c0392b;font-weight:700}

/* ---------- HOME PREVIEW CARDS ---------- */
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.preview-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:36px;transition:transform .35s,box-shadow .35s;text-decoration:none;color:inherit}
.preview-card:hover{transform:translateY(-6px);box-shadow:0 28px 56px -34px rgba(1,20,37,0.55)}
.preview-card .num{font-family:var(--serif);color:var(--gold);font-size:15px;letter-spacing:2px;margin-bottom:20px}
.preview-card h3{font-size:20px;color:var(--midnight);margin-bottom:12px;font-weight:600}
.preview-card p{font-size:14.5px;color:#62727a;font-weight:300;margin-bottom:18px}
.preview-card .link{font-size:13px;color:var(--teal);letter-spacing:1px;font-weight:600}

/* ---------- ABOUT ---------- */
.about{background:var(--midnight);color:#fff}
.about .sec-label{color:var(--slate)}
.about .sec-title{color:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;margin-top:10px}
.about-lead{font-family:var(--serif);font-size:23px;line-height:1.5;color:#fff;font-weight:300}
.about-body p{color:rgba(255,255,255,0.72);font-size:16px;margin-bottom:18px;font-weight:300}
.about-body p b{color:#fff;font-weight:600}

/* ---------- CONTACT ---------- */
.contact{background:var(--white);text-align:center}
.contact .sec-label{justify-content:center}.contact .sec-label:before{display:none}
.contact .sec-title{margin:0 auto 20px}
.contact p{color:#46575f;font-weight:300;max-width:520px;margin:0 auto 36px;font-size:18px}
.contact .email{font-family:var(--serif);font-size:clamp(22px,3vw,32px);color:var(--teal);text-decoration:none;border-bottom:1px solid var(--gold);padding-bottom:4px;transition:.3s}
.contact .email:hover{color:var(--midnight)}

/* ---------- FOOTER ---------- */
footer{background:#01101e;color:rgba(255,255,255,0.5);padding:44px 48px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px}
footer .brand{font-size:16px}footer .brand small{letter-spacing:4px}
footer .fnav{display:flex;gap:22px}
footer a{color:rgba(255,255,255,0.6);text-decoration:none}footer a:hover{color:#fff}

/* ---------- RESPONSIVE ---------- */
@media(max-width:860px){
  nav{padding:18px 22px}
  section{padding:78px 24px}
  .page-hero{padding:130px 24px 60px}
  .svc-grid,.preview-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr;gap:40px}
  .approach .step-grid{grid-template-columns:1fr;gap:32px}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .grant-nums{gap:20px}
  footer{flex-direction:column;text-align:center}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}.eyebrow,.hero h1,.hero p,.cta-row,.page-hero .eyebrow,.page-hero h1,.page-hero p{opacity:1;transform:none}}
