/* ============================================================
   KAIZEN 2000 — Bold Industrial Craft design system
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=Archivo+Expanded:wght@700;800;900&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --bg:#0E0E0F;
  --bg-2:#141416;
  --panel:#161618;
  --panel-2:#1C1C1F;
  --steel:#2A2B2E;
  --concrete:#9A9A98;
  --concrete-d:#6E6E6C;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.16);
  --paper:#F2F1EC;
  --paper-d:#C9C8C3;
  --orange:#FF5A1F;
  --orange-d:#E8480E;
  --orange-ink:#0E0E0F;
  --maxw:1320px;
  --pad:44px;
  --ease:cubic-bezier(.22,1,.36,.08);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Archivo',system-ui,sans-serif;
  background:var(--bg);color:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--orange);color:var(--orange-ink)}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.mono{font-family:'JetBrains Mono',monospace}
.disp{font-family:'Archivo Expanded','Archivo',sans-serif}
.o{color:var(--orange)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- skip link ---------- */
.skip{position:absolute;left:-999px;top:0;background:var(--orange);color:var(--orange-ink);padding:10px 16px;z-index:200;font-weight:600}
.skip:focus{left:8px;top:8px}

/* ---------- header / nav ---------- */
.site-head{position:sticky;top:0;z-index:100;background:rgba(14,14,15,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:16px var(--pad)}
.brand{display:flex;align-items:center;gap:11px;font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:20px;letter-spacing:-.01em;text-transform:uppercase}
.brand .kan{color:var(--orange);font-size:17px;font-family:'Archivo',sans-serif;font-weight:700}
.brand-logo{height:38px;width:auto;display:block}
.foot-brand .brand-logo{height:46px;margin-bottom:4px}
@media (max-width:760px){.brand-logo{height:34px}}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a.navlink{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--concrete);transition:color .2s}
.nav-links a.navlink:hover,.nav-links a.navlink[aria-current="page"]{color:var(--paper)}
.nav-links a.navlink[aria-current="page"]{position:relative}
.nav-links a.navlink[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-22px;height:2px;background:var(--orange)}
.nav-right{display:flex;gap:18px;align-items:center}
.lang-toggle{display:inline-flex;font-family:'JetBrains Mono';font-size:12px;border:1px solid var(--line);border-radius:2px;overflow:hidden}
.lang-toggle button{background:none;border:none;color:var(--concrete);padding:7px 11px;cursor:pointer;font-family:inherit;font-size:inherit;text-transform:uppercase;transition:.2s}
.lang-toggle button[aria-pressed="true"]{background:var(--orange);color:var(--orange-ink);font-weight:500}
.btn-quote{background:var(--orange);color:var(--orange-ink);font-weight:700;padding:11px 20px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;border-radius:2px;transition:background .2s,transform .12s}
.btn-quote:hover{background:#fff}
.btn-quote:active{transform:scale(.97)}
.nav-toggle{display:none;background:none;border:1px solid var(--line);color:var(--paper);width:42px;height:42px;border-radius:2px;cursor:pointer;font-size:20px;align-items:center;justify-content:center}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;padding:16px 28px;border-radius:2px;font-weight:600;transition:.2s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--orange);color:var(--orange-ink)}
.btn-primary:hover{background:#fff}
.btn-ghost{border-color:var(--line-2);color:var(--paper)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn-lg{padding:18px 34px;font-size:15px}

/* ---------- layout primitives ---------- */
section{position:relative}
.section{padding:104px 0}
.section-sm{padding:72px 0}
.kicker{font-family:'JetBrains Mono';font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--orange);display:inline-flex;align-items:center;gap:10px;margin-bottom:22px}
.kicker::before{content:"//"}
.h-xl{font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:clamp(40px,6.4vw,96px);line-height:.92;letter-spacing:-.03em;text-transform:uppercase}
.h-lg{font-family:'Archivo Expanded','Archivo';font-weight:800;font-size:clamp(32px,4.4vw,60px);line-height:.98;letter-spacing:-.02em;text-transform:uppercase}
.h-md{font-family:'Archivo Expanded','Archivo';font-weight:800;font-size:clamp(24px,2.6vw,34px);line-height:1.04;letter-spacing:-.01em;text-transform:uppercase}
.lede{font-size:clamp(17px,1.5vw,20px);line-height:1.6;color:var(--paper-d);max-width:54ch}
.muted{color:var(--concrete)}
.stroke-text{color:transparent;-webkit-text-stroke:1.5px var(--concrete)}

/* ---------- hazard / texture helpers ---------- */
.hazard-stripe{height:8px;background:repeating-linear-gradient(135deg,var(--orange) 0 16px,var(--bg) 16px 30px)}
.grid-tex{background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px}

/* ---------- HERO (home) ---------- */
.hero{position:relative;padding:72px 0 56px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent 0 22px,rgba(255,90,31,.045) 22px 24px);pointer-events:none}
.hero-meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:'JetBrains Mono';font-size:12px;color:var(--concrete);text-transform:uppercase;letter-spacing:.08em;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:13px 0;margin-bottom:46px}
.hero h1{font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:clamp(52px,9vw,150px);line-height:.88;letter-spacing:-.03em;text-transform:uppercase}
.hero-sub{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:end;margin-top:44px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stripe{margin-top:52px;display:flex;border:1px solid var(--line);flex-wrap:wrap}
.hero-stripe .cell{flex:1 1 160px;padding:22px 24px;border-right:1px solid var(--line)}
.hero-stripe .cell:last-child{border-right:none}
.hero-stripe .n{font-family:'Archivo Expanded','Archivo';font-weight:800;font-size:30px}
.hero-stripe .l{font-family:'JetBrains Mono';font-size:11px;color:var(--concrete);text-transform:uppercase;letter-spacing:.06em;margin-top:6px}
.kaizen-badge{position:absolute;right:var(--pad);top:46%;width:152px;height:152px;border-radius:50%;background:var(--orange);color:var(--orange-ink);display:flex;align-items:center;justify-content:center;text-align:center;font-family:'Archivo Expanded';font-weight:900;font-size:13px;text-transform:uppercase;line-height:1.15;letter-spacing:.02em;padding:18px;animation:spin-slow 36s linear infinite}
@keyframes spin-slow{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.kaizen-badge{animation:none}}

/* ---------- generic page hero ---------- */
.page-hero{padding:84px 0 64px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-hero::after{content:"KAIZEN";position:absolute;right:-10px;bottom:-46px;font-family:'Archivo Expanded','Archivo';font-size:150px;font-weight:900;letter-spacing:-.03em;color:rgba(255,255,255,.022);pointer-events:none;line-height:1}
.page-hero h1{font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:clamp(40px,7vw,104px);line-height:.9;letter-spacing:-.03em;text-transform:uppercase}
.page-hero .lede{margin-top:26px}
.breadcrumb{font-family:'JetBrains Mono';font-size:12px;color:var(--concrete);text-transform:uppercase;letter-spacing:.08em;margin-bottom:24px}
.breadcrumb .o{color:var(--orange)}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:20px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:30px 28px;transition:border-color .25s,transform .25s,background .25s}
.card:hover{border-color:var(--line-2);background:var(--panel-2)}
.card .idx{font-family:'JetBrains Mono';font-size:12px;color:var(--orange);letter-spacing:.06em}
.card h3{font-family:'Archivo Expanded','Archivo';font-weight:800;font-size:22px;text-transform:uppercase;letter-spacing:-.01em;margin:14px 0 12px;line-height:1.05}
.card p{color:var(--concrete);font-size:15px;line-height:1.6}
.card .ic{width:46px;height:46px;border:1px solid var(--line-2);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--orange)}

/* service card with hover accent bar */
.svc{position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:transform .3s}
.svc:hover::before{transform:scaleY(1)}

/* ---------- process steps ---------- */
.steps{display:grid;gap:0;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:120px 1fr;gap:32px;padding:38px 0;border-bottom:1px solid var(--line);align-items:start}
.step .num{font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:54px;color:transparent;-webkit-text-stroke:1.5px var(--steel);line-height:1}
.step:hover .num{-webkit-text-stroke-color:var(--orange);color:transparent}
.step h3{font-family:'Archivo Expanded','Archivo';font-weight:800;font-size:26px;text-transform:uppercase;margin-bottom:10px}
.step p{color:var(--concrete);max-width:62ch;line-height:1.65}
.step .tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.tag{font-family:'JetBrains Mono';font-size:11px;color:var(--paper-d);border:1px solid var(--line);padding:5px 10px;border-radius:2px;text-transform:uppercase;letter-spacing:.05em}

/* ---------- projects ---------- */
.proj{position:relative;border:1px solid var(--line);border-radius:3px;overflow:hidden;background:var(--panel)}
.proj .thumb{aspect-ratio:1/1;background:linear-gradient(160deg,#2a2722,#171615);position:relative;display:flex;align-items:center;justify-content:center}
.proj .thumb.grid-tex{background-image:linear-gradient(160deg,#2a2722,#171615),linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:cover,40px 40px,40px 40px}
.proj .thumb::after{content:"KAIZEN";font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:30px;color:rgba(255,255,255,.05);letter-spacing:-.02em}
.proj .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;filter:saturate(.92) contrast(1.02)}
.proj .thumb .lbl{z-index:2}
.proj:hover .thumb img{transform:scale(1.04)}
.proj .thumb img{transition:transform .5s var(--ease)}
.proj .thumb .lbl{position:absolute;top:14px;left:14px;background:var(--orange);color:var(--orange-ink);font-family:'JetBrains Mono';font-size:11px;padding:6px 10px;text-transform:uppercase;letter-spacing:.04em;border-radius:2px}
.proj .body{padding:22px 22px 24px}
.proj h3{font-family:'Archivo Expanded','Archivo';font-weight:800;font-size:20px;text-transform:uppercase;margin-bottom:6px}
.proj .meta{font-family:'JetBrains Mono';font-size:12px;color:var(--concrete);display:flex;justify-content:space-between;border-top:1px solid var(--line);margin-top:16px;padding-top:14px}

/* ---------- stats band ---------- */
.band{background:var(--orange);color:var(--orange-ink)}
.band .wrap{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;align-items:center;padding-top:54px;padding-bottom:54px}
.band .stat .n{font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:clamp(38px,4.6vw,62px);line-height:1}
.band .stat .l{font-family:'JetBrains Mono';font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-top:8px;opacity:.85}

/* ---------- split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split .visual{aspect-ratio:5/4;border:1px solid var(--line);border-radius:3px;position:relative;overflow:hidden;background:linear-gradient(160deg,#26231e,#141312);display:flex;align-items:center;justify-content:center}
.split .visual::after{content:"KAIZEN";font-family:'Archivo Expanded','Archivo';font-weight:900;font-size:40px;color:rgba(255,255,255,.05);letter-spacing:-.02em}
.split .visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;filter:saturate(.92) contrast(1.02)}
.split .visual .tagpic{z-index:2}
.split .visual .tagpic{position:absolute;left:18px;bottom:18px;background:rgba(14,14,15,.8);backdrop-filter:blur(4px);border:1px solid var(--line);padding:12px 16px;border-radius:2px;font-family:'JetBrains Mono';font-size:12px;color:var(--paper-d)}
.ticks{list-style:none;margin-top:26px;display:grid;gap:14px}
.ticks li{display:flex;gap:14px;align-items:flex-start;color:var(--paper-d);font-size:16px;line-height:1.5}
.ticks li i{color:var(--orange);font-size:20px;flex:none;margin-top:1px}

/* ---------- CTA block ---------- */
.cta-block{border:1px solid var(--line);border-radius:4px;padding:64px 56px;text-align:center;background:var(--panel);position:relative;overflow:hidden}
.cta-block::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent 0 22px,rgba(255,90,31,.05) 22px 24px)}
.cta-block>*{position:relative}
.cta-block p{color:var(--concrete);max-width:50ch;margin:18px auto 30px}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.field{margin-bottom:18px}
.field label{display:block;font-family:'JetBrains Mono';font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--concrete);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:2px;color:var(--paper);padding:14px 15px;font-family:inherit;font-size:16px;transition:border-color .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--orange)}
.field textarea{min-height:130px;resize:vertical}
.info-row{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.info-row i{color:var(--orange);font-size:24px;flex:none}
.info-row .k{font-family:'JetBrains Mono';font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--concrete)}
.info-row .v{font-size:17px;margin-top:3px}
.form-note{font-family:'JetBrains Mono';font-size:12px;color:var(--concrete);margin-top:14px}

/* ---------- footer ---------- */
.site-foot{border-top:1px solid var(--line);background:var(--bg-2);padding:70px 0 34px;margin-top:0}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:48px;border-bottom:1px solid var(--line)}
.foot-col h4{font-family:'JetBrains Mono';font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--concrete);margin-bottom:18px}
.foot-col a{display:block;color:var(--paper-d);font-size:14px;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--orange)}
.foot-brand .kan{color:var(--orange)}
.foot-brand p{color:var(--concrete);font-size:14px;line-height:1.6;margin-top:16px;max-width:34ch}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:26px;font-family:'JetBrains Mono';font-size:12px;color:var(--concrete-d);text-transform:uppercase;letter-spacing:.05em}

/* ---------- reveal animation ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  :root{--pad:28px}
  .hero-sub{grid-template-columns:1fr;gap:28px}
  .kaizen-badge{display:none}
  .split{grid-template-columns:1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:14px var(--pad) 24px;transform:translateY(-120%);transition:transform .3s var(--ease);max-height:calc(100vh - 64px);overflow:auto}
  .nav-links.open{transform:none}
  .nav-links a.navlink{width:100%;padding:14px 0;font-size:16px;border-bottom:1px solid var(--line)}
  .nav-links a.navlink[aria-current="page"]::after{display:none}
  .nav-toggle{display:inline-flex}
  .section{padding:72px 0}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .step{grid-template-columns:1fr;gap:10px}
  .step .num{font-size:42px}
  .band .wrap{gap:24px}
  .cta-block{padding:44px 26px}
  .foot-top{grid-template-columns:1fr 1fr;gap:28px}
  .btn-quote{display:none}
}
