/* Fil de vie — carnet nordique.
   Encre sur papier bleu-gris ; l'IA écrit en marge, à l'ambre. */
:root {
  color-scheme: light;
  --paper: #EDF3F2;
  --paper-top: #E4EFEC;
  --card: #FDFEFE;
  --ink: #1C2B2E;
  --ink-soft: #587076;
  --ink-faint: #9AB0AD;
  --line: #CFDEDC;
  --line-strong: #AFC6C2;
  --border: #d8d2c6;
  --spruce: #22705A;
  --spruce-soft: #D9EEE5;
  --teal: #1E8C96;
  --amber: #E08514;
  --amber-soft: #FDF1DE;
  --danger: #C2452E;
  --danger-soft: #F7ECEA;
  --grad: linear-gradient(120deg, #22705A, #1E8C96);
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}
/* Carnet nordique, la nuit : fond épinette profond, encre ivoire, accents
   ÉCLAIRCIS pour garder le punch — sombre mais vivant, jamais gris plat.
   (Bloc dupliqué plus bas pour data-theme=auto + appareil sombre.) */
[data-theme="sombre"] {
  color-scheme: dark;
  --paper: #0F1A17;
  --paper-top: #0B1513;
  --card: #152420;
  --ink: #E5EFEA;
  --ink-soft: #93ACA4;
  --ink-faint: #5F7A72;
  --line: #223730;
  --line-strong: #2F4A42;
  --border: #2F4A42;
  --spruce: #35B58F;
  --spruce-soft: #143528;
  --teal: #38B6C4;
  --amber: #F0A03C;
  --amber-soft: #2E230F;
  --danger: #E06A52;
  --danger-soft: #3A1D16;
  --grad: linear-gradient(120deg, #2AA47F, #2FA9BC);
}
@media (prefers-color-scheme: dark) {
  [data-theme="auto"] {
    color-scheme: dark;
    --paper: #0F1A17;
    --paper-top: #0B1513;
    --card: #152420;
    --ink: #E5EFEA;
    --ink-soft: #93ACA4;
    --ink-faint: #5F7A72;
    --line: #223730;
    --line-strong: #2F4A42;
    --border: #2F4A42;
    --spruce: #35B58F;
    --spruce-soft: #143528;
    --teal: #38B6C4;
    --amber: #F0A03C;
    --amber-soft: #2E230F;
    --danger: #E06A52;
    --danger-soft: #3A1D16;
    --grad: linear-gradient(120deg, #2AA47F, #2FA9BC);
  }
}
* { box-sizing: border-box; min-width: 0; }
html, body { max-width: 100%; overflow-x: hidden; } /* jamais de scroll horizontal */
body {
  margin: 0; color: var(--ink);
  background: linear-gradient(180deg, var(--paper-top) 0%, var(--paper) 240px);
  background-attachment: fixed;
  font-family: var(--sans); font-size: 16px; line-height: 1.45;
}
main { max-width: 760px; margin: 0 auto; width: 100%;
  padding: .8rem .8rem calc(4.6rem + env(safe-area-inset-bottom)); }
.entry-text, .summary-body, .ai-reaction, .ai-context, .meta {
  overflow-wrap: anywhere; }

/* ---- navigation du bas (mobile-first : l'app vit dans le pouce) ---- */
.bottomnav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 30;
  display: flex; justify-content: space-around;
  background: var(--card); border-top: 1px solid var(--line);
  padding: .3rem .2rem calc(.3rem + env(safe-area-inset-bottom));
  box-shadow: 0 -2px 12px rgba(31,42,48,.08);
}
.bottomnav a {
  display: flex; flex-direction: column; align-items: center; gap: .05rem;
  flex: 1; min-width: 0; padding: .2rem 0; border-radius: 10px;
  color: var(--ink-soft); text-decoration: none; font-size: .62rem; font-weight: 600;
  position: relative;
}
.bottomnav a span { font-size: 1.15rem; line-height: 1.15; }
.bottomnav a.on { color: var(--spruce); background: var(--spruce-soft); }
.bottomnav .badge { position: absolute; top: 0; right: 18%; }
.topbar-user { color: rgba(255,255,255,.85); font-size: .85rem; }
.mood-set { border-color: var(--amber); background: var(--amber-soft); cursor: pointer; }
.mood-chip-card { background: var(--amber-soft); color: var(--ink); border-radius: 999px;
  padding: 0 .55em; font-size: .78rem; font-weight: 600; }

/* ---- barre de navigation ---- */
.topbar {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  /* coque Android (edge-to-edge) : le dégradé coule SOUS la barre de statut,
     le contenu commence dessous — Capacitor injecte --safe-area-inset-top */
  padding: calc(.6rem + var(--safe-area-inset-top, env(safe-area-inset-top, 0px)))
           1rem .6rem; background: var(--grad); color: #fff;
  box-shadow: 0 2px 12px rgba(30, 60, 55, .25);
  position: sticky; top: 0; z-index: 10;
}
.brand { font-family: var(--serif); font-size: 1.3rem; font-weight: 700;
  color: #fff; text-decoration: none; letter-spacing: -0.02em; }
.brand span { color: #FFD9A0; font-style: italic; font-weight: 400; padding: 0 .08em; }
.brand.big { font-size: 2.2rem; color: var(--ink); }
.brand.big span { color: var(--amber); }
.topbar nav { display: flex; gap: .2rem; flex-wrap: wrap; flex: 1; }
.topbar nav a {
  color: rgba(255,255,255,.82); text-decoration: none; padding: .3rem .6rem;
  border-radius: 8px; font-size: .95rem;
}
.topbar nav a.on { color: #fff; background: rgba(255,255,255,.18); font-weight: 700; }
.topbar nav a:hover { color: #fff; background: rgba(255,255,255,.1); }
.badge { background: var(--amber); color: #fff; border-radius: 8px;
  padding: 0 .35em; font-size: .75rem; font-weight: 700; }
.logout button { background: none; border: none; color: rgba(255,255,255,.85);
  font-size: 1.1rem; cursor: pointer; }

/* ---- connexion ---- */
.login-body { display: grid; place-items: center; min-height: 100vh; }
.login-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  padding: 2rem 2.2rem; width: min(92vw, 380px);
  box-shadow: 0 8px 30px rgba(31, 42, 48, .08);
}
.login-sub { color: var(--ink-soft); font-family: var(--serif); font-style: italic;
  margin-top: .2rem; }
.login-card label { display: block; margin: 1rem 0 .3rem; font-size: .9rem;
  color: var(--ink-soft); }
.login-card input { width: 100%; }

/* ---- formulaires ---- */
input, select, textarea, button {
  font: inherit; color: inherit;
  font-size: 16px; /* évite le zoom automatique iOS au focus */
  border: 1px solid var(--line); border-radius: 8px;
  padding: .6rem .7rem; /* cibles tactiles confortables */
  background: var(--card);
}
input:focus-visible, select:focus-visible, textarea:focus-visible, button:focus-visible {
  outline: 2px solid var(--spruce); outline-offset: 1px;
}
button { cursor: pointer; background: var(--card); }
button.primary { background: var(--grad); border-color: transparent;
  color: #fff; font-weight: 700; box-shadow: 0 2px 8px rgba(34,112,90,.3); }
button.primary:hover { filter: brightness(1.1); }
button.danger { background: none; border-color: var(--danger); color: var(--danger); }
.error { color: var(--danger); font-weight: 600; }

/* ---- barre des journaux : compacte, wrappe, jamais de scroll ---- */
.journal-bar { display: flex; gap: .3rem; flex-wrap: wrap; padding: .15rem 0 .3rem; }
.journal-bar .jchip { white-space: nowrap; display: inline-flex;
  align-items: center; gap: .25rem; padding: .1rem .55rem; font-size: .8rem; }

/* ---- modes de questions couple ---- */
.couple-modes { display: flex; gap: .5rem; margin: 0 0 .5rem; }
.couple-btn { flex: 1; border-radius: 12px; padding: .55rem .4rem; font-weight: 600;
  font-size: .88rem; background: var(--card); border: 1px solid var(--line); }
.couple-btn:hover { border-color: var(--spruce); }
.couple-btn.crunchy { border-color: var(--amber); background: var(--amber-soft); }
.manual-answer { margin-top: .3rem; }
.manual-answer summary { cursor: pointer; font-size: .8rem; color: var(--ink-soft);
  list-style: none; }

/* ---- mode trajet ---- */
.trip-bar { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap;
  margin: .4rem 0 0; }
#trip-end { display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; }
#trip-end[hidden] { display: none; }
#trip-km { font-family: var(--mono); font-weight: 700; color: var(--spruce); }
.j-avatar, .journal-bar img { width: 1.3rem !important; height: 1.3rem !important;
  border-radius: 50%; object-fit: cover; flex-shrink: 0; }

/* ---- accueil du jour ---- */
.hero { display: flex; align-items: center; justify-content: space-between;
  margin: .4rem 0 .2rem; }
.hero-greet { margin: 0; font-family: var(--serif); font-size: 1.25rem; font-weight: 700; }
.hero-sub { margin: 0; color: var(--ink-soft); font-size: .85rem; }
.hero-sub::first-letter { text-transform: uppercase; }
.top-ico { text-decoration: none; font-size: 1.05rem; padding: .25rem .4rem;
  border-radius: 8px; }
.top-ico.on { background: rgba(255,255,255,.18); }

/* ---- actions rapides : tout visible, sans défilement ---- */
.qa-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(4.1rem, 1fr));
  gap: .45rem; padding: .1rem .1rem .6rem; }
.qa-btn { display: flex; flex-direction: column; align-items: center; gap: .15rem;
  padding: .6rem .2rem; border-radius: 12px;
  background: var(--card); border: 1px solid var(--line);
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease; }
.qa-btn:hover { border-color: var(--spruce); transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(46,94,78,.15); }
.qa-btn:active { transform: scale(.95); }
.qa-emoji { font-size: 1.5rem; line-height: 1; }
.qa-label { font-size: .68rem; color: var(--ink-soft); font-weight: 600; white-space: nowrap; }
@media (prefers-reduced-motion: reduce) { .qa-btn { transition: none; } }

/* ---- capture rapide : la timeline commence tout de suite en dessous ---- */
.capture { margin: .8rem 0 .5rem; }
.sugg-row { min-height: 2.2rem; align-items: center; }
.filters-fold { margin: 0 0 .4rem; }
.filters-fold summary { cursor: pointer; color: var(--ink-soft); font-size: .82rem;
  list-style: none; }
.filters-fold summary::before { content: "☰ "; }
.filters-fold .filters { margin: .4rem 0 .2rem; }
.day:first-of-type .day-head { margin-top: .4rem; }
.capture form { background: var(--card); border: 1px solid var(--line);
  border-radius: 14px; padding: .8rem; box-shadow: 0 2px 10px rgba(31,42,48,.05);
  transition: box-shadow .2s ease, border-color .2s ease; }
.capture form:focus-within { border-color: var(--spruce);
  box-shadow: 0 4px 18px rgba(46,94,78,.15); }
.capture-main { display: flex; gap: .5rem; align-items: center; }
.capture-input { flex: 1; font-size: 1.05rem; border: none; padding: .4rem .2rem; min-width: 0; }
.capture-input:focus-visible { outline: none; }
.photo-btn { cursor: pointer; font-size: 1.3rem; padding: .3rem .5rem; border-radius: 8px;
  border: 1px dashed var(--line); line-height: 1; }
.photo-btn:hover { border-color: var(--spruce); background: var(--spruce-soft); }
.capture-row { display: flex; gap: .5rem; margin-top: .4rem; flex-wrap: wrap; align-items: center; }
.capture-more summary { cursor: pointer; color: var(--ink-soft); font-size: .85rem;
  list-style: none; }
.capture-more summary::before { content: "⚙ "; }
.capture-more-row { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; margin-top: .5rem; }
.capture-more-row label { display: block; font-size: .82rem; color: var(--ink-soft); }
.capture-more-row select, .capture-more-row input { width: 100%; margin-top: .2rem; }
.spine-top { margin-top: .8rem; border-left: none; padding-left: 0; }
.spine-top .dot { display: none; }
.kind-picker { display: flex; gap: .3rem; flex-wrap: nowrap; overflow-x: auto;
  margin-top: .5rem; padding-bottom: .2rem; scrollbar-width: thin; }
.kind-picker .chip { white-space: nowrap; flex-shrink: 0; }
.sugg-row { display: flex; gap: .35rem; flex-wrap: wrap; margin-top: .35rem; }
.sugg-chip { border: 1px dashed var(--amber); background: var(--amber-soft);
  color: var(--ink); border-radius: 999px; padding: .2rem .8rem; font-size: .88rem;
  animation: card-in .2s ease both; }
.sugg-chip:hover { background: var(--amber); color: #fff; }

/* ---- filtres ---- */
.filters { display: flex; gap: .35rem; flex-wrap: wrap; margin-bottom: 1rem; }
/* cible tactile ≥ ~36px : pouce ami, densité préservée */
.chip { text-decoration: none; color: var(--ink-soft); font-size: .85rem;
  border: 1px solid var(--line); border-radius: 999px; padding: .38rem .75rem;
  background: var(--card); display: inline-flex; align-items: center;
  gap: .25rem; min-height: 2.15rem; }
.chip.on { color: #fff; background: var(--grad); border-color: transparent; }
.sugg-pending { color: var(--amber); font-size: .85rem; font-weight: 600;
  animation: pulse 1.6s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .sugg-pending { animation: none; } }

/* ---- fil / colonne vertébrale ---- */
.day-head { font-family: var(--serif); font-size: 1.15rem; font-weight: 600;
  color: var(--ink); margin: 1.6rem 0 .6rem; }
.day-head::first-letter { text-transform: uppercase; }
.day-count { font-family: var(--sans); font-size: .72rem; font-weight: 700;
  color: var(--ink-soft); background: var(--card); border: 1px solid var(--line);
  border-radius: 999px; padding: .05rem .5rem; margin-left: .6rem; vertical-align: middle; }
.spine { border-left: 2px solid var(--line); margin-left: .55rem;
  padding-left: 1.1rem; display: grid; gap: .8rem; }
.card { background: var(--card); border: none;
  border-radius: 12px; padding: .7rem .9rem; position: relative;
  box-shadow: 0 1px 4px rgba(31,42,48,.07);
  animation: card-in .25s ease both;
  transition: transform .15s ease, box-shadow .15s ease; }
.entry:hover { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(31,42,48,.1); }
@keyframes card-in { from { opacity: 0; transform: translateY(4px); } }
@media (prefers-reduced-motion: reduce) {
  .card { animation: none; transition: none; }
  .entry:hover { transform: none; }
}
/* accent par catégorie : la couleur raconte la journée d'un coup d'œil */
.kind-repas, .kind-boisson { border-left: 4px solid #C97B22; }
.kind-symptome, .kind-medicament { border-left: 4px solid #A9402E; }
.kind-sommeil { border-left: 4px solid #4A5FA5; }
.kind-activite, .kind-habitude { border-left: 4px solid #2E5E4E; }
.kind-humeur { border-left: 4px solid #B0578D; }
.kind-lieu, .kind-voyage { border-left: 4px solid #2E8093; }
.kind-besoin { border-left: 4px solid #8A6FB8; }
.kind-cycle { border-left: 4px solid #C2517A; }
.card.highlighted { border-color: var(--amber); box-shadow: 0 0 0 1px var(--amber),
  0 4px 14px rgba(201,123,34,.15); }

/* ---- moments forts ---- */
.hl-zone { position: relative; }
.hl-menu summary { cursor: pointer; list-style: none; color: var(--ink-soft);
  font-size: .95rem; padding: 0 .2rem; }
.hl-menu summary:hover { color: var(--amber); }
.hl-menu[open] .hl-opts { position: absolute; z-index: 20; top: 1.4rem; left: 0;
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  box-shadow: 0 8px 24px rgba(31,42,48,.18); padding: .35rem; display: grid;
  gap: .25rem; min-width: 11rem; }
.hl-opts button { border: none; background: none; text-align: left; padding: .35rem .5rem;
  border-radius: 6px; font-size: .88rem; }
.hl-opts button:hover { background: var(--amber-soft); }
.hl-badge { border: none; background: none; font-size: 1rem; padding: 0 .15rem; }

/* ---- humeur : bouton flottant + feuille overlay (un tap) ---- */
.mood-fab {
  position: fixed; right: .9rem; bottom: calc(4.6rem + env(safe-area-inset-bottom));
  z-index: 40; width: 3.2rem; height: 3.2rem; border-radius: 50%;
  font-size: 1.5rem; line-height: 1; border: none;
  background: var(--grad); color: #fff;
  box-shadow: 0 4px 16px rgba(30,60,55,.35);
}
.mood-fab:active { transform: scale(.92); }
#mood-overlay {
  position: fixed; inset: 0; z-index: 50;
  background: rgba(28, 43, 46, .45); backdrop-filter: blur(2px);
  display: flex; align-items: flex-end; justify-content: center;
}
#mood-overlay[hidden] { display: none; }
.mood-sheet {
  position: relative; width: min(100%, 480px);
  background: var(--card); border-radius: 18px 18px 0 0;
  padding: 1rem 1rem calc(1rem + env(safe-area-inset-bottom));
  box-shadow: 0 -8px 30px rgba(31,42,48,.3);
  animation: sheet-up .22s ease both;
}
@keyframes sheet-up { from { transform: translateY(40px); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .mood-sheet { animation: none; } }
.mood-sheet .dismiss { position: absolute; top: .6rem; right: .6rem; font-size: 1rem; }

/* ---- humeur façon « je me sens » ---- */
.mood-picker { position: relative; }
.mood-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(5.2rem, 1fr));
  gap: .4rem; margin-top: .4rem; }
.mood-btn { display: flex; flex-direction: column; align-items: center; gap: .1rem;
  padding: .5rem .2rem; border-radius: 10px; background: var(--card);
  transition: transform .12s ease, border-color .12s ease; }
.mood-btn:hover { border-color: var(--spruce); transform: translateY(-2px); }
.mood-emoji { font-size: 1.4rem; line-height: 1; }
.mood-label { font-size: .72rem; color: var(--ink-soft); font-weight: 600; }
@media (prefers-reduced-motion: reduce) { .mood-btn { transition: none; } }
.person-chip { background: var(--spruce-soft); color: var(--spruce); font-weight: 600;
  border-radius: 999px; padding: 0 .55em; font-size: .78rem; }
.chip.person { border-color: var(--spruce); }
.entry-photo { max-width: 100%; max-height: 320px; border-radius: 8px;
  margin-top: .4rem; display: block; }
.entry-head { display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap;
  font-size: .82rem; color: var(--ink-soft); }
.dot { position: absolute; left: -1.55rem; top: 1rem; width: 9px; height: 9px;
  border-radius: 50%; background: var(--spruce); border: 2px solid var(--paper); }
.hour { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.kind { font-weight: 600; }
.edit { margin-left: auto; color: var(--ink-soft); text-decoration: none; }
.entry-text { margin: .35rem 0 .1rem; font-size: 1rem; white-space: pre-wrap; }
.tags { margin: .2rem 0 0; }
.thread-line { margin: .25rem 0 0 .6rem; padding-left: .6rem; font-size: .9rem;
  color: var(--ink-soft); border-left: 2px solid var(--line); }
.tag { color: var(--spruce); font-size: .82rem; margin-right: .5rem; }
.empty { color: var(--ink-soft); font-family: var(--serif); font-style: italic;
  text-align: center; margin: 3rem 0; }

/* ---- l'IA écrit en marge ---- */
.ai-margin {
  border-left: 3px solid var(--amber); background: var(--amber-soft);
  border-radius: 0 8px 8px 0; padding: .5rem .8rem; margin-top: .6rem;
  font-size: .9rem;
}
.ai-kicker { margin: 0; font-size: .72rem; text-transform: uppercase;
  letter-spacing: .06em; color: var(--amber); font-weight: 700; }
.ai-reaction { font-family: var(--serif); font-style: italic; margin: .15rem 0; }
.ai-context { color: var(--ink-soft); margin: .15rem 0; }
.ai-margin.pending .ai-kicker { animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse { 50% { opacity: .35; } }
@media (prefers-reduced-motion: reduce) { .ai-margin.pending .ai-kicker { animation: none; } }
.ai-question, .ai-proposal { margin-top: .4rem; position: relative; padding-right: 1.6rem; }
.ai-q-text { margin: 0 0 .25rem; font-weight: 600; }
.ai-q-row { display: flex; gap: .35rem; }
.ai-q-row input { flex: 1; }
.dismiss { position: absolute; top: 0; right: 0; border: none; background: none;
  color: var(--ink-soft); font-size: .85rem; padding: .1rem .3rem; }
.dismiss:hover { color: var(--danger); }
/* réponses en un tap */
.scale-row { display: flex; gap: .25rem; flex-wrap: wrap; }
.scale-btn { min-width: 2.1rem; padding: .3rem 0; border-radius: 8px; font-weight: 600;
  font-family: var(--mono); background: var(--card); }
.scale-btn:hover { background: var(--spruce); border-color: var(--spruce); color: #fff; }
.choice-row { display: flex; gap: .4rem; flex-wrap: wrap; }
.choice-btn { border-radius: 999px; padding: .3rem .9rem; background: var(--card); font-weight: 600; }
.choice-btn:hover { background: var(--spruce); border-color: var(--spruce); color: #fff; }
.choice-btn.yes:hover { background: var(--spruce); }
.choice-btn.no:hover { background: var(--danger); border-color: var(--danger); }
.ai-margin.error-box { border-left-color: var(--danger); background: var(--danger-soft); }
.summary .summary-body { white-space: pre-wrap; font-size: .92rem; }

/* synthèses condensées : une ligne repliée, tap pour tout lire */
.summary-fold {
  border-left: 3px solid var(--amber); background: var(--amber-soft);
  border-radius: 0 8px 8px 0; padding: .4rem .7rem; margin: 0 0 .6rem .55rem;
}
.summary-fold summary { cursor: pointer; list-style: none; display: flex;
  gap: .5rem; align-items: baseline; min-width: 0; }
.summary-fold summary::-webkit-details-marker { display: none; }
.summary-preview { color: var(--ink-soft); font-size: .82rem; font-style: italic;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; }
.summary-fold[open] .summary-preview { display: none; }
.summary-fold .summary-body { white-space: pre-wrap; font-size: .9rem;
  margin-top: .5rem; }

/* ---- éditeur ---- */
.editor h2 { font-family: var(--serif); }
.editor label { display: block; margin: .8rem 0 .25rem; color: var(--ink-soft);
  font-size: .9rem; }
.editor input, .editor select, .editor textarea { width: 100%; }
.editor-row { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.editor-actions { display: flex; gap: .8rem; align-items: center; margin-top: 1rem; }
.btn-link { color: var(--spruce); }
.danger-zone { margin-top: 2rem; border-top: 1px dashed var(--line); padding-top: 1rem; }
.structured { display: grid; grid-template-columns: max-content 1fr; gap: .1rem .8rem; }
.structured dt { color: var(--ink-soft); font-size: .85rem; }
.structured dd { margin: 0; font-size: .9rem; }

/* ---- agenda / listes ---- */
.section-title { font-family: var(--serif); font-size: 1.2rem; margin: 1.4rem 0 .6rem; }
.list { display: grid; gap: .5rem; }
.month-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px;
  background: var(--line); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.month-cell { background: var(--card); min-height: 74px; padding: .25rem .35rem;
  font-size: .78rem; min-width: 0; overflow: hidden; }
.month-cell.other { background: var(--paper); color: var(--ink-soft); }
.month-cell.today { outline: 2px solid var(--spruce); outline-offset: -2px; }
.month-num { font-family: var(--mono); color: var(--ink-soft); }
.month-ev { display: block; background: var(--spruce-soft); color: var(--spruce);
  border-radius: 4px; padding: 0 .25rem; margin-top: .15rem; text-decoration: none;
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.month-ev.proposed { background: var(--amber-soft); color: var(--amber); }
.meta { color: var(--ink-soft); font-size: .85rem; }
.pill { display: inline-block; border-radius: 999px; padding: 0 .55em;
  font-size: .78rem; background: var(--spruce-soft); color: var(--spruce); font-weight: 600; }
.pill.amber { background: var(--amber-soft); color: var(--amber); }
.row-actions { display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; }

/* ---- tendances : barres CSS ---- */
.bar-row { display: grid; grid-template-columns: 9rem 1fr max-content;
  gap: .6rem; align-items: center; font-size: .88rem; margin: .2rem 0; }
.bar { background: var(--spruce); height: .8rem; border-radius: 4px; min-width: 2px; }
.bar.amber { background: var(--amber); }
table.plain { border-collapse: collapse; width: 100%; font-size: .9rem;
  display: block; overflow-x: auto; } /* le tableau défile dans SA boîte, pas la page */
table.plain th, table.plain td { text-align: left; padding: .3rem .5rem;
  border-bottom: 1px solid var(--line); }

/* ---- module budget (refonte onglets + barres) ---- */
.b-head { display: flex; align-items: center; justify-content: space-between;
  margin: .3rem 0 .5rem; }
.b-month { font-family: var(--serif); font-size: 1.1rem; font-weight: 700;
  display: flex; gap: .6rem; align-items: center; }
.b-month a { text-decoration: none; }
.b-tabs { display: flex; gap: .3rem; margin-bottom: .8rem; background: var(--card);
  border-radius: 999px; padding: .25rem; box-shadow: 0 1px 4px rgba(31,42,48,.07); }
.b-tabs a { flex: 1; text-align: center; padding: .45rem 0; border-radius: 999px;
  text-decoration: none; color: var(--ink-soft); font-weight: 600; font-size: .9rem; }
.b-tabs a.on { background: var(--grad); color: #fff; }
.b-env { background: var(--card); border-radius: 12px; padding: .55rem .8rem;
  margin-bottom: .45rem; box-shadow: 0 1px 4px rgba(31,42,48,.07); }
.b-env summary { list-style: none; cursor: pointer; }
.b-env summary::-webkit-details-marker { display: none; }
.b-env-top { display: flex; justify-content: space-between; align-items: baseline; }
.b-bar { height: .45rem; background: var(--paper); border-radius: 999px;
  margin: .3rem 0 .25rem; overflow: hidden; }
.b-bar-fill { display: block; height: 100%; background: var(--grad);
  border-radius: 999px; transition: width .3s ease; }
.b-bar-fill.over { background: var(--danger); }
.b-env-sub { display: flex; justify-content: space-between; font-size: .74rem;
  color: var(--ink-soft); }
.b-tx .row-actions { flex-wrap: nowrap; }

/* ---- module budget ---- */
.tobudget { text-align: right; background: var(--spruce-soft); border-radius: 12px;
  padding: .4rem .8rem; }
.tobudget.neg { background: var(--danger-soft); }
.tb-label { display: block; font-size: .68rem; text-transform: uppercase;
  letter-spacing: .05em; color: var(--ink-soft); font-weight: 700; }
.tb-amount { font-family: var(--mono); font-weight: 700; font-size: 1.05rem; }
.tobudget.neg .tb-amount { color: var(--danger); }
.b-groupe { font-family: var(--serif); font-size: .95rem; margin: .8rem 0 .2rem;
  color: var(--ink-soft); }
.b-row { display: grid; grid-template-columns: 1fr 6rem 5.5rem 5.5rem; gap: .5rem;
  align-items: center; background: var(--card); border-radius: 8px;
  padding: .35rem .6rem; margin-bottom: .25rem; font-size: .9rem;
  box-shadow: 0 1px 3px rgba(31,42,48,.06); }
.b-alloc input { width: 100%; text-align: right; font-family: var(--mono);
  padding: .25rem .4rem; }
.b-act, .b-avail { text-align: right; font-family: var(--mono);
  font-variant-numeric: tabular-nums; }
.b-avail.pos { color: var(--spruce); font-weight: 700; }
.neg { color: var(--danger); }
@media (max-width: 640px) {
  .b-row { grid-template-columns: 1fr 4.6rem 4.6rem 4.6rem; font-size: .8rem; }
}

/* ---- landing publique ---- */
.landing { width: min(100%, 720px); margin: 0 auto; padding: 2.5rem 1.2rem; }
.landing-hero { text-align: center; margin-bottom: 2rem; }
.landing-pitch { font-family: var(--serif); font-size: 1.25rem; line-height: 1.5;
  color: var(--ink); margin: 1rem 0 1.4rem; }
.landing-cta { display: flex; flex-direction: column; gap: .8rem; align-items: center; }
.btn-cta { display: inline-block; background: var(--grad); color: #fff; font-weight: 700;
  padding: .8rem 1.6rem; border-radius: 999px; text-decoration: none;
  box-shadow: 0 4px 16px rgba(34,112,90,.35); }
.landing-feats { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: .8rem; }
.feat { background: var(--card); border-radius: 12px; padding: 1rem;
  box-shadow: 0 1px 4px rgba(31,42,48,.07); font-size: .92rem; color: var(--ink-soft); }
.feat span { font-size: 1.4rem; display: block; margin-bottom: .3rem; }
.feat strong { color: var(--ink); }
.landing-foot { margin-top: 2rem; text-align: center; }

@media (max-width: 640px) {
  .editor-row { grid-template-columns: 1fr; }
  .capture-more-row { grid-template-columns: 1fr; }
  .topbar { gap: .4rem; }
  .month-cell { min-height: 46px; padding: .15rem .2rem; font-size: .66rem; }
  .month-ev { font-size: .6rem; }
  .scale-btn { min-width: 2.4rem; padding: .45rem 0; } /* pouces */
  .filters { overflow-x: auto; flex-wrap: nowrap; padding-bottom: .2rem; }
  .filters .chip { white-space: nowrap; flex-shrink: 0; }
  .bar-row { grid-template-columns: 6.5rem 1fr max-content; }
  .day { margin-top: .6rem; }
}

/* --- recherche dans le fil --- */
.filters-search { display: flex; gap: .4rem; width: 100%; margin-bottom: .45rem; }
.filters-search input[type="search"] {
  flex: 1; min-width: 0; padding: .45rem .65rem; font-size: .92rem;
  border: 1px solid var(--border, #d8d2c6); border-radius: .6rem;
  background: var(--card, #fff); color: inherit;
}

/* ── Coffre 🗄️ ── */
.doc-row { display: flex; align-items: center; gap: .55rem; text-decoration: none;
  color: inherit; padding: .6rem .75rem; }
.doc-row .doc-title { font-weight: 600; min-width: 0; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap; }
.doc-row .meta { margin-left: auto; text-align: right; flex-shrink: 0; max-width: 46%;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-mini { display: flex; gap: .6rem; align-items: center; text-decoration: none;
  color: inherit; background: rgba(34, 112, 90, .06); border-radius: .6rem;
  padding: .45rem .55rem; margin: .3rem 0; }
.doc-thumb { width: 52px; height: 68px; object-fit: cover; border-radius: .35rem;
  flex-shrink: 0; box-shadow: 0 1px 4px rgba(0,0,0,.18); }
.doc-pages { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: .5rem; }
.doc-pages .entry-photo { width: 100%; height: auto; }
/* liens nus : encre épinette + soulignement discret — jamais le bleu navigateur.
   Sélecteur élément (spécificité minimale) : tout lien déjà classé (chips, tabs,
   nav, cartes) garde son style. */
a { color: var(--spruce); font-weight: 600; text-decoration: underline;
  text-decoration-color: rgba(34, 112, 90, .35); text-decoration-thickness: 1px;
  text-underline-offset: 3px; }
a:hover { text-decoration-color: var(--spruce); }
a.doc-row, a.doc-mini { color: inherit; font-weight: inherit; text-decoration: none; }
.doc-row a.doc-title { color: inherit; text-decoration: none; }
.meta a, .hero-sub a { font-weight: 600; }
.topbar a { color: #fff; text-decoration: none; }
.b-tabs a { color: var(--ink-soft); text-decoration: none; }

/* ── Galerie 🖼️ ── */
.gal-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
  gap: 4px; }
.gal-item { position: relative; display: block; aspect-ratio: 1; border-radius: 10px;
  overflow: hidden; background: var(--spruce-soft); text-decoration: none; }
.gal-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gal-video { display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%; gap: .2rem; background:
  linear-gradient(135deg, #2A3D3B, #1E4B44); color: #fff; }
.gal-video span { font-size: 1.6rem; }
.gal-video time { font-size: .7rem; opacity: .8; }
.gal-badge { position: absolute; right: .25rem; bottom: .25rem; font-size: .8rem;
  background: rgba(0,0,0,.45); border-radius: 999px; padding: .05rem .3rem;
  line-height: 1.2; font-weight: 400; }
.gal-badge.gal-star { right: auto; left: .25rem; }
.gal-badge.gal-mood { bottom: auto; top: .25rem; right: .25rem; }
.capture-main .gal-pick { opacity: .75; }
video.entry-photo { width: 100%; max-height: 340px; border-radius: .6rem;
  background: #000; }

/* ── rangée médias sous la capture + menu hamburger ── */
.media-row { display: flex; gap: .4rem; margin: .35rem 0 .1rem; flex-wrap: wrap; }
.media-row .photo-btn { display: inline-flex; align-items: center; gap: .3rem;
  padding: .4rem .6rem; border-radius: 10px; font-size: 1.05rem; }
.media-row small { font-size: .72rem; color: var(--ink-soft); font-weight: 600; }
.capture-main .capture-input { flex: 1; min-width: 0; }
.topmenu { position: relative; }
.topmenu summary { list-style: none; cursor: pointer; color: #fff;
  font-size: 1.25rem; padding: .2rem .5rem; border-radius: 8px; }
.topmenu summary::-webkit-details-marker { display: none; }
.topmenu[open] summary { background: rgba(255,255,255,.18); }
.topmenu-list { position: absolute; right: 0; top: 2.2rem; z-index: 40;
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  box-shadow: 0 10px 30px rgba(31,42,48,.22); padding: .4rem; min-width: 12.5rem;
  display: flex; flex-direction: column; }
.topmenu-list a, .topmenu-list button { display: block; width: 100%; text-align: left;
  padding: .55rem .7rem; border-radius: 8px; color: var(--ink); text-decoration: none;
  font-weight: 600; font-size: .95rem; background: none; border: 0; }
.topmenu-list a:hover, .topmenu-list button:hover { background: var(--spruce-soft); }
.topmenu-list a.on { color: var(--spruce); background: var(--spruce-soft); }

/* ── galerie façon album : mosaïque + visionneuse ── */
.gal-item { border: 0; padding: 0; cursor: pointer; }
.gal-item.big { grid-column: span 2; grid-row: span 2; }
.gal-day { font-family: var(--serif); }
#lb { position: fixed; inset: 0; z-index: 80; background: rgba(12, 20, 19, .96);
  display: flex; align-items: center; justify-content: center; }
#lb[hidden] { display: none; }
.lb-stage { display: flex; flex-direction: column; align-items: center; gap: .5rem;
  max-width: 94vw; max-height: 94vh; }
#lb-img, #lb-video { max-width: 94vw; max-height: 78vh; border-radius: 10px;
  box-shadow: 0 12px 50px rgba(0,0,0,.5); object-fit: contain; background: #000; }
.lb-cap { color: rgba(255,255,255,.85); font-size: .9rem; margin: 0;
  text-align: center; max-width: 80vw; }
#lb-edit { background: rgba(255,255,255,.12); color: #fff; border: 0; }
.lb-x { position: absolute; top: max(.8rem, env(safe-area-inset-top)); right: 1rem;
  background: none; border: 0; color: #fff; font-size: 1.5rem; cursor: pointer;
  min-width: 44px; min-height: 44px; display: inline-flex; align-items: center;
  justify-content: center; }
.lb-nav { position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.1); border: 0; color: #fff; font-size: 2.2rem;
  width: 2.8rem; height: 3.6rem; border-radius: 12px; cursor: pointer; }
.lb-prev { left: .4rem; } .lb-next { right: .4rem; }
@media (max-width: 560px) { .lb-nav { display: none; } } /* mobile : balayage */

.q-face { width: 84px; height: 84px; border-radius: 14px; object-fit: cover;
  display: block; margin: 0 0 .35rem; border: 2px solid var(--line); }

/* ── page visages ── */
.vg-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(9.5rem, 1fr));
  gap: .7rem; }
.vg-card { background: var(--card); border-radius: 14px; padding: .6rem;
  box-shadow: 0 1px 10px rgba(0,0,0,.06); }
.vg-card img, .vg-ph { width: 100%; aspect-ratio: 1; object-fit: cover;
  border-radius: 10px; display: grid; place-items: center; font-size: 2.2rem;
  background: var(--paper-top); }
.vg-name { margin: .35rem 0 .1rem; font-weight: 700; }
.vg-row { display: flex; gap: .3rem; margin: .3rem 0; }
.vg-row input { flex: 1; min-width: 0; }

/* ── import du téléphone ── */
.imp-bar { height: 8px; background: var(--line); border-radius: 999px; overflow: hidden; }
.imp-fill { height: 100%; width: 0; background: var(--grad); transition: width .3s; }
.imp-report { list-style: none; padding: 0; font-size: .85rem; color: var(--ink-soft);
  overflow-wrap: anywhere; }
.imp-title { margin: .1rem 0 .4rem; font-weight: 700; }

/* ── souvenirs : carte du fil + page ── */
.sv-card { display: flex; align-items: center; gap: .65rem; margin: .6rem 0;
  padding: .6rem .75rem; border-radius: var(--r, 14px); background: var(--card, #fff);
  box-shadow: 0 1px 6px rgba(20, 40, 35, .08); text-decoration: none; color: inherit; }
.sv-thumbs { display: flex; flex-shrink: 0; }
.sv-thumbs img, .sv-thumb-fallback { width: 2.4rem; height: 2.4rem; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--card, #fff); margin-left: -.55rem;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--paper-top, #f4f1ea); font-size: 1.1rem; }
.sv-thumbs img:first-child, .sv-thumb-fallback:first-child { margin-left: 0; }
.sv-body { display: flex; flex-direction: column; gap: .1rem; min-width: 0; }
.sv-body small { color: var(--ink-soft); }
.sv-year { color: var(--ink-soft); font-weight: 400; }
.sv-item .sv-text { display: flex; align-items: center; justify-content: center;
  height: 100%; padding: .5rem; font-size: .78rem; color: var(--ink-soft);
  text-align: center; overflow: hidden; }
.sv-links { margin-top: .45rem; }
.sv-nav { justify-content: space-between; }
.lang-switch { margin-top: 1rem; text-align: center; font-size: .85rem;
  color: var(--ink-soft); }
.lang-switch .lang-on { font-weight: 700; text-decoration: underline; }

/* état « ça travaille » : tout envoi htmx grise son bouton principal */
form.htmx-request button.primary, button.primary.htmx-request {
  opacity: .55; pointer-events: none; }

/* ── fil épuré : sélecteur d'acteur + FAB à sous-FABs ── */
.acteur-row { display: flex; gap: .45rem; align-items: center; margin-bottom: .55rem; }
.acteur-select { flex: 1; min-width: 0; font-size: 1rem; font-weight: 600;
  min-height: 2.6rem; border: 1px solid var(--line); border-radius: 12px;
  padding: .3rem 2rem .3rem .7rem; background: var(--card); color: var(--ink); }
.acteur-plus { flex-shrink: 0; }
.fab-stack { position: fixed; right: .9rem;
  bottom: calc(4.6rem + env(safe-area-inset-bottom)); z-index: 45;
  display: flex; flex-direction: column; align-items: center; gap: .55rem; }
.fab-stack .mood-fab { position: static; }
.fab-menu { display: flex; flex-direction: column; gap: .55rem; }
.fab-menu[hidden] { display: none; }  /* display:flex écraserait hidden sinon */
.fab-mini { width: 2.9rem; height: 2.9rem; border-radius: 50%; border: 0;
  background: var(--card); color: var(--ink); font-size: 1.25rem; cursor: pointer;
  box-shadow: 0 6px 18px rgba(31, 42, 48, .28);
  display: inline-flex; align-items: center; justify-content: center; }
#fab-main { transition: transform .18s; }
#fab-main.fab-open { transform: rotate(45deg); }
@media (prefers-reduced-motion: reduce) { #fab-main { transition: none; } }

/* QR d'installation (réglages) */
.apk-qr { display: flex; align-items: center; gap: .8rem; margin: .55rem 0; }
.apk-qr-img { flex-shrink: 0; width: 8.5rem; height: 8.5rem; padding: .45rem;
  background: #fff; border: 1px solid var(--line); border-radius: 12px; }
.apk-qr-img svg { width: 100%; height: 100%; display: block; }

/* question visage : champ prénom toujours visible sous les choix */
.face-name { display: flex; gap: .35rem; margin: .35rem 0 0; }
.face-name input { flex: 1; min-width: 0; }
.face-name button.primary { width: auto; }

/* bannière de mise à jour de la coque Android */
.apk-banner { position: fixed; left: .6rem; right: .6rem;
  bottom: calc(4.9rem + env(safe-area-inset-bottom)); z-index: 55;
  display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
  background: var(--card, #fff); border: 1px solid var(--line);
  border-radius: 14px; padding: .7rem .85rem;
  box-shadow: 0 10px 30px rgba(31, 42, 48, .28); }
.apk-banner span { flex: 1 1 100%; font-size: .92rem; font-weight: 600; }
.apk-banner button.primary { width: auto; min-height: 2.4rem; }
.imp-big { font-size: 1.05rem; min-height: 3.1rem; }
.imp-cancel { margin-top: .45rem; min-height: 2.4rem; }
.imp-current { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── story : texte TOUJOURS hors photo, segments de progression ── */
.mt-wrap { position: relative; display: flex; flex-direction: column; gap: .45rem; }
.mt-progress { display: flex; gap: 4px; }
.mt-seg { flex: 1; height: 4px; border-radius: 999px; background: var(--line);
  overflow: hidden; }
.mt-seg i { display: block; height: 100%; width: 0; background: var(--grad); }
.mt-seg.done i { width: 100%; }
.mt-seg.run i { animation: segfill 4.5s linear forwards; }
@keyframes segfill { from { width: 0; } to { width: 100%; } }
.mt-stage { position: relative; width: 100%; aspect-ratio: 3/4; max-height: 66vh;
  background: #0c1413; border-radius: 14px; overflow: hidden; cursor: pointer; }
@media (min-width: 700px) { .mt-stage { aspect-ratio: 16/10; } }
.mt-slide { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; opacity: 0; transform: scale(1);
  transition: opacity .9s ease; }
.mt-slide.on { opacity: 1; animation: kenburns 5s ease-in-out forwards; }
@keyframes kenburns { from { transform: scale(1); } to { transform: scale(1.06); } }
.mt-band { min-height: 3.4rem; text-align: center; padding: .15rem .4rem; }
.mt-band .mt-cap { margin: 0; font-weight: 600; color: var(--ink); font-size: .95rem; }
.mt-band .mt-meta { margin: .1rem 0 0; color: var(--ink-soft); font-size: .78rem; }
.mt-intro { position: relative; aspect-ratio: 3/4; max-height: 66vh; z-index: 3;
  display: grid; place-content: center; gap: .5rem; text-align: center;
  border-radius: 14px; background: var(--grad); color: #fff; padding: 1rem; }
@media (min-width: 700px) { .mt-intro { aspect-ratio: 16/10; } }
.mt-intro.gone { display: none; }
/* tant que l'intro est là, la scène et la bande attendent en coulisse */
.mt-wrap:has(.mt-intro:not(.gone)) .mt-stage,
.mt-wrap:has(.mt-intro:not(.gone)) .mt-band { display: none; }
.mt-end { display: grid; place-content: center; gap: .5rem; text-align: center;
  border-radius: 14px; background: var(--grad); color: #fff; padding: 1.2rem; }
.mt-intro-title { margin: 0; font-family: var(--serif); font-size: 1.6rem;
  font-weight: 700; }
.mt-intro-sub { margin: 0; opacity: .92; }
.mt-intro-meta { margin: 0; font-size: .8rem; opacity: .8; }
.mt-play { background: rgba(255,255,255,.16); color: #fff; border: 1px solid
  rgba(255,255,255,.35); border-radius: 999px; padding: .7rem 1.6rem;
  font-weight: 700; font-size: 1rem; cursor: pointer; }
.mt-back { color: rgba(255,255,255,.85); font-size: .82rem; text-decoration: none; }
.mt-end-actions { display: flex; gap: .5rem; justify-content: center; flex-wrap: wrap; }
@media (prefers-reduced-motion: reduce) {
  .mt-slide.on { animation: none; }
  .mt-seg.run i { animation: none; width: 100%; } }

/* ── bulles stories dans la galerie ── */
.story-bubbles { display: flex; gap: .7rem; overflow-x: auto; padding: .2rem 0 .5rem; }
.sb { display: flex; flex-direction: column; align-items: center; gap: .25rem;
  text-decoration: none; color: var(--ink); flex: 0 0 auto; width: 4.4rem; }
.sb-ring { width: 4rem; height: 4rem; border-radius: 50%; padding: 3px;
  background: var(--line); display: block; }
.sb-new .sb-ring { background: var(--grad); }
.sb-ring img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--card); display: block; }
.sb-label { font-size: .68rem; text-align: center; color: var(--ink-soft); }

/* ── agenda : grilles Jour/Semaine + horaire du jour dans le fil ── */
.ag-head { display: flex; gap: .5rem; align-items: center; margin: .3rem 0; }
.ag-nav { display: flex; gap: .4rem; align-items: center; margin: .5rem 0 .3rem;
  flex-wrap: wrap; }
.wk { background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  overflow: hidden; }
.wk-row { display: flex; position: relative; }
.wk-gutter { width: 2.6rem; flex-shrink: 0; position: relative;
  border-right: 1px solid var(--line); }
.wk-hour { position: absolute; right: .3rem; transform: translateY(-45%);
  font-size: .62rem; color: var(--ink-soft); }
.wk-days .wk-dayhead { flex: 1; text-align: center; padding: .35rem 0;
  text-decoration: none; color: var(--ink); font-weight: 700; font-size: .95rem;
  border-right: 1px solid var(--line); display: flex; flex-direction: column; }
.wk-dayhead small { font-weight: 600; color: var(--ink-soft); font-size: .62rem;
  text-transform: uppercase; }
.wk-dayhead.today { color: var(--spruce); background: var(--spruce-soft); }
.wk-allday { flex: 1; padding: .15rem; border-right: 1px solid var(--line);
  display: flex; flex-wrap: wrap; gap: 2px; min-height: 1.4rem; }
.wk-scroll { max-height: 58vh; overflow-y: auto; }
.wk-col { flex: 1; position: relative; border-right: 1px solid var(--line);
  background: repeating-linear-gradient(to bottom, transparent 0, transparent 47px,
  var(--line) 47px, var(--line) 48px); }
.wk-col.today { background-color: rgba(34, 112, 90, .045); }
.wk-ev { position: absolute; display: block; overflow: hidden; border-radius: 7px;
  padding: .15rem .3rem; font-size: .7rem; line-height: 1.25; color: #fff;
  text-decoration: none; background: var(--spruce);
  border: 1px solid rgba(255,255,255,.5); box-shadow: 0 1px 4px rgba(0,0,0,.15); }
.wk-ev b { font-weight: 700; font-size: .64rem; opacity: .9; }
.wk-ev.kind-rappel { background: var(--teal); }
.wk-ev.kind-medicament { background: var(--amber); }
.month-cell { text-decoration: none; color: inherit; }
.month-ev.kind-rappel { color: var(--teal); }
.month-ev.kind-medicament { color: var(--amber); }
.today-sched { background: var(--card); border: 1px solid var(--line);
  border-radius: 12px; padding: .5rem .7rem; margin: .3rem 0 .55rem; }
.sched-row { display: flex; gap: .55rem; align-items: baseline; padding: .18rem 0;
  text-decoration: none; color: inherit; font-weight: 600; }
.sched-row time { font-family: var(--mono); color: var(--spruce); font-size: .82rem;
  min-width: 3.1rem; font-weight: 700; }
.linkish { background: none; border: 0; padding: 0; color: var(--spruce);
  cursor: pointer; font: inherit; font-weight: 600; text-decoration: underline; }

/* ══ SYSTÈME DE FORMULAIRES — mobile-first, aligné, pro ══
   Libellé au-dessus (petit, 600, encre douce), champ pleine largeur en dessous.
   S'applique à TOUS les forms sans réécrire les templates. */
form label {
  display: flex; flex-direction: column; gap: .3rem;
  font-size: .78rem; font-weight: 600; letter-spacing: .01em;
  color: var(--ink-soft); margin: .55rem 0 0;
}
form label > input, form label > select, form label > textarea {
  width: 100%; font-size: 16px; font-weight: 400; color: var(--ink);
  min-height: 2.75rem; margin: 0;
}
form textarea { min-height: 4.4rem; resize: vertical; }
/* cases et radios : rangée tactile, jamais la colonne */
form label:has(> input[type="checkbox"]), form label:has(> input[type="radio"]) {
  flex-direction: row; align-items: center; gap: .55rem;
  font-size: .95rem; font-weight: 500; color: var(--ink);
  min-height: 2.4rem; padding: .1rem 0;
}
input[type="checkbox"], input[type="radio"] {
  width: 1.2rem; height: 1.2rem; min-height: 0; flex-shrink: 0;
  accent-color: var(--spruce); margin: 0;
}
/* labels-boutons (📷 Joindre, chips) : ne pas les transformer en colonnes */
form label.photo-btn, form label.chip {
  flex-direction: row; align-items: center; font-size: inherit;
  font-weight: inherit; color: inherit; margin: 0;
}
/* rangées : grille qui s'empile toute seule sur mobile, colonnes ÉGALES ailleurs */
.editor-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 10.5rem), 1fr));
  gap: 0 .6rem; align-items: end;
}
/* champs : bordures nettes, états francs */
input, select, textarea { border-radius: 10px; }
input:hover, select:hover, textarea:hover { border-color: var(--line-strong); }
input::placeholder, textarea::placeholder { color: var(--ink-faint); font-weight: 400; }
input:user-invalid, select:user-invalid, textarea:user-invalid {
  border-color: var(--danger);
}
select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23587076' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right .7rem center;
  padding-right: 2rem;
}
/* aide sous un champ : la phrase sort du libellé */
.hint { font-size: .74rem; font-weight: 400; color: var(--ink-soft);
  margin: .15rem 0 0; }
/* actions : boutons francs, pleine largeur au pouce */
.editor-actions { display: flex; gap: .5rem; margin-top: .8rem; flex-wrap: wrap; }
form button[type="submit"], .editor-actions button { min-height: 2.75rem; }
@media (max-width: 560px) {
  .editor-actions button.primary, form > button.primary,
  form > div.row-actions > button.primary { flex: 1; width: 100%; }
}
/* sections de formulaire : respiration verticale régulière */
.editor { background: var(--card); border: 1px solid var(--line);
  border-radius: 14px; padding: .9rem 1rem 1.1rem; margin: .8rem 0; }
.editor h2 { margin: 0 0 .2rem; font-size: 1.02rem; }
.editor .section-title { margin-top: 1.1rem; }
details.capture summary.section-title, details summary.meta { min-height: 2.4rem;
  display: flex; align-items: center; cursor: pointer; }

/* ── constructeur de récurrence + onglet rappels ── */
.rb-days { display: flex; gap: .35rem; margin: .5rem 0 .2rem; }
.rb-day { width: 2.4rem; height: 2.4rem; border-radius: 50%; padding: 0;
  font-weight: 700; color: var(--ink-soft); }
.rb-day.on { background: var(--grad); color: #fff; border-color: transparent; }
.rb-preview { min-height: 1rem; color: var(--spruce); font-weight: 600; }
.rap-row { display: flex; gap: .6rem; align-items: center; padding: .55rem .75rem; }
.rap-row.muted { opacity: .55; }
.rap-time { font-family: var(--mono); font-weight: 700; color: var(--spruce);
  min-width: 3.2rem; font-size: .85rem; }
.rap-kind { font-size: 1.1rem; }
.rap-main { flex: 1; min-width: 0; }
.rap-actions { flex-shrink: 0; }
