/* =====================================================
   Fortrydformular - Frontend stylesheet
   Farver og fonts injiceres dynamisk via :root-variabler.
   ===================================================== */

:root {
    --ff-brand:        #8c7131;
    --ff-brand-dark:   #6e5826;
    --ff-brand-light:  #f5efe3;
    --ff-brand-rgb:    140, 113, 49;
    --ff-text:         #1a1a1a;
    --ff-text-muted:   #5a5a5a;
    --ff-border:       #e0d5c5;
    --ff-bg:           #ffffff;
    --ff-input-bg:     #faf8f5;
    --ff-radius-sm:    12px;
    --ff-font:         'Poppins', sans-serif;
    --ff-heading-font: 'Poppins', sans-serif;
}

.ff-wrapper {
    font-family: var(--ff-font);
    color: var(--ff-text);
    max-width: 780px;
    margin: 0 auto;
    padding: 0 16px;
    box-sizing: border-box;
}

.ff-card {
    background: var(--ff-bg);
    border-radius: 16px;
    overflow: hidden;
}

/* Header */
.ff-header {
    padding: 40px 40px 28px;
    border-bottom: 1px solid var(--ff-border);
}

.ff-heading {
    font-family: var(--ff-heading-font);
    font-size: 28px;
    font-weight: 700;
    color: var(--ff-text);
    margin: 0 0 12px 0;
    letter-spacing: -0.3px;
    line-height: 1.2;
}

.ff-intro {
    font-size: 14px;
    color: var(--ff-text-muted);
    margin: 0 0 14px 0;
    line-height: 1.6;
}

.ff-checklist {
    list-style: none;
    margin: 0 0 16px 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ff-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    color: var(--ff-text);
    line-height: 1.5;
}

.ff-check {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    min-width: 20px;
    background: var(--ff-brand);
    color: #fff;
    border-radius: 50%;
    margin-top: 1px;
}

.ff-note {
    font-size: 13px;
    color: var(--ff-text-muted);
    line-height: 1.6;
    margin: 0;
    padding: 14px 16px;
    background: var(--ff-brand-light);
    border-left: 3px solid var(--ff-brand);
    border-radius: 0 var(--ff-radius-sm) var(--ff-radius-sm) 0;
}

/* Info box */
.ff-info-box {
    padding: 24px 40px;
    background: #fff;
    border-bottom: 1px solid var(--ff-border);
}

.ff-info-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--ff-brand-dark);
    margin: 0 0 14px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ff-info-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ff-info-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--ff-text);
}

.ff-icon {
    width: 20px;
    min-width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ff-brand);
}

/* Form */
.ff-form-wrap {
    padding: 36px 40px 40px;
}

.ff-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}

.ff-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ff-field label {
    font-size: 13px;
    font-weight: 500;
    color: var(--ff-text);
}

.ff-req { color: var(--ff-brand); }

.ff-input-wrap { position: relative; }

.ff-input-wrap .ff-input-icon {
    position: absolute;
    left: 13px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    opacity: 0.45;
    color: var(--ff-text);
    display: flex;
    align-items: center;
}

.ff-input-wrap input {
    width: 100%;
    padding: 12px 14px 12px 40px;
    background: var(--ff-input-bg);
    border-radius: var(--ff-radius-sm);
    font-family: var(--ff-font);
    border: none;
    font-size: 14px;
    color: var(--ff-text);
    outline: none;
    transition: background 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    -webkit-appearance: none;
}

.ff-input-wrap input:focus {
    background: #fff;
    box-shadow: 0 0 0 3px rgba(var(--ff-brand-rgb), 0.14);
}

.ff-input-wrap input::placeholder {
    color: #aaa;
    font-size: 13px;
}

/* Honeypot - skjult for mennesker */
.ff-hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

/* Knap */
.ff-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--ff-brand);
    color: #fff;
    border: none;
    border-radius: var(--ff-radius-sm);
    padding: 14px 28px;
    font-family: var(--ff-font);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s;
    letter-spacing: 0.1px;
}

.ff-btn:hover { background: var(--ff-brand-dark); transform: translateY(-1px); }
.ff-btn:active { transform: translateY(0); }
.ff-btn-icon { display: flex; align-items: center; }

/* Status */
.ff-success,
.ff-error {
    padding: 16px 20px;
    border-radius: var(--ff-radius-sm);
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 24px;
}

.ff-success {
    background: #f0faf4;
    border: 1.5px solid #52c47a;
    color: #1a5c36;
}

.ff-error {
    background: #fff4f4;
    border: 1.5px solid #e06060;
    color: #7a1a1a;
}

/* Responsive */
@media (max-width: 600px) {
    .ff-header,
    .ff-info-box,
    .ff-form-wrap {
        padding-left: 20px;
        padding-right: 20px;
    }
    .ff-row { grid-template-columns: 1fr; gap: 16px; }
    .ff-heading { font-size: 22px; }
    .ff-btn { width: 100%; justify-content: center; }
}
