/* ===== RESET & BASE ===== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'DM Sans', sans-serif; -webkit-font-smoothing: antialiased; color: #333; }
a { text-decoration: none; }
img { display: block; max-width: 100%; }

/* ===== NAV ===== */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: rgba(15,14,23,0.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid rgba(255,255,255,0.06); }
.nav-inner { max-width: 1120px; margin: 0 auto; padding: 0 40px; display: flex; justify-content: space-between; align-items: center; height: 64px; }
.nav-logo { display: flex; align-items: center; gap: 10px; color: #fff; font-weight: 700; font-size: 16px; letter-spacing: -0.02em; }
.nav-logo img { height: 34px; width: auto; }
.nav-links { display: flex; gap: 32px; }
.nav-links a { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: #9e9bab; transition: color 0.2s; }
.nav-links a:hover, .nav-links a.active { color: #d6336c; }

/* ===== SHARED ELEMENTS ===== */
.grad-bar { height: 3px; background: linear-gradient(90deg, #d6336c, #7c5cbf); }
.section-label { font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 500; letter-spacing: 0.15em; text-transform: uppercase; color: #a78bca; margin-bottom: 16px; }
.btn { display: inline-block; background: #d6336c; color: #fff; border: none; border-radius: 6px; padding: 14px 32px; font-size: 14px; font-weight: 600; cursor: pointer; letter-spacing: 0.02em; transition: background 0.2s; font-family: inherit; }
.btn:hover { background: #c02d60; }

/* ===== PAGE HEADER ===== */
.page-header { background: #0f0e17; padding: 120px 40px 64px; text-align: left; }
.page-header.centered { text-align: center; }
.page-header .inner { max-width: 1120px; margin: 0 auto; }
.page-header h1 { font-size: 48px; font-weight: 700; color: #fff; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 20px; max-width: 650px; }
.page-header.centered h1 { max-width: none; }
.page-header .sub { font-size: 18px; color: #9e9bab; max-width: 580px; line-height: 1.7; }
.page-header.centered .sub { margin: 0 auto; }

/* ===== HERO (HOME) ===== */
.hero { background: #0f0e17; color: #fff; min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding: 120px 40px 80px; }
.hero-inner { max-width: 1120px; margin: 0 auto; width: 100%; }
.hero h1 { font-size: 52px; font-weight: 700; line-height: 1.1; letter-spacing: -0.03em; max-width: 740px; margin-bottom: 28px; }
.hero h1 em { color: #d6336c; font-style: italic; }
.hero .sub { font-size: 19px; color: #9e9bab; max-width: 560px; line-height: 1.7; margin-bottom: 40px; }

/* ===== CAPABILITY GRID (HOME) ===== */
.what-you-get { background: #faf8f5; padding: 80px 40px; }
.what-you-get .inner { max-width: 1120px; margin: 0 auto; }
.what-you-get h2 { font-size: 36px; font-weight: 700; line-height: 1.15; letter-spacing: -0.02em; margin-bottom: 48px; color: #0f0e17; }
.cap-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; }
.cap-card { background: #fff; border-radius: 8px; padding: 32px 28px; border-left: 4px solid #d6336c; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.cap-num { font-family: 'JetBrains Mono', monospace; font-size: 28px; font-weight: 500; color: #d6336c; margin-bottom: 6px; line-height: 1; }
.cap-title { font-size: 17px; font-weight: 700; color: #0f0e17; margin-bottom: 8px; }
.cap-desc { font-size: 14px; color: #555; line-height: 1.6; }

/* ===== SOVEREIGNTY / IP NOTES ===== */
.sovereignty-note { background: rgba(214,51,108,0.06); border-left: 3px solid #d6336c; border-radius: 6px; padding: 20px 28px; margin-top: 32px; }
.sovereignty-note p { font-size: 14.5px; color: #444; line-height: 1.6; }
.sovereignty-note strong { color: #0f0e17; }
.ip-note { background: rgba(214,51,108,0.08); border-left: 3px solid #d6336c; border-radius: 6px; padding: 20px 28px; margin-top: 32px; }
.ip-note p { font-size: 15px; color: #e8e4df; line-height: 1.6; }
.ip-note strong { color: #fff; }

/* ===== PROOF STRIP ===== */
.proof { background: #0f0e17; padding: 64px 40px; }
.proof .inner { max-width: 1120px; margin: 0 auto; }
.proof-grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 24px; }
.proof-val { font-size: 30px; font-weight: 700; color: #d6336c; margin-bottom: 6px; }
.proof-desc { font-size: 13px; color: #9e9bab; line-height: 1.4; }
.proof-clients { font-size: 13px; color: #555; font-family: 'JetBrains Mono', monospace; }

/* ===== CTA STRIP ===== */
.cta { background: #faf8f5; padding: 80px 40px; text-align: center; }
.cta h2 { font-size: 34px; font-weight: 700; color: #0f0e17; margin-bottom: 16px; }
.cta p { font-size: 16px; color: #666; margin-bottom: 32px; line-height: 1.7; max-width: 520px; margin-left: auto; margin-right: auto; }
.cta-compact { padding: 64px 40px; }

/* ===== SOLUTIONS LIST ===== */
.solutions-list { background: #faf8f5; padding: 64px 40px; }
.solutions-list .inner { max-width: 1120px; margin: 0 auto; }
.sol-card { background: #fff; border-radius: 8px; padding: 36px 40px; margin-bottom: 20px; border-left: 4px solid #d6336c; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.sol-num { font-family: 'JetBrains Mono', monospace; font-size: 32px; font-weight: 500; color: #d6336c; line-height: 1; margin-bottom: 6px; }
.sol-title { font-size: 20px; font-weight: 700; color: #0f0e17; margin-bottom: 8px; }
.sol-desc { font-size: 15px; color: #555; line-height: 1.6; max-width: 720px; margin-bottom: 14px; }
.sol-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.sol-tag { font-family: 'JetBrains Mono', monospace; font-size: 11px; background: rgba(124,92,191,0.08); color: #7c5cbf; padding: 4px 12px; border-radius: 4px; }

/* ===== PHASES ===== */
.phases { background: #0f0e17; padding: 64px 40px; }
.phases .inner { max-width: 1120px; margin: 0 auto; }
.phases h2 { font-size: 34px; font-weight: 700; color: #fff; margin-bottom: 8px; }
.phases .sub { font-size: 15px; color: #9e9bab; margin-bottom: 40px; }
.phase-card { background: #1a1930; border-radius: 8px; padding: 32px 36px; border-top: 3px solid #d6336c; margin-bottom: 8px; }
.phase-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: #a78bca; margin-bottom: 6px; }
.phase-title { font-size: 20px; font-weight: 700; color: #fff; margin-bottom: 8px; }
.phase-desc { font-size: 14px; color: #9e9bab; margin-bottom: 12px; line-height: 1.6; }
.phase-get { font-size: 13px; color: #e8628a; font-weight: 500; }
.phase-arrow { text-align: center; color: #555; font-size: 18px; margin: 4px 0; }

/* ===== ABOUT: WHY CARDS ===== */
.why { background: #faf8f5; padding: 64px 40px; }
.why .inner { max-width: 1120px; margin: 0 auto; }
.why h2 { font-size: 32px; font-weight: 700; color: #0f0e17; margin-bottom: 40px; }
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.why-card { background: #fff; border-radius: 8px; padding: 32px 28px; border-top: 3px solid #d6336c; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.why-card h3 { font-size: 18px; font-weight: 700; color: #0f0e17; margin-bottom: 10px; }
.why-card p { font-size: 14.5px; color: #555; line-height: 1.65; }

/* ===== ABOUT: TRACK RECORD ===== */
.record { background: #0f0e17; padding: 64px 40px; }
.record .inner { max-width: 1120px; margin: 0 auto; }
.record h2 { font-size: 32px; font-weight: 700; color: #fff; margin-bottom: 40px; }
.rec-card { border-left: 4px solid #d6336c; padding: 24px 32px; margin-bottom: 20px; background: rgba(255,255,255,0.02); border-radius: 0 8px 8px 0; }
.rec-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: #a78bca; margin-bottom: 8px; }
.rec-head { font-size: 19px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.rec-body { font-size: 14px; color: #9e9bab; line-height: 1.6; margin-bottom: 10px; }
.rec-stat { font-size: 14px; font-weight: 600; color: #d6336c; }
.rec-clients { font-size: 13px; color: #555; font-family: 'JetBrains Mono', monospace; margin-top: 32px; }

/* ===== ABOUT: ORIGIN ===== */
.origin { background: #faf8f5; padding: 64px 40px; }
.origin .inner { max-width: 700px; margin: 0 auto; }
.origin p { font-size: 16px; color: #444; line-height: 1.8; margin-bottom: 16px; }
.origin p:last-child { margin-bottom: 0; }

/* ===== CONTACT ===== */
.contacts { background: #faf8f5; padding: 64px 40px; }
.contacts .inner { max-width: 1080px; margin: 0 auto; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 32px; }
.contact-card { background: #fff; border-radius: 8px; padding: 32px; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.contact-role { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: #d6336c; margin-bottom: 8px; }
.contact-name { font-size: 20px; font-weight: 700; color: #0f0e17; margin-bottom: 10px; }
.contact-details { font-size: 14px; color: #666; line-height: 1.8; }
.contact-details a { color: #d6336c; }

.form-card { background: #fff; border-radius: 8px; padding: 40px; box-shadow: 0 1px 3px rgba(0,0,0,0.04); width: 100%; }
.form-card h3 { font-size: 18px; font-weight: 700; color: #0f0e17; margin-bottom: 24px; }
.form-label { display: block; font-size: 12px; font-weight: 600; color: #333; margin-bottom: 6px; letter-spacing: 0.02em; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.form-card input, .form-card textarea { padding: 12px 16px; font-size: 14px; border: 1px solid #ddd; border-radius: 6px; outline: none; font-family: 'DM Sans', sans-serif; width: 100%; transition: border-color 0.2s; }
.form-card input:focus, .form-card textarea:focus { border-color: #d6336c; }
.form-card .full { margin-bottom: 16px; width: 100%; }
.form-card .full input, .form-card .full select, .form-card .full textarea { width: 100%; display: block; }
.form-card textarea { resize: vertical; margin-bottom: 20px; }

.next-steps { background: #0f0e17; padding: 64px 40px; }
.next-steps .inner { max-width: 800px; margin: 0 auto; text-align: center; }
.next-steps h2 { font-size: 26px; font-weight: 700; color: #fff; margin-bottom: 32px; }
.steps-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; text-align: left; }
.step-num { font-family: 'JetBrains Mono', monospace; font-size: 24px; font-weight: 500; color: #d6336c; margin-bottom: 8px; }
.step-title { font-size: 15px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.step-desc { font-size: 13px; color: #9e9bab; line-height: 1.6; }

/* ===== CONTACT: TWO-COLUMN LAYOUT ===== */
.contact-two-col { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 56px; align-items: start; }
.contact-two-col > * { min-width: 0; }

/* ===== CONTACT: FORM LABELS & SELECT ===== */
.form-label { display: block; font-size: 13px; font-weight: 600; color: #0f0e17; margin-bottom: 6px; letter-spacing: 0.01em; }
.form-card select {
  padding: 12px 36px 12px 16px; font-size: 14px; border: 1px solid #ddd; border-radius: 6px;
  outline: none; font-family: 'DM Sans', sans-serif; width: 100%; color: #333;
  appearance: none; background: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B6B78' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center;
  transition: border-color 0.2s;
}
.form-card select:focus { border-color: #d6336c; }

/* ===== CONTACT: SIDEBAR ===== */
.contact-sidebar { padding-top: 8px; }
.sidebar-block { margin-bottom: 32px; }
.sidebar-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: #a78bca; margin-bottom: 10px; }
.sidebar-text { font-size: 14px; line-height: 1.7; color: #333; }
.sidebar-text a { color: #d6336c; text-decoration: none; transition: color 0.2s; }
.sidebar-text a:hover { color: #0f0e17; }
.sidebar-muted { font-size: 13px; color: #888; margin-top: 4px; }

/* ===== CONTACT: EXPECT LIST ===== */
.expect-list { margin-top: 8px; }
.expect-item { display: flex; gap: 12px; align-items: baseline; padding: 11px 0; border-bottom: 1px solid rgba(0,0,0,0.05); }
.expect-item:last-child { border-bottom: none; }
.expect-num { font-family: 'JetBrains Mono', monospace; font-size: 16px; font-weight: 500; color: #d6336c; min-width: 20px; line-height: 1; }
.expect-text { font-size: 13px; color: #555; line-height: 1.55; }

/* ===== CONTACT: CONFIDENTIAL NOTE ===== */
.confidential-note { margin-top: 8px; padding: 16px 18px; background: rgba(214,51,108,0.04); border: 1px solid rgba(214,51,108,0.12); border-radius: 6px; }
.confidential-note p { font-size: 12px; color: #888; line-height: 1.55; }

/* ===== FOOTER ===== */
footer { background: #0f0e17; padding: 40px; border-top: 1px solid rgba(255,255,255,0.06); }
footer .inner { max-width: 1120px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; }
footer .copy { font-size: 12px; color: #555; }
footer .url { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: #555; }

/* ===== RESPONSIVE ===== */
@media (max-width: 900px) {
  .cap-grid { grid-template-columns: 1fr 1fr; }
  .proof-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .nav-inner { padding: 0 20px; }
  .nav-links { gap: 16px; }
  .nav-links a { font-size: 10px; }
  .hero { padding: 100px 20px 60px; }
  .hero h1 { font-size: 34px; }
  .hero .sub { font-size: 16px; }
  .page-header { padding: 100px 20px 48px; }
  .page-header h1 { font-size: 32px; }
  .cap-grid { grid-template-columns: 1fr; }
  .proof-grid { grid-template-columns: 1fr 1fr; }
  .why-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .contact-two-col { grid-template-columns: 1fr; gap: 40px; }
  .form-row { grid-template-columns: 1fr; }
  .steps-grid { grid-template-columns: 1fr; }
  .what-you-get, .solutions-list, .phases, .proof, .cta, .why, .record, .origin, .contacts, .next-steps { padding-left: 20px; padding-right: 20px; }
  .sol-card { padding: 24px; }
  footer { padding: 32px 20px; }
}
