/* ============================================================
   CABINET LAWRENCE — UI Search Engine (premium)
   Namespace: .cl-*
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
    --cl-bg: #f9fafb;
    --cl-card: #ffffff;
    --cl-ink: #0f172a;
    --cl-muted: #475569;
    --cl-muted-2: #64748b;
    --cl-border: #e5e7eb;
    --cl-border-2: #dbeafe;
    --cl-shadow: 0 12px 30px rgba(15, 23, 42, .08);

    --cl-blue: #0c6b9e;
    --cl-blue-2: #1e40af;
    --cl-blue-soft: rgba(12, 107, 158, .10);

    --cl-gold-1: #d6b25e;
    --cl-gold-2: #b8892f;

    --cl-radius: 16px;
    --cl-radius-sm: 12px;

    --cl-focus: 0 0 0 4px rgba(12, 107, 158, .18);
    --cl-transition: 160ms ease;
}

/* ✅ important: Webflow + modals */
[hidden] {
    display: none !important;
}

/* ---------- Base ---------- */
* {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
}

body {
    margin: 0;
    padding: 24px;
    background: var(--cl-bg);
    color: var(--cl-ink);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

.cl-container {
    max-width: 980px;
    margin: 0 auto;
}

.cl-header {
    margin-bottom: 14px;
}

.cl-header h1 {
    margin: 0 0 6px 0;
    font-size: 1.45rem;
    letter-spacing: .2px;
    color: var(--cl-ink);
}

.cl-header p {
    margin: 0 0 18px 0;
    color: var(--cl-muted);
    font-size: 1rem;
    line-height: 1.5;
}

/* ---------- Search input ---------- */
.cl-searchWrap {
    position: relative;
}

.cl-search {
    width: 100%;
    padding: 16px 16px;
    padding-right: 3.25rem;
    /* place bouton */
    border-radius: var(--cl-radius);
    border: 1px solid var(--cl-border);
    background: #fff;
    font-size: 1.05rem;
    color: var(--cl-ink);
    outline: none;
    box-shadow: 0 2px 10px rgba(15, 23, 42, .04);
    transition: box-shadow var(--cl-transition), border-color var(--cl-transition);
}

.cl-search::placeholder {
    color: rgba(71, 85, 105, .75);
}

.cl-search:focus {
    border-color: rgba(12, 107, 158, .45);
    box-shadow: var(--cl-focus);
}

.cl-searchBtn {
    position: absolute;
    right: 0.6rem;
    top: 50%;
    transform: translateY(-50%);
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, .12);
    background: rgba(255, 255, 255, .9);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
}

.cl-searchBtn:hover {
    transform: translateY(-50%) scale(1.02);
    border-color: rgba(15, 23, 42, .22);
    background: #fff;
}

.cl-searchBtn:active {
    transform: translateY(-50%) scale(.98);
}

.cl-searchBtn[disabled] {
    opacity: .55;
    cursor: not-allowed;
}

.cl-searchBtnIcon {
    display: block;
}

/* ---------- Results container ---------- */
.cl-results {
    margin-top: 18px;
    transition: opacity 220ms ease;
}

/* ---------- Section titles ---------- */
.cl-sectionTitle {
    margin: 14px 0 10px 0;
    font-weight: 800;
    font-size: .95rem;
    color: var(--cl-blue-2);
    letter-spacing: .2px;
}

/* ---------- Cards ---------- */
.cl-card {
    background: var(--cl-card);
    border: 1px solid var(--cl-border);
    border-radius: var(--cl-radius);
    box-shadow: var(--cl-shadow);
    overflow: hidden;
    margin-bottom: 14px;
}

.cl-cardHeader {
    padding: 18px 18px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
    background: linear-gradient(180deg, var(--cl-blue-soft), transparent);
    transition: background var(--cl-transition);
    user-select: none;
}

.cl-cardHeader:hover {
    background: linear-gradient(180deg, rgba(12, 107, 158, .14), transparent);
}

.cl-cardHeader:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

.cl-cardTitle {
    margin: 0 0 4px 0;
    color: var(--cl-blue-2);
    font-size: 1.15rem;
    line-height: 1.15;
}

.cl-cardDesc {
    margin: 0;
    color: var(--cl-muted);
    font-size: .98rem;
    line-height: 1.45;
}

.cl-cardBody {
    padding: 16px 18px 18px 18px;
}

/* ---------- Field / Select ---------- */
.cl-field {
    margin: 10px 0 14px 0;
}

.cl-label {
    display: block;
    margin-bottom: 6px;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--cl-muted-2);
}

.cl-select {
    width: 100%;
    padding: 12px 12px;
    border-radius: var(--cl-radius-sm);
    border: 1px solid var(--cl-border);
    background: #fff;
    color: var(--cl-ink);
    font-size: 1rem;
    outline: none;
    transition: box-shadow var(--cl-transition), border-color var(--cl-transition);
}

.cl-select:focus {
    border-color: rgba(12, 107, 158, .45);
    box-shadow: var(--cl-focus);
}

/* ---------- Hint block ---------- */
.cl-hint {
    margin: 10px 0 14px 0;
    padding: 12px;
    border-radius: var(--cl-radius-sm);
    border: 1px solid var(--cl-border-2);
    background: rgba(219, 234, 254, .25);
}

.cl-hintTitle {
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--cl-blue-2);
    margin-bottom: 8px;
}

/* ---------- CTA Button (gold) ---------- */
.cl-btn {
    width: 100%;
    border: 0;
    border-radius: 14px;
    padding: 12px 14px;
    cursor: pointer;
    font-weight: 850;
    font-size: 1rem;
    color: #0b1220;
    background: linear-gradient(90deg, var(--cl-gold-1), var(--cl-gold-2));
    box-shadow: 0 10px 18px rgba(184, 137, 47, .18);
    transition: transform var(--cl-transition), filter var(--cl-transition), box-shadow var(--cl-transition);
}

.cl-btn:hover {
    filter: brightness(1.03);
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(184, 137, 47, .22);
}

.cl-btn:active {
    transform: translateY(0);
    box-shadow: 0 10px 18px rgba(184, 137, 47, .18);
}

.cl-btn:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

/* ---------- Blocks (pre / next) ---------- */
.cl-block {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--cl-border);
}

.cl-blockTitle {
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--cl-muted-2);
    margin-bottom: 10px;
}

/* ---------- Pills ---------- */
.cl-pillRow {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cl-pill {
    border: 1px solid var(--cl-border);
    background: #fff;
    color: var(--cl-ink);
    padding: 7px 10px;
    border-radius: 999px;
    font-weight: 750;
    font-size: .9rem;
    cursor: pointer;
    transition: background var(--cl-transition), border-color var(--cl-transition), transform var(--cl-transition);
}

.cl-pill:hover {
    transform: translateY(-1px);
    background: rgba(15, 23, 42, .02);
}

.cl-pill:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

.cl-pill--pre {
    background: #ecfdf5;
    border-color: #a7f3d0;
    color: #065f46;
}

.cl-pill--next {
    background: #f5f3ff;
    border-color: #ddd6fe;
    color: #5b21b6;
}

/* ---------- Footer card ---------- */
.cl-footerCard {
    margin-top: 18px;
    border: 1px solid var(--cl-border);
    background: rgba(71, 85, 105, .04);
    border-radius: var(--cl-radius);
    padding: 12px;
    text-align: center;
}

.cl-footerBtn {
    width: 100%;
    border: none;
    background: transparent;
    color: var(--cl-muted);
    font-weight: 800;
    cursor: pointer;
    font-size: .95rem;
    padding: 10px 8px;
    border-radius: 12px;
    transition: background var(--cl-transition), color var(--cl-transition);
}

.cl-footerBtn:hover {
    background: rgba(15, 23, 42, .04);
    color: var(--cl-ink);
}

.cl-footerBtn:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

/* ============================================================
     MODAL — Intake (#clIntake) - même classes que ton HTML
     ============================================================ */

.cl-modalOverlay {
    position: fixed;
    inset: 0;
    background: rgba(2, 6, 23, .55);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    animation: clFadeIn 180ms ease;
}

@keyframes clFadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.cl-modal {
    width: 100%;
    max-width: 420px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--cl-border);
    box-shadow: 0 30px 80px rgba(2, 6, 23, .25);
    overflow: hidden;
    transform: translateY(0);

    /* ✅ utile si tu ajoutes l’auto-resize dans intake.js */
    transition: height 180ms ease;
    will-change: height;
}

.cl-modalHeader {
    padding: 16px 16px 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(180deg, rgba(12, 107, 158, .10), transparent);
    border-bottom: 1px solid var(--cl-border);
}

.cl-modalTitle {
    margin: 0;
    font-size: 1.05rem;
    color: var(--cl-ink);
    font-weight: 900;
}

.cl-modalClose {
    border: 1px solid var(--cl-border);
    background: #fff;
    color: var(--cl-muted);
    border-radius: 12px;
    cursor: pointer;
    padding: 8px 10px;
    font-weight: 900;
    transition: background var(--cl-transition), color var(--cl-transition), border-color var(--cl-transition);
}

.cl-modalClose:hover {
    background: rgba(15, 23, 42, .04);
    color: var(--cl-ink);
}

.cl-modalClose:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

.cl-modalDesc {
    margin: 0;
    padding: 12px 16px 0 16px;
    color: var(--cl-muted);
    font-size: .95rem;
    line-height: 1.45;
}

.cl-modalBody {
    padding: 14px 16px 12px 16px;
    max-height: 320px;
    overflow: auto;
}

.cl-modalBody::-webkit-scrollbar {
    width: 10px;
}

.cl-modalBody::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, .35);
    border-radius: 999px;
    border: 3px solid #fff;
}

.cl-modalBtn {
    display: block;
    width: 100%;
    margin: 8px 0;
    padding: 12px 12px;
    text-align: left;
    border-radius: 14px;
    border: 1px solid var(--cl-border);
    background: #fff;
    color: var(--cl-ink);
    cursor: pointer;
    font-weight: 750;
    transition: transform var(--cl-transition), background var(--cl-transition), border-color var(--cl-transition);
}

.cl-modalBtn:hover {
    transform: translateY(-1px);
    background: rgba(15, 23, 42, .02);
    border-color: rgba(12, 107, 158, .30);
}

.cl-modalBtn:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

.cl-modalCancel {
    width: calc(100% - 32px);
    margin: 0 16px 16px 16px;
    border: 1px solid var(--cl-border);
    background: rgba(71, 85, 105, .06);
    color: var(--cl-muted);
    border-radius: 14px;
    padding: 12px 14px;
    cursor: pointer;
    font-weight: 850;
    transition: background var(--cl-transition), color var(--cl-transition);
}

.cl-modalCancel:hover {
    background: rgba(71, 85, 105, .10);
    color: var(--cl-ink);
}

.cl-modalCancel:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
    body {
        padding: 16px;
    }

    .cl-cardHeader {
        padding: 16px;
    }

    .cl-cardBody {
        padding: 14px 16px 16px 16px;
    }

    .cl-header h1 {
        font-size: 1.28rem;
    }
}

/* --- Modal: bouton retour --- */
.cl-modalBack {
    border: 1px solid var(--cl-border);
    background: #fff;
    color: var(--cl-muted);
    border-radius: 12px;
    cursor: pointer;
    padding: 8px 10px;
    font-weight: 900;
    transition: background var(--cl-transition), color var(--cl-transition), border-color var(--cl-transition);
}

.cl-modalBack:hover {
    background: rgba(15, 23, 42, .04);
    color: var(--cl-ink);
}

.cl-modalBack:focus {
    outline: none;
    box-shadow: var(--cl-focus);
}

/* --- Modal: erreurs user-friendly --- */
.cl-error {
    margin: 10px 0 12px 0;
    padding: 12px;
    border-radius: var(--cl-radius-sm);
    border: 1px solid rgba(185, 28, 28, .25);
    background: rgba(185, 28, 28, .06);
    color: #991b1b;
    font-weight: 700;
    font-size: .95rem;
}

.cl-error[hidden] {
    display: none !important;
}

/* --- "Autre" caché par défaut --- */
#clOtherWrap[hidden] {
    display: none !important;
}

#clOtherWrap {
    margin-top: 10px;
}

/* --- Radios en “cards” claires --- */
.cl-choiceCard {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    margin: 8px 0;
    padding: 12px 12px;
    border-radius: 14px;
    border: 1px solid var(--cl-border);
    background: #fff;
    cursor: pointer;
    font-weight: 800;
    color: var(--cl-ink);
    transition: transform var(--cl-transition), background var(--cl-transition), border-color var(--cl-transition);
}

.cl-choiceCard:hover {
    transform: translateY(-1px);
    background: rgba(15, 23, 42, .02);
    border-color: rgba(12, 107, 158, .30);
}

.cl-choiceCard input {
    margin: 0;
}

/* --- Transition douce entre steps --- */
.cl-step {
    animation: clStepIn 140ms ease;
}

@keyframes clStepIn {
    from {
        opacity: 0;
        transform: translateY(2px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}



/* =========================================
   INTAKE MODAL — auto-resize (no internal scroll)
   ========================================= */

/* On évite de scroller dans le body interne */
#clIntake .cl-modalBody {
    max-height: none;
    overflow: visible;
}

/* Le panneau/containeur du modal doit pouvoir animer sa hauteur */
#clIntake .cl-modal {
    /* important: transition douce de taille */
    transition: height 220ms ease, max-height 220ms ease;
    will-change: height;
}

/* On limite uniquement pour les petits écrans : scroll sur overlay (pas dans la carte) */
#clIntake.cl-modalOverlay {
    overflow: auto;
    /* scroll du voile si nécessaire */
    -webkit-overflow-scrolling: touch;
}

/* Optionnel: sur petit écran, la carte prend presque toute la hauteur */
@media (max-height: 740px) {
    #clIntake .cl-modal {
        max-height: calc(100vh - 36px);
    }
}

/* =========================================================
   MOBILE ONLY — bouton "Démarrer ce dossier" plein largeur
   (scopé au widget: #pathwayContainer)
   ========================================================= */
@media (max-width: 640px) {

    #pathwayContainer .cl-btn-gold,
    #pathwayContainer .cl-btn--gold {
        width: 100%;
        max-width: 100%;
        display: flex;
        /* évite le shrink inline-flex */
        justify-content: center;
        box-sizing: border-box;
    }

    /* si ton bouton est dans un conteneur flex */
    #pathwayContainer .cl-cardBody>.cl-btn-gold,
    #pathwayContainer .cl-cardBody>.cl-btn--gold {
        align-self: stretch;
    }
}


/* =========================================================
   SEARCH PANEL — “carte” qui porte titre + barre + résultats
   ========================================================= */
.cl-searchPanel {
    background: #fff;
    border: 1px solid var(--cl-border);
    border-radius: var(--cl-radius);
    box-shadow: var(--cl-shadow);
    padding: 18px;
    margin-top: 18px;
}

/* le header n’a plus besoin de marge “flottante” */
.cl-searchPanel .cl-header {
    margin-bottom: 12px;
}

/* on aligne l’ensemble sur la largeur des résultats */
.cl-searchPanel .cl-results {
    margin-top: 16px;
}

/* petit “filet” de séparation quand des résultats existent */
.cl-searchPanel .cl-results:not(:empty) {
    padding-top: 14px;
    border-top: 1px solid rgba(15, 23, 42, .06);
}

/* responsive */
@media (max-width: 640px) {
    .cl-searchPanel {
        padding: 14px;
    }
}


/* Header cliquable plus explicite */
.cl-cardHeader {
    position: relative;
}

/* micro-indication : “Cliquer pour ouvrir” */
.cl-cardHeader::after {
    content: "Cliquer pour ouvrir";
    position: absolute;
    right: 44px;
    top: 18px;
    font-size: .78rem;
    font-weight: 800;
    color: rgba(71, 85, 105, .75);
    letter-spacing: .02em;
}

.cl-cardHeader[aria-expanded="true"]::after {
    content: "Réduire";
}

/* plein largeur pour le bouton start uniquement dans le widget */
#pathwayContainer .cl-btn-gold {
    display: flex;
    justify-content: center;
    width: 100%;
}

/* Textarea: même look que inputs */
.cl-textarea {
    resize: vertical;
    /* user-friendly */
    min-height: 96px;
    max-height: 220px;
    line-height: 1.35;
}


/* =========================================
   LOADING UI — Search (spinner)
   ========================================= */

.cl-results {
    position: relative;
}

.cl-results[aria-busy="true"]::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, .55);
    backdrop-filter: blur(1.5px);
    border-radius: var(--cl-radius);
    z-index: 5;
}

.cl-results[aria-busy="true"]::after {
    content: "";
    position: absolute;
    top: 18px;
    right: 18px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 2px solid rgba(15, 23, 42, .20);
    border-top-color: rgba(15, 23, 42, .75);
    animation: clSpin .8s linear infinite;
    z-index: 6;
}

/* Bouton loupe : spinner */
.cl-searchBtn {
    position: absolute;
    /* déjà chez toi, on le rappelle juste */
}

.cl-searchBtn[data-loading="1"] .cl-searchBtnIcon {
    opacity: 0;
}

.cl-searchBtn[data-loading="1"]::after {
    content: "";
    position: absolute;
    inset: 0;
    margin: auto;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 2px solid rgba(15, 23, 42, .20);
    border-top-color: rgba(15, 23, 42, .75);
    animation: clSpin .8s linear infinite;
}

@keyframes clSpin {
    to {
        transform: rotate(360deg);
    }
}