/* ════════════════════════════════════════════════════════════════════
   CARO — Espace d'administration
   Élégant, clair et rassurant. Simple à utiliser, mais premium.
   ════════════════════════════════════════════════════════════════════ */

:root{
    --ink:#241f17;
    --ink-soft:#5b5446;
    --ink-faint:#8d846f;
    --gold:#a9824c;
    --gold-deep:#876239;
    --espresso:#231d15;
    --bg:#f6f1e7;
    --paper:#ffffff;
    --line:#e6dcc8;
    --line-soft:#efe7d6;
    --ok:#2e7d32;
    --ok-bg:#eaf5ea;
    --err:#b3261e;
    --err-bg:#fbe9e7;
    --ui:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
    --serif:'Cormorant Garamond',Georgia,serif;
    --radius:12px;
    --shadow:0 16px 40px rgba(90,66,30,.10);
    --shadow-soft:0 8px 22px rgba(90,66,30,.07);
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--ui);font-size:16px;line-height:1.6;color:var(--ink);background:var(--bg)}
a{color:var(--gold-deep);text-decoration:none}
img{max-width:100%;display:block}

/* ── Barre supérieure ──────────────────────────────────── */
.abar{background:var(--espresso);color:#f2e9d8;position:sticky;top:0;z-index:50;box-shadow:0 4px 20px rgba(0,0,0,.18)}
.abar__in{max-width:1080px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.abar__brand{display:flex;flex-direction:column;line-height:1.05;color:#fff}
.abar__brand strong{font-family:var(--serif);font-size:23px;font-weight:600}
.abar__brand span{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.abar__nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-left:auto}
.abar__nav a{color:#e7dcc6;font-weight:500;font-size:14px;padding:8px 14px;border-radius:8px;transition:background .2s,color .2s}
.abar__nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.abar__nav a.is-active{background:var(--gold);color:#fff}
.abar__see{border:1px solid rgba(255,255,255,.22)}
.abar__out{color:#e0b3ac!important}
.abar__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.abar__burger span{width:26px;height:2px;background:#f2e9d8;border-radius:2px;transition:.3s}
.abar__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.abar__burger.is-open span:nth-child(2){opacity:0}
.abar__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Conteneur ─────────────────────────────────────────── */
.awrap{max-width:1080px;margin:0 auto;padding:40px 24px 64px}
.apage-head{margin-bottom:30px}
.apage-head h1{font-family:var(--serif);font-size:38px;font-weight:600;margin:0 0 8px;line-height:1.05}
.apage-head p{color:var(--ink-soft);margin:0 0 18px;max-width:680px;font-size:16px}
.aback{display:inline-block;margin-bottom:10px;font-weight:500;font-size:14px}

/* ── Messages ──────────────────────────────────────────── */
.aflash{padding:15px 20px;border-radius:10px;font-weight:500;margin:0 0 20px;font-size:16px;border:1px solid}
.aflash--ok{background:var(--ok-bg);color:var(--ok);border-color:#c6e3c8}
.aflash--erreur{background:var(--err-bg);color:var(--err);border-color:#f0c4bf}

/* ── Accueil : cartes ──────────────────────────────────── */
.ahero{margin-bottom:32px;padding-bottom:26px;border-bottom:1px solid var(--line)}
.ahero h1{font-family:var(--serif);font-size:40px;font-weight:600;margin:0 0 8px}
.ahero p{color:var(--ink-soft);max-width:660px;font-size:17px}
.acards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px}
.acard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;
    text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:8px;
    box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s,border-color .25s}
.acard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold)}
.acard__ic{font-size:30px;color:var(--gold)}
.acard__t{font-family:var(--serif);font-size:25px;font-weight:600}
.acard__d{color:var(--ink-soft);font-size:15px;line-height:1.5}
.acard--see{background:var(--espresso);color:#fff;border-color:var(--espresso)}
.acard--see .acard__ic{color:var(--gold-light,#c6a06a)}
.acard--see .acard__d{color:rgba(255,255,255,.7)}

.anote{margin-top:34px;background:#fbf6ec;border:1px solid var(--line);border-radius:var(--radius);padding:22px 26px}
.anote strong{font-size:16px}
.anote p{margin:8px 0 0;color:var(--ink-soft);font-size:15px}

/* ── Blocs / formulaires ───────────────────────────────── */
.abloc{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px 32px;margin:0 0 24px;
    box-shadow:var(--shadow-soft);scroll-margin-top:90px}
.abloc--narrow{max-width:560px}
.abloc__title{font-family:var(--serif);font-size:27px;font-weight:600;margin:0 0 22px;padding-bottom:14px;border-bottom:1px solid var(--line)}

.afield{display:block;margin:0 0 20px}
.afield__lbl{display:block;font-weight:600;font-size:15px;margin-bottom:7px;color:var(--ink)}
.afield__lbl em{color:var(--gold-deep);font-style:normal;font-weight:500;font-size:13px}
.afield__hint{display:block;color:var(--ink-faint);font-size:13px;margin-top:6px}
.afield input[type=text],.afield input[type=password],.afield textarea{
    width:100%;font-family:var(--ui);font-size:16px;color:var(--ink);padding:12px 15px;
    border:1px solid var(--line);border-radius:9px;background:#fffdf9;transition:border-color .2s, box-shadow .2s}
.afield input:focus,.afield textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(169,130,76,.13)}
.afield textarea{resize:vertical;line-height:1.6;min-height:120px;font-family:var(--serif);font-size:18px}
.aform-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 22px}

/* ── Boutons ───────────────────────────────────────────── */
.abtn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--ui);font-size:15px;font-weight:600;
    cursor:pointer;padding:12px 24px;border-radius:9px;border:1px solid transparent;text-decoration:none;
    transition:transform .2s, box-shadow .2s, background .2s, color .2s}
.abtn--gold{background:var(--gold);color:#fff;box-shadow:0 8px 20px rgba(169,130,76,.28)}
.abtn--gold:hover{background:var(--gold-deep);transform:translateY(-2px)}
.abtn--ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.abtn--ghost:hover{border-color:var(--gold);color:var(--gold-deep)}
.abtn--danger{background:#fff;border-color:#e7b9b3;color:var(--err)}
.abtn--danger:hover{background:var(--err);color:#fff;border-color:var(--err)}
.abtn--lg{font-size:16px;padding:15px 32px}
.abtn--full{width:100%}
.abtn--mini{padding:9px 13px;font-size:15px;background:#fff;border-color:var(--line);color:var(--ink)}
.abtn--mini:hover:not(:disabled){border-color:var(--gold)}
.abtn:disabled{opacity:.35;cursor:not-allowed}
.abtn--file{cursor:pointer}

/* ── Liste des livres ──────────────────────────────────── */
.alivres{display:flex;flex-direction:column;gap:16px}
.aempty{color:var(--ink-faint);font-style:italic}
.alivre{display:flex;gap:20px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
    padding:16px 18px;box-shadow:var(--shadow-soft);flex-wrap:wrap}
.alivre.is-hidden{opacity:.6}
.alivre__thumb{width:74px;height:100px;flex:0 0 auto;border-radius:6px;overflow:hidden;background:var(--espresso);display:flex;align-items:center;justify-content:center}
.alivre__thumb img{width:100%;height:100%;object-fit:cover}
.alivre__noimg{color:#c9bda3;font-size:12px;text-align:center;line-height:1.3}
.alivre__info{flex:1 1 220px;min-width:200px}
.alivre__info h3{font-family:var(--serif);font-size:25px;font-weight:600;margin:0 0 3px;line-height:1.1}
.alivre__auteur{color:var(--ink-soft);margin:0;font-size:15px}
.alivre__badge{display:inline-block;margin-top:8px;font-size:12px;font-weight:600;color:var(--err);background:var(--err-bg);padding:3px 9px;border-radius:7px}
.alivre__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-left:auto}
.inline{display:inline-flex;gap:6px;margin:0}

/* ── Pastille « non lus » ──────────────────────────────── */
.abadge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;
    font-size:12px;font-weight:700;line-height:1;color:#fff;background:var(--err);border-radius:11px;margin-left:2px}
.abadge--card{position:absolute;transform:translate(6px,-10px);box-shadow:0 2px 6px rgba(0,0,0,.25)}
.acard__ic{position:relative}

/* ── Liste des messages ────────────────────────────────── */
.amsgs{display:flex;flex-direction:column;gap:16px}
.amsg{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
    padding:20px 22px;box-shadow:var(--shadow-soft)}
.amsg--unread{border-color:var(--gold);box-shadow:0 10px 26px rgba(169,130,76,.16);background:linear-gradient(0deg,#fff,#fffaf0)}
.amsg__head{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.amsg__who h3{font-family:var(--serif);font-size:24px;font-weight:600;margin:0 0 4px;line-height:1.1;display:flex;align-items:center;gap:8px}
.amsg__dot{width:9px;height:9px;border-radius:50%;background:var(--err);display:inline-block}
.amsg__meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;color:var(--ink-faint);font-size:13.5px}
.amsg__tag{font-size:12px;font-weight:600;padding:3px 9px;border-radius:7px}
.amsg__tag--mail{color:var(--ok);background:var(--ok-bg)}
.amsg__tag--db{color:var(--gold-deep);background:#f4ead6}
.amsg__coords{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 4px}
.amsg__chip{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--ink);
    background:#faf5ea;border:1px solid var(--line);padding:6px 13px;border-radius:30px}
.amsg__chip:hover{border-color:var(--gold);color:var(--gold-deep)}
.amsg__body{margin:12px 0 16px;color:var(--ink-soft);font-size:16px;line-height:1.7;white-space:normal;
    background:#fcfaf4;border:1px solid var(--line-soft);border-radius:9px;padding:14px 16px}
.amsg__actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* ── Photo ─────────────────────────────────────────────── */
.aphoto{margin:24px 0}
.aphoto__row{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;margin-top:8px}
.aphoto__preview{width:150px;height:200px;flex:0 0 auto;border-radius:8px;overflow:hidden;background:var(--espresso);
    display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.aphoto__preview img{width:100%;height:100%;object-fit:cover}
.aphoto__none{color:#c9bda3;text-align:center;font-size:14px;line-height:1.4}
.aphoto__controls{display:flex;flex-direction:column;gap:12px;align-items:flex-start;max-width:360px}
.aphoto__name{color:var(--ink-soft);font-size:14px;font-style:italic}
.acheck{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--ink-soft);cursor:pointer}
.acheck input{width:18px;height:18px}
.aform-foot{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px;padding-top:20px;border-top:1px solid var(--line)}

/* ── Vidéo ─────────────────────────────────────────────── */
.avideo-now video,.avideo-preview video{width:100%;max-width:620px;border-radius:10px;background:#000;display:block;box-shadow:var(--shadow-soft)}
.avideo-preview{margin-top:6px}

/* ── Pied ──────────────────────────────────────────────── */
.afoot{text-align:center;padding:30px 20px 50px;color:var(--ink-faint);font-size:14px}

/* ── Connexion ─────────────────────────────────────────── */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;
    background:radial-gradient(120% 120% at 50% 0%,#34291a,#1a150e)}
.login-card{background:var(--paper);border-radius:16px;padding:46px 42px;width:100%;max-width:430px;
    box-shadow:0 30px 80px rgba(0,0,0,.45);text-align:center}
.login-card h1{font-family:var(--serif);font-size:36px;font-weight:600;margin:0 0 6px}
.login-sub{color:var(--ink-soft);margin:0 0 26px;font-size:16px}
.login-card .afield{text-align:left}
.login-back{margin-top:22px}
.login-back a{font-size:14px}

/* ── Responsive ────────────────────────────────────────── */

/* Tablette */
@media (max-width:860px){
    .awrap{padding:30px 18px 54px}
    .abloc{padding:26px 22px}
    .acards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
}

/* Mobile : menu repliable */
@media (max-width:760px){
    .abar__in{padding:12px 18px;gap:14px;flex-wrap:nowrap}
    .abar__burger{display:flex}
    .abar__nav{position:absolute;top:100%;left:0;right:0;margin:0;flex-direction:column;align-items:stretch;gap:4px;
        background:var(--espresso);padding:10px 14px 16px;box-shadow:0 14px 30px rgba(0,0,0,.3);
        max-height:0;overflow:hidden;opacity:0;pointer-events:none;transition:max-height .35s ease, opacity .25s}
    .abar__nav.is-open{max-height:80vh;opacity:1;pointer-events:auto}
    .abar__nav a{font-size:16px;padding:13px 14px;border-radius:9px}
    .abar__see{border-color:rgba(255,255,255,.22);text-align:center}
    .abar__out{text-align:center}

    .awrap{padding:26px 16px 48px}
    .apage-head h1,.ahero h1{font-size:28px}
    .apage-head p,.ahero p{font-size:15px}
    .abloc{padding:22px 18px}
    .abloc__title{font-size:23px;margin-bottom:18px}
    .aform-grid{grid-template-columns:1fr;gap:0}

    .acards{grid-template-columns:1fr;gap:14px}
    .acard{padding:22px 20px}

    /* Livres : carte en pile, image + infos lisibles */
    .alivre{gap:14px}
    .alivre__info{flex:1 1 100%;min-width:0}
    .alivre__actions{margin-left:0;width:100%;justify-content:flex-start}
    .alivre__actions .abtn{flex:1 1 auto;justify-content:center}

    /* Photo de couverture : empilée */
    .aphoto__row{gap:16px}
    .aphoto__controls{max-width:none;width:100%}
    .abtn--file{width:100%}

    .aform-foot{flex-direction:column;align-items:stretch}
    .aform-foot .abtn{width:100%}

    /* Messages : actions pleine largeur, plus aérées */
    .amsg{padding:18px 16px}
    .amsg__actions .abtn{flex:1 1 auto;justify-content:center}
    .amsg__who h3{font-size:21px}

    .login-card{padding:34px 24px}
    .login-card h1{font-size:30px}
}

/* Petit mobile */
@media (max-width:430px){
    .abar__brand strong{font-size:19px}
    .apage-head h1,.ahero h1{font-size:25px}
    .abloc__title{font-size:21px}
    .abtn{padding:12px 18px;font-size:14.5px}
    .abtn--lg{font-size:15px;padding:14px 22px}
    .alivre__thumb{width:60px;height:82px}
    .alivre__info h3{font-size:22px}
}
