/* Super Mémoire — "Cabinet" : éditorial, encre chaude & vermillon, grain papier. */
:root {
  --bg: #17110c;
  --bg-2: #1d1610;
  --card: #211910;
  --ink: #efe6d5;
  --ink-soft: #c4b6a0;
  --ink-faint: #8b7d68;
  --line: #3a2e21;
  --line-soft: #2a2017;
  --ember: #e4552b;
  --ember-2: #f4895f;
  --gold: #d8a441;
  --sage: #9bb068;
  --rose: #e2799a;
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--serif);
  font-optical-sizing: auto;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.5;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  position: relative;
  overflow-x: hidden;
}
/* atmosphere: warm radial glows (kept subtle) */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(120% 80% at 88% -20%, rgba(228, 85, 43, 0.07), transparent 58%),
    radial-gradient(90% 60% at -10% 110%, rgba(216, 164, 65, 0.035), transparent 58%),
    var(--bg);
}
/* atmosphere: fine paper grain */
body::after {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection { background: var(--ember); color: #fff7f2; }
.hidden { display: none !important; }

.eyebrow {
  font-family: var(--mono); font-size: 0.64rem; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint);
}
.ledger { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.04em; color: var(--ink-soft); }

/* ---- layout ---- */
main { max-width: 760px; margin: 0 auto; padding: clamp(28px, 6vw, 64px) clamp(18px, 5vw, 40px) 80px; }

/* ---- masthead (nameplate) ---- */
.masthead { animation: rise 0.7s cubic-bezier(0.2, 0.7, 0.2, 1) both; }
.masthead-top {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 14px; border-bottom: 1px solid var(--line);
}
.nameplate {
  font-family: var(--serif); font-weight: 700;
  font-size: clamp(2.6rem, 9vw, 4.4rem); line-height: 0.94; letter-spacing: -0.022em;
  margin: 0.34em 0 0.18em; color: var(--ink);
}
.nameplate em { font-style: italic; font-weight: 500; color: var(--ember); }
.masthead-foot {
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
  padding-top: 14px; border-top: 1px solid var(--line); flex-wrap: wrap;
}
.masthead-foot .ledger:first-child { text-transform: capitalize; }

/* live status */
.status { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-faint); display: inline-flex; align-items: center; gap: 8px; }
.status i { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-faint); display: inline-block; transition: background 0.3s; }
.status.ok { color: var(--gold); }
.status.ok i { background: var(--gold); box-shadow: 0 0 0 0 rgba(216, 164, 65, 0.5); animation: beat 2s ease-out infinite; }

/* ---- deposit (capture) ---- */
.deposit {
  margin-top: 36px; padding: 24px 24px 22px; position: relative;
  background: var(--bg-2);
  border: 1px solid var(--line-soft); border-radius: 3px;
  animation: rise 0.6s cubic-bezier(0.2, 0.7, 0.2, 1) both; animation-delay: 0.06s;
}
.deposit .eyebrow { display: block; margin-bottom: 14px; }
#url {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--line);
  color: var(--ink); font-family: var(--serif); font-size: clamp(1.1rem, 3.5vw, 1.4rem);
  padding: 6px 2px 10px; outline: none; transition: border-color 0.25s;
}
#url::placeholder { color: var(--ink-faint); font-style: italic; }
#url:focus { border-color: var(--ember); }
.deposit-row { display: flex; gap: 12px; margin-top: 16px; align-items: stretch; }
#note {
  flex: 1; background: transparent; border: 1px solid var(--line); border-radius: 2px;
  color: var(--ink-soft); font-family: var(--mono); font-size: 0.82rem; padding: 10px 12px; outline: none; transition: border-color 0.25s;
}
#note::placeholder { color: var(--ink-faint); }
#note:focus { border-color: var(--line); border-color: var(--ink-faint); }

button {
  font-family: var(--mono); font-size: 0.74rem; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: #fff7f2; background: var(--ember); border: none;
  border-radius: 2px; padding: 0 20px; cursor: pointer; white-space: nowrap;
  transition: transform 0.08s, box-shadow 0.25s, background 0.25s;
}
button:hover { background: #ef5e34; }
button:active { transform: translateY(1px) scale(0.99); }
button:disabled { opacity: 0.45; cursor: default; box-shadow: none; }

.msg { font-family: var(--mono); font-size: 0.74rem; margin-top: 14px; letter-spacing: 0.03em; }
.msg.ok { color: var(--sage); }
.msg.error { color: var(--ember-2); }

/* ---- toolbar ---- */
.toolbar { margin: 40px 0 8px; }
#search {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--line);
  color: var(--ink); font-family: var(--serif); font-style: italic; font-size: 1.05rem;
  padding: 8px 2px; outline: none; transition: border-color 0.25s;
}
#search::placeholder { color: var(--ink-faint); }
#search:focus { border-color: var(--gold); }

/* ---- feed (catalogue) ---- */
.feed { list-style: none; margin-top: 8px; }
.item {
  position: relative; padding: 22px 4px 22px 22px; border-top: 1px solid var(--line-soft);
  transition: background 0.25s; animation: rise 0.5s cubic-bezier(0.2, 0.7, 0.2, 1) both;
  animation-delay: calc(var(--i, 0) * 45ms + 0.12s);
}
.item::before {
  content: ""; position: absolute; left: 0; top: -1px; bottom: -1px; width: 2px;
  background: var(--ember); transform: scaleY(0); transform-origin: top; transition: transform 0.3s ease;
}
.item:hover { background: rgba(244, 137, 95, 0.03); }
.item:hover::before { transform: scaleY(1); }
.item-head { display: flex; align-items: center; gap: 12px; margin-bottom: 9px; }
.num { font-family: var(--mono); font-size: 0.68rem; color: var(--ink-faint); letter-spacing: 0.05em; }
.kind {
  font-family: var(--mono); font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ember-2);
}
.k-article { color: var(--ink-soft); } .k-tweet, .k-thread { color: var(--ember-2); }
.k-video { color: var(--ink-soft); } .k-image { color: var(--ink-soft); } .k-unknown { color: var(--ink-faint); }
.time { margin-left: auto; font-family: var(--mono); font-size: 0.68rem; color: var(--ink-faint); }
.title {
  display: block; font-family: var(--serif); font-weight: 600; font-size: clamp(1.15rem, 3.6vw, 1.4rem);
  line-height: 1.28; color: var(--ink); text-decoration: none; letter-spacing: -0.01em;
  transition: color 0.2s;
}
.title:hover { color: var(--ember-2); }
.meta { margin-top: 8px; font-family: var(--mono); font-size: 0.72rem; color: var(--ink-faint); }
.meta .author { color: var(--ink-soft); }
.meta .src { color: var(--ink-soft); }
.meta .via { color: var(--ink-faint); font-style: normal; }
.meta .sep { margin: 0 8px; opacity: 0.5; }

/* per-row delete (✕) — discreet, reveals on hover, vermillon on intent */
.item-del {
  background: none; border: none; padding: 3px 7px; margin: -3px -4px -3px 0;
  font-family: var(--mono); font-size: 0.95rem; line-height: 1; letter-spacing: 0;
  text-transform: none; color: var(--ink-faint); cursor: pointer; border-radius: 3px;
  transition: color 0.2s, background 0.2s, opacity 0.2s;
}
.item-del:hover { color: var(--ember-2); background: rgba(228, 85, 43, 0.12); }
/* mouse users: keep it hidden until the row is hovered. touch: always visible. */
@media (hover: hover) {
  .item-del { opacity: 0; }
  .item:hover .item-del, .item:focus-within .item-del { opacity: 0.6; }
  .item-del:hover { opacity: 1; }
}

/* delete in flight: dim the card + spin the trigger; then fade the row out */
.item.is-deleting { opacity: 0.5; pointer-events: none; }
.item.is-removing {
  opacity: 0; transform: translateX(14px); pointer-events: none;
  transition: opacity 0.28s ease, transform 0.28s ease;
}
.item-del.is-loading, .d-del.is-loading {
  color: transparent !important; pointer-events: none; position: relative; opacity: 1 !important;
}
.item-del.is-loading::after, .d-del.is-loading::after {
  content: ""; position: absolute; top: 50%; left: 50%;
  width: 12px; height: 12px; margin: -6px 0 0 -6px; border-radius: 50%;
  border: 2px solid rgba(196, 182, 160, 0.35); border-top-color: var(--ember-2);
  animation: spin 0.6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.empty { text-align: center; padding: 60px 0; font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--ink-soft); }
.empty span { display: block; margin-top: 8px; font-size: 0.85rem; font-style: normal; font-family: var(--mono); letter-spacing: 0.05em; color: var(--ink-faint); }

/* ---- login ---- */
.login { min-height: 100vh; min-height: 100dvh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-card {
  width: 100%; max-width: 380px; display: flex; flex-direction: column; gap: 8px;
  padding: 40px 34px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px;
  position: relative; animation: rise 0.6s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}
.login-card::before { content: ""; position: absolute; inset: 6px; border: 1px solid var(--line-soft); border-radius: 3px; pointer-events: none; }
.login-title { font-family: var(--serif); font-weight: 900; font-size: 2.2rem; line-height: 1; margin: 6px 0; }
.login-title em { font-style: italic; font-weight: 600; color: var(--ember); }
.login-sub { font-family: var(--serif); font-style: italic; color: var(--ink-soft); margin-bottom: 18px; }
.login-card input {
  background: transparent; border: none; border-bottom: 1px solid var(--line); color: var(--ink);
  font-family: var(--mono); font-size: 0.95rem; padding: 10px 2px; outline: none; transition: border-color 0.25s;
}
.login-card input:focus { border-color: var(--ember); }
.login-card button { margin-top: 18px; padding: 13px; }
.error { font-family: var(--mono); font-size: 0.74rem; color: var(--ember-2); margin-top: 10px; }

/* ---- detail (one bookmark) ---- */
.detail {
  max-width: 760px; margin: 0 auto; padding: 0 clamp(18px, 5vw, 40px) 96px;
  animation: rise 0.5s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}
.detail-bar {
  position: sticky; top: 0; z-index: 5; padding: 20px 0 14px; margin-bottom: 10px;
  background: linear-gradient(var(--bg) 62%, rgba(23, 17, 12, 0));
}
.back {
  font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.06em;
  color: var(--ink-faint); text-decoration: none; transition: color 0.2s;
}
.back:hover { color: var(--ember-2); }

.d-head { padding-bottom: 20px; border-bottom: 1px solid var(--line); }
.d-eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.d-eyebrow .kind { font-family: var(--mono); font-size: 0.62rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; }
.d-eyebrow .num { font-family: var(--mono); font-size: 0.68rem; color: var(--ink-faint); }
.d-eyebrow .d-when { margin-left: auto; font-family: var(--mono); font-size: 0.68rem; color: var(--ink-faint); }
.d-title {
  font-family: var(--serif); font-weight: 600; font-size: clamp(1.7rem, 5vw, 2.5rem);
  line-height: 1.16; letter-spacing: -0.018em; color: var(--ink);
}
.d-byline { margin-top: 14px; font-family: var(--mono); font-size: 0.76rem; color: var(--ink-faint); display: flex; flex-wrap: wrap; align-items: center; }
.d-byline .author { color: var(--ink-soft); }
.d-byline .src { color: var(--ink-soft); }
.d-byline .sep { margin: 0 9px; opacity: 0.45; }

.d-actions { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin: 22px 0; }
.d-open {
  font-family: var(--mono); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ember-2); text-decoration: none;
  border: 1px solid var(--line); border-radius: 2px; padding: 9px 16px;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.d-open:hover { border-color: var(--ember); background: var(--ember); color: #fff7f2; }
.d-captured { font-family: var(--mono); font-size: 0.72rem; color: var(--ink-faint); }
.d-del {
  margin-left: auto; font-family: var(--mono); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint);
  background: transparent; border: 1px solid var(--line); border-radius: 2px; padding: 9px 16px;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.d-del:hover { border-color: var(--ember); color: #fff7f2; background: var(--ember); }

.d-note {
  margin: 22px 0; padding: 14px 18px; border-left: 2px solid var(--ember);
  background: var(--bg-2); border-radius: 0 3px 3px 0;
  font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--ink-soft);
  display: flex; gap: 10px;
}
.d-note span { font-style: normal; }

.d-meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1px;
  margin: 22px 0; background: var(--line-soft); border: 1px solid var(--line-soft); border-radius: 3px; overflow: hidden;
}
.d-meta > div { background: var(--bg); padding: 12px 16px; }
.d-meta dt { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 5px; }
.d-meta dd { font-family: var(--mono); font-size: 0.82rem; color: var(--ink-soft); word-break: break-word; }

.d-tags { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin: 22px 0; }
.d-tags li {
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.06em; color: var(--ink-soft);
  border: 1px solid var(--line); border-radius: 2px; padding: 4px 10px;
}

.d-links { margin: 26px 0; }
.d-links .eyebrow { display: block; margin-bottom: 12px; }
.d-links ul { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.d-links a {
  display: flex; flex-direction: column; gap: 2px; text-decoration: none;
  padding: 11px 14px; border: 1px solid var(--line-soft); border-radius: 3px; transition: border-color 0.2s, background 0.2s;
}
.d-links a:hover { border-color: var(--line); background: var(--bg-2); }
.d-links a b { font-family: var(--serif); font-weight: 600; font-size: 0.98rem; color: var(--ink); }
.d-links a span { font-family: var(--mono); font-size: 0.7rem; color: var(--ink-faint); word-break: break-all; }

/* rendered markdown body */
.d-content { margin-top: 30px; font-size: 1.05rem; line-height: 1.75; color: #d8cdb9; }
.d-content > *:first-child { margin-top: 0; }
.d-content .md-h2 {
  font-family: var(--serif); font-weight: 600; font-size: 1.45rem; line-height: 1.25; color: var(--ink);
  letter-spacing: -0.01em; margin: 40px 0 4px; padding-bottom: 8px; border-bottom: 1px solid var(--line-soft);
}
.d-content .md-h3 { font-family: var(--serif); font-weight: 600; font-size: 1.18rem; color: var(--ink); margin: 30px 0 2px; }
.d-content .md-h4 { font-family: var(--mono); font-weight: 600; font-size: 0.82rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); margin: 24px 0 0; }
.d-content p { margin: 16px 0; }
.d-content a { color: var(--ember-2); text-decoration: none; border-bottom: 1px solid rgba(244, 137, 95, 0.3); transition: border-color 0.2s; }
.d-content a:hover { border-color: var(--ember-2); }
.d-content strong { color: var(--ink); font-weight: 600; }
.d-content em { font-style: italic; }
.d-content ul { margin: 16px 0; padding-left: 4px; list-style: none; }
.d-content li { position: relative; padding-left: 22px; margin: 8px 0; }
.d-content li::before { content: "—"; position: absolute; left: 0; color: var(--ink-faint); }
.d-content blockquote {
  margin: 20px 0; padding: 4px 0 4px 20px; border-left: 2px solid var(--line);
  color: var(--ink-soft); font-style: italic;
}
.d-content code {
  font-family: var(--mono); font-size: 0.86em; background: var(--bg-2);
  border: 1px solid var(--line-soft); border-radius: 3px; padding: 1px 6px; color: var(--ember-2);
}
.d-content pre {
  margin: 20px 0; padding: 16px 18px; background: #120d09; border: 1px solid var(--line-soft);
  border-radius: 4px; overflow-x: auto;
}
.d-content pre code { background: none; border: none; padding: 0; color: var(--ink-soft); font-size: 0.82rem; line-height: 1.6; }
.d-content .md-img { max-width: 100%; height: auto; border-radius: 4px; border: 1px solid var(--line); margin: 20px 0; display: block; }
.d-content .md-embed { font-family: var(--mono); font-size: 0.78rem; color: var(--ink-faint); }

.d-loading, .d-empty { padding: 60px 0; text-align: center; font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: var(--ink-faint); }

/* ---- motion ---- */
@keyframes rise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
@keyframes beat {
  0% { box-shadow: 0 0 0 0 rgba(216, 164, 65, 0.35); }
  70% { box-shadow: 0 0 0 5px rgba(216, 164, 65, 0); }
  100% { box-shadow: 0 0 0 0 rgba(216, 164, 65, 0); }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; } }

/* ---- scrollbar ---- */
::-webkit-scrollbar { width: 11px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--line); border: 3px solid var(--bg); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--ink-faint); }
