/* =================================================================
   NEWIN TECHNOLOGIES — shared design system
   Dark · cinematic · berry-gloss-pink neon
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  /* ink + surfaces */
  --ink:        #060509;
  --bg:         #0a0810;
  --bg-2:       #0d0a14;
  --surface:    #120e1b;
  --surface-2:  #181222;
  --line:       rgba(255,255,255,0.09);
  --line-soft:  rgba(255,255,255,0.05);

  /* text */
  --text:       #f4eef3;
  --muted:      #a499ab;
  --faint:      #6f6675;

  /* berry gloss pink — the brand · Rust-Oleum Gloss Berry Pink #D53B77 */
  --berry:       #d53b77;
  --berry-bright:#ff639f;
  --berry-deep:  #a82c5e;
  --berry-ink:   #270a17;
  --berry-glow:  rgba(213,59,119,0.45);
  --berry-haze:  rgba(213,59,119,0.14);

  --radius:   14px;
  --radius-lg:22px;
  --maxw:     1200px;

  --font-display:'Space Grotesk', system-ui, sans-serif;
  --font-body:   'Manrope', system-ui, sans-serif;
  --font-mono:   'JetBrains Mono', ui-monospace, monospace;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* page-wide atmospheric glow */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(900px 600px at 12% -5%, rgba(213,59,119,0.16), transparent 60%),
    radial-gradient(800px 700px at 100% 0%, rgba(168,44,94,0.12), transparent 55%),
    radial-gradient(1000px 800px at 50% 120%, rgba(213,59,119,0.08), transparent 60%);
  pointer-events:none;
}
/* fine grid texture */
body::after{
  content:"";
  position:fixed; inset:0; z-index:-3;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 50% 30%, black, transparent 85%);
  pointer-events:none;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:110px 0; position:relative; }
.section.tight{ padding:72px 0; }
.center{ text-align:center; }
.mx-auto{ margin-left:auto; margin-right:auto; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:700; line-height:1.04; letter-spacing:-0.02em; margin:0; }
.display{
  font-size:clamp(44px, 7vw, 92px);
  line-height:0.98;
  letter-spacing:-0.035em;
}
.h1{ font-size:clamp(38px,5.2vw,64px); letter-spacing:-0.03em; }
.h2{ font-size:clamp(30px,3.8vw,46px); letter-spacing:-0.025em; }
.h3{ font-size:clamp(21px,2vw,26px); letter-spacing:-0.015em; }
.lead{ font-size:clamp(18px,1.5vw,21px); color:var(--muted); line-height:1.6; max-width:60ch; }
.muted{ color:var(--muted); }
.faint{ color:var(--faint); }

.kicker{
  font-family:var(--font-mono);
  font-size:12.5px;
  font-weight:500;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--berry-bright);
  display:inline-flex; align-items:center; gap:10px;
}
.kicker::before{
  content:""; width:26px; height:1px;
  background:linear-gradient(90deg, var(--berry), transparent);
}
.kicker.solo::before{ display:none; }

.grad-text{
  background:linear-gradient(120deg, #fff 30%, var(--berry-bright) 75%, var(--berry) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-body); font-weight:600; font-size:15.5px;
  padding:14px 26px; border-radius:999px; cursor:pointer;
  border:1px solid transparent; transition:.22s ease; white-space:nowrap;
  letter-spacing:-0.01em;
}
.btn-lg{ padding:17px 34px; font-size:16.5px; }
.btn-primary{
  background:linear-gradient(180deg, var(--berry-bright), var(--berry));
  color:#fff;
  box-shadow:0 8px 30px -8px var(--berry-glow), inset 0 1px 0 rgba(255,255,255,0.35);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -8px var(--berry-glow), inset 0 1px 0 rgba(255,255,255,0.4); }
.btn-ghost{
  background:rgba(255,255,255,0.03);
  border-color:var(--line);
  color:var(--text);
  backdrop-filter:blur(6px);
}
.btn-ghost:hover{ border-color:var(--berry); color:#fff; background:var(--berry-haze); }
.btn-arrow{ transition:transform .22s ease; }
.btn:hover .btn-arrow{ transform:translateX(4px); }

/* ---------- chips / badges ---------- */
.chip{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em;
  text-transform:uppercase; color:var(--muted);
  padding:7px 13px; border:1px solid var(--line); border-radius:999px;
  background:rgba(255,255,255,0.02);
}
.chip .dot{ width:6px; height:6px; border-radius:50%; background:var(--berry-bright); box-shadow:0 0 10px var(--berry-bright); }

/* ---------- cards ---------- */
.card{
  background:linear-gradient(180deg, var(--surface), var(--bg-2));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:30px;
  position:relative;
  transition:.25s ease;
  overflow:hidden;
}
.card:hover{ border-color:rgba(213,59,119,0.45); transform:translateY(-3px); }
.card::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(400px 200px at 80% -10%, var(--berry-haze), transparent 70%);
  opacity:0; transition:.25s ease;
}
.card:hover::after{ opacity:1; }

.grid{ display:grid; gap:22px; }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }

/* numbered index for cards */
.idx{ font-family:var(--font-mono); font-size:12px; color:var(--berry-bright); letter-spacing:0.1em; }

/* ---------- divider ---------- */
.hr{ height:1px; background:linear-gradient(90deg, transparent, var(--line), transparent); border:0; margin:0; }

/* ---------- image placeholder (striped) ---------- */
.ph{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--line);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.022) 0 2px, transparent 2px 11px),
    linear-gradient(160deg, var(--surface-2), var(--bg-2));
  display:flex; align-items:flex-end;
  min-height:220px;
}
.ph .ph-tag{
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.12em;
  color:var(--faint); text-transform:uppercase;
  padding:14px 16px;
}
image-slot{ border-radius:var(--radius-lg); overflow:hidden; }
.gear-img{ height:170px; overflow:hidden; padding:0; }
.gear-img img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(8,6,12,0.72);
  backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:14px 28px;
  display:flex; align-items:center; gap:26px;
}
.brand{ display:flex; align-items:center; gap:11px; flex-shrink:0; }
.brand-mark{ height:34px; width:auto; display:block; filter:drop-shadow(0 0 14px rgba(213,59,119,0.35)); }
.brand-word{ font-family:var(--font-display); font-weight:700; font-size:21px; letter-spacing:-0.03em; line-height:1; color:var(--berry-bright); white-space:nowrap; }
.brand-word b{ font-weight:700; }
.brand-word span{ font-weight:500; opacity:0.92; margin-left:0.3em; }
.nav-links{ display:flex; align-items:center; gap:4px; margin-left:8px; }
.nav-links a{
  font-size:14.5px; font-weight:500; color:var(--muted);
  padding:9px 14px; border-radius:9px; transition:.18s; position:relative;
}
.nav-links a:hover{ color:var(--text); background:rgba(255,255,255,0.04); }
.nav-links a.active{ color:#fff; }
.nav-links a.nthelp{ color:var(--berry-bright); }
.nav-links a.nthelp .dot{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--berry-bright); margin-left:7px; vertical-align:middle;
  box-shadow:0 0 9px var(--berry-bright); animation:pulse 2s infinite;
}
@keyframes pulse{ 0%,100%{opacity:1; transform:scale(1);} 50%{opacity:.4; transform:scale(.7);} }
.nav-spacer{ flex:1; }
.nav-tel{ font-family:var(--font-mono); font-size:13px; color:var(--muted); }
.nav-tel:hover{ color:var(--text); }

.menu-btn{ display:none; }

/* ---------- footer ---------- */
.footer{ border-top:1px solid var(--line); background:var(--ink); padding:70px 0 36px; margin-top:40px; position:relative; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer h5{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--faint); margin:0 0 18px; font-weight:500; }
.footer a{ display:block; color:var(--muted); font-size:14.5px; padding:6px 0; transition:.15s; }
.footer a:hover{ color:var(--berry-bright); }
.footer img.fbrand{ height:36px; margin-bottom:18px; }
.footer .fbrand-lockup{ display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.footer .fbrand-lockup img{ height:40px; width:auto; filter:drop-shadow(0 0 14px rgba(213,59,119,0.3)); }
.footer .fbrand-lockup .brand-word{ font-size:24px; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; margin-top:50px; padding-top:26px; border-top:1px solid var(--line-soft); flex-wrap:wrap; }
.footer-bottom span{ font-family:var(--font-mono); font-size:12px; color:var(--faint); letter-spacing:0.04em; }

/* ---------- reveal-on-scroll ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- utility ---------- */
.flex{ display:flex; }
.items-center{ align-items:center; }
.gap-sm{ gap:10px; } .gap{ gap:18px; } .gap-lg{ gap:28px; }
.wrap-btns{ display:flex; flex-wrap:wrap; gap:14px; }
.stack-lg > * + *{ margin-top:22px; }
.eyebrow-row{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.maxw-720{ max-width:720px; } .maxw-620{ max-width:620px; }

/* ---------- responsive ---------- */
@media (max-width:980px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .g-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:820px){
  .nav-links, .nav-tel{ display:none; }
  .menu-btn{ display:inline-flex; }
  .section{ padding:78px 0; }
  .g-2,.g-3{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .wrap{ padding:0 20px; }
  .g-4{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
}
