/* =============================================================================
 * val_form — design system « 6ème École de Provence »
 *
 * Direction : joyeux + rassurant + ludique, adapté à des élèves de 11 ans.
 * Palette inspirée du logo (rouge, jaune, bleu) adoucie par des pastels.
 * Fonts self-hostées dans /public/fonts/ (RGPD-friendly, pas de Google Fonts CDN).
 * ===========================================================================*/

/* -- 1. Fonts locales -------------------------------------------------------- */
@font-face {
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('/public/fonts/baloo2-500.woff2') format('woff2');
}
@font-face {
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('/public/fonts/baloo2-700.woff2') format('woff2');
}
@font-face {
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 800;
    font-display: swap;
    src: url('/public/fonts/baloo2-800.woff2') format('woff2');
}
@font-face {
    font-family: 'Quicksand';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('/public/fonts/quicksand-400.woff2') format('woff2');
}
@font-face {
    font-family: 'Quicksand';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('/public/fonts/quicksand-500.woff2') format('woff2');
}
@font-face {
    font-family: 'Quicksand';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('/public/fonts/quicksand-600.woff2') format('woff2');
}

/* -- 2. Design tokens -------------------------------------------------------- */
:root {
    --ink:      #2D2D34;
    --ink-soft: #5A5A66;
    --paper:    #FFFBF4;
    --paper-2:  #FFF4DE;
    --bubble:   #FFC4D6;
    --mint:     #A0E7E5;
    --sand:     #FBE7C6;
    --sprout:   #B4F8C8;
    --lilac:    #E0C3FC;

    --accent:   #C8261C;
    --accent-2: #1E5C8E;
    --sunshine: #F8D229;
    --grass:    #2A9D5F;

    --font-display: 'Baloo 2', 'Comic Sans MS', cursive;
    --font-body:    'Quicksand', system-ui, sans-serif;

    --space-1: .25rem; --space-2: .5rem;  --space-3: .75rem;
    --space-4: 1rem;   --space-6: 1.5rem; --space-8: 2rem;
    --space-12: 3rem;  --space-16: 4rem;  --space-24: 6rem;

    --radius-sm: .5rem;
    --radius-md: 1rem;
    --radius-lg: 1.5rem;
    --radius-xl: 2rem;
    --radius-pill: 999px;

    --shadow-sm: 0 2px 0 rgba(45,45,52,.08);
    --shadow-md: 0 4px 0 rgba(45,45,52,.12), 0 8px 24px rgba(45,45,52,.08);
    --shadow-lg: 0 6px 0 rgba(45,45,52,.15), 0 16px 40px rgba(45,45,52,.12);
    --shadow-stick: 0 4px 0 var(--ink);

    --t-fast: 150ms cubic-bezier(.4,0,.2,1);
    --t:      300ms cubic-bezier(.4,0,.2,1);
    --t-slow: 600ms cubic-bezier(.4,0,.2,1);
    --bounce: cubic-bezier(.34,1.56,.64,1);
}

/* -- 3. Reset léger ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.55;
    color: var(--ink);
    background: var(--paper);
    min-height: 100vh;
}
h1, h2, h3, h4 {
    font-family: var(--font-display);
    font-weight: 800;
    color: var(--ink);
    margin: 0;
    line-height: 1.15;
}

/* -- 4. Bulles décoratives en arrière-plan ---------------------------------- */
.bg-bubbles {
    position: fixed;
    inset: 0;
    z-index: -1;
    overflow: hidden;
    pointer-events: none;
    background: var(--paper);
}
.bg-bubbles::before,
.bg-bubbles::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    filter: blur(40px);
    opacity: .55;
    animation: float 18s ease-in-out infinite;
}
.bg-bubbles::before {
    width: 380px; height: 380px;
    background: var(--bubble);
    top: -120px; left: -120px;
}
.bg-bubbles::after {
    width: 460px; height: 460px;
    background: var(--mint);
    bottom: -160px; right: -160px;
    animation-delay: -6s;
}
.bg-bubbles .bubble {
    position: absolute;
    border-radius: 50%;
    filter: blur(30px);
    opacity: .4;
    animation: float 22s ease-in-out infinite;
}
.bg-bubbles .bubble--sand   { width: 260px; height: 260px; background: var(--sand);   top: 30%; left: 70%; animation-delay: -3s; }
.bg-bubbles .bubble--sprout { width: 220px; height: 220px; background: var(--sprout); top: 65%; left: 5%;  animation-delay: -9s; }
.bg-bubbles .bubble--lilac  { width: 180px; height: 180px; background: var(--lilac);  top: 12%; left: 50%; animation-delay: -14s; }

@keyframes float {
    0%, 100% { transform: translate(0,0) scale(1); }
    33%      { transform: translate(40px,-30px) scale(1.05); }
    66%      { transform: translate(-30px,20px) scale(.95); }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        transition-duration: .01ms !important;
    }
    .bg-bubbles::before,
    .bg-bubbles::after,
    .bg-bubbles .bubble { animation: none; }
}

/* -- 5. Layout formulaire enfant -------------------------------------------- */
.form-shell {
    max-width: 720px;
    margin: 0 auto;
    padding: var(--space-6) var(--space-4) var(--space-16);
    position: relative;
}
.form-shell__header {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: var(--space-8);
}
.form-shell__logo {
    height: 56px;
    width: auto;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,.08));
}
.form-shell__title-wrap { flex: 1; min-width: 0; }
.form-shell__eyebrow {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--accent);
    margin: 0 0 .15rem;
}
.form-shell__title {
    font-size: clamp(1.4rem, 4vw, 2rem);
    line-height: 1.05;
}
.form-shell__title em {
    font-style: normal;
    color: var(--accent-2);
    background: linear-gradient(180deg, transparent 60%, var(--sunshine) 60%);
    padding: 0 .15em;
}

.step-card {
    background: white;
    border-radius: var(--radius-xl);
    padding: var(--space-8) var(--space-6);
    box-shadow: var(--shadow-lg);
    border: 2px solid var(--ink);
    position: relative;
    overflow: hidden;
}
.step-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 8px;
    background: linear-gradient(90deg,
        var(--bubble) 0%, var(--sand) 25%,
        var(--mint) 50%, var(--sprout) 75%,
        var(--lilac) 100%);
}
.step-card__intro {
    color: var(--ink-soft);
    margin: var(--space-2) 0 var(--space-6);
    font-size: 1rem;
}

/* -- 6. Progression --------------------------------------------------------- */
.progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    margin-bottom: var(--space-6);
    flex-wrap: wrap;
}
.progress__dot {
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--paper-2);
    border: 2px solid var(--ink);
    transition: all var(--t) var(--bounce);
}
.progress__dot--active {
    background: var(--accent);
    transform: scale(1.4);
}
.progress__dot--done {
    background: var(--grass);
}
.progress__label {
    margin-left: var(--space-3);
    font-weight: 600;
    color: var(--ink-soft);
    font-size: .92rem;
}

/* -- 7. Champs --------------------------------------------------------------- */
.field {
    margin-bottom: var(--space-6);
}
.field__label {
    display: block;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: var(--space-2);
    color: var(--ink);
}
.field__label .req { color: var(--accent); margin-left: .2em; }
.field__hint {
    color: var(--ink-soft);
    font-size: .9rem;
    margin: -.25rem 0 var(--space-2);
}
.field__error {
    color: var(--accent);
    font-weight: 600;
    font-size: .9rem;
    margin-top: var(--space-2);
    display: flex; align-items: center; gap: var(--space-1);
}
.field__error::before { content: '⚠'; }

.input, .textarea {
    width: 100%;
    font: inherit;
    color: var(--ink);
    background: white;
    border: 2px solid var(--ink);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    transition: all var(--t-fast);
    box-shadow: var(--shadow-sm);
}
.input:focus, .textarea:focus {
    outline: none;
    border-color: var(--accent-2);
    box-shadow: 0 0 0 4px rgba(30,92,142,.15), var(--shadow-sm);
}
.textarea { min-height: 140px; resize: vertical; }
.input--invalid, .textarea--invalid {
    border-color: var(--accent);
    background: #FFF5F4;
}
.input-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}
@media (max-width: 520px) {
    .input-row { grid-template-columns: 1fr; }
}

/* -- 8. Boutons radio « gros et joyeux » ------------------------------------ */
.choice-list {
    display: grid;
    gap: var(--space-3);
    list-style: none;
    padding: 0; margin: 0;
}
.choice {
    position: relative;
}
.choice__input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.choice__label {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-6);
    background: white;
    border: 2px solid var(--ink);
    border-radius: var(--radius-lg);
    font-weight: 500;
    cursor: pointer;
    box-shadow: var(--shadow-stick);
    transition: all var(--t-fast) var(--bounce);
}
.choice__label::before {
    content: '';
    flex-shrink: 0;
    width: 28px; height: 28px;
    border-radius: 50%;
    border: 2px solid var(--ink);
    background: var(--paper);
    transition: all var(--t-fast);
}
.choice__label:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 0 var(--ink);
}
.choice__input:focus-visible + .choice__label {
    outline: 3px solid var(--accent-2);
    outline-offset: 3px;
}
.choice__input:checked + .choice__label {
    background: var(--sand);
    transform: translateY(2px);
    box-shadow: 0 1px 0 var(--ink);
}
.choice__input:checked + .choice__label::before {
    background: var(--accent);
    box-shadow: inset 0 0 0 5px white;
}

/* -- 9. Drag & drop classement ---------------------------------------------- */
.rank {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: var(--space-6);
    align-items: start;
}
@media (max-width: 720px) {
    .rank { grid-template-columns: 1fr; }
}
.rank__column-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1rem;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: var(--space-3);
}
.rank__slots {
    list-style: none; padding: 0; margin: 0;
    display: grid; gap: var(--space-2);
}
.rank__slot {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    background: rgba(255,255,255,.6);
    border: 2px dashed var(--ink-soft);
    border-radius: var(--radius-md);
    padding: var(--space-2);
    min-height: 64px;
    transition: all var(--t-fast);
}
.rank__slot[data-position="1"] { border-color: var(--accent);   background: #FFF1F0; }
.rank__slot[data-position="2"] { border-color: #E8643E; }
.rank__slot[data-position="3"] { border-color: var(--sunshine); }
.rank__slot[data-position="4"] { border-color: var(--grass); }
.rank__slot[data-position="5"] { border-color: var(--accent-2); }
.rank__slot[data-position="6"] { border-color: var(--ink-soft); }
.rank__slot.sortable-ghost {
    background: var(--sprout) !important;
    border-style: solid;
}
.rank__position {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--ink);
    color: white;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1.4rem;
    flex-shrink: 0;
    box-shadow: var(--shadow-sm);
}
.rank__slot[data-position="1"] .rank__position { background: var(--accent); }
.rank__slot[data-position="2"] .rank__position { background: #E8643E; }
.rank__slot[data-position="3"] .rank__position { background: var(--sunshine); color: var(--ink); }
.rank__slot[data-position="4"] .rank__position { background: var(--grass); }
.rank__slot[data-position="5"] .rank__position { background: var(--accent-2); }
.rank__slot[data-position="6"] .rank__position { background: var(--ink-soft); }

.rank__pool {
    list-style: none; padding: 0; margin: 0;
    display: grid; gap: var(--space-2);
    background: rgba(255,255,255,.3);
    border-radius: var(--radius-md);
    padding: var(--space-2);
    min-height: 80px;
}
.rank__item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    background: white;
    border: 2px solid var(--ink);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    cursor: grab;
    box-shadow: var(--shadow-stick);
    transition: transform var(--t-fast), box-shadow var(--t-fast);
    user-select: none;
    touch-action: none;
}
.rank__item:hover {
    transform: translateY(-1px) rotate(-.5deg);
    box-shadow: 0 6px 0 var(--ink);
}
.rank__item.sortable-chosen {
    cursor: grabbing;
    transform: rotate(2deg) scale(1.02);
    box-shadow: 0 10px 24px rgba(45,45,52,.25);
}
.rank__item.sortable-drag {
    opacity: .9;
    cursor: grabbing;
}
.rank__letter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--mint);
    color: var(--ink);
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1.1rem;
    flex-shrink: 0;
}

/* -- 10. CTA & navigation --------------------------------------------------- */
.actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-4);
    margin-top: var(--space-8);
}
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.1rem;
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-pill);
    border: 2px solid var(--ink);
    cursor: pointer;
    background: white;
    color: var(--ink);
    box-shadow: var(--shadow-stick);
    transition: transform var(--t-fast) var(--bounce), box-shadow var(--t-fast);
    text-decoration: none;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--ink); }
.btn:active { transform: translateY(2px); box-shadow: 0 1px 0 var(--ink); }
.btn[data-loading="true"] { opacity: .6; cursor: progress; pointer-events: none; }
.btn--primary {
    background: var(--accent);
    color: white;
    font-size: 1.2rem;
    padding: var(--space-4) var(--space-8);
}
.btn--primary:hover { background: #B01F16; }
.btn--ghost {
    background: transparent;
    border-color: var(--ink-soft);
    color: var(--ink-soft);
    box-shadow: none;
}
.btn--ghost:hover { background: var(--paper-2); transform: none; box-shadow: none; }
.btn--big {
    width: 100%;
    justify-content: center;
    font-size: 1.4rem;
    padding: var(--space-4) var(--space-8);
}

/* -- 11. Mascotte (SVG inline) ---------------------------------------------- */
.mascot {
    position: relative;
    display: inline-block;
    width: 80px; height: 80px;
    animation: bobbing 4s ease-in-out infinite;
}
.mascot--large { width: 140px; height: 140px; }
@keyframes bobbing {
    0%, 100% { transform: translateY(0) rotate(-2deg); }
    50%      { transform: translateY(-6px) rotate(2deg); }
}

/* -- 12. Étapes (transitions) ---------------------------------------------- */
[data-step] {
    display: none;
    animation: stepIn .4s var(--bounce);
}
[data-step].is-active {
    display: block;
}
@keyframes stepIn {
    from { opacity: 0; transform: translateX(24px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* -- 13. Encart RGPD -------------------------------------------------------- */
.rgpd-card {
    background: var(--paper-2);
    border: 2px solid var(--sunshine);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-6);
    margin: var(--space-4) 0;
    font-size: .95rem;
    color: var(--ink-soft);
    line-height: 1.5;
}
.rgpd-card strong { color: var(--ink); }
.rgpd-card a { color: var(--accent-2); text-decoration: underline; }

.checkbox-row {
    display: flex;
    gap: var(--space-3);
    align-items: flex-start;
    margin-top: var(--space-4);
    padding: var(--space-4);
    background: white;
    border: 2px solid var(--ink);
    border-radius: var(--radius-md);
    cursor: pointer;
}
.checkbox-row input[type="checkbox"] {
    flex-shrink: 0;
    width: 24px; height: 24px;
    accent-color: var(--accent);
    margin: 0;
    cursor: pointer;
}
.checkbox-row span { font-size: .95rem; line-height: 1.45; }

/* -- 14. Récap final -------------------------------------------------------- */
.recap {
    background: var(--paper-2);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-6);
}
.recap__title {
    font-family: var(--font-display);
    font-weight: 700;
    color: var(--accent);
    margin-bottom: var(--space-2);
}
.recap__item { margin-bottom: var(--space-3); }
.recap__item dt {
    font-weight: 600;
    color: var(--ink-soft);
    font-size: .85rem;
    margin-bottom: var(--space-1);
}
.recap__item dd { margin: 0; color: var(--ink); }

/* -- 15. Page success ------------------------------------------------------- */
.success {
    text-align: center;
    padding: var(--space-16) var(--space-4);
}
.success__icon {
    font-size: 5rem;
    line-height: 1;
    margin-bottom: var(--space-4);
}
.success__title {
    font-size: clamp(2rem, 6vw, 3.5rem);
    margin-bottom: var(--space-3);
}
.success__lead {
    font-size: 1.2rem;
    color: var(--ink-soft);
    max-width: 480px;
    margin: 0 auto var(--space-8);
}

/* -- 16. Dashboard (sélecteur + carte de réponse) -------------------------- */
.dash-shell {
    max-width: 920px;
    margin: 0 auto;
    padding: var(--space-6) var(--space-4) var(--space-16);
}
.dash-header {
    background: white;
    border: 2px solid var(--ink);
    border-radius: var(--radius-lg);
    padding: var(--space-4) var(--space-6);
    margin-bottom: var(--space-4);
    box-shadow: var(--shadow-md);
}
.dash-toolbar {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-3);
    align-items: end;
}
@media (max-width: 640px) {
    .dash-toolbar { grid-template-columns: 1fr; }
}
.dash-empty {
    text-align: center;
    padding: var(--space-16);
    color: var(--ink-soft);
}

.answer-card {
    background: white;
    border: 2px solid var(--ink);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    margin-bottom: var(--space-4);
    box-shadow: var(--shadow-md);
}
.answer-card__title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--paper-2);
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
}
.answer-card__name {
    font-size: 1.6rem;
    color: var(--accent-2);
}
.answer-card__date {
    color: var(--ink-soft);
    font-size: .9rem;
}
.answer-card__section {
    margin-bottom: var(--space-6);
}
.answer-card__section h3 {
    font-size: 1.1rem;
    color: var(--accent);
    margin-bottom: var(--space-3);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.answer-card__qa {
    margin-bottom: var(--space-3);
    padding-left: var(--space-4);
    border-left: 3px solid var(--sand);
}
.answer-card__q {
    font-weight: 600;
    color: var(--ink-soft);
    font-size: .92rem;
    margin-bottom: var(--space-1);
}
.answer-card__a {
    color: var(--ink);
    white-space: pre-wrap;
    word-break: break-word;
}
.rank-result {
    display: flex; flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-2);
}
.rank-result__chip {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    background: var(--paper-2);
    border-radius: var(--radius-pill);
    font-size: .9rem;
    font-weight: 600;
}
.rank-result__chip span { color: var(--accent); }

/* -- 17. Header / nav admin ------------------------------------------------- */
.topbar {
    background: white;
    border-bottom: 2px solid var(--ink);
    padding: var(--space-3) var(--space-4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: var(--font-display);
    font-weight: 700;
}
.topbar a { color: var(--ink); text-decoration: none; transition: color var(--t-fast); }
.topbar a:hover { color: var(--accent); }
.topbar nav { display: flex; gap: var(--space-4); align-items: center; font-size: .95rem; }
.topbar form { display: inline; }
.topbar button {
    font: inherit; background: none; border: none; cursor: pointer;
    color: var(--ink-soft);
}
.topbar button:hover { color: var(--accent); }

/* -- 18. Flash messages ----------------------------------------------------- */
.flash {
    border: 2px solid var(--ink);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    margin: var(--space-3) auto;
    max-width: 720px;
    font-weight: 500;
    box-shadow: var(--shadow-sm);
}
.flash--success { background: #E9FBE4; border-color: var(--grass); }
.flash--error   { background: #FFE9E7; border-color: var(--accent); }
.flash--warning { background: #FFF7DA; border-color: var(--sunshine); }
.flash--info    { background: #E4F2FB; border-color: var(--accent-2); }

/* -- 19. Footer ------------------------------------------------------------- */
.footer {
    text-align: center;
    padding: var(--space-8) var(--space-4);
    font-size: .85rem;
    color: var(--ink-soft);
}
.footer a { color: var(--accent-2); }

/* -- 20. Admin (rétro-compat : on garde les classes Tailwind dans l'admin) - */
/* Le runtime Tailwind chargé en local génère le reste à la volée. */

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px white inset;
    box-shadow: 0 0 0 1000px white inset;
}

button[data-loading="true"] {
    opacity: 0.6;
    cursor: progress;
    pointer-events: none;
}

pre.json-view {
    background: #0f172a;
    color: #e2e8f0;
    padding: 1rem;
    border-radius: 0.5rem;
    overflow-x: auto;
    font-size: 0.875rem;
    line-height: 1.5;
}
