/* ===================================================
   Abbaye de Sorde — Enquête 2026
   =================================================== */

:root {
    --color-primary:   #5a3a1a;
    --color-accent:    #b8860b;
    --color-bg:        #faf7f2;
    --color-card:      #ffffff;
    --color-border:    #d4c5a9;
    --color-text:      #382F22;
    --color-muted:     #7a6a55;
    --color-error:     #c0392b;
    --color-success:   #27ae60;
    --color-required:  #c0392b;
    --radius:          8px;
    --shadow:          0 2px 12px rgba(90,58,26,.10);
    --max-width:       760px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: 'Segoe UI', Arial, sans-serif;
    background: var(--color-bg);
    color: var(--color-text);
    line-height: 1.6;
    padding: 2rem 1rem 4rem;
}

/* ── Survey wrapper ── */
.survey-wrapper {
    max-width: var(--max-width);
    margin: 0 auto;
}

.survey-header {
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius) var(--radius) 0 0;
    padding: 2rem 2rem 1.5rem;
    text-align: center;
}
.survey-header .logo { max-height: 80px; margin-bottom: 1rem;
    background: #fff; padding: 30px; border-radius: 8px; }
.survey-header h1 { font-size: 1.5rem; font-weight: 700; margin-bottom: .5rem; }
.survey-header .survey-desc { font-size: .95rem; opacity: .9; margin-bottom: .75rem; }
.survey-header .mention-collecte { font-size: .82rem; opacity: .75; font-style: italic; }
.survey-header .obligatoire-legende { margin-top: .75rem; font-size: .85rem; opacity: .8; }
.req { color: #f8c471; font-weight: 700; }

/* ── Question blocks ── */
.question-block {
    background: var(--color-card);
    border: 1px solid var(--color-border);
    border-top: none;
    padding: 1.5rem 2rem;
    transition: background .2s;
}
.question-block:last-of-type { border-radius: 0 0 var(--radius) var(--radius); }
.question-block.has-error { background: #fff8f8; border-left: 4px solid var(--color-error); }

.question-label {
    display: block;
    font-weight: 600;
    margin-bottom: .75rem;
    color: var(--color-primary);
}
fieldset.fieldset-group { border: none; }
fieldset.fieldset-group legend { font-weight: 600; color: var(--color-primary); margin-bottom: .75rem; width: 100%; }
fieldset.fieldset-error { background: #fff8f8; }

/* ── Inputs ── */
.input-text, .input-textarea {
    width: 100%;
    padding: .55rem .85rem;
    border: 1.5px solid var(--color-border);
    border-radius: 5px;
    font-size: .95rem;
    font-family: inherit;
    background: #fdfaf5;
    transition: border-color .2s;
}
.input-text:focus, .input-textarea:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(184,134,11,.15);
}
.input-error { border-color: var(--color-error) !important; }
.input-textarea { resize: vertical; min-height: 100px; }

/* ── Radio / Checkbox ── */
.radio-label, .checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: .6rem;
    margin-bottom: .45rem;
    cursor: pointer;
    font-size: .95rem;
}
.radio-label input, .checkbox-label input {
    margin-top: 3px;
    accent-color: var(--color-accent);
    width: 17px; height: 17px;
    flex-shrink: 0;
}

/* ── Scale (NPS) ── */
.scale-labels {
    display: flex;
    justify-content: space-between;
    font-size: .8rem;
    color: var(--color-muted);
    margin-bottom: .4rem;
}
.scale-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
}
.scale-label { cursor: pointer; }
.scale-label input { display: none; }
.scale-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px; height: 42px;
    border: 2px solid var(--color-border);
    border-radius: 6px;
    font-weight: 600;
    font-size: .9rem;
    background: #fdfaf5;
    transition: all .15s;
}
.scale-label input:checked + .scale-btn {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}
.scale-label:hover .scale-btn { border-color: var(--color-accent); background: #fef9ec; }

/* ── Matrix ── */
.matrix-scroll { overflow-x: auto; }
.matrix-table { border-collapse: collapse; width: 100%; min-width: 520px; font-size: .88rem; }
.matrix-table th {
    background: var(--color-primary);
    color: #fff;
    padding: .5rem .4rem;
    text-align: center;
    font-weight: 500;
    font-size: .82rem;
}
.matrix-table td { padding: .45rem .4rem; border-bottom: 1px solid var(--color-border); text-align: center; }
.matrix-row-label { text-align: left !important; font-size: .88rem; min-width: 180px; padding-left: .5rem !important; }
.matrix-table tr:nth-child(even) td { background: #faf7f2; }
.matrix-table input[type=radio] { accent-color: var(--color-accent); width: 18px; height: 18px; cursor: pointer; }

/* ── RGPD block ── */
.rgpd-block {
    background: #f5f0e8;
    border-left: 4px solid var(--color-accent);
    padding: 1.2rem;
    border-radius: 5px;
    font-size: .9rem;
}
.rgpd-block h3 { color: var(--color-primary); margin-bottom: .75rem; font-size: 1rem; }
.rgpd-block p { margin-bottom: .6rem; color: var(--color-muted); }
.rgpd-block a { color: var(--color-accent); }
.rgpd-consent { margin-top: 1rem; align-items: flex-start; font-weight: 500; color: var(--color-text); }

/* ── Errors ── */
.error-msg { display: block; color: var(--color-error); font-size: .83rem; margin-top: .35rem; }
.alert-error {
    background: #fdecea; border: 1px solid #f5b7b1;
    color: var(--color-error); padding: 1rem 1.5rem;
    border-radius: var(--radius); margin-bottom: 1rem;
}

/* ── Submit ── */
.submit-block {
    background: var(--color-card);
    border: 1px solid var(--color-border);
    border-top: none;
    border-radius: 0 0 var(--radius) var(--radius);
    padding: 1.5rem 2rem 2rem;
    text-align: center;
}
.btn-submit {
    background: var(--color-primary);
    color: #fff;
    border: none;
    padding: .85rem 3rem;
    border-radius: 30px;
    font-size: 1.05rem;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: .04em;
    transition: background .2s, transform .1s;
}
.btn-submit:hover  { background: var(--color-accent); }
.btn-submit:active { transform: scale(.97); }

/* ── Merci page ── */
.merci-container {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.merci-card {
    background: var(--color-card);
    max-width: 480px;
    width: 100%;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 3rem 2.5rem;
    text-align: center;
}
.merci-icon {
    width: 72px; height: 72px;
    background: var(--color-success);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 700;
    margin: 0 auto 1.5rem;
}
.merci-card h1 { color: var(--color-primary); font-size: 1.4rem; margin-bottom: .75rem; }
.merci-card p  { color: var(--color-muted); font-size: .95rem; margin-bottom: 1rem; }
.countdown-bar { height: 6px; background: #e8e0d0; border-radius: 3px; overflow: hidden; margin: 1rem 0 .5rem; }
.countdown-fill { height: 100%; width: 100%; background: var(--color-accent); border-radius: 3px; }
.countdown-text { font-size: .88rem; color: var(--color-muted); }

/* ── Admin styles ── */
.admin-layout { display: flex; min-height: 100vh; }
.admin-sidebar {
    width: 240px; flex-shrink: 0;
    background: var(--color-primary);
    color: #fff; padding: 1.5rem 1rem;
}
.admin-sidebar h2 { font-size: 1rem; margin-bottom: 1.5rem; opacity: .85; }
.admin-sidebar nav a {
    display: block; color: #e8d5b0; text-decoration: none;
    padding: .6rem .8rem; border-radius: 5px;
    margin-bottom: .25rem; font-size: .92rem;
    transition: background .15s;
}
.admin-sidebar nav a:hover, .admin-sidebar nav a.active { background: rgba(255,255,255,.15); color: #fff; }
.admin-main { flex: 1; padding: 2rem; overflow-x: auto; }
.admin-main h1 { color: var(--color-primary); margin-bottom: 1.5rem; font-size: 1.4rem; }

/* ── Tables admin ── */
.data-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.data-table th { background: var(--color-primary); color: #fff; padding: .6rem .8rem; text-align: left; font-weight: 500; }
.data-table td { padding: .55rem .8rem; border-bottom: 1px solid var(--color-border); }
.data-table tr:nth-child(even) td { background: #faf7f2; }
.data-table tr:hover td { background: #fef9ec; }

/* ── Filters ── */
.filter-bar { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; align-items: flex-end; }
.filter-bar label { font-size: .85rem; font-weight: 600; color: var(--color-primary); display: block; margin-bottom: .25rem; }
.filter-bar input, .filter-bar select {
    padding: .45rem .75rem; border: 1.5px solid var(--color-border);
    border-radius: 5px; font-size: .9rem; background: #fdfaf5;
}
.btn { padding: .5rem 1.2rem; border-radius: 20px; border: none; cursor: pointer; font-size: .9rem; font-weight: 600; }
.btn-primary { background: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-accent); }
.btn-secondary { background: var(--color-border); color: var(--color-text); }
.btn-secondary:hover { background: #c4b49a; }
.btn-danger { background: var(--color-error); color: #fff; }

/* ── Stats ── */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.25rem; margin-bottom: 2rem; }
.stat-card { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 1.25rem; text-align: center; }
.stat-card .stat-num { font-size: 2.5rem; font-weight: 700; color: var(--color-primary); }
.stat-card .stat-label { font-size: .85rem; color: var(--color-muted); margin-top: .25rem; }
.chart-card { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 1.5rem; margin-bottom: 1.5rem; }
.chart-card h3 { color: var(--color-primary); margin-bottom: 1rem; font-size: 1rem; }

/* ── Login ── */
.login-container { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.login-card { background: var(--color-card); border-radius: var(--radius); box-shadow: var(--shadow); padding: 2.5rem 2rem; width: 100%; max-width: 380px; }
.login-card h1 { text-align: center; color: var(--color-primary); margin-bottom: 1.5rem; font-size: 1.3rem; }
.form-group { margin-bottom: 1.1rem; }
.form-group label { display: block; font-weight: 600; font-size: .88rem; margin-bottom: .35rem; color: var(--color-primary); }
.form-group input { width: 100%; padding: .55rem .85rem; border: 1.5px solid var(--color-border); border-radius: 5px; font-size: .95rem; }

/* ── Responsive ── */
@media (max-width: 600px) {
    body { padding: 0 0 3rem; }
    .survey-header, .question-block, .submit-block { padding: 1.2rem 1rem; }
    .scale-btn { width: 35px; height: 35px; font-size: .82rem; }
    .admin-layout { flex-direction: column; }
    .admin-sidebar { width: 100%; }
}

/* ── Date picker ── */
.input-date {
    cursor: pointer;
    max-width: 220px;
}
.input-date::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: .7;
    filter: invert(20%) sepia(40%) saturate(600%) hue-rotate(10deg);
}

/* ── Logo page remerciements ── */
.merci-logo-wrap {
    background: #fff;
    padding: 30px;
    display: inline-block;
    margin-bottom: 1.5rem;
}
.merci-logo {
    width: 300px;
    height: 160px;
    object-fit: contain;
    display: block;
}
