/* =====================================================================
   SKH Company Profile — Frontend styles
   Design: full-viewport "one screen per menu" (desktop), graceful scroll
   on tablet/mobile. Brand: teal #0E8C74 + orange #F47A1F.
   ===================================================================== */
:root{
  --teal:#0E8C74; --teal-d:#0a6f5c; --teal-l:#14A085; --teal-bright:#28C8A4; --teal-vivid:#34D6B0;
  --orange:#F47A1F; --ink:#0A1F1C; --ink2:#0E1A18; --muted:#5C726D; --muted2:#6B7C77;
  --bg:#F6F9F8; --line:#E7EDEB; --card:#ffffff;
  --nav-h:74px;
  --maxw:1340px;
  --font:'Inter','Segoe UI',Arial,Helvetica,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:var(--font);color:var(--ink2);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.5;overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.orange{color:var(--orange)} .teal{color:var(--teal)}

/* ---------- App shell: nav fixed, content fills the rest, no page scroll ---------- */
.app{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}
.screen{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
/* Each page is auto-scaled by JS to fit one screen (no scroll, no clipping) */
.screen>.container{height:auto !important;width:100%;padding-top:14px !important;padding-bottom:14px !important}
.container{max-width:var(--maxw);margin:0 auto;padding:0 40px}

/* ---------- Top navigation ---------- */
.nav{height:var(--nav-h);display:flex;align-items:center;padding:0 40px;flex-shrink:0;
  background:#fff;border-bottom:1px solid var(--line);position:relative;z-index:60}
.nav.transparent{background:transparent;border-bottom:none;position:absolute;left:0;right:0;top:0}
.brand{display:flex;align-items:center;gap:14px}
.brand img{width:50px;height:50px}
.brand .bt{font-size:29px;font-weight:800;letter-spacing:.5px;color:var(--orange);line-height:1}
.brand .bs{font-size:10.5px;font-weight:700;letter-spacing:2.2px;color:var(--teal);display:block;margin-top:3px}
.nav.transparent .brand .bs{color:#9FD9CC}
.menu{display:flex;align-items:center;gap:30px;margin-left:auto}
.menu a.link{font-size:14.5px;font-weight:600;color:#42564F;letter-spacing:.2px;white-space:nowrap}
.menu a.link.on{color:var(--teal)}
.menu a.link:hover{color:var(--teal)}
.nav.transparent .menu a.link{color:#C4D6D1}
.nav.transparent .menu a.link.on,.nav.transparent .menu a.link:hover{color:#fff}
.langsw{display:flex;gap:2px;align-items:center;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.nav.transparent .langsw{border-color:rgba(255,255,255,.25)}
.langsw a{font-size:12px;font-weight:700;padding:6px 9px;color:var(--muted)}
.langsw a.on{background:var(--teal);color:#fff}
.nav.transparent .langsw a{color:#C4D6D1}
.nav.transparent .langsw a.on{background:var(--teal);color:#fff}
.cta{display:inline-block;background:linear-gradient(135deg,var(--teal-l),var(--teal));color:#fff;
  padding:11px 20px;border-radius:11px;font-size:14px;font-weight:700;
  box-shadow:0 10px 24px rgba(20,160,133,.30);border:none;cursor:pointer}
.cta:hover{filter:brightness(1.05)}
.btn-ghost{display:inline-block;padding:14px 24px;border:1.5px solid var(--line);border-radius:11px;font-weight:700;color:#2C4640}
.nav.transparent .btn-ghost{border-color:rgba(255,255,255,.3);color:#fff}
.hamburger{display:none;margin-left:auto;width:42px;height:42px;border:1px solid var(--line);border-radius:10px;
  background:transparent;cursor:pointer;align-items:center;justify-content:center}
.hamburger span{display:block;width:18px;height:2px;background:#2C4640;position:relative}
.hamburger span:before,.hamburger span:after{content:"";position:absolute;left:0;width:18px;height:2px;background:#2C4640}
.hamburger span:before{top:-6px}.hamburger span:after{top:6px}
.nav.transparent .hamburger span,.nav.transparent .hamburger span:before,.nav.transparent .hamburger span:after{background:#fff}
.nav.transparent .hamburger{border-color:rgba(255,255,255,.3)}

/* ---------- Common section bits ---------- */
.eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:2.6px;color:var(--teal);
  text-transform:uppercase;background:#E4F4EF;padding:7px 15px;border-radius:999px}
.eyebrow.ondark{background:rgba(40,200,164,.14);color:var(--teal-vivid)}
h1.title{font-size:33px;font-weight:800;line-height:1.06;color:var(--ink2);letter-spacing:-.6px}
.lead{font-size:14.5px;line-height:1.6;color:#46584F}
.dots{position:absolute;bottom:28px;left:40px;display:flex;gap:9px;z-index:30}
.dots span{width:9px;height:9px;border-radius:50%;background:#CBD8D4}
.dots span.on{background:var(--teal);width:26px;border-radius:6px}
.pageno{position:absolute;bottom:24px;right:40px;font-size:12.5px;font-weight:700;color:#9FB0AB;letter-spacing:1px;z-index:30}

/* ---------- HOME / HERO ---------- */
.hero{position:absolute;inset:0;overflow:hidden;background:var(--ink)}
.hero .bg-blur{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.12);filter:blur(24px) brightness(.5);z-index:0}
.hero .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,26,23,.95) 0%,rgba(8,26,23,.62) 46%,rgba(8,26,23,.35) 100%)}
.hero .hero-photo{position:absolute;right:5%;top:50%;transform:translateY(-50%);width:min(340px,28vw);max-height:72%;object-fit:contain;border-radius:16px;z-index:2;border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 80px rgba(0,0,0,.5)}
.hero .inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 40px;height:100%;display:flex;flex-direction:column;justify-content:center;color:#fff}
.hero h1{font-size:44px;font-weight:800;line-height:1.04;letter-spacing:-1px;margin:16px 0 0}
.hero p.sub{font-size:15px;line-height:1.6;color:#BFD3CD;margin-top:14px;max-width:560px}
.hero .actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero .stats{display:flex;gap:34px;margin-top:28px;flex-wrap:wrap}
.hero .stats .v{font-size:30px;font-weight:800;color:var(--teal-vivid)}
.hero .stats .l{font-size:13px;color:#9FB3AD;margin-top:2px}
.materials{position:absolute;left:0;right:0;bottom:58px;display:flex;align-items:center;justify-content:center;gap:16px;z-index:3}
.materials .lbl{color:#7E938D;font-size:13px;font-weight:700;letter-spacing:1px}
.materials .chip{background:#fff;border-radius:12px;padding:14px 26px;display:flex;align-items:center}
.materials .chip img{height:58px;width:auto}

/* ---------- ABOUT ---------- */
.split{display:flex;min-height:100%;width:100%}
.split .media{width:42%;position:relative}
.split .media img{width:100%;height:100%;object-fit:cover}
.split .media .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,31,28,.10) 40%,rgba(8,22,20,.82))}
.split .media .cap{position:absolute;left:40px;bottom:36px;color:#fff}
.split .media .cap .k{font-size:14px;font-weight:800;letter-spacing:1px;color:var(--teal-vivid)}
.split .media .cap .d{font-size:16px;color:#DCEAE6;max-width:380px;margin-top:6px;line-height:1.5}
.split .body{flex:1;display:flex;flex-direction:column;justify-content:center;padding:0 56px}
.about-cards{display:flex;gap:16px;margin-top:34px}
.about-cards .c{flex:1;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px}
.about-cards .c .ic{width:42px;height:42px;border-radius:11px;background:#E4F4EF;display:flex;align-items:center;justify-content:center;font-size:20px}
.about-cards .c.alt .ic{background:#FCEBDD}
.about-cards .c h4{font-size:16px;margin-top:14px;color:var(--ink2)}
.about-cards .c p{font-size:13.5px;color:var(--muted2);margin-top:5px;line-height:1.5}
.readmore{display:inline-block;margin-top:20px;color:var(--teal);font-weight:800;font-size:15px;
  border-bottom:2px solid var(--teal);padding-bottom:3px;cursor:pointer}

/* ---------- Read-more slide-in panel ---------- */
.overlay{position:fixed;inset:0;background:rgba(8,22,20,.55);z-index:200;opacity:0;visibility:hidden;transition:.25s}
.overlay.open{opacity:1;visibility:visible}
.panel{position:fixed;top:0;right:0;width:min(720px,92vw);height:100vh;height:100dvh;background:#fff;z-index:210;
  transform:translateX(100%);transition:transform .3s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column}
.panel.open{transform:translateX(0);box-shadow:-30px 0 80px rgba(8,22,20,.35)}
.panel .ph{padding:28px 48px 18px;border-bottom:1px solid #EEF2F1;flex-shrink:0}
.panel .ph .top{display:flex;align-items:center}
.panel .ph .x{margin-left:auto;width:40px;height:40px;border-radius:50%;background:#F1F5F4;border:none;
  display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--muted);cursor:pointer}
.panel .ph h2{font-size:26px;margin-top:14px;color:var(--ink2)}
.panel .pb{padding:24px 48px 30px;overflow-y:auto;flex:1}
.panel .pb p{font-size:15.5px;line-height:1.75;color:#46584F;margin-bottom:14px}
.panel .pf{padding:18px 48px;border-top:1px solid #EEF2F1;display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}
.methods{background:#F4F9F7;border:1px solid #E0EEE9;border-radius:14px;padding:18px 22px;margin:6px 0 16px}
.methods .t{font-weight:800;color:var(--teal);font-size:13px;letter-spacing:.5px}
.methods .chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.methods .chips span{background:#fff;border:1px solid #DDEAE6;border-radius:8px;padding:8px 14px;font-size:13.5px;font-weight:600;color:#2C4640}

/* ---------- SERVICES ---------- */
.sec-head{display:flex;align-items:flex-end;gap:30px}
.sec-head .sub{margin-left:auto;max-width:300px;font-size:13px;color:var(--muted2);line-height:1.55;padding-bottom:4px}
.cards3{display:flex;gap:16px;margin-top:18px}
.scard{flex:1;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 14px 34px rgba(10,31,28,.06)}
.scard .ph{height:116px;position:relative}
.scard .ph img{width:100%;height:116px;object-fit:cover}
.scard .ph .tag{position:absolute;left:14px;top:14px;background:rgba(8,22,20,.78);color:#fff;font-size:11px;font-weight:700;letter-spacing:1px;padding:6px 11px;border-radius:7px}
.scard .bd{padding:13px 18px 15px}
.scard .bd h3{font-size:16px;color:var(--ink2)}
.scard .bd p{font-size:13.5px;color:var(--muted2);line-height:1.55;margin-top:8px}
.scard .bd .rm{margin-top:13px;color:var(--teal);font-weight:800;font-size:13.5px;cursor:pointer}
.duo{display:flex;gap:16px;margin-top:14px}
.lapsbox{flex:2;background:linear-gradient(120deg,var(--teal),var(--ink));border-radius:16px;padding:18px 26px;color:#fff;position:relative;overflow:hidden}
.lapsbox h3{font-size:21px;margin-top:9px}
.lapsbox p{font-size:14px;color:#BFD3CD;margin-top:10px;max-width:560px;line-height:1.6}
.lapsbox .row{display:flex;gap:28px;margin-top:12px}
.lapsbox .row .v{font-size:26px;font-weight:800;color:var(--teal-vivid)}
.lapsbox .row .l{font-size:12.5px;color:#9FB3AD}
.autobox{flex:1;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 22px}
.autobox .new{font-size:12px;font-weight:800;letter-spacing:1.5px;color:var(--orange)}
.autobox h3{font-size:20px;margin-top:8px;color:var(--ink2)}
.autobox p{font-size:13.5px;color:var(--muted2);line-height:1.6;margin-top:8px}
.autobox a{display:inline-block;margin-top:14px;color:var(--teal);font-weight:800;font-size:13.5px}
/* Slim LAPS banner (Services page only) */
.laps-banner{margin-top:16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:linear-gradient(120deg,var(--teal),var(--ink));color:#fff;border-radius:14px;padding:14px 22px;text-decoration:none}
.laps-banner .lb-tag{font-size:10.5px;font-weight:800;letter-spacing:1.6px;color:var(--teal-vivid);background:rgba(40,200,164,.16);padding:5px 10px;border-radius:999px;white-space:nowrap}
.laps-banner .lb-title{font-weight:800;font-size:15.5px}
.laps-banner .lb-sep{opacity:.4}
.laps-banner .lb-auto{font-size:13px;color:#BFD3CD}
.laps-banner .lb-auto em{font-style:normal;font-size:10px;font-weight:800;letter-spacing:1px;color:var(--orange);margin-left:4px}
.laps-banner .lb-go{margin-left:auto;font-weight:800;font-size:14px;color:#fff;white-space:nowrap}
.laps-banner:hover{filter:brightness(1.06)}
@media (max-width:700px){.laps-banner .lb-go{margin-left:0}}

/* ---------- LAPS page ---------- */
.laps-grid{display:flex;gap:26px;align-items:center;height:100%}
.laps-grid .left{flex:1.1}
.laps-grid .right{flex:1;position:relative}
.laps-grid .right img{width:100%;border-radius:20px;box-shadow:0 24px 60px rgba(10,31,28,.18)}
.benefits{margin-top:24px}
.benefits .b{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.benefits .b .n{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.benefits .b p{font-size:15px;color:#3a4d47}
.autoband{margin-top:24px;background:#0a2a25;border-radius:16px;padding:22px 26px;color:#fff;display:flex;gap:18px;align-items:center}
.autoband .new{font-size:11px;font-weight:800;letter-spacing:1.5px;color:var(--orange)}
.autoband h4{font-size:20px;margin-top:4px}
.autoband p{font-size:13.5px;color:#BFD3CD;margin-top:6px;line-height:1.55}

/* ---------- PORTFOLIO ---------- */
.pfilter{margin-left:auto;display:flex;gap:7px;flex-wrap:wrap;padding-bottom:4px;justify-content:flex-end}
.pfilter .f{background:#fff;border:1px solid #E2EAE7;color:#46584F;font-size:12px;font-weight:600;padding:6px 12px;border-radius:8px;cursor:pointer}
.pfilter .f.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.pcard{position:relative;border-radius:14px;overflow:hidden;height:196px;cursor:pointer}
.pcard img{width:100%;height:100%;object-fit:cover;transition:.4s}
.pcard:hover img{transform:scale(1.06)}
.pcard .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,22,20,0) 38%,rgba(8,22,20,.85))}
.pcard .cat{position:absolute;left:14px;top:14px;background:rgba(244,122,31,.95);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:1px;padding:5px 10px;border-radius:6px}
.pcard .meta{position:absolute;left:16px;right:16px;bottom:14px;color:#fff}
.pcard .meta h4{font-size:16px;line-height:1.25}
.pcard .meta .vc{font-size:12px;color:#BFD3CD;margin-top:3px}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(6,18,16,.92);z-index:220;display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox .lb{max-width:920px;width:100%;background:#0f2a26;border-radius:18px;overflow:hidden;display:flex;max-height:86vh}
.lightbox .lb img{width:55%;object-fit:cover}
.lightbox .lb .info{flex:1;padding:34px;color:#DCEAE6;overflow:auto}
.lightbox .lb .info .cat{color:var(--teal-vivid);font-weight:700;font-size:12px;letter-spacing:1px}
.lightbox .lb .info h3{color:#fff;font-size:23px;margin:8px 0 12px}
.lightbox .lb .info p{font-size:14.5px;line-height:1.7;color:#AFC4BD}
.lightbox .x{position:absolute;top:24px;right:30px;color:#fff;font-size:30px;cursor:pointer;background:none;border:none}

/* ---------- PARTNERS ---------- */
.plogos{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-top:22px}
.plogo{flex:0 1 300px;max-width:320px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 24px;text-align:center;
  display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}
.plogo img{height:150px;width:auto;max-width:88%;object-fit:contain;margin-bottom:18px}
.plogo .nm{font-weight:800;color:var(--ink2);font-size:17px}
.plogo .ds{font-size:13px;color:var(--muted2);margin-top:6px;line-height:1.5}
a.plogo{text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
a.plogo:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(14,140,116,.18);border-color:var(--teal)}
.plogo .ph{height:150px;width:200px;background:#EDF3F1;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--teal);font-weight:800;font-size:30px;margin-bottom:18px}

/* ---------- TEAM ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 14px 34px rgba(10,31,28,.05)}
.tcard .ph{padding:22px 22px 2px;display:flex;justify-content:center;background:transparent}
.tcard .ph img{width:190px;height:190px;max-width:100%;object-fit:cover;border-radius:14px;background:#eef3f1}
.tcard .bd{padding:14px 22px 20px;text-align:center}
.tcard .bd .nm{font-size:18px;font-weight:800;color:var(--ink2)}
.tcard .bd .ro{font-size:13px;font-weight:700;color:var(--teal);margin-top:3px}
.tcard .bd .bio{font-size:13px;color:var(--muted2);line-height:1.55;margin-top:10px}

/* ---------- CONTACT ---------- */
.contact-grid{display:flex;gap:40px;height:100%;align-items:center}
.contact-grid .info{flex:1}
.contact-grid .formwrap{flex:1.05;background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:0 20px 50px rgba(10,31,28,.07)}
.cinfo-item{display:flex;gap:14px;margin-top:22px;align-items:flex-start}
.cinfo-item .ic{width:44px;height:44px;border-radius:12px;background:#E4F4EF;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.cinfo-item .k{font-size:12px;font-weight:700;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
.cinfo-item .v{font-size:15.5px;color:var(--ink2);margin-top:2px;line-height:1.5;white-space:pre-line}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;color:#2C4640;margin-bottom:6px}
.field input,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;font-size:14.5px;font-family:inherit;color:var(--ink2);background:#fbfdfc}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal)}
.field textarea{resize:vertical;min-height:96px}
.frow{display:flex;gap:14px}.frow .field{flex:1}
.alert{padding:12px 16px;border-radius:11px;font-size:14px;margin-bottom:16px}
.alert.ok{background:#E4F4EF;color:#0a6f5c;border:1px solid #BfE8DD}
.alert.err{background:#FCE9E6;color:#9b3024;border:1px solid #F3C9C2}

/* ---------- Footer strip (compact, inside viewport) ---------- */
/* (kept minimal; main info is on the contact screen) */

/* =====================================================================
   RESPONSIVE — relax the strict no-scroll on tablet & mobile
   ===================================================================== */
@media (max-width:1100px){
  h1.title,.hero h1{font-size:38px}
  .hero h1{font-size:44px}
  .split .body{padding:0 32px}
  .pgrid,.tgrid,.plogos{gap:16px}
}
@media (max-width:900px){
  body{overflow:auto}
  .app{height:auto;min-height:100vh}
  .screen{overflow:visible;display:block}
  .screen>.container{min-height:0}
  .menu{position:fixed;top:var(--nav-h);left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;
    gap:0;padding:10px 20px 20px;border-bottom:1px solid var(--line);box-shadow:0 20px 40px rgba(0,0,0,.08);
    transform:translateY(-130%);transition:.25s;z-index:55}
  .menu.open{transform:translateY(0)}
  .nav.transparent .menu{background:#0a201c}
  .menu a.link{padding:13px 4px;border-bottom:1px solid var(--line)}
  .nav.transparent .menu a.link{color:#cfe; border-color:rgba(255,255,255,.08)}
  .hamburger{display:flex}
  .cta.navcta{margin-top:10px;text-align:center}
  .langsw{margin-top:10px;width:max-content}
  .hero{position:relative;min-height:88vh}
  .hero .hero-photo{display:none}
  .hero .inner{padding:120px 24px 60px}
  .container{padding:0 24px}
  .split{flex-direction:column;height:auto;min-height:0}
  .split .media{width:100%;height:300px}
  .split .body{padding:40px 24px}
  .cards3,.duo,.contact-grid,.laps-grid{flex-direction:column}
  .pgrid,.tgrid{grid-template-columns:repeat(2,1fr)}
  .plogos{grid-template-columns:repeat(2,1fr)}
  .pcard{height:220px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:12px}
  .sec-head .sub{margin-left:0}
  .materials{position:static;margin-top:30px;flex-wrap:wrap}
  .dots{display:none}.pageno{display:none}
  .screen{padding:40px 0}
  .lightbox .lb{flex-direction:column;max-height:90vh;overflow:auto}
  .lightbox .lb img{width:100%;height:240px}
}
@media (max-width:560px){
  .pgrid,.tgrid,.plogos{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  h1.title{font-size:30px}
  .frow{flex-direction:column;gap:0}
  .hero .stats{gap:24px}
}
/* page-enter animation */
.screen>.container,.hero .inner,.split{animation:fade .5s ease both}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
