/* ============================================================
   CONTACT — form + details
   ============================================================ */

.contact-hero {
    padding-block: var(--sp-8) var(--sp-6);
    background:
        radial-gradient(700px 320px at -10% -20%, color-mix(in srgb, var(--c-accent) 14%, transparent), transparent 60%),
        var(--bg-sunken);
}
.contact-hero h1 { max-width: 18ch; }

.contact-body { padding-block: var(--sp-7); }

.contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-6);
    align-items: start;
}

/* ---------- form ---------- */
.contact-form-wrap { padding: var(--sp-6); }

.field { margin-bottom: var(--sp-4); }
.field-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0 var(--sp-4);
}

.field label {
    display: block;
    font-weight: 600;
    font-size: var(--fs-300);
    margin-bottom: var(--sp-2);
}
.label-hint { font-weight: 400; color: var(--text-muted); }

.field input,
.field textarea {
    width: 100%;
    padding: 0.8rem 1rem;
    font: inherit;
    color: var(--text);
    background: var(--bg-raised);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    transition: border-color var(--speed) ease, box-shadow var(--speed) ease;
}
.field input:focus,
.field textarea:focus {
    outline: none;
    border-color: var(--c-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 18%, transparent);
}
.field textarea { resize: vertical; min-height: 130px; }

.has-error input, .has-error textarea { border-color: var(--c-danger); }
.field-error { color: var(--c-danger); font-size: var(--fs-200); margin-top: var(--sp-1); }

/* honeypot — visually removed, still in the DOM for bots */
.hp-field {
    position: absolute !important;
    left: -9999px !important;
    width: 1px; height: 1px;
    overflow: hidden;
}

.form-banner {
    display: flex;
    gap: var(--sp-3);
    align-items: flex-start;
    padding: var(--sp-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--sp-5);
    font-size: var(--fs-300);
    animation: banner-in 0.5s var(--ease-out);
}
@keyframes banner-in {
    from { opacity: 0; transform: translateY(-8px); }
}
.form-banner svg { width: 26px; height: 26px; flex-shrink: 0; }
.form-success {
    background: color-mix(in srgb, var(--c-success) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--c-success) 40%, transparent);
    color: var(--c-success);
}
.form-success p:last-child, .form-banner p:last-child { color: var(--text-muted); }
.form-success p strong { color: var(--c-success); }
.form-error {
    background: color-mix(in srgb, var(--c-danger) 10%, transparent);
    border: 1px solid color-mix(in srgb, var(--c-danger) 40%, transparent);
    color: var(--c-danger);
}

.form-note {
    margin-top: var(--sp-3);
    font-size: var(--fs-200);
    color: var(--text-muted);
    text-align: center;
}

/* ---------- details ---------- */
.detail-card {
    background: var(--bg-raised);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    padding: var(--sp-6);
    box-shadow: var(--shadow-sm);
}
.detail-card h2 { font-size: var(--fs-600); margin-bottom: var(--sp-4); }

.detail-line {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    padding-block: var(--sp-3);
    border-bottom: 1px dashed var(--line);
    color: var(--text);
    font-size: var(--fs-300);
}
.detail-line:last-child { border-bottom: 0; }
.detail-line svg { width: 20px; height: 20px; flex-shrink: 0; color: var(--c-primary); margin-top: 2px; }
a.detail-line:hover { color: var(--c-primary); text-decoration: none; }

.map-frame {
    margin-top: var(--sp-5);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--line);
}
.map-frame iframe {
    width: 100%;
    height: 280px;
    border: 0;
    display: block;
}

/* ---------- breakpoints ---------- */
@media (min-width: 768px) {
    .field-row { grid-template-columns: 1fr 1fr; }
    .contact-form-wrap { padding: var(--sp-7); }
}
@media (min-width: 1024px) {
    .contact-grid { grid-template-columns: 1.5fr 1fr; }
}
