/*
 * Feedback Page CSS — KGM Editorial
 */
.fb-hero {
    position: relative;
    padding: clamp(40px, 5vw, 70px) 6vw clamp(30px, 3vw, 40px);
    background: var(--bg-section);
    display: grid; grid-template-columns: 1fr 60px; gap: 40px; overflow: hidden;
}
.fb-hero::before {
    content: ""; position: absolute; inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(26,26,24,0.04) 1px, transparent 0);
    background-size: 18px 18px; opacity: 0.5; pointer-events: none;
}
.fb-hero__inner { position: relative; max-width: 1180px; margin: 0 auto; width: 100%; }
.fb-hero__eyebrow { display: flex; align-items: center; margin-bottom: 16px; }
.fb-rule { display: inline-block; width: 36px; height: 1px; background: var(--terracotta); margin-right: 14px; flex-shrink: 0; }
.fb-eyebrow-text { font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-muted); font-weight: 500; }
.fb-hero__title { font-family: var(--font-heading); font-size: clamp(2rem, 3.5vw, 2.8rem); font-weight: 400; line-height: 1.05; letter-spacing: -0.02em; color: var(--text-primary); margin: 0 0 14px; }
.fb-hero__title em { font-style: italic; color: var(--terracotta); }
.fb-hero__lede { font-size: clamp(0.95rem, 1.2vw, 1.1rem); color: var(--text-secondary); max-width: 60ch; }
.fb-hero__sidebar { display: flex; flex-direction: column; justify-content: space-between; align-items: center; padding: 10px 0; }
.fb-hero__folio { font-family: var(--font-heading); font-style: italic; font-size: 13px; color: var(--text-muted); letter-spacing: 0.06em; }
.fb-hero__vertical { writing-mode: vertical-rl; transform: rotate(180deg); font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--text-muted); }

/* ── FORM BODY ── */
.fb-body { padding: 4rem 0; }
.fb-form { max-width: 680px; }
.fb-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 1.5rem; }
.fb-field { margin-bottom: 1.5rem; }
.fb-field label { display: block; font-size: 0.8rem; font-weight: 600; color: var(--text-primary); margin-bottom: 0.5rem; letter-spacing: 0.04em; }
.fb-required { color: var(--terracotta); }
.fb-field input,
.fb-field select,
.fb-field textarea {
    width: 100%; padding: 0.75rem 1rem; border: 1.5px solid var(--border-medium);
    font-family: var(--font-body); font-size: 0.95rem; color: var(--text-primary);
    background: #fff; transition: border-color 0.2s;
}
.fb-field input:focus,
.fb-field select:focus,
.fb-field textarea:focus { outline: none; border-color: var(--terracotta); }

/* ── RATING STARS ── */
.fb-rating { display: flex; flex-direction: row-reverse; gap: 0.25rem; justify-content: flex-end; }
.fb-rating input { display: none; }
.fb-rating label { font-size: 1.8rem; color: var(--border-medium); cursor: pointer; transition: color 0.2s; }
.fb-rating input:checked ~ label,
.fb-rating label:hover,
.fb-rating label:hover ~ label { color: var(--terracotta); }

.fb-submit { margin-top: 1rem; }

/* ── SUCCESS / ERROR ── */
.fb-success { text-align: center; padding: 4rem 2rem; }
.fb-success__icon { font-size: 3rem; color: var(--forest); margin-bottom: 1rem; }
.fb-success h2 { font-family: var(--font-heading); font-size: 2rem; margin-bottom: 0.5rem; }
.fb-success p { color: var(--text-secondary); margin-bottom: 2rem; }
.fb-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; padding: 1rem 1.25rem; margin-bottom: 2rem; font-size: 0.9rem; }

@media (max-width: 1024px) { .fb-hero { grid-template-columns: 1fr; } .fb-hero__sidebar { display: none; } }
@media (max-width: 640px) { .fb-grid { grid-template-columns: 1fr; } }

.page-template-page-feedback .um-newsletter { background-color: var(--bg-light); border-top: 1px solid var(--border-light); }

/* Two-column layout: form + contact info */
.fb-layout { display: grid; grid-template-columns: 1fr 340px; gap: 48px; align-items: start; }
.fb-layout__form { min-width: 0; }
.fb-layout__info  { position: sticky; top: 120px; }

.fb-info__title {
    font-family: var(--font-heading); font-size: 1.15rem; font-weight: 400;
    margin: 0 0 20px; padding-bottom: 14px; border-bottom: 2px solid var(--terracotta);
    color: #1A1A18;
}

.fb-layout__info .contact-block { border-bottom: 1px solid #f0ede8; padding: 16px 0; }
.fb-layout__info .contact-block:first-of-type { padding-top: 0; }
.fb-layout__info .contact-block:last-child { border-bottom: none; padding-bottom: 0; }
.fb-layout__info .contact-block__label {
    font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--terracotta); margin: 0 0 6px;
}
.fb-layout__info .contact-block p,
.fb-layout__info .contact-block a {
    font-size: 0.95rem; line-height: 1.55; margin: 0; color: #1A1A18; text-decoration: none;
}
.fb-layout__info .contact-block a:hover { color: var(--terracotta); text-decoration: underline; }

@media (max-width: 860px) {
    .fb-layout { grid-template-columns: 1fr; gap: 32px; }
    .fb-layout__info { position: static; }
}
