/* ============================================================
   KIMIPACK — Blueprint / precision-lab design system
   ============================================================ */

/* ---- Tokens ------------------------------------------------ */
:root{
  --ink:       #0B0E12;
  --panel:     #11151B;
  --panel-2:   #0E1217;
  --line:      rgba(120,160,180,0.18);
  --line-soft: rgba(120,160,180,0.10);
  --line-strong: rgba(120,160,180,0.34);
  --cyan:      #35D0E6;
  --cyan-deep: #0FA3B8;
  --amber:     #F2A33C;
  --text:      #E6EDF2;
  --muted:     #8A98A6;
  --tile:      #FFFFFF;
  --tile-ink:  #0B2230;     /* schematic line color on white tiles */

  --accent:    var(--cyan);  /* tweakable */
  --grid:      28px;          /* blueprint grid cell */

  --font-display: "Inter Tight", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --font-ar: "IBM Plex Sans Arabic", "Inter Tight", system-ui, sans-serif;

  --maxw: 1320px;
  --pad: clamp(20px, 4.5vw, 64px);
}

/* Light "paper" mode */
[data-theme="light"]{
  --ink:       #F4F1E9;
  --panel:     #FBFAF5;
  --panel-2:   #F0ECE0;
  --line:      rgba(28,60,92,0.20);
  --line-soft: rgba(28,60,92,0.10);
  --line-strong: rgba(28,60,92,0.40);
  --cyan:      #0E6E86;
  --cyan-deep: #0A5366;
  --amber:     #C9741A;
  --text:      #15222B;
  --muted:     #5C6B73;
  --tile:      #FFFFFF;
  --tile-ink:  #0B2230;
}

/* ---- Reset ------------------------------------------------- */
*{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  background: var(--ink);
  color: var(--text);
  font-family: var(--font-display);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
[lang="ar"], [dir="rtl"]{ font-family: var(--font-ar); }
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; color: inherit; cursor: pointer; }
::selection{ background: var(--accent); color: var(--ink); }

/* Blueprint canvas grid */
.blueprint{
  background-image:
    linear-gradient(var(--line-soft) 0.5px, transparent 0.5px),
    linear-gradient(90deg, var(--line-soft) 0.5px, transparent 0.5px);
  background-size: var(--grid) var(--grid);
  background-position: center top;
}

/* ---- Utility ----------------------------------------------- */
.wrap{ max-width: var(--maxw); margin:0 auto; padding-inline: var(--pad); }
.mono{ font-family: var(--font-mono); font-variant-numeric: tabular-nums; letter-spacing: 0.02em; }
.muted{ color: var(--muted); }
.accent{ color: var(--accent); }
.hairline{ border: 0; border-top: 0.5px solid var(--line); }
.eyebrow{
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--muted);
}
.tick-label{
  font-family: var(--font-mono); font-size:11px; letter-spacing:0.12em;
  color: var(--accent); text-transform: uppercase;
}

/* Registration / corner marks */
.regmark{ position:absolute; width:14px; height:14px; pointer-events:none; opacity:.55; }
.regmark::before,.regmark::after{ content:""; position:absolute; background: var(--line-strong); }
.regmark::before{ left:50%; top:0; width:0.5px; height:100%; transform:translateX(-50%); }
.regmark::after{ top:50%; left:0; height:0.5px; width:100%; transform:translateY(-50%); }
.regmark.tl{ left:-1px; top:-1px } .regmark.tr{ right:-1px; top:-1px }
.regmark.bl{ left:-1px; bottom:-1px } .regmark.br{ right:-1px; bottom:-1px }

/* ---- Buttons ----------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-mono); font-size:13px; letter-spacing:0.06em;
  text-transform: uppercase;
  padding: 13px 20px; border: 0.5px solid var(--line-strong);
  background: transparent; color: var(--text);
  transition: border-color .2s ease, background .2s ease, color .2s ease;
}
.btn:hover{ border-color: var(--accent); color: var(--accent); }
.btn-amber{
  background: var(--amber); color:#1A1206; border-color: var(--amber);
  font-weight: 500;
}
.btn-amber:hover{ background: transparent; color: var(--amber); }
.btn-cyan{ border-color: var(--accent); color: var(--accent); }
.btn-cyan:hover{ background: var(--accent); color: var(--ink); }
.btn .ico{ width:16px; height:16px; display:block; }

/* ---- Header ------------------------------------------------ */
.site-header{
  position: sticky; top:0; z-index: 60;
  background: color-mix(in srgb, var(--ink) 86%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 0.5px solid var(--line);
}
.site-header .bar{
  display:flex; align-items:center; gap: clamp(14px,2.5vw,28px);
  height: 64px;
}
.wordmark{ display:flex; align-items:center; gap:11px; flex:0 0 auto; }
.wordmark .reticle{ width:26px; height:26px; flex:0 0 auto; color: var(--accent); }
.wordmark b{ font-weight:500; font-size:18px; letter-spacing:0.01em; }
.wordmark .tm{ font-family:var(--font-mono); font-size:9px; color:var(--muted); align-self:flex-start; margin-top:2px; }

.h-search{
  flex:1 1 auto; max-width:420px; position:relative;
  display:flex; align-items:center;
}
.h-search input{
  width:100%; background: var(--panel); border:0.5px solid var(--line);
  color: var(--text); font-family: var(--font-mono); font-size:12px;
  padding: 9px 12px 9px 34px; letter-spacing:0.04em;
}
[dir="rtl"] .h-search input{ padding: 9px 34px 9px 12px; }
.h-search input::placeholder{ color: var(--muted); }
.h-search input:focus{ outline:none; border-color: var(--accent); }
.h-search .si{ position:absolute; inset-inline-start:11px; width:14px; height:14px; color:var(--muted); pointer-events:none; }

.h-spacer{ flex:1 1 auto; }
.h-actions{ display:flex; align-items:center; gap:12px; flex:0 0 auto; }
.lang-toggle{
  display:flex; border:0.5px solid var(--line); font-family:var(--font-mono);
  font-size:12px;
}
.lang-toggle button{ background:transparent; border:0; padding:7px 11px; color:var(--muted); letter-spacing:0.08em; }
.lang-toggle button.on{ background: var(--accent); color: var(--ink); }
.cod-badge{
  display:inline-flex; align-items:center; gap:7px;
  border:0.5px solid var(--line); padding:6px 11px;
  font-family: var(--font-mono); font-size:10.5px; letter-spacing:0.08em;
  text-transform: uppercase; color: var(--muted); white-space:nowrap;
}
.cod-badge .dot{ width:6px; height:6px; background: var(--amber); border-radius:50%; flex:0 0 auto; }
.theme-toggle{ width:34px; height:34px; display:grid; place-items:center; border:0.5px solid var(--line); background:transparent; color:var(--muted); }
.theme-toggle:hover{ color: var(--accent); border-color: var(--accent); }
.nav-links{ display:flex; gap:18px; font-family:var(--font-mono); font-size:12px; letter-spacing:0.06em; text-transform:uppercase; }
.nav-links a{ color:var(--muted); padding:4px 0; border-bottom:1px solid transparent; }
.nav-links a:hover, .nav-links a.active{ color:var(--text); border-color: var(--accent); }

/* ---- Footer title block ------------------------------------ */
.title-block{
  border:0.5px solid var(--line-strong); margin: 64px 0 40px;
  font-family: var(--font-mono);
}
.tb-row{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; }
.tb-cell{ border-inline-start:0.5px solid var(--line); padding:18px 20px; }
.tb-cell:first-child{ border-inline-start:0; }
.tb-row + .tb-row{ border-top:0.5px solid var(--line); }
.tb-k{ font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
.tb-v{ font-size:13px; color:var(--text); line-height:1.6; }
.tb-big{ font-family: var(--font-display); font-size:22px; font-weight:500; letter-spacing:0.01em; }

/* ---- Product card ------------------------------------------ */
.grid-cards{
  display:grid; gap:0;
  grid-template-columns: repeat(auto-fill, minmax(248px,1fr));
  border-top:0.5px solid var(--line); border-inline-start:0.5px solid var(--line);
}
.card{
  position:relative; border-inline-end:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
  background: var(--panel); display:flex; flex-direction:column;
  overflow:hidden; content-visibility:auto; contain-intrinsic-size: 320px;
}
.card .tile{
  position:relative; aspect-ratio: 4/3; background: var(--tile);
  display:grid; place-items:center; overflow:hidden;
}
.card .tile svg.schematic{ width:62%; height:62%; color: var(--tile-ink); }
.card .tile-img{ width:100%; height:100%; object-fit:contain; padding:12px; transition: transform .45s cubic-bezier(.2,.7,.2,1); }
.card:hover .tile-img{ transform: scale(1.05); }
.card .tile-fallback{ display:grid; place-items:center; width:100%; height:100%; }
.card .tile-fallback svg.schematic{ width:58%; height:58%; color:var(--tile-ink); }
.card .tile .tile-sku{
  position:absolute; left:10px; top:9px; font-family:var(--font-mono);
  font-size:10px; letter-spacing:0.08em; color: rgba(11,34,48,.5);
}
.card .tile .tile-cat{
  position:absolute; right:10px; bottom:9px; font-family:var(--font-mono);
  font-size:9px; letter-spacing:0.1em; text-transform:uppercase; color: rgba(11,34,48,.42);
}
[dir="rtl"] .card .tile .tile-sku{ left:auto; right:10px; }
[dir="rtl"] .card .tile .tile-cat{ right:auto; left:10px; }
/* scan-line sweep */
.card .scan{
  position:absolute; inset:0; pointer-events:none; opacity:0;
  background: linear-gradient(180deg, transparent 0%, color-mix(in srgb, var(--accent) 38%, transparent) 50%, transparent 100%);
  height:42%; transform: translateY(-120%);
}
.card:hover .scan{ animation: scan 0.7s ease-out forwards; }
.no-scan .card:hover .scan{ animation:none; }
@keyframes scan{ 0%{opacity:.9; transform:translateY(-110%);} 100%{opacity:0; transform:translateY(280%);} }

.card .body{ padding:14px 15px 16px; display:flex; flex-direction:column; gap:9px; flex:1; }
.card .ctag{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); }
.card h3{ margin:0; font-size:15px; font-weight:500; line-height:1.3; letter-spacing:0.005em; }
.card .price{ font-family:var(--font-mono); font-size:15px; color: var(--text); margin-top:auto; }
.card .price .cur{ font-size:11px; color: var(--muted); }
.card .order{
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin-top:4px; padding:10px; background: var(--amber); color:#1A1206;
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase;
  border:0.5px solid var(--amber); transition: background .15s, color .15s;
}
.card .order:hover{ background: transparent; color: var(--amber); }
.card .order .ico{ width:15px; height:15px; }

/* spec panel slide-up on hover */
.card .specpop{
  position:absolute; left:0; right:0; bottom:0;
  background: color-mix(in srgb, var(--panel) 96%, var(--accent) 4%);
  border-top:0.5px solid var(--accent);
  padding:12px 15px; transform: translateY(101%); transition: transform .26s cubic-bezier(.2,.7,.2,1);
  font-family: var(--font-mono); font-size:11px;
}
.card:hover .specpop{ transform: translateY(0); }
.card .specpop .sp-row{ display:flex; justify-content:space-between; gap:10px; padding:3px 0; color:var(--muted); }
.card .specpop .sp-row b{ color:var(--text); font-weight:400; }
.card .specpop .sp-h{ color: var(--accent); letter-spacing:0.14em; text-transform:uppercase; font-size:9.5px; margin-bottom:5px; }

@media (prefers-reduced-motion: reduce){
  .card:hover .scan{ animation:none; }
  *{ scroll-behavior:auto; }
}

/* ---- Category rail (control panel) ------------------------- */
.cat-rail{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.04em;
  padding:9px 14px; border:0.5px solid var(--line); background: var(--panel);
  color:var(--muted); transition: all .16s ease; text-transform:uppercase;
}
.chip:hover{ border-color: var(--line-strong); color: var(--text); }
.chip.on{ border-color: var(--accent); color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, var(--panel)); }
.chip .led{ width:6px; height:6px; border:0.5px solid currentColor; }
.chip.on .led{ background: var(--accent); border-color: var(--accent); box-shadow:0 0 6px var(--accent); }
.chip .ct{ color: color-mix(in srgb, currentColor 60%, transparent); }

/* ---- Section headers --------------------------------------- */
.sec-head{ display:flex; align-items:baseline; justify-content:space-between; gap:20px; padding: 0 0 20px; }
.sec-head h2{ font-size: clamp(22px,3vw,34px); font-weight:500; margin:0; letter-spacing:-0.01em; }
.sec-head .idx{ font-family:var(--font-mono); font-size:12px; color:var(--muted); letter-spacing:0.12em; }
.section{ padding: clamp(48px,7vw,96px) 0; position:relative; }
.section + .section{ border-top:0.5px solid var(--line); }

/* dimension annotation line */
.dim{ position:relative; }
.dim-line{ stroke: var(--accent); stroke-width:0.5; }

/* Arabic numerals helper */
[dir="rtl"] .price, [dir="rtl"] .mono{ direction:ltr; unicode-bidi: plaintext; }

/* ---- Motion: reveal-on-scroll (only when motion is live) -- */
html.kp-motion [data-reveal]{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--ri,0)*45ms); }
html.kp-motion [data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  html.kp-motion [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
}

/* plotter draw-in for schematics — clip-path wipe (base = visible) */
html.kp-motion svg.schematic.kp-wipe{ animation: kpwipe var(--kpd,.7s) cubic-bezier(.4,.1,.2,1) backwards; }
@keyframes kpwipe{ from{ clip-path: inset(0 0 100% 0); } to{ clip-path: inset(0 0 0 0); } }

@media (prefers-reduced-motion: reduce){
  html.kp-motion svg.schematic.kp-wipe{ animation:none; clip-path:none; }
  html.kp-motion .pp-figure .figscan{ display:none; }
  html.kp-motion .pp-figure .figcross b{ animation:none; }
}

/* tile corner ticks + targeting crosshair */.card .tile::before, .card .tile::after{
  content:""; position:absolute; width:9px; height:9px; pointer-events:none;
  border-color: rgba(11,34,48,.22); border-style:solid; border-width:0;
}
.card .tile::before{ left:8px; top:8px; border-left-width:0.5px; border-top-width:0.5px; }
.card .tile::after{ right:8px; bottom:8px; border-right-width:0.5px; border-bottom-width:0.5px; }
.tile-cross{ position:absolute; left:50%; top:50%; width:30px; height:30px; transform:translate(-50%,-50%) scale(.55); opacity:0; transition:opacity .3s ease, transform .3s cubic-bezier(.2,.7,.2,1); pointer-events:none; }
.tile-cross::before,.tile-cross::after{ content:""; position:absolute; background: var(--cyan-deep); }
.tile-cross::before{ left:50%; top:0; width:0.5px; height:100%; transform:translateX(-50%); }
.tile-cross::after{ top:50%; left:0; height:0.5px; width:100%; transform:translateY(-50%); }
.card:hover .tile-cross{ opacity:.6; transform:translate(-50%,-50%) scale(1); }
.card:hover .tile svg.schematic{ transition: transform .4s cubic-bezier(.2,.7,.2,1); transform: scale(1.04); }
.card .tile svg.schematic{ transition: transform .4s ease; }

/* ---- Hero -------------------------------------------------- */
.hero{ position:relative; overflow:hidden; border-bottom:0.5px solid var(--line); }
.hero-grid{ display:grid; grid-template-columns: 1.05fr 0.95fr; gap:40px; align-items:center; min-height: min(82vh, 760px); padding: clamp(40px,6vw,80px) 0; }
.hero-copy{ position:relative; z-index:3; max-width:560px; }
.hero h1{ font-size: clamp(34px, 5vw, 62px); line-height:1.04; font-weight:500; letter-spacing:-0.02em; margin:18px 0 0; text-wrap:balance; }
.hero .sub{ color:var(--muted); font-size: clamp(15px,1.5vw,18px); line-height:1.6; margin:20px 0 0; max-width:46ch; }
.hero-cta{ display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
.trust{ display:grid; grid-template-columns: repeat(3,1fr); gap:0; margin-top:44px; border-top:0.5px solid var(--line); }
.trust .ti{ padding:16px 16px 4px 0; border-inline-end:0.5px solid var(--line); }
.trust .ti:last-child{ border-inline-end:0; }
.trust .ti .n{ font-family:var(--font-mono); font-size:11px; color:var(--accent); letter-spacing:0.1em; }
.trust .ti b{ display:block; font-weight:500; font-size:14px; margin-top:8px; }
.trust .ti span{ display:block; color:var(--muted); font-size:12px; margin-top:3px; line-height:1.4; }

.hero-stage{ position:relative; align-self:stretch; min-height:420px; }
.hero-canvas{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.callout{ position:absolute; transform:translate(-50%,-50%); pointer-events:none; z-index:4; white-space:nowrap; }
.callout .cv{ font-family:var(--font-mono); font-size:13px; color:var(--text); letter-spacing:0.04em; }
.callout .ck{ font-family:var(--font-mono); font-size:9.5px; color:var(--muted); letter-spacing:0.18em; text-transform:uppercase; display:block; margin-bottom:2px; }
.reticle-cursor{ position:absolute; top:0; left:0; width:0; height:0; opacity:0; transition:opacity .2s; pointer-events:none; z-index:6; }
.reticle-cursor .rc-h, .reticle-cursor .rc-v{ position:absolute; background:var(--accent); opacity:.5; }
.reticle-cursor .rc-h{ left:-26px; top:0; width:52px; height:0.5px; }
.reticle-cursor .rc-v{ top:-26px; left:0; height:52px; width:0.5px; }
.reticle-cursor .rc-ring{ position:absolute; left:-9px; top:-9px; width:18px; height:18px; border:0.5px solid var(--accent); border-radius:50%; }
.reticle-cursor .rc-read{ position:absolute; left:14px; top:10px; font-family:var(--font-mono); font-size:9px; color:var(--accent); letter-spacing:0.08em; line-height:1.4; }
[dir="rtl"] .reticle-cursor .rc-read{ left:auto; right:14px; }

.hero-meta{ position:absolute; bottom:14px; inset-inline-start:0; font-family:var(--font-mono); font-size:10px; color:var(--muted); letter-spacing:0.14em; text-transform:uppercase; z-index:3; }

/* ---- How-it-works ----------------------------------------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:0.5px solid var(--line); }
.step{ padding:28px; border-inline-start:0.5px solid var(--line); position:relative; }
.step:first-child{ border-inline-start:0; }
.step .sn{ font-family:var(--font-mono); font-size:12px; color:var(--accent); letter-spacing:0.14em; }
.step h4{ font-size:18px; font-weight:500; margin:16px 0 8px; }
.step p{ color:var(--muted); font-size:14px; margin:0; line-height:1.55; }

/* ---- Responsive ------------------------------------------- */
@media (max-width: 1020px){
  .hero-grid{ grid-template-columns:1fr; min-height:auto; gap:24px; }
  .hero-stage{ min-height:360px; order:-1; }
  .nav-links{ display:none; }
}
@media (max-width: 720px){
  .h-search{ display:none; }
  .cod-badge .lbl{ display:none; }
  .tb-row{ grid-template-columns:1fr; }
  .tb-cell{ border-inline-start:0; border-top:0.5px solid var(--line); }
  .tb-row:first-child .tb-cell:first-child{ border-top:0; }
  .trust{ grid-template-columns:1fr; }
  .trust .ti{ border-inline-end:0; border-bottom:0.5px solid var(--line); padding:14px 0; }
  .steps{ grid-template-columns:1fr; }
  .step{ border-inline-start:0; border-top:0.5px solid var(--line); }
  .step:first-child{ border-top:0; }
  .grid-cards{ grid-template-columns: repeat(2,1fr); }
  .card .order{ font-size:10px; }
}
@media (max-width: 420px){
  .grid-cards{ grid-template-columns:1fr; }
}

/* ---- Catalog toolbar -------------------------------------- */
.cat-hero{ padding: clamp(28px,4vw,48px) 0 22px; border-bottom:0.5px solid var(--line); position:relative; }
.cat-hero h1{ font-size: clamp(28px,4vw,46px); font-weight:500; margin:10px 0 0; letter-spacing:-0.015em; }
.cat-hero .count{ font-family:var(--font-mono); font-size:12px; color:var(--muted); letter-spacing:0.08em; margin-top:12px; }
.cat-hero .count b{ color: var(--accent); font-weight:400; }
.toolbar{
  position:sticky; top:64px; z-index:40; background: color-mix(in srgb, var(--ink) 90%, transparent);
  backdrop-filter: blur(10px); border-bottom:0.5px solid var(--line);
  padding: 14px 0;
}
.toolbar .row{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.tb-rail{ display:flex; gap:7px; flex-wrap:wrap; flex:1; min-width:0; }
.sortbox{ display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:0.08em; text-transform:uppercase; flex:0 0 auto; }
.sortbox select{
  background: var(--panel); color: var(--text); border:0.5px solid var(--line);
  font-family:var(--font-mono); font-size:11px; padding:7px 9px; letter-spacing:0.04em;
}
.sortbox select:focus{ outline:none; border-color: var(--accent); }
.no-res{ padding:80px 0; text-align:center; font-family:var(--font-mono); color:var(--muted); }
.no-res button{ margin-top:16px; }

/* ---- Product page ----------------------------------------- */
.pp-crumb{ font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:0.1em; text-transform:uppercase; padding:22px 0 0; display:flex; gap:8px; align-items:center; }
.pp-crumb a:hover{ color: var(--accent); }
.pp-grid{ display:grid; grid-template-columns: 1.05fr 0.95fr; gap:0; border:0.5px solid var(--line); margin:18px 0 0; }
.pp-figure{ position:relative; background: var(--tile); aspect-ratio: 1/1; display:grid; place-items:center; overflow:hidden; }
.pp-figure svg.schematic{ width:54%; height:54%; color: var(--tile-ink); }
.pp-figure .pp-img{ width:80%; height:80%; object-fit:contain; z-index:1; }
.pp-figure .figscan{ display:none; position:absolute; left:6%; right:6%; height:30%; pointer-events:none; z-index:2;
  background:linear-gradient(180deg, transparent, color-mix(in srgb, var(--cyan-deep) 16%, transparent), transparent); }
html.kp-motion .pp-figure .figscan{ display:block; animation: figscan 5.2s cubic-bezier(.5,0,.5,1) infinite; }
@keyframes figscan{ 0%{transform:translateY(-110%); opacity:0} 12%{opacity:1} 88%{opacity:1} 100%{transform:translateY(380%); opacity:0} }
.pp-figure .figcross{ position:absolute; left:50%; top:50%; width:42px; height:42px; transform:translate(-50%,-50%); pointer-events:none; z-index:3; }
.pp-figure .figcross::before,.pp-figure .figcross::after{ content:""; position:absolute; background: var(--cyan-deep); opacity:.4; }
.pp-figure .figcross::before{ left:50%; top:0; width:0.5px; height:100%; transform:translateX(-50%); }
.pp-figure .figcross::after{ top:50%; left:0; height:0.5px; width:100%; transform:translateY(-50%); }
.pp-figure .figcross b{ position:absolute; left:50%; top:50%; width:8px; height:8px; border:0.5px solid var(--cyan-deep); border-radius:50%; transform:translate(-50%,-50%); }
html.kp-motion .pp-figure .figcross b{ animation: figpulse 2.6s ease-out infinite; }
@keyframes figpulse{ 0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--cyan-deep) 50%,transparent)} 70%,100%{box-shadow:0 0 0 16px transparent} }
@media (prefers-reduced-motion: reduce){ .pp-figure .figscan, .pp-figure .figcross b{ animation:none; } .pp-figure .figscan{ display:none; } }
.pp-figure .fg-sku{ position:absolute; top:16px; inset-inline-start:16px; font-family:var(--font-mono); font-size:11px; color:rgba(11,34,48,.55); letter-spacing:0.1em; }
.pp-figure .dimv, .pp-figure .dimh{ position:absolute; font-family:var(--font-mono); font-size:10px; color: var(--cyan-deep); letter-spacing:0.08em; }
.pp-figure .dimv{ inset-inline-end:14px; top:50%; transform:translateY(-50%) ; writing-mode:vertical-rl; }
.pp-figure .dimh{ bottom:14px; left:50%; transform:translateX(-50%); }
.pp-figure .axis{ position:absolute; background: rgba(11,34,48,.25); }
.pp-info{ padding: clamp(24px,3vw,40px); border-inline-start:0.5px solid var(--line); display:flex; flex-direction:column; }
.pp-info .ctag{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); }
.pp-info h1{ font-size: clamp(24px,3vw,38px); font-weight:500; margin:14px 0 0; line-height:1.12; letter-spacing:-0.01em; }
.pp-price{ font-family:var(--font-mono); font-size:28px; margin:22px 0 4px; }
.pp-price .cur{ font-size:14px; color:var(--muted); }
.pp-price .unit{ font-size:12px; color:var(--muted); margin-inline-start:8px; }
.pp-meta{ display:flex; gap:18px; flex-wrap:wrap; margin:14px 0 4px; font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:0.06em; }
.pp-meta .ok{ color: var(--accent); }
.pp-order{ margin-top:22px; display:flex; gap:10px; flex-wrap:wrap; }
.pp-order .btn-amber{ flex:1; justify-content:center; padding:15px 20px; }
.pp-note{ margin-top:auto; padding-top:24px; }
.pp-note .nh{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.pp-note p{ font-size:13px; color:var(--muted); line-height:1.6; margin:0; max-width:46ch; }

.spec-table{ border:0.5px solid var(--line); margin:24px 0 0; font-family:var(--font-mono); }
.spec-table .sth{ padding:13px 18px; border-bottom:0.5px solid var(--line); display:flex; justify-content:space-between; align-items:center; }
.spec-table .sth .t{ font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); }
.spec-table .sth .s{ font-size:10px; color:var(--muted); letter-spacing:0.1em; }
.spec-row{ display:grid; grid-template-columns: 1fr 1.4fr; }
.spec-row + .spec-row{ border-top:0.5px solid var(--line); }
.spec-row .k{ padding:12px 18px; color:var(--muted); font-size:12px; border-inline-end:0.5px solid var(--line); letter-spacing:0.04em; }
.spec-row .v{ padding:12px 18px; color:var(--text); font-size:12.5px; letter-spacing:0.02em; }

@media (max-width: 880px){
  .pp-grid{ grid-template-columns:1fr; }
  .pp-info{ border-inline-start:0; border-top:0.5px solid var(--line); }
}

/* ============================================================
   v2 — quote basket, expanded homepage, about & contact
   ============================================================ */

/* ---- Card actions (WhatsApp + add-to-quote) --------------- */
.card-actions{ display:flex; gap:0; margin-top:4px; }
.card-actions .order{ flex:1; margin-top:0; }
.qadd{
  flex:0 0 auto; width:42px; display:grid; place-items:center;
  background: var(--panel); color: var(--muted);
  border:0.5px solid var(--line-strong); border-inline-end:0;
  transition: background .15s, color .15s, border-color .15s;
}
[dir="rtl"] .qadd{ border-inline-end:0.5px solid var(--line-strong); border-inline-start:0; }
.qadd svg{ width:16px; height:16px; transition: transform .25s cubic-bezier(.2,.7,.2,1); }
.qadd:hover{ color: var(--accent); border-color: var(--accent); }
.qadd:hover svg{ transform: rotate(90deg); }
.qadd.added{ color: var(--ink); background: var(--accent); border-color: var(--accent); }
.qadd.added svg{ transform: rotate(45deg); }

/* ---- Header quote button ---------------------------------- */
.quote-btn{
  position:relative; display:inline-flex; align-items:center; gap:8px;
  background: transparent; border:0.5px solid var(--line);
  padding:7px 12px; font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.08em; text-transform:uppercase; color: var(--muted);
  transition: border-color .18s, color .18s; flex:0 0 auto;
}
.quote-btn svg{ width:16px; height:16px; }
.quote-btn:hover{ color: var(--accent); border-color: var(--accent); }
.quote-btn .qcount{
  min-width:18px; height:18px; padding:0 5px; border-radius:9px;
  display:grid; place-items:center; font-size:10px; line-height:1;
  background: var(--line); color: var(--muted); transition: background .18s, color .18s;
}
.quote-btn .qcount.on{ background: var(--amber); color:#1A1206; }
@media (max-width: 720px){ .quote-btn .ql{ display:none; } .quote-btn{ padding:7px 10px; } }

/* ---- Quote drawer ----------------------------------------- */
.kp-quote-overlay{
  position:fixed; inset:0; z-index:90; background: color-mix(in srgb, var(--ink) 64%, transparent);
  backdrop-filter: blur(2px); opacity:0; pointer-events:none; transition: opacity .3s ease;
}
.kp-quote-overlay.open{ opacity:1; pointer-events:auto; }
.kp-quote-drawer{
  position:fixed; top:0; inset-inline-end:0; z-index:91; height:100%;
  width:min(440px, 100vw); background: var(--panel);
  border-inline-start:0.5px solid var(--line-strong);
  display:flex; flex-direction:column;
  transform: translateX(100%); transition: transform .42s cubic-bezier(.3,.8,.2,1);
  box-shadow: -30px 0 80px -40px rgba(0,0,0,.6);
}
[dir="rtl"] .kp-quote-drawer{ transform: translateX(-100%); border-inline-start:0; border-inline-end:0.5px solid var(--line-strong); }
.kp-quote-drawer.open{ transform: translateX(0); }
.qd-head{ display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:0.5px solid var(--line); }
.qd-h-title{ display:flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:12px; letter-spacing:0.18em; text-transform:uppercase; color: var(--text); }
.qd-dot{ width:7px; height:7px; background: var(--accent); box-shadow:0 0 8px var(--accent); }
.qd-close{ width:32px; height:32px; display:grid; place-items:center; border:0.5px solid var(--line); background:transparent; color:var(--muted); }
.qd-close:hover{ color:var(--accent); border-color: var(--accent); }
.qd-close svg{ width:15px; height:15px; }
.qd-scroll{ flex:1; overflow-y:auto; }
.qd-body{ display:flex; flex-direction:column; }
.qd-item{ display:grid; grid-template-columns: 64px 1fr auto; gap:14px; padding:16px 20px; border-bottom:0.5px solid var(--line); align-items:center; }
.qd-thumb{ width:64px; height:64px; background: var(--tile); display:grid; place-items:center; overflow:hidden; border:0.5px solid var(--line); }
.qd-thumb img{ width:100%; height:100%; object-fit:contain; padding:7px; }
.qd-thumb .tile-fallback svg.schematic{ width:60%; height:60%; color: var(--tile-ink); }
.qd-meta{ min-width:0; }
.qd-sku{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.08em; color:var(--muted); }
.qd-name{ display:block; font-size:13px; line-height:1.35; margin:4px 0 6px; color:var(--text);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.qd-name:hover{ color: var(--accent); }
.qd-price{ font-family:var(--font-mono); font-size:13px; color: var(--text); }
.qd-price .cur{ color:var(--muted); font-size:10px; }
.qd-each{ color:var(--muted); font-size:10px; }
.qd-ctrls{ display:flex; flex-direction:column; align-items:flex-end; gap:8px; }
.qd-rm{ width:24px; height:24px; display:grid; place-items:center; border:0.5px solid var(--line); background:transparent; color:var(--muted); }
.qd-rm:hover{ color: var(--amber); border-color: var(--amber); }
.qd-rm svg{ width:12px; height:12px; }
.qd-step{ display:flex; align-items:center; border:0.5px solid var(--line); font-family:var(--font-mono); }
.qd-step button{ width:26px; height:26px; background:transparent; color:var(--muted); font-size:14px; line-height:1; }
.qd-step button:hover{ color: var(--accent); }
.qd-step span{ min-width:26px; text-align:center; font-size:12px; color:var(--text); }
.qd-empty{ padding:64px 32px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:14px; }
.qd-empty svg{ width:44px; height:44px; color: var(--line-strong); }
.qd-empty .qe-h{ font-family:var(--font-mono); font-size:13px; letter-spacing:0.06em; color:var(--text); }
.qd-empty .qe-s{ font-size:13px; color:var(--muted); line-height:1.55; max-width:30ch; }
.qd-empty .btn{ margin-top:6px; }
.qd-foot{ border-top:0.5px solid var(--line); padding:18px 20px; display:none; }
.qd-foot.on{ display:block; }
.qd-total{ display:flex; align-items:baseline; justify-content:space-between; font-family:var(--font-mono); margin-bottom:14px; }
.qd-total span{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); }
.qd-total b{ font-size:22px; font-weight:500; color:var(--text); }
.qd-total .cur{ font-size:13px; color:var(--muted); }
.qd-send{ display:flex; align-items:center; justify-content:center; gap:10px; width:100%;
  background: var(--amber); color:#1A1206; border:0.5px solid var(--amber);
  font-family:var(--font-mono); font-size:12.5px; letter-spacing:0.06em; text-transform:uppercase;
  padding:15px; transition: background .15s, color .15s; }
.qd-send:hover{ background: transparent; color: var(--amber); }
.qd-send .ico{ width:17px; height:17px; }
.qd-note{ font-size:11px; color:var(--muted); line-height:1.55; margin-top:12px; text-align:center; }

/* ---- Toast ------------------------------------------------ */
.kp-toast{
  position:fixed; bottom:24px; inset-inline-start:50%; transform:translate(-50%, 24px); z-index:95;
  display:flex; align-items:center; gap:10px; padding:12px 16px;
  background: var(--panel); border:0.5px solid var(--accent);
  font-family:var(--font-mono); font-size:12px; color:var(--text); letter-spacing:0.03em;
  opacity:0; pointer-events:none; transition: opacity .3s ease, transform .3s cubic-bezier(.2,.7,.2,1);
  box-shadow: 0 20px 50px -25px rgba(0,0,0,.7);
}
.kp-toast.show{ opacity:1; transform:translate(-50%, 0); pointer-events:auto; }
.kp-toast svg{ width:16px; height:16px; color: var(--accent); }
.kp-toast-cta{ background:transparent; border:0; color:var(--accent); font-family:inherit; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; border-bottom:0.5px solid var(--accent); padding:1px 0; margin-inline-start:4px; }

/* ---- Marquee ticker --------------------------------------- */
.marquee{ border-block:0.5px solid var(--line); overflow:hidden; background: var(--panel-2); position:relative; }
.marquee::before, .marquee::after{ content:""; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none; }
.marquee::before{ inset-inline-start:0; background:linear-gradient(90deg, var(--panel-2), transparent); }
.marquee::after{ inset-inline-end:0; background:linear-gradient(270deg, var(--panel-2), transparent); }
[dir="rtl"] .marquee::before{ background:linear-gradient(270deg, var(--panel-2), transparent); }
[dir="rtl"] .marquee::after{ background:linear-gradient(90deg, var(--panel-2), transparent); }
.marquee-track{ display:flex; gap:0; width:max-content; animation: mq 38s linear infinite; }
.no-scan .marquee-track{ animation:none; }
[dir="rtl"] .marquee-track{ animation-name: mq-rtl; }
.marquee:hover .marquee-track{ animation-play-state: paused; }
.mq-item{ display:inline-flex; align-items:center; gap:12px; padding:14px 30px; font-family:var(--font-mono); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.mq-item .star{ width:6px; height:6px; background: var(--accent); transform:rotate(45deg); flex:0 0 auto; }
@keyframes mq{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@keyframes mq-rtl{ from{ transform:translateX(0);} to{ transform:translateX(50%);} }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

/* ---- Stats band ------------------------------------------- */
.stats{ display:grid; grid-template-columns: repeat(4,1fr); border:0.5px solid var(--line); }
.stat{ padding:34px 28px; border-inline-start:0.5px solid var(--line); position:relative; overflow:hidden; }
.stat:first-child{ border-inline-start:0; }
.stat .sv{ font-family:var(--font-mono); font-size: clamp(34px,4.5vw,56px); font-weight:400; color:var(--text); letter-spacing:-0.01em; line-height:1; font-variant-numeric: tabular-nums; }
.stat .sv .suf{ color: var(--accent); font-size:0.5em; margin-inline-start:2px; }
.stat .sl{ font-size:13px; color:var(--muted); margin-top:12px; line-height:1.4; }
.stat .sbar{ position:absolute; inset-inline-start:0; bottom:0; height:2px; width:0; background: var(--accent); transition: width 1.1s cubic-bezier(.2,.7,.2,1); }
.stat.in .sbar{ width:100%; }
@media (max-width: 880px){ .stats{ grid-template-columns:repeat(2,1fr); } .stat:nth-child(3){ border-inline-start:0; } .stat:nth-child(n+3){ border-top:0.5px solid var(--line); } }

/* ---- Section eyebrow head --------------------------------- */
.sec-head .ey-row{ display:flex; align-items:center; gap:12px; }
.sec-head .ey-row::before{ content:""; width:24px; height:0.5px; background: var(--accent); }
.sec-head .lead{ color:var(--muted); font-size:14px; max-width:42ch; margin:10px 0 0; line-height:1.55; }
.sec-head .head-l{ min-width:0; }

/* ---- Categories grid -------------------------------------- */
.catgrid{ display:grid; grid-template-columns: repeat(3,1fr); border-top:0.5px solid var(--line); border-inline-start:0.5px solid var(--line); }
.catcard{ position:relative; border-inline-end:0.5px solid var(--line); border-bottom:0.5px solid var(--line); padding:26px 24px 22px; display:flex; flex-direction:column; gap:14px; min-height:220px; overflow:hidden; transition: background .25s; }
.catcard:hover{ background: color-mix(in srgb, var(--accent) 5%, var(--panel)); }
.catcard .cc-fig{ width:64px; height:64px; }
.catcard .cc-fig svg.schematic{ width:100%; height:100%; color: var(--accent); }
.catcard .cc-n{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); position:absolute; top:18px; inset-inline-end:20px; }
.catcard h3{ margin:0; font-size:19px; font-weight:500; letter-spacing:-0.005em; }
.catcard .cc-count{ font-family:var(--font-mono); font-size:12px; color:var(--muted); margin-top:auto; }
.catcard .cc-go{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--accent); opacity:0; transform:translateY(4px); transition: opacity .22s, transform .22s; margin-top:6px; }
.catcard:hover .cc-go{ opacity:1; transform:none; }
.catcard .cc-go svg{ width:14px; height:14px; }
[dir="rtl"] .catcard .cc-go svg{ transform: scaleX(-1); }
.catcard::after{ content:""; position:absolute; inset-inline-end:-1px; bottom:-1px; width:40px; height:40px; border-inline-end:0.5px solid var(--line-strong); border-bottom:0.5px solid var(--line-strong); opacity:0; transition: opacity .25s; }
.catcard:hover::after{ opacity:1; }
@media (max-width: 880px){ .catgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 520px){ .catgrid{ grid-template-columns:1fr; } }

/* ---- Story split ------------------------------------------ */
.story{ display:grid; grid-template-columns: 0.92fr 1.08fr; gap:0; border:0.5px solid var(--line); align-items:stretch; }
.story-fig{ position:relative; background: var(--panel-2); overflow:hidden; min-height:420px; border-inline-end:0.5px solid var(--line); }
.story-canvas{ position:absolute; inset:0; width:100%; height:100%; }
.story-fig .sf-meta{ position:absolute; bottom:14px; inset-inline-start:18px; font-family:var(--font-mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); z-index:2; }
.story-fig .regmark{ opacity:.7; }
.story-copy{ padding: clamp(30px,4vw,52px); display:flex; flex-direction:column; justify-content:center; }
.story-copy h2{ font-size: clamp(26px,3.4vw,40px); font-weight:500; letter-spacing:-0.015em; margin:16px 0 0; line-height:1.1; text-wrap:balance; }
.story-copy .sp{ color:var(--muted); font-size:15px; line-height:1.65; margin:18px 0 0; max-width:52ch; }
.story-list{ margin:28px 0 0; display:flex; flex-direction:column; }
.story-li{ display:grid; grid-template-columns:auto 1fr; gap:14px; padding:16px 0; border-top:0.5px solid var(--line); align-items:start; }
.story-li .sli-n{ font-family:var(--font-mono); font-size:12px; color:var(--accent); letter-spacing:0.1em; padding-top:2px; }
.story-li b{ font-weight:500; font-size:15px; display:block; }
.story-li span{ color:var(--muted); font-size:13.5px; line-height:1.5; display:block; margin-top:3px; }
@media (max-width: 900px){ .story{ grid-template-columns:1fr; } .story-fig{ border-inline-end:0; border-bottom:0.5px solid var(--line); min-height:300px; } }

/* ---- Industries ------------------------------------------- */
.indgrid{ display:grid; grid-template-columns: repeat(4,1fr); border-top:0.5px solid var(--line); border-inline-start:0.5px solid var(--line); }
.indcard{ border-inline-end:0.5px solid var(--line); border-bottom:0.5px solid var(--line); padding:26px 22px; display:flex; flex-direction:column; gap:14px; position:relative; overflow:hidden; }
.indcard .ic-fig{ width:46px; height:46px; color:var(--accent); }
.indcard .ic-fig svg{ width:100%; height:100%; }
.indcard h4{ margin:0; font-size:16px; font-weight:500; line-height:1.25; }
.indcard p{ margin:0; color:var(--muted); font-size:13px; line-height:1.55; }
.indcard .ic-i{ position:absolute; top:18px; inset-inline-end:20px; font-family:var(--font-mono); font-size:10px; color:var(--muted); letter-spacing:0.12em; }
.indcard .ic-sweep{ position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--accent) 8%,transparent),transparent); transform:translateY(-100%); }
.indcard:hover .ic-sweep{ animation: scan 0.9s ease-out forwards; }
@media (max-width: 880px){ .indgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 460px){ .indgrid{ grid-template-columns:1fr; } }

/* ---- Why / guarantees row --------------------------------- */
.whyrow{ display:grid; grid-template-columns:repeat(4,1fr); border:0.5px solid var(--line); }
.whycell{ padding:26px 22px; border-inline-start:0.5px solid var(--line); }
.whycell:first-child{ border-inline-start:0; }
.whycell .wc-ic{ width:30px; height:30px; color:var(--accent); margin-bottom:16px; }
.whycell .wc-ic svg{ width:100%; height:100%; }
.whycell b{ font-weight:500; font-size:15px; display:block; }
.whycell span{ color:var(--muted); font-size:13px; line-height:1.5; display:block; margin-top:6px; }
@media (max-width: 880px){ .whyrow{ grid-template-columns:repeat(2,1fr); } .whycell:nth-child(3){ border-inline-start:0; } .whycell:nth-child(n+3){ border-top:0.5px solid var(--line); } }
@media (max-width: 460px){ .whyrow{ grid-template-columns:1fr; } .whycell{ border-inline-start:0; border-top:0.5px solid var(--line); } .whycell:first-child{ border-top:0; } }

/* ---- CTA band --------------------------------------------- */
.ctaband{ position:relative; border:0.5px solid var(--line-strong); padding: clamp(40px,6vw,72px) clamp(28px,5vw,64px); overflow:hidden; background: var(--panel); }
.ctaband .regmark{ opacity:.8; }
.ctaband-grid{ display:grid; grid-template-columns: 1.2fr auto; gap:30px; align-items:center; position:relative; z-index:2; }
.ctaband h2{ font-size: clamp(28px,4vw,46px); font-weight:500; letter-spacing:-0.02em; margin:0; line-height:1.06; text-wrap:balance; }
.ctaband p{ color:var(--muted); font-size:15px; line-height:1.6; margin:16px 0 0; max-width:46ch; }
.ctaband-cta{ display:flex; gap:12px; flex-wrap:wrap; }
.ctaband .bgline{ position:absolute; inset:0; opacity:.5; pointer-events:none; }
@media (max-width: 820px){ .ctaband-grid{ grid-template-columns:1fr; } }

/* ---- About page ------------------------------------------- */
.page-hero{ padding: clamp(40px,6vw,86px) 0 clamp(30px,4vw,54px); border-bottom:0.5px solid var(--line); position:relative; }
.page-hero .eyebrow{ margin-bottom:16px; }
.page-hero h1{ font-size: clamp(32px,5vw,60px); font-weight:500; letter-spacing:-0.02em; line-height:1.04; margin:0; max-width:18ch; text-wrap:balance; }
.page-hero .ph-lead{ color:var(--muted); font-size: clamp(15px,1.6vw,19px); line-height:1.6; margin:22px 0 0; max-width:56ch; }
.prose-grid{ display:grid; grid-template-columns: 0.8fr 1.2fr; gap:0; border:0.5px solid var(--line); }
.prose-side{ padding: clamp(24px,3vw,40px); border-inline-end:0.5px solid var(--line); }
.prose-side .ps-k{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }
.prose-side .ps-v{ font-size:18px; font-weight:500; margin-top:8px; line-height:1.3; }
.prose-main{ padding: clamp(24px,3vw,40px); }
.prose-main p{ font-size:15px; line-height:1.7; color: var(--text); margin:0 0 18px; max-width:62ch; }
.prose-main p.muted{ color: var(--muted); }
.prose-main h3{ font-size:14px; font-family:var(--font-mono); letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); margin:34px 0 14px; }
.valuegrid{ display:grid; grid-template-columns:repeat(3,1fr); border-top:0.5px solid var(--line); border-inline-start:0.5px solid var(--line); }
.valcell{ padding:26px 22px; border-inline-end:0.5px solid var(--line); border-bottom:0.5px solid var(--line); }
.valcell .vn{ font-family:var(--font-mono); font-size:12px; color:var(--accent); letter-spacing:0.12em; }
.valcell h4{ margin:14px 0 8px; font-size:17px; font-weight:500; }
.valcell p{ margin:0; color:var(--muted); font-size:13.5px; line-height:1.55; }
@media (max-width: 820px){ .prose-grid{ grid-template-columns:1fr; } .prose-side{ border-inline-end:0; border-bottom:0.5px solid var(--line); } .valuegrid{ grid-template-columns:1fr; } }

.timeline{ border:0.5px solid var(--line); }
.tl-row{ display:grid; grid-template-columns: 150px 1fr; gap:0; }
.tl-row + .tl-row{ border-top:0.5px solid var(--line); }
.tl-y{ padding:22px 22px; font-family:var(--font-mono); font-size:13px; color:var(--accent); letter-spacing:0.08em; border-inline-end:0.5px solid var(--line); }
.tl-c{ padding:22px 24px; }
.tl-c b{ font-weight:500; font-size:15px; display:block; }
.tl-c span{ color:var(--muted); font-size:13.5px; line-height:1.55; display:block; margin-top:5px; }
@media (max-width: 620px){ .tl-row{ grid-template-columns:1fr; } .tl-y{ border-inline-end:0; border-bottom:0.5px solid var(--line); padding-bottom:8px; } }

/* ---- Contact page ----------------------------------------- */
.contact-grid{ display:grid; grid-template-columns: 1fr 1fr; border:0.5px solid var(--line); }
.contact-form{ padding: clamp(26px,3.4vw,44px); border-inline-end:0.5px solid var(--line); }
.contact-aside{ padding: clamp(26px,3.4vw,44px); background: var(--panel-2); display:flex; flex-direction:column; gap:26px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.field input, .field select, .field textarea{
  width:100%; background: var(--ink); border:0.5px solid var(--line); color:var(--text);
  font-family: var(--font-display); font-size:14px; padding:12px 13px; transition: border-color .18s;
}
.field textarea{ resize:vertical; min-height:108px; font-family: var(--font-display); }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color: var(--accent); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.contact-submit{ width:100%; justify-content:center; padding:15px; margin-top:6px; }
.cinfo .ci-k{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.cinfo .ci-v{ font-size:15px; line-height:1.55; }
.cinfo .ci-v a:hover{ color: var(--accent); }
.cmap{ position:relative; aspect-ratio: 16/10; background: var(--ink); border:0.5px solid var(--line); overflow:hidden; }
.cmap svg{ width:100%; height:100%; display:block; }
.cmap .cm-tag{ position:absolute; bottom:10px; inset-inline-start:12px; font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); }
.formnote{ font-size:12px; color:var(--muted); line-height:1.55; margin-top:14px; }
.form-success{ display:none; padding:18px; border:0.5px solid var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); font-family:var(--font-mono); font-size:13px; color:var(--text); margin-bottom:20px; align-items:center; gap:10px; }
.form-success.show{ display:flex; }
.form-success svg{ width:18px; height:18px; color:var(--accent); flex:0 0 auto; }
@media (max-width: 760px){ .contact-grid{ grid-template-columns:1fr; } .contact-form{ border-inline-end:0; border-bottom:0.5px solid var(--line); } .field-row{ grid-template-columns:1fr; } }

/* ---- Reveal helpers for new sections ---------------------- */
html.kp-motion [data-reveal-x]{ opacity:0; transform: translateX(var(--rx,-24px)); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
html.kp-motion [data-reveal-x].in{ opacity:1; transform:none; }
html.kp-motion [data-reveal-s]{ opacity:0; transform: scale(.96); transition: opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--ri,0)*55ms); }
html.kp-motion [data-reveal-s].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  html.kp-motion [data-reveal-x], html.kp-motion [data-reveal-s]{ opacity:1 !important; transform:none !important; }
}
