/* @package FillTheRig */

.hs-disclaimer {
    background: rgba(45,140,255,0.08);
    border-bottom: 1px solid rgba(45,140,255,0.2);
    padding: var(--sp-sm) 0;
    font-size: 0.82rem;
    color: var(--color-text-muted);
    text-align: center;
}
.hs-disclaimer p { margin: 0; }
.hs-disclaimer i { color: var(--color-blue); margin-right: 6px; }

.hs-layout {
    max-width: 820px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-2xl);
    align-items: start;
}
@media (min-width: 960px) {
    .hs-layout.hs-has-results {
        max-width: 100%;
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-3xl);
    }
}

.hs-fieldset {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-xl);
    margin-bottom: var(--sp-lg);
    background: var(--color-bg-card);
}
.hs-fieldset legend {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-accent);
    padding: 0 var(--sp-sm);
    letter-spacing: 0.03em;
    text-transform: uppercase;
}
.hs-fieldset-note {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    margin: 0 0 var(--sp-md);
}

.hs-field {
    margin-bottom: var(--sp-lg);
}
.hs-field:last-child { margin-bottom: 0; }
.hs-field > label {
    display: block;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--sp-sm);
}

.hs-radio-group,
.hs-check-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-sm);
}
.hs-radio-group--stack {
    flex-direction: column;
}

.hs-radio,
.hs-check {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: var(--sp-sm) var(--sp-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 0.88rem;
    color: var(--color-text);
    background: var(--color-bg-input);
    transition: border-color 0.15s, background 0.15s;
    user-select: none;
}
.hs-radio:hover,
.hs-check:hover {
    border-color: var(--color-accent);
    background: rgba(255,107,26,0.06);
}
.hs-radio input,
.hs-check input {
    accent-color: var(--color-accent);
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.hs-select {
    width: 100%;
    padding: var(--sp-sm) var(--sp-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-input);
    color: var(--color-text);
    font-size: 0.9rem;
    font-family: var(--font-body);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A95AD' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--sp-md) center;
    padding-right: var(--sp-3xl);
}
.hs-select:focus {
    outline: none;
    border-color: var(--color-accent);
}

.hs-error {
    background: rgba(231,76,60,0.1);
    border: 1px solid rgba(231,76,60,0.4);
    border-radius: var(--radius-md);
    color: #e74c3c;
    padding: var(--sp-sm) var(--sp-md);
    font-size: 0.88rem;
    margin-bottom: var(--sp-lg);
}

.hs-submit {
    width: 100%;
    justify-content: center;
    gap: var(--sp-sm);
    font-family: var(--font-display);
    font-size: 1.1rem;
    letter-spacing: 0.04em;
}

/* Results */
.hs-results-col {
    position: sticky;
    top: var(--sp-2xl);
}
@media (max-width: 959px) {
    .hs-results-col { position: static; }
}

.hs-score-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-md);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--sp-2xl) var(--sp-xl) var(--sp-xl);
    margin-bottom: var(--sp-lg);
}
.hs-ring-wrap {
    position: relative;
    width: 140px;
    height: 140px;
    flex-shrink: 0;
}
.hs-ring {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}
.ring-bg {
    fill: none;
    stroke: var(--color-border);
    stroke-width: 8;
}
.ring-fill {
    fill: none;
    stroke-width: 8;
    stroke-linecap: round;
    transition: stroke-dashoffset 0.8s cubic-bezier(0.4,0,0.2,1);
}
.tier-green  .ring-fill { stroke: var(--color-success); }
.tier-yellow .ring-fill { stroke: #f1c40f; }
.tier-orange .ring-fill { stroke: var(--color-warning); }
.tier-red    .ring-fill, .tier-dark-red .ring-fill { stroke: var(--color-error); }

.ring-inner {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
}
.ring-score {
    font-family: var(--font-display);
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1;
}
.ring-denom {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}
.tier-green  .ring-score { color: var(--color-success); }
.tier-yellow .ring-score { color: #f1c40f; }
.tier-orange .ring-score { color: var(--color-warning); }
.tier-red    .ring-score, .tier-dark-red .ring-score { color: var(--color-error); }

.hs-tier-badge {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: var(--sp-xs) var(--sp-lg);
    border-radius: var(--radius-full);
}
.tier-green  .hs-tier-badge { background: rgba(46,204,113,0.15); color: var(--color-success); }
.tier-yellow .hs-tier-badge { background: rgba(241,196,15,0.15);  color: #f1c40f; }
.tier-orange .hs-tier-badge { background: rgba(243,156,18,0.15);  color: var(--color-warning); }
.tier-red    .hs-tier-badge,
.tier-dark-red .hs-tier-badge { background: rgba(231,76,60,0.15); color: var(--color-error); }

.hs-tier-msg {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--sp-md) var(--sp-lg);
    margin-bottom: var(--sp-lg);
}

.hs-factor-block {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-lg);
    margin-bottom: var(--sp-md);
}
.hs-factor-title {
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--sp-sm);
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
}
.hs-pos-title { color: var(--color-success); }
.hs-neg-title { color: var(--color-error); }

.hs-factor-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.hs-factor-list li {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    padding-left: var(--sp-md);
    position: relative;
    line-height: 1.5;
}
.hs-pos-list li::before { content: '✓'; position: absolute; left: 0; color: var(--color-success); font-size: 0.8rem; top: 1px; }
.hs-neg-list li::before { content: '!'; position: absolute; left: 0; color: var(--color-error);   font-size: 0.8rem; top: 1px; font-weight: 700; }

.hs-result-cta {
    text-align: center;
    margin-top: var(--sp-xl);
    padding-top: var(--sp-xl);
    border-top: 1px solid var(--color-border);
}
.hs-result-cta .btn { width: 100%; justify-content: center; margin-bottom: var(--sp-sm); }
.hs-cta-note {
    font-size: 0.8rem;
    color: var(--color-text-dim);
    margin: 0;
}

.hs-retake {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    background: none;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-muted);
    font-family: var(--font-body);
    font-size: 0.85rem;
    cursor: pointer;
    padding: var(--sp-sm) var(--sp-md);
    margin-top: var(--sp-md);
    transition: border-color 0.15s, color 0.15s;
    width: 100%;
    justify-content: center;
}
.hs-retake:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* FAQ */
.hs-faq-item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--sp-sm);
    background: var(--color-bg-card);
    overflow: hidden;
}
.hs-faq-item summary {
    padding: var(--sp-md) var(--sp-lg);
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--color-text);
}
.hs-faq-item summary::-webkit-details-marker { display: none; }
.hs-faq-item summary::after {
    content: '+';
    font-size: 1.2rem;
    color: var(--color-accent);
    line-height: 1;
    flex-shrink: 0;
    margin-left: var(--sp-md);
}
.hs-faq-item[open] summary::after { content: '−'; }
.hs-faq-item p {
    padding: 0 var(--sp-lg) var(--sp-md);
    font-size: 0.88rem;
    color: var(--color-text-muted);
    line-height: 1.7;
    margin: 0;
}
