/* ===== BAADSONSFJORD — shared site stylesheet (SSOT for all pages) ===== */

/* Self-hosted brand fonts (urls relative to /assets/) */
@font-face{font-family:'Libre Baskerville';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/libre-baskerville-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Libre Baskerville';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/libre-baskerville-latin-ext-400-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Libre Baskerville';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/libre-baskerville-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Libre Baskerville';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/libre-baskerville-latin-ext-700-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url('fonts/manrope-latin-wght-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url('fonts/manrope-latin-ext-wght-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2C60-2C7F,U+A720-A7FF}

:root{
 --ink:#131b2b;--ink2:#1b2438;--ink3:#222f51;--panel:#19223a;
 --steel:#8fa0bc;--live:#a9c0f0;--mist:#e6e8eb;
 --text:#dfe4ee;--muted:#9aa6bd;--line:rgba(143,160,188,.16);--line2:rgba(143,160,188,.30);
 --mono:ui-monospace,"SF Mono","Menlo","Consolas",monospace;--maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Manrope',system-ui,sans-serif;background:var(--ink);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
h1,h2,h3{font-family:'Libre Baskerville',Georgia,serif;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.12}
a{color:inherit}
img{max-width:100%;display:block}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.22em;color:var(--steel);text-transform:uppercase}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.btn{display:inline-block;padding:13px 24px;border-radius:2px;font-size:13.5px;font-weight:600;letter-spacing:.03em;text-decoration:none;transition:.18s}
.btn-primary{background:var(--steel);color:var(--ink)}
.btn-primary:hover{background:var(--live)}
.btn-ghost{border:1px solid var(--line2);color:var(--text)}
.btn-ghost:hover{border-color:var(--steel);color:#fff}
.sec{padding:104px 0;border-top:1px solid var(--line)}
.sec-head{max-width:62ch}
.sec-head .eyebrow{display:block;margin-bottom:18px}
.sec-head h2{font-size:clamp(28px,3.3vw,40px)}
.lead{font-size:clamp(17px,1.5vw,20px);font-weight:300;color:#c3cad8;line-height:1.66}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:50;padding:20px 0;transition:.25s;border-bottom:1px solid transparent}
header.solid{background:rgba(15,21,38,.86);backdrop-filter:blur(10px);border-bottom-color:var(--line);padding:14px 0}
.hdr{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand img{height:24px}
.mainnav{display:flex;gap:30px;margin-left:auto}
.mainnav a{font-size:13.5px;font-weight:500;letter-spacing:.03em;color:var(--text);text-decoration:none;opacity:.86}
.mainnav a:hover{opacity:1;color:#fff}
.hdr-right{display:flex;align-items:center;gap:22px}
.lang{font-size:12px;letter-spacing:.08em;color:var(--muted)}
.lang b{color:#fff}.lang a{text-decoration:none;color:var(--muted)}.lang a:hover{color:var(--steel)}
.navtoggle{display:none;background:none;border:0;color:#fff;font-size:22px;cursor:pointer}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
 background-image:linear-gradient(90deg,rgba(15,21,38,.94),rgba(15,21,38,.72) 42%,rgba(15,21,38,.34)),linear-gradient(0deg,rgba(15,21,38,.92),rgba(15,21,38,0) 46%),url('img/towers-fog-duotone.webp');
 background-size:cover;background-position:center}
.hero .wrap{padding:150px 40px 64px;width:100%}
.hero h1{font-size:clamp(36px,5vw,64px);max-width:17ch;margin-top:24px;color:#fff}
.hero .sub{font-size:clamp(17px,1.5vw,20px);font-weight:300;color:#ccd3e1;max-width:56ch;margin-top:26px}
.hero .cta{display:flex;gap:20px;align-items:center;margin-top:38px;flex-wrap:wrap}
.howlink{color:var(--steel);text-decoration:none;font-size:14px;font-weight:600;letter-spacing:.03em}
.howlink:hover{color:var(--live)}

/* Single line */
.sld{margin-top:78px;border-top:1px solid var(--line);padding-top:28px}
.sldrow{display:flex;align-items:center;font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}
.node{width:9px;height:9px;border-radius:50%;background:var(--live);box-shadow:0 0 12px 3px rgba(169,192,240,.5);flex:0 0 auto}
.seg{height:1px;background:linear-gradient(90deg,var(--steel),var(--live));flex:1;margin:0 5px;transform-origin:left;animation:grow 1.1s ease forwards}
@keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.sld .pill{border:1px solid var(--steel);color:var(--mist);padding:8px 15px;border-radius:2px;font-size:11px;letter-spacing:.18em;white-space:nowrap}
.sld .label{padding:0 14px;white-space:nowrap}

/* Trust */
.trust{background:var(--ink2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;justify-content:space-between;gap:24px;padding:34px 40px;flex-wrap:wrap}
.trust .num{font-size:23px;font-weight:700;color:#fff;display:block;font-family:'Manrope';font-variant-numeric:tabular-nums}
.trust .lbl{font-size:12px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-top:6px;display:block}

/* Two-col */
.two{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.two p{color:#c3cad8;font-weight:300;font-size:16.5px;margin-top:14px}
.kicker{font-size:12px;letter-spacing:.2em;color:var(--steel);text-transform:uppercase;font-weight:600;margin-bottom:13px}
.two h3{font-size:26px;margin-bottom:2px}

/* Process */
.proc{display:grid;grid-template-columns:repeat(7,1fr);gap:0;margin-top:52px}
.step{position:relative;padding:0 16px 0 0}
.step .dot{width:11px;height:11px;border-radius:50%;background:var(--steel);position:relative;z-index:2}
.step.lit .dot{background:var(--live);box-shadow:0 0 10px 2px rgba(169,192,240,.55)}
.step .bar{position:absolute;top:5px;left:11px;right:0;height:1px;background:var(--line2)}
.step:last-child .bar{display:none}
.step .no{font-family:var(--mono);font-size:12px;color:var(--steel);margin-top:18px;letter-spacing:.06em}
.step .nm{font-size:14.5px;font-weight:600;color:#fff;margin-top:6px;line-height:1.3}

/* Services */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:48px;background:var(--line);border:1px solid var(--line)}
.svc .it{background:var(--ink);padding:26px 26px 30px}
.svc .it h4{font-family:'Manrope';font-size:15.5px;font-weight:600;color:#fff;line-height:1.35}
.svc .it.note{background:var(--ink2)}
.svc .it.note p{color:var(--muted);font-size:14px;font-weight:300;line-height:1.6}

/* Sectors */
.sect{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:48px}
.card{border:1px solid var(--line);background:var(--ink2);padding:24px 20px;border-radius:3px;transition:.2s;min-height:170px;display:flex;flex-direction:column;justify-content:space-between}
.card:hover{border-color:var(--steel);transform:translateY(-3px)}
.card .ic{width:26px;height:26px;margin-bottom:auto;opacity:.9}
.card h4{font-family:'Manrope';font-size:15px;font-weight:600;color:#fff;margin-top:16px;line-height:1.3}

/* Feature band */
.band{position:relative;padding:120px 0;border:0;
 background-image:linear-gradient(90deg,rgba(15,21,38,.93),rgba(15,21,38,.66)),url('img/storm-lightning-duotone.webp');
 background-size:cover;background-position:center}
.band .wrap{max-width:980px}
.band .eyebrow{display:block;margin-bottom:20px}
.band q{font-family:'Libre Baskerville',serif;font-weight:700;color:#fff;font-size:clamp(24px,3vw,38px);line-height:1.28;quotes:none}
.band .src{color:var(--steel);font-size:13px;letter-spacing:.04em;margin-top:24px;font-weight:500}

/* Advantages */
.adv{display:grid;grid-template-columns:repeat(3,1fr);gap:28px 40px;margin-top:50px}
.adv .a{border-top:1px solid var(--line2);padding-top:18px}
.adv .a .n{font-family:var(--mono);font-size:12px;color:var(--steel)}
.adv .a p{font-size:15.5px;color:var(--text);font-weight:400;margin-top:10px;line-height:1.45}

/* Technical */
.tech{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;margin-top:48px;align-items:start}
.spec{border:1px solid var(--line);border-radius:3px;overflow:hidden}
.spec .r{display:flex;justify-content:space-between;gap:16px;padding:14px 22px;border-bottom:1px solid var(--line);font-size:14px}
.spec .r:last-child{border-bottom:0}
.spec .r .k{color:var(--muted)}
.spec .r .v{color:#fff;font-family:var(--mono);font-size:13px;text-align:right}
.tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.tag{font-family:var(--mono);font-size:12px;color:var(--steel);border:1px solid var(--line2);border-radius:2px;padding:6px 11px;letter-spacing:.04em}
.techtext p{color:#c3cad8;font-weight:300;font-size:16.5px;margin-top:16px}

/* Mission */
.mission{text-align:center}
.mission .wrap{max-width:920px}
.mission h2{font-size:clamp(26px,3vw,40px);margin:18px 0 26px}
.mission p{font-size:clamp(17px,1.6vw,20px);font-weight:300;color:#c8cfdd;line-height:1.7}

/* Contact */
.contact{background:var(--ink2);border-top:1px solid var(--line)}
.cwrap{display:grid;grid-template-columns:1fr 1fr;gap:72px}
.contact h2{font-size:clamp(28px,3.2vw,40px)}
.contact .lead{margin-top:16px;max-width:46ch}
.ceos{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:34px}
.ceo{border:1px solid var(--line);border-radius:3px;padding:22px}
.ceo .nm{font-weight:600;color:#fff;font-size:16px}
.ceo .role{color:var(--steel);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;margin-top:3px}
.ceo a{display:block;color:var(--text);text-decoration:none;font-size:14px;margin-top:12px;font-family:var(--mono)}
.ceo a:hover{color:var(--steel)}
form .f{margin-bottom:16px}
form label{display:block;font-size:12.5px;letter-spacing:.04em;color:var(--muted);margin-bottom:7px}
form input,form select,form textarea{width:100%;background:var(--ink);border:1px solid var(--line2);border-radius:2px;color:#fff;font-family:'Manrope';font-size:15px;padding:12px 14px}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--steel)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted);font-weight:300}
.consent input{width:auto;margin-top:3px}
form button{margin-top:8px;width:100%;cursor:pointer;border:0}

/* Footer */
footer{background:#0f1626;border-top:1px solid var(--line);padding:64px 0 40px}
.fgrid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.fbrand img{height:30px;margin-bottom:16px}
.fbrand p{color:var(--muted);font-size:13.5px;font-weight:300;max-width:34ch;line-height:1.6}
.fnav{display:flex;gap:64px}
.fcol h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--steel);margin-bottom:14px;font-weight:600}
.fcol a{display:block;color:var(--text);opacity:.8;text-decoration:none;font-size:14px;margin-bottom:9px}
.fcol a:hover{opacity:1;color:#fff}
.fbar{display:flex;justify-content:space-between;gap:16px;margin-top:48px;padding-top:22px;border-top:1px solid var(--line);color:var(--muted);font-size:12.5px;flex-wrap:wrap}
.fbar a{color:var(--muted);text-decoration:none}.fbar a:hover{color:var(--steel)}

/* Reveal */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}

/* Legal pages */
.legal{padding:148px 0 96px}
.legal .wrap{max-width:880px}
.legal h1{font-size:clamp(30px,4vw,46px);margin-bottom:10px}
.legal .updated{color:var(--muted);font-size:13px;font-family:var(--mono);margin-bottom:8px}
.legal .intro{color:#c3cad8;font-weight:300;font-size:17px;line-height:1.7;margin:18px 0 30px}
.legal h2{font-size:21px;margin:40px 0 12px;color:#fff;font-family:'Libre Baskerville',serif}
.legal h3{font-size:16px;margin:24px 0 8px;font-family:'Manrope';color:#fff;font-weight:600}
.legal p,.legal li{color:#c3cad8;font-weight:300;font-size:15.5px;line-height:1.72;margin-bottom:12px}
.legal ul{padding-left:20px;margin-bottom:16px}
.legal a{color:var(--steel);text-decoration:underline}
.legal .ph{background:rgba(143,160,188,.12);border:1px dashed var(--line2);border-radius:3px;padding:1px 7px;color:var(--steel);font-family:var(--mono);font-size:13px}
.legal .box{border:1px solid var(--line);border-radius:4px;padding:20px 24px;margin:18px 0;background:var(--ink2)}
.legal .note{border-left:2px solid var(--steel);padding:6px 0 6px 16px;margin:22px 0;color:var(--muted);font-size:14px}
.legal table{width:100%;border-collapse:collapse;margin:14px 0 20px}
.legal td{border:1px solid var(--line);padding:11px 14px;font-size:14.5px;color:#c3cad8;font-weight:300;vertical-align:top}
.legal td:first-child{color:#fff;width:34%;font-weight:500}

/* Form + thank-you utilities (hoisted from inline styles — keeps site.css the single style source) */
.hp{position:absolute;left:-9999px}
.ts-slot{margin:2px 0 16px}
.consent a{color:var(--steel)}
#about .eyebrow{margin-bottom:16px}
#about h2{font-size:clamp(26px,3vw,38px)}
#about .two p{margin-top:6px}
.ty{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px}
.ty .inner{max-width:560px}
.ty img{height:30px;margin:0 auto 40px}
.ty h1{font-size:clamp(30px,4vw,46px);margin-bottom:18px}
.ty p{color:#c3cad8;font-weight:300;font-size:18px;line-height:1.6;margin-bottom:34px}

/* ===== Chinese (zh-Hans) — system CJK font stack; zero third-party requests, GDPR-clean.
   The brand Latin webfonts are unicode-range-limited to Latin, so CJK glyphs fall through here. ===== */
html[lang="zh-Hans"] body,
html[lang="zh-Hans"] .trust .num,
html[lang="zh-Hans"] .svc .it h4,
html[lang="zh-Hans"] .card h4,
html[lang="zh-Hans"] .sldrow,
html[lang="zh-Hans"] form input,
html[lang="zh-Hans"] form select,
html[lang="zh-Hans"] form textarea{
 font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei","Noto Sans CJK SC","Noto Sans SC",system-ui,sans-serif;
}
html[lang="zh-Hans"] h1,
html[lang="zh-Hans"] h2,
html[lang="zh-Hans"] h3,
html[lang="zh-Hans"] .band q{
 font-family:"Songti SC","STSong","Noto Serif CJK SC","Noto Serif SC",Georgia,serif;
 letter-spacing:0;
}
html[lang="zh-Hans"] .eyebrow,
html[lang="zh-Hans"] .kicker,
html[lang="zh-Hans"] .trust .lbl,
html[lang="zh-Hans"] .fcol h5,
html[lang="zh-Hans"] .ceo .role,
html[lang="zh-Hans"] .sldrow{letter-spacing:.06em}

/* Responsive */
@media(max-width:980px){
 .two,.tech,.cwrap{grid-template-columns:1fr;gap:40px}
 .svc{grid-template-columns:repeat(2,1fr)}
 .adv{grid-template-columns:1fr 1fr}
 .sect{grid-template-columns:repeat(2,1fr)}
 .proc{grid-template-columns:repeat(2,1fr);gap:26px 16px}
 .step .bar{display:none}
}
@media(max-width:680px){
 .wrap{padding:0 22px}.hero .wrap{padding:120px 22px 56px}
 .mainnav,.hdr-right .lang{display:none}.navtoggle{display:block}
 .sec{padding:72px 0}.legal{padding:120px 0 72px}
 .svc,.sect,.adv,.frow,.ceos{grid-template-columns:1fr}
 .proc{grid-template-columns:1fr}
 .trust .wrap{gap:20px}
 .sldrow{flex-wrap:wrap;gap:8px}.seg{min-width:22px}
 .fnav{gap:36px}.legal td:first-child{width:42%}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.js .reveal{opacity:1;transform:none}}
