/* NetSmiths — netsmiths.com · dark only, no JS required */

:root{
  --bg:#0C0D10; --bg-2:#121319;
  --steel-1:#EDF1F7; --steel-2:#C5CCD7; --steel-3:#9AA2B0; --steel-4:#7E8694;
  --metal-grad:linear-gradient(180deg,#F8FAFD 28%,#C9D0DB 72%,#9AA2B0);
  --gun-grad:linear-gradient(180deg,#3E424B,#21242A);
  --accent:#FF8A3D; --accent-2:#FF5E2C;
  --spark-grad:linear-gradient(135deg,#FFE2A8,#FF9E48,#FF5E2C);
  --text:#F5F6FA; --muted:#9AA3B2; --faint:#6C7280;
  --glass:rgba(255,255,255,.05); --glass-border:rgba(255,255,255,.10); --glass-hi:rgba(255,255,255,.16);
  --r-card:22px; --r-btn:14px; --maxw:900px;
}

*{box-sizing:border-box}
html{color-scheme:dark}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
}
::selection{background:rgba(255,138,61,.28)}
.defs{position:absolute}

/* ground: brushed-steel sheen over obsidian + faint grain */
.ground{position:fixed; inset:0; z-index:0; pointer-events:none}
.ground::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg,rgba(237,241,247,.045),rgba(237,241,247,0) 24%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.013) 0 1px,transparent 1px 3px);
}
.ground::after{
  content:""; position:absolute; inset:0; opacity:.05;
  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='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
}

.wrap{
  position:relative; z-index:1;
  max-width:var(--maxw); margin:0 auto;
  padding:0 clamp(24px,6vw,48px);
  display:flex; flex-direction:column; min-height:100vh;
}
main{flex:1}

/* header */
header.site{display:flex; align-items:center; gap:14px; padding:clamp(24px,4vw,38px) 0}
.wordmark{font-size:21px; font-weight:800; letter-spacing:-.5px}
.wordmark .net{color:var(--muted)}

/* hero */
.hero{
  position:relative; display:flex; flex-direction:column; align-items:center;
  text-align:center; gap:24px;
  padding:clamp(48px,10vh,104px) 0 clamp(56px,9vh,92px);
}
.hero::before{ /* the one ember glow, low in the hero */
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  bottom:-6%; width:min(1100px,120vw); height:60%;
  background:radial-gradient(55% 65% at 50% 100%,rgba(255,138,61,.13),rgba(0,0,0,0) 72%);
  pointer-events:none;
}
.hero>*{position:relative}
.eyebrow{margin:0; font-size:13px; font-weight:600; letter-spacing:.17em; color:var(--accent)}
h1{
  margin:0; font-size:clamp(38px,6.5vw,66px); font-weight:800;
  letter-spacing:-.022em; line-height:1.06; max-width:17ch;
  background:var(--metal-grad);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-wrap:balance;
}
.sub{margin:4px 0 0; font-size:clamp(16px,2vw,19px); line-height:1.65; color:var(--muted); max-width:54ch; text-wrap:pretty}
.cta{
  display:inline-flex; align-items:center; gap:10px; margin-top:10px;
  padding:15px 28px; border-radius:var(--r-btn);
  background:var(--glass); border:1px solid rgba(255,255,255,.13);
  box-shadow:inset 0 1px 0 var(--glass-hi),0 8px 24px rgba(0,0,0,.35);
  color:var(--text); font-size:16px; font-weight:600; text-decoration:none;
  transition:border-color .2s,color .2s;
}
.cta:hover,.cta:focus-visible{border-color:rgba(255,158,72,.5); color:#FFE2A8}
.forge-line{margin:22px 0 0; font-size:14px; color:var(--faint)}

/* ethos */
.ethos{
  display:grid; grid-template-columns:repeat(2,1fr); gap:16px;
  padding-bottom:clamp(56px,9vh,92px);
}
.ethos article{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--r-card); padding:26px 28px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.09);
}
.ethos h2{margin:0 0 8px; font-size:18px; font-weight:700; letter-spacing:-.01em}
.ethos p{margin:0; font-size:15px; line-height:1.6; color:var(--muted)}

/* footer */
footer.site{
  border-top:1px solid rgba(255,255,255,.08);
  padding:28px 0 40px;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  gap:14px 24px;
}
.foot-contact{display:flex; align-items:center; gap:12px; font-size:14px; color:var(--muted)}
.foot-contact a{color:var(--text); text-decoration:none; border-bottom:1px solid rgba(255,255,255,.25); transition:border-color .2s,color .2s}
.foot-contact a:hover,.foot-contact a:focus-visible{color:#FFE2A8; border-color:rgba(255,158,72,.5)}
.legal{margin:0; font-size:13px; color:var(--faint); line-height:1.6; text-wrap:pretty}

/* mobile */
@media (max-width:640px){
  .hero{align-items:flex-start; text-align:left}
  .hero::before{left:0; transform:none; width:140vw}
  .ethos{grid-template-columns:1fr}
}
