/*
Theme Name:  Uppsala Taxi Child
Description: Child-tema för Uppsala Taxi. Åtgärdar säkerhets-, tillgänglighets- och kodkvalitetsbrister samt säkerställer korrekt visning av FluentForms-formulär.
Author:      Uppsala Taxi
Template:    uppsala-taxi
Version:     1.0.1
Text Domain: uppsala-taxi-child
*/

/* ================================================
   FluentForms – fix för korrekt formulärvisning
   ================================================
   OBS: Modertemat använder html { font-size: 62.5% } vilket
   gör att 1rem = 10px (inte 16px som standard). Alla rem-värden
   nedan är anpassade för detta: 1.5rem = 15px, 1.6rem = 16px.
   ================================================ */

/* Etiketter
   Fix: "för stor text" – normalisera alla ff-labels till 14px (1.4rem).
   Undviker att labels ärver heading-stilar (h2 = 27–40px) eller
   paragraph-stilar (p = 16–18px) från temat. */
.fluentform label,
.fluentform .ff-el-input--label label,
.fluentform p.ff-el-input--label,
.fluentform .ff-el-input--label span.label-element {
    display: block !important;
    font-size: 1.4rem !important;   /* 14px i detta tema */
    font-weight: 600 !important;
    line-height: 1.4 !important;
    margin-bottom: 6px !important;
    color: var(--text-clr, #333) !important;
    /* Nollställ ärvda heading-stilar */
    text-transform: none !important;
    letter-spacing: normal !important;
    font-family: var(--text-font, inherit) !important;
}

/* Obligatorisk asterisk */
.fluentform .ff-el-is-required .ff-label-content::after {
    content: ' *';
    color: #c0392b;
}

/* Textfält, e-post, telefon, number
   Fix: font-size 1.6rem = 16px i detta tema (inte 1rem = 10px). */
.fluentform .ff-el-form-control {
    display: block;
    width: 100%;
    padding: 10px 14px;
    font-size: 1.6rem !important;   /* 16px i detta tema */
    font-family: var(--text-font, inherit);
    line-height: 1.5;
    color: #333;
    background-color: #fff;
    border: 1px solid #ccc !important;
    border-radius: 4px;
    box-sizing: border-box;
    transition: border-color 0.15s ease;
}

.fluentform .ff-el-form-control:focus {
    outline: 2px solid var(--color-primary, #1a1a1a);
    outline-offset: 2px;
    border-color: var(--color-primary, #1a1a1a) !important;
}

/* Textarea */
.fluentform textarea.ff-el-form-control {
    min-height: 120px;
    resize: vertical;
}

/* Select */
.fluentform select.ff-el-form-control {
    cursor: pointer;
}

/* Fältgrupp-marginal */
.fluentform .ff-el-group {
    margin-bottom: 1.6rem;  /* 16px */
}

/* Skicka-knapp */
.fluentform .ff_submit_btn_wrapper {
    margin-top: 2rem;  /* 20px */
}

.fluentform .ff-btn,
.fluentform .ff-btn-submit {
    display: inline-block;
    padding: 12px 28px;
    background-color: var(--color-primary, #1a1a1a);
    color: #fff !important;
    border: none;
    border-radius: 4px;
    font-size: 1.6rem !important;  /* 16px */
    font-family: var(--text-font, inherit);
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.2s ease;
    text-decoration: none;
    /* Nollställ button-reset från temat */
    letter-spacing: normal;
    text-transform: none;
}

.fluentform .ff-btn:hover,
.fluentform .ff-btn-submit:hover {
    opacity: 0.85;
}

.fluentform .ff-btn:focus-visible,
.fluentform .ff-btn-submit:focus-visible {
    outline: 2px solid var(--color-primary, #1a1a1a);
    outline-offset: 3px;
}

/* Valideringsfel – fält */
.fluentform .ff-el-is-error .ff-el-form-control {
    border-color: #c0392b !important;
}

/* Valideringsfel – text */
.fluentform .error.text-danger,
.fluentform .ff-el-help-message.ff-el-is-error {
    display: block;
    color: #c0392b;
    font-size: 1.3rem;  /* 13px */
    margin-top: 4px;
}

/* Framgångsmeddelande */
.fluentform .ff-message-success {
    padding: 16px 20px;
    background-color: #d4edda;
    border: 1px solid #c3e6cb;
    color: #155724;
    border-radius: 4px;
    margin-top: 1.6rem;
    font-size: 1.6rem;
}

/* Felsammanfattning */
.fluentform .ff-errors-in-stack {
    padding: 12px 16px;
    background-color: #f8d7da;
    border: 1px solid #f5c6cb;
    color: #721c24;
    border-radius: 4px;
    margin-bottom: 1.6rem;
    font-size: 1.6rem;
}

/* Checkbox- och radiogrupper */
.fluentform .ff-el-form-check {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.fluentform .ff-el-form-check input[type="checkbox"],
.fluentform .ff-el-form-check input[type="radio"] {
    width: auto;
    flex-shrink: 0;
    margin: 0;
    accent-color: var(--color-primary, #1a1a1a);
}

/* Stegs-indikator (multi-step forms) */
.fluentform .ff-step-titles {
    display: flex;
    gap: 8px;
    margin-bottom: 2rem;
    list-style: none;
    padding: 0;
}

/* Laddningsindikator */
.fluentform.ff-loading {
    opacity: 0.6;
    pointer-events: none;
}

/* ================================================
   FluentForms – datum- och tidfält (flatpickr)
   ================================================
   FluentForms använder flatpickr-biblioteket för datum/tid.
   Fälten renderas som <input type="text" class="flatpickr-input">
   och är readonly (flatpickr öppnar en kalender vid klick).
   ================================================ */

/* Normalisera alla labels i formuläret – inkl. datum/tid-kolumner */
.fluentform .ff-el-input--label label,
.fluentform .ff-el-input--label span.label-element {
    font-size: 1.4rem !important;  /* 14px */
}

/* Datum- och tidinmatningsfält (flatpickr-input)
   Fix: flatpickr sätter readonly på inmatningsfältet.
   Temat kan ha regler som blockerar readonly-inputs (pointer-events etc).
   Vi säkerställer att fältet alltid är klickbart. */
.fluentform input.flatpickr-input,
.fluentform .ff-el-form-control.flatpickr-input {
    display: block !important;
    width: 100% !important;
    padding: 10px 14px !important;
    font-size: 1.6rem !important;  /* 16px */
    font-family: var(--text-font, inherit) !important;
    line-height: 1.5 !important;
    color: #333 !important;
    background-color: #fff !important;
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
    pointer-events: all !important;  /* Säkerställer klickbarhet även om readonly */
    opacity: 1 !important;
}

.fluentform input.flatpickr-input:focus,
.fluentform .ff-el-form-control.flatpickr-input:focus {
    outline: 2px solid var(--color-primary, #1a1a1a);
    outline-offset: 2px;
    border-color: var(--color-primary, #1a1a1a) !important;
}

/* Flatpickr kalender-popup */
.flatpickr-calendar {
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 6px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    z-index: 99999 !important; /* Säkerställer att kalendern visas ovanpå allt */
    width: 307px;
    font-family: inherit;
    font-size: 1.3rem;  /* 13px i detta tema (62.5% base) */
}

.flatpickr-calendar.open {
    display: inline-block !important;
}

.flatpickr-months {
    display: flex;
    align-items: center;
    padding: 8px 0;
}

.flatpickr-month {
    flex: 1;
    text-align: center;
    font-weight: 600;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    padding: 8px 12px;
    cursor: pointer;
    color: #333;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    color: var(--color-primary, #1a1a1a);
}

.flatpickr-weekdays {
    display: flex;
    background: #f5f5f5;
}

.flatpickr-weekday {
    flex: 1;
    text-align: center;
    padding: 6px 0;
    font-size: 1.1rem;  /* 11px */
    color: #666;
    font-weight: 600;
}

.flatpickr-days {
    width: 100%;
}

.dayContainer {
    display: flex;
    flex-wrap: wrap;
    padding: 4px;
    width: 100%;
}

.flatpickr-day {
    flex: 0 0 calc(100% / 7);
    text-align: center;
    padding: 8px 0;
    cursor: pointer;
    border-radius: 4px;
    font-size: 1.3rem;  /* 13px */
    color: #333;
}

.flatpickr-day:hover {
    background-color: #f0f0f0;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background-color: var(--color-primary, #1a1a1a);
    color: #fff;
}

.flatpickr-day.today {
    border: 1px solid var(--color-primary, #1a1a1a);
}

.flatpickr-day.disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: #ccc;
    cursor: default;
}

/* Tid-väljare i flatpickr */
.flatpickr-time {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
    border-top: 1px solid #eee;
}

.flatpickr-time input.flatpickr-hour,
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second {
    width: 50px !important;
    text-align: center;
    border: 1px solid #ccc !important;
    border-radius: 4px;
    padding: 4px !important;
    font-size: 1.6rem !important;  /* 16px */
    pointer-events: all !important;
    cursor: text !important;
}

.flatpickr-time .flatpickr-time-separator {
    padding: 0 4px;
    font-weight: bold;
}

/* Formulär med kolumner (Datum + Tid bredvid varandra) */
.fluentform .ff-t-container {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.fluentform .ff-t-cell {
    flex: 1 1 200px;
}

/* Filinmatning */
.fluentform .ff-el-form-control[type="file"] {
    padding: 8px;
    border: 2px dashed #ccc;
    background: #fafafa;
    cursor: pointer;
    min-height: 60px;
}

.fluentform .ff-el-form-control[type="file"]:hover {
    border-color: var(--color-primary, #1a1a1a);
    background: #f5f5f5;
}
