
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#0d0d0b;
  --ink-2:#1a1a17;
  --ink-3:#2e2e2a;
  --rule:#e8e4dc;
  --rule-2:#d4cfc4;
  --paper:#f7f4ee;
  --paper-2:#ece8e0;
  --lime:#b8e04a;
  --lime-dim:#9acc2e;
  --text:#0d0d0b;
  --muted:#7a7670;
  --serif:'Libre Baskerville',Georgia,serif;
  --sans:'Space Grotesk',sans-serif;
}

html{scroll-behavior:smooth}

body{
  background:var(--paper);
  color:var(--text);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
}

/* UTILITY */
.eyebrow{
  font-family:var(--sans);
  font-size:0.7rem;
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted);
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5vw;
  height:64px;
  background:rgba(247,244,238,0.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--rule);
}

.logo{
  font-family:var(--serif);
  font-size:1.15rem;
  font-weight:700;
  color:var(--ink);
  text-decoration:none;
  letter-spacing:-0.01em;
}
.logo em{font-style:normal;color:var(--muted)}

.nav-links{display:flex;align-items:center;gap:2.5rem;list-style:none}
.nav-links a{
  color:var(--muted);text-decoration:none;
  font-size:0.8rem;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;
  transition:color 0.2s;
}
.nav-links a:hover{color:var(--ink)}

.nav-cta{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:var(--ink);color:var(--paper) !important;
  padding:0.55rem 1.2rem;border-radius:2px;
  font-weight:600 !important;letter-spacing:0.04em;
  transition:background 0.2s !important;
}
.nav-cta:hover{background:var(--ink-3) !important}

/* HERO */
#hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  padding-top:64px;
  position:relative;
  overflow:hidden;
}

.hero-left{
  padding:8rem 5vw 6rem 5vw;
  display:flex;flex-direction:column;justify-content:center;
  border-right:1px solid var(--rule);
  position:relative;
  z-index:1;
}

.hero-right{
  background:var(--ink);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:4rem 4rem 5rem;
  position:relative;
  overflow:hidden;
}

/* big typographic watermark */
.hero-wm{
  position:absolute;
  top:-2rem;right:-1rem;
  font-family:var(--serif);
  font-size:22rem;
  font-weight:700;
  line-height:1;
  color:rgba(255,255,255,0.03);
  pointer-events:none;
  user-select:none;
  letter-spacing:-0.05em;
}

.hero-index{
  position:absolute;top:3rem;left:4rem;
  font-size:0.65rem;letter-spacing:0.2em;
  text-transform:uppercase;color:rgba(255,255,255,0.25);
  font-family:var(--sans);
}

.hero-tag{
  display:inline-flex;align-items:center;gap:0.4rem;
  font-size:0.68rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:2.5rem;
  opacity:0;animation:fadeUp 0.5s 0.1s forwards;
}
.hero-tag::before{
  content:'';display:block;width:24px;height:1px;background:var(--rule-2);
}

h1{
  font-family:var(--serif);
  font-size:clamp(2.8rem,5.5vw,5rem);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-0.02em;
  color:var(--ink);
  margin-bottom:2rem;
  opacity:0;animation:fadeUp 0.6s 0.2s forwards;
}
h1 .accent{
  font-style:italic;
  color:var(--ink-3);
}

.hero-desc{
  font-size:1rem;font-weight:300;color:var(--muted);
  max-width:400px;line-height:1.8;
  margin-bottom:3rem;
  opacity:0;animation:fadeUp 0.6s 0.35s forwards;
}

.hero-actions{
  display:flex;gap:0.75rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp 0.6s 0.5s forwards;
}

.btn{
  display:inline-flex;align-items:center;gap:0.4rem;
  font-family:var(--sans);font-size:0.82rem;font-weight:600;
  text-decoration:none;border-radius:2px;cursor:pointer;border:none;
  padding:0.8rem 1.6rem;letter-spacing:0.04em;
  transition:all 0.22s;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--ink-3);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule-2)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-1px)}

/* right panel stat block */
.hero-stat-block{
  position:relative;z-index:1;
  opacity:0;animation:fadeUp 0.6s 0.6s forwards;
}

.stat-big{
  font-family:var(--serif);
  font-size:6rem;
  font-weight:700;
  line-height:1;
  color:var(--lime);
  letter-spacing:-0.04em;
}
.stat-caption{
  font-size:0.75rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);margin-top:0.5rem;
}

.hero-divider{
  width:100%;height:1px;background:rgba(255,255,255,0.08);
  margin:2rem 0;
}

.hero-meta{
  display:flex;gap:2.5rem;
  opacity:0;animation:fadeUp 0.6s 0.75s forwards;
}
.meta-item .val{
  font-family:var(--serif);
  font-size:1.5rem;font-weight:700;color:#fff;
}
.meta-item .lbl{
  font-size:0.65rem;font-weight:500;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.35);
  margin-top:0.15rem;
}

/* TICKER */
.ticker{
  background:var(--lime);
  padding:0.7rem 0;
  overflow:hidden;
  white-space:nowrap;
  border-top:1px solid var(--lime-dim);
  border-bottom:1px solid var(--lime-dim);
}
.ticker-inner{
  display:inline-flex;gap:0;
  animation:ticker 28s linear infinite;
}
.ticker-inner span{
  font-size:0.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink);padding:0 2.5rem;
}
.ticker-inner span::after{content:'—';margin-left:2.5rem;opacity:0.4}

@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:7rem 5vw;position:relative}

h2{
  font-family:var(--serif);
  font-size:clamp(2rem,3.5vw,2.8rem);
  font-weight:700;
  letter-spacing:-0.02em;
  color:var(--ink);
  line-height:1.1;
}

/* SERVICES */
#services{border-top:1px solid var(--rule)}

.services-top{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;
  margin-bottom:5rem;
}
.services-top h2{margin-bottom:0}
.services-top p{color:var(--muted);font-weight:300;font-size:0.95rem;line-height:1.85;max-width:360px}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  border:1px solid var(--rule);
}

.svc-card{
  padding:2.5rem 2rem;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  position:relative;
  transition:background 0.22s;
  overflow:hidden;
}
.svc-card:nth-child(3n){border-right:none}
.svc-card:nth-child(n+4){border-bottom:none}
.svc-card::before{
  content:'';
  position:absolute;bottom:0;left:0;
  width:100%;height:3px;
  background:var(--lime);
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s;
}
.svc-card:hover{background:var(--paper-2)}
.svc-card:hover::before{transform:scaleX(1)}

.svc-num{
  font-family:var(--serif);
  font-size:0.75rem;font-weight:700;
  color:var(--rule-2);
  margin-bottom:2rem;
  display:block;
}

.svc-card h3{
  font-family:var(--serif);
  font-size:1.1rem;font-weight:700;
  color:var(--ink);margin-bottom:0.75rem;
}
.svc-card p{color:var(--muted);font-size:0.875rem;font-weight:300;line-height:1.75}

.svc-arrow{
  display:block;margin-top:2rem;
  font-size:1.2rem;color:var(--rule-2);
  transition:all 0.22s;
}
.svc-card:hover .svc-arrow{color:var(--ink);transform:translate(3px,-3px)}

/* PROCESS */
#process{
  background:var(--ink);
  color:#fff;
  border-top:1px solid var(--ink-2);
}

#process .eyebrow{color:rgba(255,255,255,0.3)}

.process-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:5rem;
  padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,0.08);
}

#process h2{color:#fff}

.process-note{
  max-width:280px;
  font-size:0.875rem;color:rgba(255,255,255,0.4);
  font-weight:300;line-height:1.8;
}

.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0}

.pstep{
  padding:2.5rem 2rem 2.5rem 0;
  border-right:1px solid rgba(255,255,255,0.07);
  padding-right:2rem;
}
.pstep:last-child{border-right:none;padding-right:0}
.pstep:not(:first-child){padding-left:2rem}

.pstep-num{
  font-family:var(--serif);
  font-size:3rem;font-weight:700;
  color:rgba(255,255,255,0.07);
  line-height:1;margin-bottom:1.5rem;
  transition:color 0.3s;
}
.pstep:hover .pstep-num{color:var(--lime)}

.pstep h3{
  font-family:var(--serif);
  font-size:1.05rem;font-weight:700;
  color:rgba(255,255,255,0.9);
  margin-bottom:0.6rem;
}
.pstep p{font-size:0.855rem;color:rgba(255,255,255,0.38);font-weight:300;line-height:1.75}

/* WHY */
#why{border-top:1px solid var(--rule)}

.why-grid{
  display:grid;grid-template-columns:5fr 7fr;
  gap:0;
}

.why-left{
  padding-right:5rem;
  border-right:1px solid var(--rule);
}
.why-left h2{margin:1rem 0 1.5rem}
.why-left > p{color:var(--muted);font-weight:300;line-height:1.85;margin-bottom:2.5rem;font-size:0.95rem}

.why-checks{display:flex;flex-direction:column;gap:0.75rem}
.check-row{
  display:flex;align-items:flex-start;gap:0.85rem;
  font-size:0.88rem;color:var(--muted);
  padding:0.6rem 0;
  border-bottom:1px solid var(--rule);
}
.check-row:last-child{border-bottom:none}
.check-icon{
  width:18px;height:18px;flex-shrink:0;
  background:var(--lime);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-top:1px;
  font-size:0.6rem;color:var(--ink);font-weight:700;
}

.why-right{padding-left:5rem}

.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem}
.metric-tile{
  padding:2rem 1.5rem;
  border:1px solid var(--rule);
  border-radius:2px;
  position:relative;
  overflow:hidden;
}
.metric-tile::after{
  content:'';
  position:absolute;top:0;left:0;
  width:3px;height:100%;
  background:var(--lime);
}
.metric-tile.wide{grid-column:span 2}

.metric-val{
  font-family:var(--serif);
  font-size:2.6rem;font-weight:700;
  color:var(--ink);line-height:1;
  margin-bottom:0.4rem;
}
.metric-val sup{font-size:1.2rem;color:var(--muted)}
.metric-desc{font-size:0.75rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted)}

/* CONTACT */
#contact{
  background:var(--ink);
  border-top:1px solid var(--ink-2);
}

#contact .eyebrow{color:rgba(255,255,255,0.3)}

.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;
}

.contact-left{
  padding-right:5vw;
  border-right:1px solid rgba(255,255,255,0.08);
}

#contact h2{color:#fff;margin:1rem 0 1.5rem}
.contact-left > p{color:rgba(255,255,255,0.4);font-size:0.95rem;font-weight:300;line-height:1.85;margin-bottom:2.5rem}

.contact-info{display:flex;flex-direction:column;gap:0}
.contact-info a{
  display:flex;align-items:center;gap:0.75rem;
  color:rgba(255,255,255,0.4);text-decoration:none;
  font-size:0.875rem;padding:0.9rem 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition:color 0.2s;
}
.contact-info a:hover{color:var(--lime)}
.ci-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,0.15);flex-shrink:0;
}

.contact-right{padding-left:5vw}

.cf{display:flex;flex-direction:column;gap:0.75rem}
.cf input,.cf textarea,.cf select{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  color:#fff;
  font-family:var(--sans);font-size:0.88rem;
  padding:0.9rem 1rem;border-radius:2px;
  outline:none;transition:border-color 0.2s;width:100%;
}
.cf input:focus,.cf textarea:focus{border-color:var(--lime)}
.cf input::placeholder,.cf textarea::placeholder{color:rgba(255,255,255,0.2)}
.cf textarea{min-height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem}

.btn-lime{
  background:var(--lime);color:var(--ink);
  font-size:0.85rem;font-weight:700;padding:0.9rem 1.6rem;
  border:none;border-radius:2px;cursor:pointer;width:100%;
  font-family:var(--sans);letter-spacing:0.04em;
  transition:all 0.22s;
}
.btn-lime:hover{background:var(--lime-dim);transform:translateY(-1px)}

#form-msg{font-size:0.82rem;color:var(--lime);display:none}

/* FOOTER */
footer{
  background:var(--ink-2);
  border-top:1px solid rgba(255,255,255,0.05);
  padding:2rem 5vw;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;
}
footer p{font-size:0.75rem;color:rgba(255,255,255,0.25)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:0.75rem;color:rgba(255,255,255,0.25);text-decoration:none;transition:color 0.2s}
.footer-links a:hover{color:rgba(255,255,255,0.6)}

/* DECORATIVE LINE */
.deco-line{
  position:absolute;right:0;top:0;bottom:0;
  width:1px;background:var(--rule);
}

/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.55s ease,transform 0.55s ease}
.reveal.visible{opacity:1;transform:none}

/* ANIMATIONS */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

/* RESPONSIVE */
@media(max-width:900px){
  #hero{grid-template-columns:1fr}
  .hero-right{min-height:360px}
  .services-top{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr 1fr}
  .svc-card:nth-child(3n){border-right:1px solid var(--rule)}
  .svc-card:nth-child(2n){border-right:none}
  .process-steps{grid-template-columns:1fr 1fr}
  .pstep{padding:2rem 0}
  .pstep:not(:first-child){padding-left:0}
  .process-head{flex-direction:column;gap:1.5rem}
  .why-grid{grid-template-columns:1fr}
  .why-left{padding-right:0;border-right:none;padding-bottom:4rem;border-bottom:1px solid var(--rule)}
  .why-right{padding-left:0;padding-top:4rem}
  .contact-grid{grid-template-columns:1fr}
  .contact-left{padding-right:0;border-right:none;padding-bottom:4rem}
  .contact-right{padding-left:0}
  .nav-links{display:none}
}

@media(max-width:600px){
  h1{font-size:2.4rem}
  .services-grid{grid-template-columns:1fr}
  .svc-card{border-right:none}
  .metrics-grid{grid-template-columns:1fr}
  .metric-tile.wide{grid-column:span 1}
  .form-row{grid-template-columns:1fr}
}
