/*
 * Website Analyzer — stylesheet
 * Krachtig Online huisstijl · v1.0.0
 * Geladen alleen op pagina's met de shortcode.
 */

/* ── Custom properties ──────────────────────────────────────────────────── */
.kp-wa-wrap {
    --ko-blauw:        #41c0f0;
    --ko-blauw-licht:  #b7e2fa;
    --ko-blauw-bg:     #eaf6fd;
    --ko-oranje:       #fab700;
    --ko-oranje-licht: #ffdb97;
    --ko-donker:       #444f50;
    --ko-grijs:        #a0aaac;
    --ko-wit:          #ffffff;
    --ko-radius:       10px;
    --ko-shadow:       0 1px 3px rgba(0,0,0,.08);
    --ko-font:         -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

    font-family:  var(--ko-font);
    font-size:    16px;
    line-height:  1.6;
    color:        var(--ko-donker);
    max-width:    720px;
    margin:       0 auto;
}

/* ── Utility ─────────────────────────────────────────────────────────────── */
.kp-wa-sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

.kp-wa-hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

/* ── Kaart ───────────────────────────────────────────────────────────────── */
.kp-wa-card {
    background:    var(--ko-wit);
    border:        1px solid #e2e8ec;
    border-radius: var(--ko-radius);
    padding:       1.25rem 1.5rem;
    margin-bottom: 1rem;
    box-shadow:    var(--ko-shadow);
}

/* ── Header ──────────────────────────────────────────────────────────────── */
.kp-wa-header {
    display:     flex;
    align-items: center;
    gap:         14px;
    margin-bottom: 1rem;
    background:  var(--ko-donker);
    border-radius: var(--ko-radius);
    padding:     1rem 1.25rem;
    margin:      -1.25rem -1.5rem 1.25rem;
    border-radius: var(--ko-radius) var(--ko-radius) 0 0;
}

.kp-wa-icon {
    font-size:   22px;
    color:       var(--ko-blauw);
    flex-shrink: 0;
}

.kp-wa-titel {
    margin:      0 0 2px;
    font-size:   1.1rem;
    font-weight: 600;
    color:       var(--ko-wit);
    line-height: 1.3;
}

.kp-wa-subtitel {
    margin:    0;
    font-size: .875rem;
    color:     var(--ko-grijs);
}

/* ── URL-invoer ──────────────────────────────────────────────────────────── */
.kp-wa-url-row {
    display:   flex;
    gap:       8px;
    flex-wrap: wrap;
}

.kp-wa-url-input {
    flex:         1;
    min-width:    200px;
    padding:      10px 14px;
    border:       1px solid #d0d9df;
    border-radius: 6px;
    font-size:    1rem;
    font-family:  var(--ko-font);
    transition:   border-color .15s;
}

.kp-wa-url-input:focus {
    outline:      none;
    border-color: var(--ko-blauw);
    box-shadow:   0 0 0 3px rgba(65,192,240,.15);
}

/* ── Knoppen ─────────────────────────────────────────────────────────────── */
.kp-wa-btn {
    display:       inline-flex;
    align-items:   center;
    justify-content: center;
    gap:           6px;
    padding:       10px 20px;
    border-radius: 6px;
    font-size:     .9375rem;
    font-weight:   600;
    font-family:   var(--ko-font);
    cursor:        pointer;
    border:        2px solid transparent;
    transition:    background .15s, border-color .15s, opacity .15s;
    white-space:   nowrap;
}

@media (max-width: 480px) {
    .kp-wa-btn {
        white-space: normal;
        text-align:  center;
        width:       100%;
    }
    .kp-wa-btn-ghost {
        width: auto;
    }
    .kp-wa-form-footer {
        flex-direction: column;
        align-items: stretch;
    }
}

.kp-wa-btn-primary {
    background:  var(--ko-blauw);
    color:       var(--ko-wit);
    border-color: var(--ko-blauw);
}

.kp-wa-btn-primary:hover {
    background:  #2fb0e0;
    border-color: #2fb0e0;
}

.kp-wa-btn-primary:disabled {
    opacity: .5;
    cursor: not-allowed;
}

.kp-wa-btn-oranje {
    background:  var(--ko-oranje);
    color:       #3a2800;
    border-color: var(--ko-oranje);
}

.kp-wa-btn-oranje:hover {
    background:  #e8a800;
    border-color: #e8a800;
}

.kp-wa-btn-ghost {
    background:  transparent;
    color:       var(--ko-grijs);
    border-color: #d0d9df;
}

.kp-wa-btn-ghost:hover {
    background: #f5f7f8;
}

/* ── Status-tekst ────────────────────────────────────────────────────────── */
.kp-wa-status {
    margin:    .5rem 0 0;
    font-size: .875rem;
    color:     var(--ko-grijs);
    min-height: 20px;
}

.kp-wa-status.kp-wa-fout {
    color: #c0392b;
}

/* ── Scores grid ─────────────────────────────────────────────────────────── */
.kp-wa-scores {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap:                   8px;
    margin-bottom:         1rem;
}

.kp-wa-score-tegel {
    background:     #f7f9fa;
    border:         1px solid #e2e8ec;
    border-radius:  8px;
    padding:        .75rem 1rem;
    text-align:     center;
    display:        flex;
    flex-direction: column;
    align-items:    center;
    justify-content: flex-start;
}

.kp-wa-score-label {
    font-size:   .7rem;
    color:       var(--ko-grijs);
    margin-top:  4px;
    line-height: 1.2;
    text-align:  center;
    min-height:  2em;
}

.kp-wa-score-waarde {
    font-size:   1.5rem;
    font-weight: 700;
    line-height: 1;
}

.kp-wa-score-balk-bg {
    height:        3px;
    background:    #e2e8ec;
    border-radius: 2px;
    margin-top:    6px;
}

.kp-wa-score-balk {
    height:        3px;
    border-radius: 2px;
    transition:    width .6s ease;
}

/* Kleurschema scores */
.kp-wa-score--groen .kp-wa-score-waarde { color: #1D9E75; }
.kp-wa-score--groen .kp-wa-score-balk   { background: #1D9E75; }
.kp-wa-score--oranje .kp-wa-score-waarde { color: #fab700; }
.kp-wa-score--oranje .kp-wa-score-balk   { background: #fab700; }
.kp-wa-score--rood .kp-wa-score-waarde  { color: #c0392b; }
.kp-wa-score--rood .kp-wa-score-balk    { background: #c0392b; }

/* ── Categorie-kaarten ───────────────────────────────────────────────────── */
.kp-wa-kaarten {
    display:        flex;
    flex-direction: column;
    gap:            .75rem;
    margin-bottom:  1rem;
}

.kp-wa-kaart {
    background:    var(--ko-wit);
    border:        1px solid #e2e8ec;
    border-radius: var(--ko-radius);
    padding:       1rem 1.25rem;
    box-shadow:    var(--ko-shadow);
}

.kp-wa-kaart-header {
    display:       flex;
    align-items:   center;
    gap:           10px;
    margin-bottom: .5rem;
}

.kp-wa-kaart-icon {
    width:          30px;
    height:         30px;
    border-radius:  6px;
    display:        flex;
    align-items:    center;
    justify-content: center;
    font-size:      16px;
    flex-shrink:    0;
}

.kp-wa-kaart-titel {
    margin:      0;
    font-size:   1rem;
    font-weight: 600;
}

.kp-wa-situatie {
    margin:      0 0 .65rem;
    font-size:   .9375rem;
    color:       #555f61;
    line-height: 1.65;
}

.kp-wa-topadvies {
    background:    var(--ko-blauw-bg);
    border-left:   3px solid var(--ko-blauw);
    padding:       .65rem .9rem;
    font-size:     .9375rem;
    line-height:   1.6;
}

.kp-wa-prio {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 9px;
    border-radius: 99px;
    margin-left: auto;
    flex-shrink: 0;
}
.kp-wa-prio-hoog   { background: #FDECEA; color: #C0392B; }
.kp-wa-prio-middel { background: #EAF3FB; color: #2980B9; }
.kp-wa-prio-laag   { background: #F4F4F4; color: #7F8C8D; }

.kp-wa-topadvies-label {
    display:     block;
    font-size:   .75rem;
    font-weight: 700;
    color:       #185FA5;
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* ── CTA-strip ───────────────────────────────────────────────────────────── */
.kp-wa-cta-strip {
    background:    var(--ko-donker);
    border-radius: var(--ko-radius);
    padding:       1.1rem 1.4rem;
    display:       flex;
    align-items:   center;
    justify-content: space-between;
    gap:           1rem;
    flex-wrap:     wrap;
    margin-bottom: 1rem;
}

.kp-wa-cta-tekst strong {
    display:     block;
    font-size:   1rem;
    font-weight: 600;
    color:       var(--ko-wit);
    margin-bottom: 2px;
}

.kp-wa-cta-tekst p {
    margin:    0;
    font-size: .875rem;
    color:     var(--ko-grijs);
}

/* ── Formulier ───────────────────────────────────────────────────────────── */
.kp-wa-form-titel {
    margin:    0 0 1rem;
    font-size: 1.1rem;
    font-weight: 600;
}

.kp-wa-fieldset {
    border:        1px solid #e2e8ec;
    border-radius: 8px;
    padding:       1rem 1.25rem;
    margin:        0 0 1rem;
}

.kp-wa-fieldset legend {
    font-weight:  600;
    font-size:    .9375rem;
    padding:      0 6px;
    color:        var(--ko-donker);
}

.kp-wa-form-row {
    display:   flex;
    gap:       12px;
    flex-wrap: wrap;
}

.kp-wa-form-row--2col > .kp-wa-form-field {
    flex: 1;
    min-width: 180px;
}

.kp-wa-form-field {
    margin-bottom: .75rem;
    display:       flex;
    flex-direction: column;
    gap:           4px;
}

.kp-wa-form-field label,
.kp-wa-label {
    font-size:   .875rem;
    font-weight: 500;
    color:       var(--ko-donker);
}

.kp-wa-form-field input[type="text"],
.kp-wa-form-field input[type="email"],
.kp-wa-form-field input[type="tel"],
.kp-wa-form-field input[type="url"],
.kp-wa-form-field select,
.kp-wa-form-field textarea {
    padding:       9px 12px;
    border:        1px solid #d0d9df;
    border-radius: 6px;
    font-size:     .9375rem;
    font-family:   var(--ko-font);
    color:         var(--ko-donker);
    background:    var(--ko-wit);
    transition:    border-color .15s;
    width:         100%;
    box-sizing:    border-box;
}

.kp-wa-form-field input:focus,
.kp-wa-form-field select:focus,
.kp-wa-form-field textarea:focus {
    outline:      none;
    border-color: var(--ko-blauw);
    box-shadow:   0 0 0 3px rgba(65,192,240,.15);
}

.kp-wa-checkboxes {
    display:   flex;
    flex-wrap: wrap;
    gap:       8px;
    margin-top: 4px;
}

.kp-wa-checkbox-label {
    display:     flex;
    align-items: center;
    gap:         6px;
    font-size:   .9375rem;
    cursor:      pointer;
}

.kp-wa-checkbox-label--block {
    display:       flex;
    align-items:   center;
    margin-bottom: .5rem;
    gap:           8px;
}

@media (max-width: 600px) {
    .kp-wa-checkboxes {
        flex-direction: column;
        gap: 10px;
    }
    .kp-wa-checkboxes .kp-wa-checkbox-label {
        font-size:  1rem;
        min-height: 36px;
    }
    .kp-wa-checkboxes input[type="checkbox"] {
        width:  20px;
        height: 20px;
        flex-shrink: 0;
    }
}

.kp-wa-verplicht-toelichting {
    font-size: .8125rem;
    color:     var(--ko-grijs);
    margin:    .5rem 0;
}

@media (max-width: 600px) {
    .kp-wa-checkbox-label--block {
        font-size:  1rem;
        min-height: 36px;
        flex-wrap:  nowrap;
        align-items: flex-start;
        padding:    4px 0;
    }
    .kp-wa-checkbox-label--block input[type="checkbox"] {
        width:      20px;
        height:     20px;
        margin-top: 2px;
        flex-shrink: 0;
    }
    fieldset.kp-wa-fieldset {
        padding: .75rem;
    }
    .kp-wa-fieldset legend {
        padding: 0 4px;
    }
}

.kp-wa-form-footer {
    display:    flex;
    gap:        10px;
    flex-wrap:  wrap;
    margin-top: .75rem;
}

.kp-wa-form-status {
    margin:    .5rem 0 0;
    font-size: .875rem;
    min-height: 20px;
}

.kp-wa-form-status.kp-wa-succes { color: #1D9E75; }
.kp-wa-form-status.kp-wa-fout   { color: #c0392b; }

/* ── AVG-melding onder analyseknop ──────────────────────────────────────── */
.kp-wa-avg-melding {
    font-size:   12px;
    color:       #a0aaac;
    margin:      8px 0 0;
    line-height: 1.5;
}
.kp-wa-avg-melding a {
    color: #a0aaac;
    text-decoration: underline;
}

/* ── Herhaalanalyse melding ──────────────────────────────────────────────── */
.kp-wa-herhaal-melding {
    background:    #f0f8ff;
    border:        1px solid #b8d9f0;
    border-radius: 8px;
    padding:       10px 14px;
    font-size:     13px;
    color:         #1a5276;
    line-height:   1.5;
    margin-bottom: 12px;
}

/* ── Score-vergelijking badges ───────────────────────────────────────────── */
.kp-wa-score-verg {
    font-size:   .65rem;
    font-weight: 700;
    padding:     1px 5px;
    border-radius: 4px;
    margin-left: 4px;
    vertical-align: middle;
}
.kp-wa-verg-omhoog { background: #d4edda; color: #155724; }
.kp-wa-verg-omlaag { background: #f8d7da; color: #721c24; }

/* ── Bevestigingsblok ───────────────────────────────────────────────────── */
.kp-wa-bevestiging {
    text-align:    center;
    padding:       2rem 1.5rem;
    margin-top:    1rem;
    background:    #f0faf5;
    border:        2px solid #1D9E75;
    border-radius: 10px;
}

.kp-wa-bevestiging-icoon {
    display:          inline-flex;
    align-items:      center;
    justify-content:  center;
    width:            56px;
    height:           56px;
    border-radius:    50%;
    background:       #1D9E75;
    color:            #fff;
    font-size:        1.75rem;
    margin-bottom:    1rem;
}

.kp-wa-bevestiging-titel {
    font-size:     1.125rem;
    font-weight:   700;
    color:         #155f3e;
    margin-bottom: .5rem;
}

.kp-wa-bevestiging-tekst {
    font-size:  1rem;
    color:      #1a7a4a;
    line-height: 1.6;
}

/* ── Animaties ───────────────────────────────────────────────────────────── */
@keyframes kp-wa-spin {
    to { transform: rotate(360deg); }
}

.kp-wa-spinner {
    display:      inline-block;
    width:        14px;
    height:       14px;
    border:       2px solid rgba(255,255,255,.4);
    border-top-color: var(--ko-wit);
    border-radius: 50%;
    animation:    kp-wa-spin .7s linear infinite;
    vertical-align: -2px;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
    .kp-wa-card { padding: 1rem; }
    .kp-wa-header { padding: .85rem 1rem; margin: -1rem -1rem 1rem; }
    .kp-wa-cta-strip { flex-direction: column; align-items: flex-start; }
    .kp-wa-form-row--2col { flex-direction: column; }
}

/* ── Verborgen hulpklasse ────────────────────────────────────────────────── */
[hidden] { display: none !important; }
