/* ============================================================================
 * d2-tilbud — /software-tilbud/ side stylesheet
 * Version: 1.0.2
 *
 * Changelog:
 *   1.0.2 — Skift d2-forms tema fra light-card til dark-box (accessibility:
 *           højere kontrast, bedre læsbarhed for svagtseende).
 *         — Neutralisér .d2tb-form__card (fjern bg/border/radius/padding/
 *           shadow). Dark-box tema ejer surface; wrapper holder kun
 *           flex-center alignment.
 *         — Centrér .d2-form-wrap inde i .d2tb-form__card via flex-center
 *           (DS v3.0 form-shortcode integration pattern).
 *         — Udvid Divi border-override til <select> (samme problem som
 *           <textarea> i v1.0.1 — Divi stripper border på begge).
 *         — Plugin håndhæver nu D2 Fullbleed Page template via PHP
 *           (template_include filter) — fjerner Divi sidebar-streg.
 *
 * Sektioner (alle med .d2tb- prefix):
 *   1. Hero            — sort boxed kort
 *   2. Process-strip   — 3 punkter, lys grå
 *   3. Form-card       — wrapper for [d2form theme="dark-box"] embed
 *   4. Alt contact     — sort boxed kort
 *   5. USP-blok        — 4 punkter, hvid
 *
 * Lag 1 (CSS variabler + .d2-btn) leveres af d2-tokens.css globalt.
 * Divi-neutralisering håndteres af .d2-fullbleed-page i d2-tokens.css.
 *
 * Breakpoints:
 *   < 720px   — Mobile (single col)
 *   720-1023  — Tablet (process 3-col fra her, form-card centeret)
 *   1024-1279 — Laptop
 *   ≥ 1280px  — Desktop wide
 *   ≥ 1600px  — Ultra-wide (max-width øges til 1480px)
 * ============================================================================ */

/* ----------------------------------------------------------------------------
 * PAGE WRAPPER
 * ---------------------------------------------------------------------------- */

.d2tb-page {
    font-family: var(--d2-font-body, Arial, Helvetica, sans-serif);
    color: var(--d2-ink-body, #292929);
    line-height: 1.65;
    background: var(--d2-surface, #ffffff);
}

.d2tb-page * {
    box-sizing: border-box;
}

/* ----------------------------------------------------------------------------
 * SEKTION 1: HERO (sort boxed)
 * ---------------------------------------------------------------------------- */

.d2tb-hero {
    padding: 20px 16px 0;
}

.d2tb-hero__inner {
    background: var(--d2-ink-strong, #1a1a1a);
    color: #ffffff;
    border-radius: var(--d2-radius-lg, 12px);
    padding: 56px 28px 48px;
    max-width: 1280px;
    margin: 0 auto;
    text-align: center;
}

.d2tb-hero__eyebrow {
    color: var(--d2-orange, #fc8902);
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 12.5px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin: 0 0 20px;
}

.d2tb-hero__heading {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 800;
    font-size: 32px;
    line-height: 1.15;
    letter-spacing: -0.015em;
    color: #ffffff;
    margin: 0 0 24px;
}

.d2tb-hero__heading em {
    color: var(--d2-orange, #fc8902);
    font-style: italic;
    font-weight: 800;
}

.d2tb-hero__lead {
    font-size: 17px;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.78);
    margin: 0 auto 32px;
    max-width: 640px;
}

.d2tb-hero__contact {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.72);
    margin: 0;
}

.d2tb-hero__contact a {
    color: #ffffff;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}

.d2tb-hero__contact a:hover {
    color: var(--d2-orange, #fc8902);
}

.d2tb-hero__sep {
    margin: 0 10px;
    color: rgba(255, 255, 255, 0.4);
}

/* ----------------------------------------------------------------------------
 * SEKTION 2: PROCESS-STRIP (lys grå, 3 punkter)
 * ---------------------------------------------------------------------------- */

.d2tb-process {
    background: var(--d2-surface-alt, #f7f7f7);
    padding: 56px 24px;
    margin-top: 32px;
}

.d2tb-process__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}

.d2tb-process__step {
    text-align: left;
}

.d2tb-process__number {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 800;
    font-size: 32px;
    color: var(--d2-orange, #fc8902);
    line-height: 1;
    margin-bottom: 12px;
}

.d2tb-process__title {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 20px;
    color: var(--d2-ink, #222222);
    line-height: 1.3;
    margin: 0 0 8px;
}

.d2tb-process__desc {
    font-size: 15px;
    line-height: 1.6;
    color: var(--d2-ink-muted, #444444);
    margin: 0;
}

/* ----------------------------------------------------------------------------
 * SEKTION 3: FORM-CARD (centreret hvid)
 * ---------------------------------------------------------------------------- */

.d2tb-form {
    padding: 56px 16px 56px;
}

.d2tb-form__inner {
    max-width: 880px;
    margin: 0 auto;
}

.d2tb-form__intro {
    text-align: center;
    margin-bottom: 32px;
}

.d2tb-form__eyebrow {
    color: var(--d2-orange, #fc8902);
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 12.5px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin: 0 0 12px;
}

.d2tb-form__heading {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 800;
    font-size: 26px;
    line-height: 1.2;
    letter-spacing: -0.015em;
    color: var(--d2-ink, #222222);
    margin: 0 0 12px;
}

.d2tb-form__lead {
    font-size: 15px;
    line-height: 1.6;
    color: var(--d2-ink-muted, #444444);
    margin: 0;
}

.d2tb-form__required {
    color: var(--d2-orange, #fc8902);
    font-weight: 700;
}

.d2tb-form__card {
    /* Neutraliseret v1.0.2 — wrapper for [d2form theme="dark-box"].
     * Dark-box temaet ejer hele surface-stylingen (baggrund, border, radius,
     * padding, indre layout). Wrapper'en holder kun flex-center alignment
     * af .d2-form-wrap (DS v3.0 form-shortcode integration pattern). */
    display: flex;
    justify-content: center;
}

/* ----------------------------------------------------------------------------
 * SEKTION 4: ALTERNATIV KONTAKT (sort boxed)
 * ---------------------------------------------------------------------------- */

.d2tb-alt {
    padding: 24px 16px 24px;
}

.d2tb-alt__inner {
    background: var(--d2-ink-strong, #1a1a1a);
    color: #ffffff;
    border-radius: var(--d2-radius-lg, 12px);
    padding: 48px 28px;
    max-width: 1280px;
    margin: 0 auto;
    text-align: center;
}

.d2tb-alt__eyebrow {
    color: var(--d2-orange, #fc8902);
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 12.5px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin: 0 0 16px;
}

.d2tb-alt__heading {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 800;
    font-size: 26px;
    line-height: 1.2;
    letter-spacing: -0.015em;
    color: #ffffff;
    margin: 0 0 32px;
}

.d2tb-alt__heading em {
    color: var(--d2-orange, #fc8902);
    font-style: italic;
    font-weight: 800;
}

.d2tb-alt__channels {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 600px;
    margin: 0 auto;
}

.d2tb-alt__channel {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 18px 16px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--d2-radius-md, 6px);
    text-decoration: none;
    color: #ffffff;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.d2tb-alt__channel:not(.d2tb-alt__channel--static):hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--d2-orange, #fc8902);
}

.d2tb-alt__channel--static {
    cursor: default;
}

.d2tb-alt__channel-label {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 1.8px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
}

.d2tb-alt__channel-value {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 17px;
    color: #ffffff;
}

/* ----------------------------------------------------------------------------
 * SEKTION 5: USP-BLOK (hvid baggrund, 4 punkter)
 * ---------------------------------------------------------------------------- */

.d2tb-usp {
    padding: 64px 24px 80px;
}

.d2tb-usp__inner {
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
}

.d2tb-usp__eyebrow {
    color: var(--d2-orange, #fc8902);
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 12.5px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin: 0 0 12px;
}

.d2tb-usp__heading {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 800;
    font-size: 28px;
    line-height: 1.2;
    letter-spacing: -0.015em;
    color: var(--d2-ink, #222222);
    margin: 0 0 36px;
}

.d2tb-usp__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    text-align: left;
}

.d2tb-usp__item {
    background: var(--d2-surface-alt, #f7f7f7);
    border-radius: var(--d2-radius-md, 6px);
    padding: 24px 20px;
    border-left: 3px solid var(--d2-orange, #fc8902);
}

.d2tb-usp__title {
    font-family: var(--d2-font-display, 'Montserrat', Arial, sans-serif);
    font-weight: 700;
    font-size: 17px;
    line-height: 1.3;
    color: var(--d2-ink, #222222);
    margin: 0 0 8px;
}

.d2tb-usp__desc {
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--d2-ink-muted, #444444);
    margin: 0;
}

/* ============================================================================
 * TABLET — small (>= 720px)
 * ============================================================================ */

@media (min-width: 720px) {
    .d2tb-hero {
        padding: 28px 24px 0;
    }
    .d2tb-hero__inner {
        padding: 64px 48px 56px;
    }
    .d2tb-hero__heading {
        font-size: 40px;
        max-width: 800px;
        margin-left: auto;
        margin-right: auto;
    }
    .d2tb-hero__lead {
        font-size: 18px;
    }

    .d2tb-process {
        padding: 72px 32px;
        margin-top: 40px;
    }
    .d2tb-process__inner {
        grid-template-columns: repeat(3, 1fr);
        gap: 40px;
    }
    .d2tb-process__number {
        font-size: 36px;
    }
    .d2tb-process__title {
        font-size: 21px;
    }

    .d2tb-form {
        padding: 72px 32px;
    }
    .d2tb-form__heading {
        font-size: 32px;
    }
    /* .d2tb-form__card padding fjernet v1.0.2 — dark-box tema ejer padding. */

    .d2tb-alt {
        padding: 32px 24px;
    }
    .d2tb-alt__inner {
        padding: 56px 48px;
    }
    .d2tb-alt__heading {
        font-size: 32px;
    }
    .d2tb-alt__channels {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
        max-width: 880px;
    }

    .d2tb-usp {
        padding: 80px 32px 96px;
    }
    .d2tb-usp__heading {
        font-size: 32px;
    }
    .d2tb-usp__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 28px;
    }
    .d2tb-usp__item {
        padding: 28px 24px;
    }
}

/* ============================================================================
 * LAPTOP / DESKTOP (>= 1024px)
 * ============================================================================ */

@media (min-width: 1024px) {
    .d2tb-hero {
        padding: 32px 32px 0;
    }
    .d2tb-hero__inner {
        padding: 88px 64px 72px;
    }
    .d2tb-hero__heading {
        font-size: 52px;
        max-width: 900px;
    }
    .d2tb-hero__lead {
        font-size: 19px;
        max-width: 720px;
    }

    .d2tb-process {
        padding: 88px 40px;
        margin-top: 48px;
    }

    .d2tb-form {
        padding: 88px 40px;
    }
    .d2tb-form__inner {
        max-width: 960px;
    }
    .d2tb-form__heading {
        font-size: 36px;
    }
    /* .d2tb-form__card padding fjernet v1.0.2 — dark-box tema ejer padding. */

    .d2tb-alt {
        padding: 40px 32px;
    }
    .d2tb-alt__inner {
        padding: 72px 64px;
    }
    .d2tb-alt__heading {
        font-size: 36px;
    }

    .d2tb-usp {
        padding: 96px 40px 112px;
    }
    .d2tb-usp__heading {
        font-size: 36px;
    }
    .d2tb-usp__grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 24px;
    }
}

/* ============================================================================
 * ULTRA-WIDE (>= 1600px) — øg max-width til 1480px så det matcher d2-frontpage
 * ============================================================================ */

@media (min-width: 1600px) {
    .d2tb-hero__inner,
    .d2tb-alt__inner {
        max-width: 1480px;
    }
}

/* ============================================================================
 * v1.0.1 — DIVI TEXTAREA OVERRIDE
 * v1.0.2 — udvidet til at dække <select> (samme problem som textarea)
 *
 * Divi's egen frontend CSS rammer alle <textarea> OG <select> elementer i
 * .entry-content og overskriver border til transparent/usynlig samt baggrund
 * til grå. d2-forms' input-styling klarer text/email/tel-inputs fint, men
 * textarea og select kapres af Divi's regler.
 *
 * Vi tvinger synlig border og hvid baggrund tilbage på begge element-typer
 * inde i form-card'et på /software-tilbud/-siden.
 *
 * Scoped til .d2-tilbud-page så ingen andre d2-forms instances påvirkes.
 * ============================================================================ */

body.d2-tilbud-page .d2tb-form .d2-form .d2-field textarea,
body.d2-tilbud-page .d2tb-form .d2-form .d2-field select {
    border: 1px solid var(--d2-line-strong, #d8d8d8) !important;
    background: var(--d2-surface, #ffffff) !important;
    color: var(--d2-ink-body, #292929) !important;
    box-shadow: none !important;
}

body.d2-tilbud-page .d2tb-form .d2-form .d2-field textarea:focus,
body.d2-tilbud-page .d2tb-form .d2-form .d2-field select:focus {
    border-color: var(--d2-orange, #fc8902) !important;
    box-shadow: 0 0 0 3px rgba(252, 137, 2, 0.15) !important;
}
