/* =====================================================================
   NEXSOLID  ·  nexsolid.com.au
   Direction E — Apple/Rivian calm. Paper light, one teal node,
   Schibsted Grotesk + Fraunces italic + Space Mono micro-type.
   ===================================================================== */

:root{
  --ink:#0A0A0B;
  --ink-2:#55565B;
  --ink-3:#8A8B90;
  --ink-4:#B7B8BD;
  --paper:#FBFBFD;
  --paper-2:#F4F4F7;
  --line:#E2E2E6;
  --line-soft:#EDEDF0;
  --teal:#15B8AF;
  --teal-ink:#0C8C85;
  --maxw:1200px;
  --pad:64px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:"Schibsted Grotesk",system-ui,sans-serif;
  font-feature-settings:"ss01","cv01";font-variant-numeric:tabular-nums;
  line-height:1.5;overflow-x:hidden;
}
::selection{background:var(--teal);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
em{font-family:"Fraunces",Georgia,serif;font-style:italic;font-weight:400;letter-spacing:-.01em}
.mono{font-family:"Space Mono",monospace}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

/* grain */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.030;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- signature: left measurement rail ---------- */
.rail{position:fixed;left:26px;top:0;bottom:0;width:52px;z-index:40;display:flex;align-items:center;pointer-events:none}
.rail-line{position:absolute;left:8px;top:12vh;bottom:12vh;width:1px;background:var(--line)}
.rail-node{position:absolute;left:4px;width:9px;height:9px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 4px rgba(21,184,175,.14);transition:top .15s linear}
.rail-ticks{position:absolute;left:0;top:12vh;bottom:12vh;list-style:none;display:flex;flex-direction:column;justify-content:space-between}
.rail-ticks li{position:relative;height:0;display:flex;align-items:center;gap:9px;pointer-events:auto}
.rail-ticks li::before{content:"";width:7px;height:1px;background:var(--line)}
.rail-ticks li i{font-family:"Space Mono",monospace;font-style:normal;font-size:10px;color:var(--ink-4);transition:color .3s}
.rail-ticks li span{font-family:"Space Mono",monospace;font-size:9.5px;letter-spacing:.06em;color:transparent;white-space:nowrap;transition:color .3s;text-transform:uppercase}
.rail-ticks li.on i{color:var(--ink)}
.rail-ticks li.on span{color:var(--ink-3)}
@media (max-width:1320px){.rail{display:none}}

/* ---------- top rule + nav ---------- */
.topbar-rule{height:2px;width:100%;background:var(--line-soft);position:relative;z-index:30}
.topbar-rule::after{content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--ink);transition:width 1.2s var(--ease)}
.topbar-rule.in::after{width:34%}
nav{display:flex;align-items:baseline;justify-content:space-between;padding:28px 0 0;position:relative;z-index:30}
.brand{display:flex;align-items:baseline;gap:13px}
.brand .mark{font-size:19px;font-weight:600;letter-spacing:-.04em;color:var(--ink)}
.brand .sub{font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.navlinks{display:flex;gap:32px;font-size:13.5px;color:var(--ink-2);letter-spacing:.01em}
.navlinks a{position:relative;padding-bottom:3px;transition:color .25s}
.navlinks a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--ink);transition:width .3s var(--ease)}
.navlinks a:hover{color:var(--ink)}
.navlinks a:hover::after{width:100%}
.navlinks a.now{color:var(--ink)}

/* ---------- hero ---------- */
.hero{padding:74px 0 0}
.eyebrow{font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:30px;display:flex;align-items:center;gap:12px;opacity:0;transform:translateY(8px);transition:.8s var(--ease) .1s}
.eyebrow.in{opacity:1;transform:none}
.eyebrow .pip{width:5px;height:5px;border-radius:50%;background:var(--teal);display:inline-block}
h1{font-size:clamp(46px,9.2vw,116px);line-height:.95;letter-spacing:-.045em;font-weight:500;max-width:15ch}
.reveal-lines .ln{display:block;overflow:hidden;padding-bottom:.04em}
.reveal-lines .ln>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}
.reveal-lines.in .ln:nth-child(1)>span{transition-delay:.05s}
.reveal-lines.in .ln:nth-child(2)>span{transition-delay:.16s}
.reveal-lines.in .ln>span{transform:none}
.lede{margin-top:34px;max-width:54ch;font-size:clamp(16px,1.5vw,19px);line-height:1.55;color:var(--ink-2)}
.herometa{margin-top:48px;display:flex;gap:34px;align-items:center;border-top:1px solid var(--line);padding-top:22px;flex-wrap:wrap}
.cta{font-size:14px;letter-spacing:.01em;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;transition:.25s}
.cta:hover{color:var(--teal-ink);border-color:var(--teal)}
.loc{font-family:"Space Mono",monospace;font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;margin-left:auto}

/* ---------- photo plates ---------- */
.plate-row{padding:78px 0 0}
.plate{position:relative;border-radius:14px;overflow:hidden;background:#0E1112;box-shadow:0 1px 0 var(--line),0 34px 70px -42px rgba(10,12,16,.5)}
.plate img{display:block;width:100%;height:clamp(320px,52vw,560px);object-fit:cover;will-change:transform}
.plate.sm img{height:clamp(260px,32vw,400px)}
.plate .cap{position:absolute;left:24px;bottom:20px;color:#F4F5F6;font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.04em;display:flex;align-items:center;gap:11px;text-shadow:0 1px 18px rgba(0,0,0,.5)}
.plate .cap .dot{width:6px;height:6px;border-radius:50%;background:var(--teal)}
.plate .cap .sep{color:rgba(244,245,246,.45)}
.plates{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:60px}

/* ---------- stats ---------- */
.stats{padding:112px 0 0}
.head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:18px}
.head .t{font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.head .n{font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.1em;color:var(--ink-3)}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);margin-top:54px}
.stat{padding:0 30px;border-left:1px solid var(--line)}
.stat:first-child{border-left:0;padding-left:0}
.stat .fig{font-size:clamp(44px,5.4vw,68px);line-height:1;letter-spacing:-.04em;font-weight:500}
.stat .fig sub{font-size:.36em;vertical-align:baseline;letter-spacing:-.02em;color:var(--ink-2);margin-left:3px}
.stat .lab{margin-top:18px;font-size:13.5px;line-height:1.5;color:var(--ink-2);max-width:23ch}

/* ---------- block / intro ---------- */
.block{padding:clamp(96px,12vw,164px) 0}
.block.tint{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.intro{display:grid;grid-template-columns:.4fr .6fr;gap:40px;align-items:start}
.intro .l{font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);padding-top:10px}
.intro h2{font-size:clamp(28px,4.2vw,44px);line-height:1.06;letter-spacing:-.035em;font-weight:500;max-width:19ch}
.archnote{margin-top:46px;max-width:60ch;font-size:clamp(16px,1.5vw,19px);line-height:1.55;color:var(--ink-2);padding-left:clamp(0px,42%,460px)}
.archnote strong{font-weight:600;color:var(--ink)}
.lede2{font-size:clamp(15px,1.4vw,18px);line-height:1.6;color:var(--ink-2);max-width:54ch}

/* ---------- editorial list ---------- */
.list{margin-top:60px;border-top:1px solid var(--line);list-style:none}
.item{display:grid;grid-template-columns:60px .4fr .6fr;gap:0 40px;align-items:baseline;padding:30px 0;border-bottom:1px solid var(--line);position:relative}
.item .idx{font-family:"Space Mono",monospace;font-size:13px;color:var(--ink-3)}
.item .name{font-size:clamp(20px,2.3vw,25px);letter-spacing:-.02em;font-weight:500}
.item .name .sci{font-family:"Space Mono",monospace;font-size:.6em;color:var(--ink-3);margin-left:8px;letter-spacing:0}
.item .name .tag{display:inline-block;margin-left:14px;font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-ink);vertical-align:middle}
.item .desc{font-size:15px;line-height:1.55;color:var(--ink-2);max-width:48ch}
.item.flag::before{content:"";position:absolute;left:-26px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--teal)}
.item.flag .name{font-weight:600}

/* ---------- vertical integration chain ---------- */
.chain{margin-top:58px;list-style:none;display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line)}
.chain li{padding:30px 24px 36px 0;border-right:1px solid var(--line);position:relative}
.chain li:last-child{border-right:0}
.chain li::before{content:"";position:absolute;left:0;top:-1px;width:0;height:2px;background:var(--teal);transition:width 1s var(--ease)}
.chain li.in::before{width:30px}
.chain .ci{font-family:"Space Mono",monospace;font-size:12px;color:var(--ink-3)}
.chain h3{margin-top:22px;font-size:17px;line-height:1.2;letter-spacing:-.02em;font-weight:600}
.chain p{margin-top:12px;font-size:13.5px;line-height:1.5;color:var(--ink-2)}

/* ---------- company ---------- */
.company{margin-top:62px;display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.company .cleft .lede2+ .lede2{margin-top:20px}
.offices{margin-top:38px;display:flex;gap:40px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:24px}
.office{display:flex;flex-direction:column;gap:6px}
.office .ot{font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.office .oc{font-size:16px;letter-spacing:-.01em}

/* ---------- contact ---------- */
.contact{background:var(--ink);color:var(--paper);border:0}
.contact .l{font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-4)}
.cgrid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:end}
.contact h2.big{margin-top:24px;font-size:clamp(32px,5vw,62px);line-height:1.02;letter-spacing:-.04em;font-weight:500;color:var(--paper);max-width:16ch}
.contact h2.big em{color:#fff}
.maillink{font-size:clamp(20px,2.4vw,28px);letter-spacing:-.02em;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:5px;transition:.25s}
.maillink:hover{border-color:var(--teal);color:var(--teal)}
.crow{display:flex;gap:10px;flex-wrap:wrap;margin-top:34px}
.crow span{font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.04em;color:var(--paper);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:8px 15px}
.cnote{margin-top:28px;font-size:14.5px;line-height:1.6;color:var(--ink-4);max-width:42ch}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--ink-4);padding:30px 0 56px}
.frow{display:flex;justify-content:space-between;align-items:baseline;gap:24px;flex-wrap:wrap;font-family:"Space Mono",monospace;font-size:11.5px;letter-spacing:.05em;border-top:1px solid rgba(255,255,255,.12);padding-top:30px}
.fbrand{color:var(--paper);font-family:"Schibsted Grotesk",sans-serif;font-weight:600;font-size:16px;letter-spacing:-.03em;display:flex;align-items:baseline;gap:14px}
.fbrand i{font-family:"Space Mono",monospace;font-style:normal;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);font-weight:400}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.statgrid .stat:nth-child(2){transition-delay:.07s}
.statgrid .stat:nth-child(3){transition-delay:.14s}
.statgrid .stat:nth-child(4){transition-delay:.21s}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important}
  .reveal,.eyebrow{opacity:1;transform:none}
  .reveal-lines .ln>span{transform:none}
}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  :root{--pad:40px}
  .statgrid{grid-template-columns:repeat(2,1fr);gap:44px 0}
  .stat{border-left:0;padding-left:0}
  .stat:nth-child(3){padding-left:0}
  .chain{grid-template-columns:repeat(2,1fr)}
  .chain li{border-right:0;border-bottom:1px solid var(--line)}
  .archnote{padding-left:0}
}
@media (max-width:760px){
  :root{--pad:24px}
  .intro,.company,.cgrid,.plates{grid-template-columns:1fr;gap:24px}
  .navlinks{display:none}
  .item{grid-template-columns:40px 1fr;gap:6px 18px}
  .item .desc{grid-column:2}
  .herometa{gap:22px}.loc{margin-left:0;width:100%}
  .chain{grid-template-columns:1fr}
  .frow{flex-direction:column;gap:14px}
}
