@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;1,400&family=Inter:wght@400;500&display=swap');

:root{
  --paper:#f4efe6;
  --card:#fffdf8;
  --ink:#2e2a24;
  --ink-soft:#6b6258;
  --ink-faint:#a59b8d;
  --line:#e6ddcf;
  --accent:#9a6b4f;
  --shadow:0 1px 2px rgba(60,48,32,.06), 0 8px 24px rgba(60,48,32,.05);
  --serif:'Lora', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, system-ui, sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:620px;margin:0 auto;padding:0 16px 96px}

/* Header */
.top{
  position:sticky;top:0;z-index:20;
  background:rgba(244,239,230,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.top-in{max-width:620px;margin:0 auto;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:.2px}
.brand small{display:block;font-family:var(--sans);font-size:12px;color:var(--ink-soft);font-weight:400;letter-spacing:.3px;text-transform:capitalize}
.avatars{display:flex;gap:6px}
.av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:500;font-family:var(--sans);overflow:hidden;flex-shrink:0}
.av img{width:100%;height:100%;object-fit:cover;display:block}
.av.big{width:76px;height:76px;font-size:30px}

/* Composer */
.composer{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:14px 16px;margin:18px 0}
.composer textarea{width:100%;border:none;background:transparent;resize:none;font-family:var(--serif);font-size:16px;line-height:1.6;color:var(--ink);min-height:44px;outline:none}
.composer textarea::placeholder{color:var(--ink-faint)}
.composer-bar{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:10px;border-top:1px solid var(--line)}
.tools{display:flex;gap:6px}
.tool{width:38px;height:38px;border-radius:50%;border:none;background:transparent;color:var(--ink-soft);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.tool:hover{background:#efe7d8;color:var(--ink)}
.tool.on{background:#efe7d8;color:var(--accent)}
.btn{font-family:var(--sans);font-size:14px;font-weight:500;border:none;border-radius:999px;padding:9px 20px;background:var(--ink);color:#fdf8ee;cursor:pointer;transition:.15s}
.btn:hover{opacity:.9}
.btn[disabled]{opacity:.4;cursor:default}
.thumb-row{display:flex;align-items:center;gap:10px;margin-top:10px}
.thumb-row img{width:64px;height:64px;object-fit:cover;border-radius:10px}
.mood-pick{font-size:22px;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:8px;line-height:1}
.mood-pick:hover{background:#efe7d8}
.mood-wrap{position:relative;display:inline-block}
.mood-pop{position:absolute;bottom:46px;left:0;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;display:none;grid-template-columns:repeat(6,1fr);gap:2px;z-index:30;width:248px}
.mood-pop.open{display:grid}
.mood-pop button{font-size:20px;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;line-height:1;color:var(--ink-soft)}
.mood-pop button:hover{background:#efe7d8}

/* Fenêtre de confirmation */
.modal-overlay{position:fixed;inset:0;background:rgba(46,42,36,.45);display:none;align-items:center;justify-content:center;z-index:60;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--card);border-radius:18px;box-shadow:var(--shadow);padding:24px;max-width:340px;width:100%;text-align:center}
.modal-q{font-family:var(--serif);font-size:18px;margin:0 0 4px}
.modal-sub{color:var(--ink-soft);font-size:14px;margin:0 0 20px}
.modal-actions{display:flex;gap:10px;justify-content:center}
.btn-ghost{flex:1;padding:11px;border:1px solid var(--line);background:transparent;border-radius:11px;font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink);cursor:pointer}
.btn-ghost:hover{background:#efe7d8}
.btn-danger{flex:1;padding:11px;border:none;background:#b5524a;color:#fff;border-radius:11px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer}
.btn-danger:hover{opacity:.92}

/* Édition inline */
.entry-edit{display:none;margin:4px 0}
.entry.editing .entry-edit{display:block}
.entry.editing .entry-static,.entry.editing .entry-foot{display:none}
.entry-edit textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 13px;font-family:var(--serif);font-size:16px;line-height:1.55;color:var(--ink);background:#fff;outline:none;resize:vertical;min-height:64px}
.entry-edit textarea:focus{border-color:var(--accent)}
.edit-rm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);margin-top:10px;cursor:pointer}
.edit-rm span{color:#b5524a}
.edit-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}
.btn-save{padding:9px 18px;border:none;border-radius:999px;background:var(--ink);color:#fdf8ee;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer}
.btn-save:hover{opacity:.9}
.comment-edit{display:none;align-items:center;gap:6px;margin-top:2px}
.comment.editing .comment-edit{display:flex}
.comment.editing .comment-text,.comment.editing .comment-meta{display:none}
.comment-edit input[type=text]{flex:1;min-width:0;border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:14px;font-family:var(--sans);background:#fff;color:var(--ink);outline:none}
.comment-edit input[type=text]:focus{border-color:var(--accent)}

/* En-tête de jour */
.day-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:18px 0 14px}
.day-nav h2{font-family:var(--serif);font-weight:500;font-size:21px;margin:0;text-align:center;flex:1;text-transform:capitalize}
.day-arrow{color:var(--ink-soft);font-size:22px;padding:6px 10px;border-radius:10px;display:flex;align-items:center}
.day-arrow:hover{background:#efe7d8;color:var(--ink)}
.day-arrow.disabled{color:var(--line);pointer-events:none}
.day-note{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);background:#f0e7d6;border:1px solid var(--line);border-radius:12px;padding:9px 13px;margin:0 0 16px}
.day-note i{color:var(--accent);font-size:17px}

/* Bande de vignettes du jour */
.day-photos{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
.day-thumb{position:relative;width:72px;height:72px;border-radius:12px;overflow:hidden;border:1px solid var(--line);display:block}
.day-thumb img{width:100%;height:100%;object-fit:cover}
.day-thumb .vbadge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(46,42,36,.28);color:#fff;font-size:20px}

/* Texte de réglages (white-space normal -> pas de faux alinéa) */
.set-text{font-family:var(--serif);font-size:15px;line-height:1.6;margin:6px 0 0;white-space:normal}
.pw-form{display:flex;flex-direction:column;gap:10px;max-width:340px;margin-top:6px}
.pw-form input{border:1px solid var(--line);border-radius:11px;padding:10px 13px;font-size:15px;font-family:var(--sans);background:#fff;color:var(--ink);outline:none}
.pw-form input:focus{border-color:var(--accent)}
.pw-form .btn{align-self:flex-start}
.prof-row{display:flex;gap:16px;align-items:flex-start;margin-top:8px}
.prof-actions{display:flex;flex-direction:column;gap:10px}
.prof-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.prof-form input[type=file]{font-size:13px;max-width:210px}
.link-danger{background:none;border:none;color:#b5524a;font-size:13px;cursor:pointer;padding:0;text-align:left}
.link-danger:hover{text-decoration:underline}

/* Indicateur « modifié » discret */
.edited{font-size:11px;color:var(--ink-faint);font-style:italic;margin-left:2px}

/* Souvenir */
.memory{display:flex;align-items:center;gap:10px;background:#f0e7d6;border:1px solid var(--line);border-radius:14px;padding:10px 14px;margin:6px 0 18px;color:var(--ink-soft);font-size:14px}
.memory i{color:var(--accent);font-size:18px}
.memory a{font-weight:500}

/* Fil */
.day-sep{font-family:var(--sans);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin:26px 4px 12px;display:flex;align-items:center;gap:10px}
.day-sep::after{content:"";flex:1;height:1px;background:var(--line)}

.entry{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:16px 18px;margin-bottom:16px}
.entry-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.entry-head .name{font-weight:500;font-size:15px}
.entry-head .time{font-size:12px;color:var(--ink-faint)}
.entry-head .mood{margin-left:auto;font-size:20px}
.entry-body{font-family:var(--serif);font-size:16.5px;line-height:1.65;white-space:pre-wrap;word-wrap:break-word}
.entry-photo{display:block;margin-top:12px;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.entry-photo img{width:100%;height:auto;display:block}
.entry-photo video{width:100%;display:block;background:#000}
.entry-foot{display:flex;align-items:center;gap:14px;margin-top:12px}
.heart{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:var(--ink-soft);font-size:14px;font-family:var(--sans);padding:4px 6px;border-radius:8px}
.heart:hover{background:#efe7d8}
.heart.on{color:#c45c89}
.heart i{font-size:18px}
.heart.sm{font-size:12px;padding:2px 4px;gap:4px}
.heart.sm i{font-size:15px}
.iconbtn{display:flex;align-items:center;background:none;border:none;cursor:pointer;color:var(--ink-faint);font-size:14px;padding:4px 6px;border-radius:8px}
.iconbtn:hover{background:#f3e3df;color:#b5524a}
.iconbtn i{font-size:18px}
.cdel{background:none;border:none;cursor:pointer;color:var(--ink-faint);padding:2px 4px;border-radius:6px;display:inline-flex}
.cdel:hover{color:#b5524a}
.cdel i{font-size:15px}

/* Commentaires */
.av.sm{width:26px;height:26px;font-size:12px;flex-shrink:0}
.comments{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.comment{display:flex;gap:9px;margin-bottom:11px}
.comment-main{flex:1;min-width:0}
.comment-text{font-size:14.5px;line-height:1.5;word-wrap:break-word}
.comment-text .cname{font-weight:500}
.comment-meta{display:flex;align-items:center;gap:10px;margin-top:1px;font-size:12px;color:var(--ink-faint)}
.comment-add{display:flex;align-items:center;gap:9px;margin-top:4px}
.comment-add input[type=text]{flex:1;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:14px;font-family:var(--sans);background:#fff;color:var(--ink);outline:none}
.comment-add input[type=text]:focus{border-color:var(--accent)}
.comment-send{border:none;background:transparent;color:var(--accent);font-size:20px;cursor:pointer;padding:4px;display:flex}
.comment-send:hover{opacity:.7}

/* Admin / membres */
.badge{font-size:11px;font-weight:500;color:var(--accent);background:#f0e7d6;border:1px solid var(--line);border-radius:999px;padding:1px 9px}
.mini-btn{font-family:var(--sans);font-size:12px;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:999px;padding:5px 11px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.mini-btn:hover{background:#efe7d8}
.mini-btn i{font-size:14px}

.empty{text-align:center;color:var(--ink-soft);font-family:var(--serif);font-size:17px;margin:48px 16px;line-height:1.7}

/* Rail gauche + panneau droit (desktop) — masqués par défaut (mobile) */
.rail,.aside-right{display:none}

@media (min-width:900px){
  .top{display:none}
  .nav{display:none}
  body{padding-left:248px}
  .rail{display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:248px;background:var(--card);border-right:1px solid var(--line);padding:24px 16px;z-index:30}
  .rail-brand{font-family:var(--serif);font-size:23px;color:var(--ink);display:block;margin:2px 10px 22px}
  .rail-nav{display:flex;flex-direction:column;gap:2px}
  .rail-nav a{display:flex;align-items:center;gap:13px;padding:11px 13px;border-radius:12px;color:var(--ink-soft);font-size:15px;font-weight:500}
  .rail-nav a i{font-size:21px}
  .rail-nav a:hover{background:#efe7d8;color:var(--ink)}
  .rail-nav a.active{background:#efe7d8;color:var(--accent)}
  .wrap{padding-top:6px}
}
@media (min-width:1200px){
  body{padding-right:312px}
  .aside-right{display:flex;flex-direction:column;gap:14px;position:fixed;top:0;right:0;bottom:0;width:312px;padding:26px 18px;overflow-y:auto}
  .side-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px 17px;display:block;color:var(--ink)}
  a.side-card:hover{border-color:var(--accent)}
  .side-card h3{font-family:var(--serif);font-weight:500;font-size:15px;margin:0 0 11px;display:flex;align-items:center;gap:7px}
  .side-members{display:flex;flex-direction:column;gap:9px}
  .member{display:flex;align-items:center;gap:9px;font-size:14px}
  .side-souvenir h3 i{color:var(--accent)}
  .side-souvenir p{margin:0;font-size:13px;color:var(--ink-soft)}
  .side-feat img{width:100%;border-radius:10px;display:block}
}

/* Nav bas */
.nav{position:fixed;bottom:0;left:0;right:0;z-index:20;background:rgba(255,253,248,.95);backdrop-filter:blur(8px);border-top:1px solid var(--line)}
.nav-in{max-width:620px;margin:0 auto;display:flex}
.nav a{flex:1;text-align:center;padding:12px 0;color:var(--ink-faint);font-size:22px;transition:.15s}
.nav a.active{color:var(--accent)}
.nav a:hover{color:var(--ink)}

/* Auth */
.auth{max-width:380px;margin:8vh auto 0;padding:0 20px}
.auth h1{font-family:var(--serif);font-size:30px;font-weight:500;text-align:center;margin:0 0 6px}
.auth p.sub{text-align:center;color:var(--ink-soft);margin:0 0 28px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:24px}
.auth label{display:block;font-size:13px;color:var(--ink-soft);margin:14px 0 5px}
.auth input[type=text],.auth input[type=password]{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-size:15px;font-family:var(--sans);background:#fff;color:var(--ink);outline:none}
.auth input:focus{border-color:var(--accent)}
.auth .btn{width:100%;margin-top:20px;padding:12px}
.tabs{display:flex;gap:4px;background:#efe7d8;border-radius:12px;padding:4px;margin-bottom:20px}
.tabs a{flex:1;text-align:center;padding:8px;border-radius:9px;font-size:14px;font-weight:500;color:var(--ink-soft)}
.tabs a.active{background:var(--card);color:var(--ink);box-shadow:var(--shadow)}
.swatches{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;border:2px solid transparent}
.swatch.sel{border-color:var(--ink)}
.flash{background:#f6e0db;color:#9a3b32;border:1px solid #ecc7c0;border-radius:11px;padding:10px 13px;font-size:14px;margin-bottom:16px}

/* Calendrier */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin:20px 0 14px}
.cal-head h2{font-family:var(--serif);font-weight:500;font-size:20px;margin:0;text-transform:capitalize}
.cal-nav{color:var(--ink-soft);font-size:22px;padding:6px 10px;border-radius:10px}
.cal-nav:hover{background:#efe7d8}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{text-align:center;font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.05em;padding-bottom:4px}
.cal-cell{aspect-ratio:1;border-radius:11px;border:1px solid var(--line);background:var(--card);position:relative;overflow:hidden;display:flex;align-items:flex-start;justify-content:flex-end}
.cal-cell.empty{background:transparent;border:none}
.cal-cell .num{font-size:12px;color:var(--ink-soft);padding:4px 6px;position:relative;z-index:2}
.cal-cell.has{outline:2px solid transparent}
.cal-cell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.cal-cell.today{border-color:var(--accent);border-width:2px}
.cal-cell .dot{position:absolute;bottom:5px;left:5px;width:7px;height:7px;border-radius:50%;z-index:2}
