/* Shared styles for legal/contact pages */
.legal-page, .contact-page { padding: 120px 0 80px; min-height: 80vh; }

.legal-header { margin-bottom: 48px; border-bottom: 1px solid var(--border); padding-bottom: 32px; }
.legal-header h1 { font-family: var(--display); font-size: 2.8rem; font-weight: 800; letter-spacing: -0.03em; color: var(--text); margin-bottom: 8px; }
.legal-header p { font-family: var(--mono); font-size: 0.78rem; color: var(--muted); }
.legal-body { max-width: 720px; }
.legal-body h2 { font-family: var(--display); font-size: 1.15rem; font-weight: 700; color: var(--text); margin: 36px 0 12px; letter-spacing: -0.02em; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body p { font-size: 0.9rem; color: var(--muted2); line-height: 1.75; margin-bottom: 12px; font-weight: 300; }
.legal-body a { color: var(--lime); text-decoration: underline; text-decoration-color: rgba(201,255,48,0.3); }
.legal-body a:hover { text-decoration-color: var(--lime); }

.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
.contact-info .section-tag { display: inline-flex; margin-bottom: 12px; }
.contact-info h1 { font-family: var(--display); font-size: 2.8rem; font-weight: 800; letter-spacing: -0.04em; color: var(--text); margin-bottom: 16px; line-height: 1.05; }
.contact-info > p { font-size: 0.95rem; color: var(--muted); font-weight: 300; line-height: 1.7; margin-bottom: 40px; }
.contact-details { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--border); margin-bottom: 32px; }
.contact-detail { display: flex; align-items: flex-start; gap: 16px; padding: 18px 20px; border-bottom: 1px solid var(--border); transition: background 0.15s; }
.contact-detail:last-child { border-bottom: none; }
.contact-detail:hover { background: var(--bg3); }
.detail-icon { font-size: 1rem; color: var(--lime); width: 24px; flex-shrink: 0; margin-top: 1px; }
.contact-detail strong { display: block; font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.contact-detail span { font-size: 0.88rem; color: var(--muted2); }
.contact-services-note { padding: 20px; border: 1px solid var(--border); }
.contact-services-note strong { display: block; font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
.contact-services-note ul { display: flex; flex-direction: column; gap: 8px; }
.contact-services-note li { font-size: 0.85rem; color: var(--muted2); font-weight: 300; }
.contact-services-note li::before { content: '→ '; color: var(--lime); font-family: var(--mono); }

.contact-form-wrap { background: var(--bg2); border: 1px solid var(--border); padding: 40px; }
.contact-form { display: flex; flex-direction: column; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 7px; }
.form-group label { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
.form-group input, .form-group select, .form-group textarea {
  background: var(--bg3); border: 1px solid var(--border); color: var(--text);
  font-family: var(--body); font-size: 0.88rem; padding: 11px 14px;
  border-radius: 4px; outline: none; transition: border-color 0.15s;
  -webkit-appearance: none;
}
.form-group input::placeholder, .form-group textarea::placeholder { color: #3a3a3a; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--lime); background: rgba(201,255,48,0.02);
}
.form-group select { cursor: pointer; color: var(--muted2); }
.form-group select option { background: #111; color: var(--text); }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-status { padding: 12px 16px; border-radius: 4px; font-size: 0.85rem; margin-top: 8px; }
.form-status--success { background: rgba(201,255,48,0.08); border: 1px solid rgba(201,255,48,0.25); color: var(--lime); }

@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; gap: 40px; } }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } .legal-header h1, .contact-info h1 { font-size: 2rem; } }
