/* Calculator rating + feedback widget (calculator.php #calcFeedback).
   Loaded only on calculator pages via an in-body <link> (same pattern as the
   ApexCharts stylesheet). Uses the global brand tokens from style.css with
   literal fallbacks so it renders correctly even if a token is renamed. */

.calc-feedback {
    margin: 1.75rem 0 0.5rem;
    padding: 1.5rem 1.25rem;
    border: 1px solid var(--line, #ececf3);
    border-radius: 16px;
    background: var(--pale, #f5f9ff);
    scroll-margin-top: 90px; /* so the action-bar "Rate" link doesn't tuck it under the nav */
}

/* Brief highlight when the user jumps here from the action-bar "Rate" pill. */
@keyframes calcFeedbackFlash {
    0%   { box-shadow: 0 0 0 0 rgba(31, 18, 128, 0); }
    30%  { box-shadow: 0 0 0 4px rgba(31, 18, 128, 0.18); }
    100% { box-shadow: 0 0 0 0 rgba(31, 18, 128, 0); }
}
.calc-feedback.is-flash { animation: calcFeedbackFlash 1.2s ease; }

/* Respect users who prefer reduced motion. */
@media (prefers-reduced-motion: reduce) {
    .calc-feedback.is-flash { animation: none; }
    .calc-star { transition: none; }
    .calc-feedback-send { transition: none; }
}

.calc-feedback-head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    margin-bottom: 0.75rem;
}

.calc-feedback-title {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--ink, #0c0c14);
}

.calc-rating-summary {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--muted, #6a6a82);
}

.calc-rating-summary .crs-star { color: #f5b301; }

/* Star row */
.calc-stars {
    display: inline-flex;
    gap: 0.15rem;
}

.calc-star {
    padding: 0.1rem 0.15rem;
    border: 0;
    background: transparent;
    font-size: 2rem;
    line-height: 1;
    color: #cfd2dc;
    cursor: pointer;
    transition: color 0.12s ease, transform 0.12s ease;
}

.calc-star:hover,
.calc-star:focus-visible { transform: scale(1.08); outline: none; }

.calc-star.is-on { color: #f5b301; }

.calc-feedback.is-rated .calc-star { cursor: default; }
.calc-feedback.is-rated .calc-star:hover { transform: none; }

/* Reveal panel */
.calc-feedback-panel { margin-top: 1.1rem; }

.calc-feedback-thanks {
    margin: 0 0 0.55rem;
    font-weight: 600;
    color: var(--ink, #0c0c14);
}

.calc-feedback-text,
.calc-feedback-email {
    width: 100%;
    margin-bottom: 0.6rem;
}

.calc-feedback-text { resize: vertical; min-height: 4.5rem; }

.calc-feedback-privacy {
    margin: -0.2rem 0 0.7rem;
    font-size: 0.82rem;
    line-height: 1.35;
    color: var(--muted, #6a6a82);
}

/* Off-screen honeypot — real visitors never see or fill it. */
.calc-feedback-hp {
    position: absolute !important;
    left: -9999px !important;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.calc-feedback-actions { margin-top: 0.15rem; }

.calc-feedback-send {
    padding: 0.55rem 1.4rem;
    border: 0;
    border-radius: 999px;
    background: var(--brand, #1f1280);
    color: #fff;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease, opacity 0.15s ease;
}

.calc-feedback-send:hover { background: var(--brand-deep, #14094f); }
.calc-feedback-send:disabled { opacity: 0.6; cursor: default; }

.calc-feedback-status {
    margin: 0.6rem 0 0;
    font-size: 0.9rem;
    color: var(--muted, #6a6a82);
    min-height: 1.1em;
}

.calc-feedback-status.is-error { color: #d33; }

.calc-feedback-done {
    margin: 0;
    font-weight: 600;
    color: var(--brand, #1f1280);
}

.cf-turnstile-holder { margin-top: 0.75rem; }
