.contact-layout { display: grid; grid-template-columns: 1fr 1.6fr; gap: 4rem; align-items: start; }
@media (max-width: 860px) { .contact-layout { grid-template-columns: 1fr; } }

.contact-info h2 { font-size: 1.5rem; margin-bottom: .5rem; }
.contact-info__intro { color: var(--gray-600); margin-bottom: 2rem; line-height: 1.6; }

.contact-item { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; }
.contact-item__icon { width: 44px; height: 44px; border-radius: var(--radius-md); background: rgba(27,77,56,.1); color: var(--forest-700); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-item__icon svg { width: 20px; height: 20px; }
.contact-item__label { font-size: .78rem; color: var(--gray-600); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; margin-bottom: .2rem; }
.contact-item__value { font-size: .95rem; color: var(--charcoal); font-weight: 500; }

.contact-note { display: flex; align-items: flex-start; gap: .6rem; background: rgba(232,150,14,.08); border: 1px solid rgba(232,150,14,.2); border-radius: var(--radius-md); padding: 1rem 1.25rem; margin-top: .5rem; color: var(--amber-600); font-size: .85rem; line-height: 1.55; }
.contact-note svg { flex-shrink: 0; margin-top: 2px; }

.contact-form-wrap { background: var(--white); border-radius: var(--radius-lg); padding: 2.5rem; box-shadow: var(--shadow-md); border: 1px solid var(--gray-200); }
.contact-form-wrap h2 { font-size: 1.4rem; margin-bottom: .4rem; }
.contact-form-wrap__sub { color: var(--gray-600); font-size: .9rem; margin-bottom: 1.75rem; }

.contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
@media (max-width: 480px) { .form-row { grid-template-columns: 1fr; } }
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-group label { font-size: .85rem; font-weight: 600; color: var(--charcoal); }
.form-group input, .form-group select, .form-group textarea { padding: .7rem 1rem; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); font-size: .93rem; font-family: var(--font); color: var(--charcoal); background: var(--cream); transition: border-color 150ms, box-shadow 150ms; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline: none; border-color: var(--amber-500); box-shadow: 0 0 0 3px rgba(232,150,14,.15); background: var(--white); }
.form-group input::placeholder, .form-group select::placeholder, .form-group textarea::placeholder { color: var(--gray-400); }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-note { font-size: .78rem; color: var(--gray-600); text-align: center; }
.form-note a { color: var(--forest-700); }
