/* ============================================================================
   PERSO OS — direction "TACTICAL COMMAND CENTER" perso.
   Langage Split OS : topbar + hub par modules + cards liseré/halo + mono.
   Palette : noir bleuté + bleu marine. Clash Display / Satoshi / JetBrains Mono.
   ============================================================================ */
:root{
  --bg:#06070b; --bg-2:#0a0c12; --surface:#0f1219; --surface-2:#151a26;
  --border:#1e2433; --border-strong:#2f3850;
  --text:#f4f6fb; --text-2:#a3aabf; --muted:#7e87a0;
  --accent:#5b8cff; --accent-2:#7da4ff; --accent-soft:#a8c1ff;
  --success:#22c55e; --danger:#ef4444; --warning:#fbbf24; --teal:#2dd4bf; --purple:#a78bfa; --rose:#f472b6;
  /* couleurs des 5 piliers */
  --p-corps:#f87171; --p-esprit:#a78bfa; --p-langue:#2dd4bf; --p-voix:#fbbf24; --p-empire:#5b8cff;
  --radius:16px; --radius-sm:11px; --radius-pill:999px;
  --display:'Clash Display','Satoshi',sans-serif;
  --body:'Satoshi',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;
  --topbar:50px;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%;}
body{
  min-height:100vh; background:var(--bg); color:var(--text);
  font-family:var(--body); font-size:14px; line-height:1.55; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  position:relative; overflow-x:hidden;
  padding-top:calc(var(--topbar) + env(safe-area-inset-top, 0px));
  padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px));
}
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 6%, var(--bg)) 0%, var(--bg) 44%) fixed;
}
.grain{position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

svg{display:block;}

/* ============================================================================
   TOPBAR — fine, fixe, verre flouté (langage sos-topbar)
   ============================================================================ */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  height:calc(var(--topbar) + env(safe-area-inset-top, 0px));
  padding:env(safe-area-inset-top, 0px) 16px 0;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  background:color-mix(in srgb, var(--bg-2) 86%, transparent);
  -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--text); min-width:0;}
.brand-mark{
  width:28px; height:28px; flex-shrink:0; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:#fff;
  background:linear-gradient(140deg, var(--accent) 0%, #2f56c4 100%);
  box-shadow:0 4px 14px -6px var(--accent), inset 0 0 0 1px color-mix(in srgb, #fff 18%, transparent);
}
.brand-mark svg{width:15px; height:15px;}
.brand-name{font-family:var(--display); font-size:15px; font-weight:600; letter-spacing:-.01em; white-space:nowrap;}
.brand-name b{color:var(--accent); font-weight:600;}
.topbar-tag{
  font-family:var(--mono); font-size:9.5px; font-weight:500; letter-spacing:.12em;
  text-transform:uppercase; color:var(--muted);
  padding:4px 11px; border-radius:var(--radius-pill);
  background:var(--surface); box-shadow:inset 0 0 0 1px var(--border);
  white-space:nowrap;
}
.topbar-tag b{color:var(--accent); font-weight:600;}

main{padding:18px 16px 28px; max-width:980px; margin:0 auto;}

/* ============================================================================
   HERO (hub) — compteur d'arc + stats, façon hero Split OS
   ============================================================================ */
.hero{padding:16px 2px 6px;}
.hero-eyebrow{
  font-family:var(--mono); font-size:9.5px; font-weight:500; letter-spacing:.22em;
  text-transform:uppercase; color:var(--muted); display:flex; align-items:center; gap:9px;
}
.hero-eyebrow::before{content:""; width:20px; height:1px; background:color-mix(in srgb, var(--accent) 55%, transparent);}
.hero h1{
  margin:14px 0 0; font-family:var(--display); font-size:clamp(30px, 6vw, 40px);
  font-weight:600; letter-spacing:-.025em; word-spacing:.12em; line-height:1.08; color:var(--text);
}
.hero h1 em{font-style:normal;
  background:linear-gradient(110deg, var(--accent-soft) 0%, var(--accent) 55%, var(--accent-2) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;}
.hero-sub{margin:10px 0 0; max-width:520px; font-size:14px; line-height:1.6; color:var(--text-2);}
.hero-stats{display:flex; flex-wrap:wrap; align-items:stretch; gap:20px; margin-top:22px;}
.stat{display:flex; flex-direction:column; gap:3px;}
.stat .sv{font-family:var(--display); font-size:24px; font-weight:600; letter-spacing:-.02em; line-height:1; color:var(--text);}
.stat .sv span{color:var(--accent);}
.stat .sv.ok{color:var(--success);}
.stat .sv.bad{color:var(--danger);}
.stat .sl{font-family:var(--mono); font-size:9px; letter-spacing:.13em; text-transform:uppercase; color:var(--muted);}
.stat-sep{width:1px; align-self:stretch; background:var(--border);}
.hero-bar{margin-top:20px;}

/* ============================================================================
   SECTIONS MODULES (départements)
   ============================================================================ */
.dept{margin-top:38px;}
.dept-head{display:flex; align-items:center; gap:12px; margin-bottom:16px;}
.dept-idx{font-family:var(--mono); font-size:10.5px; font-weight:500; color:var(--muted); letter-spacing:.06em;}
.dept-name{display:flex; align-items:center; gap:10px; margin:0; font-family:var(--display);
  font-size:17px; font-weight:600; letter-spacing:-.01em; word-spacing:.1em; color:var(--text);}
.dept-dot{width:8px; height:8px; border-radius:3px; background:var(--d); box-shadow:0 0 11px -1px var(--d);}
.dept-meta{font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; color:var(--muted);
  border:1px solid var(--border); border-radius:var(--radius-pill); padding:3px 9px; white-space:nowrap;}
.dept-rule{flex:1; height:1px;
  background:linear-gradient(90deg, color-mix(in srgb, var(--d) 45%, transparent), transparent 70%);}

/* ============================================================================
   GRILLE + CARDS du hub (langage .card Split OS)
   ============================================================================ */
.grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(250px, 1fr)); gap:14px;}
.bcard{
  position:relative; display:flex; flex-direction:column; min-height:158px; padding:18px;
  background:linear-gradient(165deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 60%, var(--bg)) 100%);
  border:1px solid var(--border); border-radius:var(--radius);
  color:var(--text); text-decoration:none; overflow:hidden; isolation:isolate;
  transition:border-color .22s ease, transform .22s cubic-bezier(.2,.8,.2,1), box-shadow .22s ease;
}
.bcard::before{content:""; position:absolute; top:16px; bottom:16px; left:0; width:3px; border-radius:3px;
  background:var(--c); opacity:0; transform:scaleY(.4); transform-origin:center;
  transition:opacity .22s ease, transform .22s ease;}
.bcard-glow{position:absolute; z-index:-1; top:-40%; right:-30%; width:75%; height:75%; border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb, var(--c) 26%, transparent), transparent 70%);
  opacity:0; transition:opacity .3s ease; pointer-events:none;}
a.bcard:hover{
  border-color:color-mix(in srgb, var(--c) 60%, var(--border)); transform:translateY(-4px);
  box-shadow:0 22px 46px -22px color-mix(in srgb, var(--c) 60%, transparent), 0 3px 12px rgba(0,0,0,.55);
}
a.bcard:hover::before{opacity:1; transform:scaleY(1);}
a.bcard:hover .bcard-glow{opacity:1;}
a.bcard:focus-visible{outline:2px solid var(--c); outline-offset:3px;}

.bcard-head{display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:auto;}
.ico{width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  background:color-mix(in srgb, var(--c) 13%, var(--surface-2)); color:var(--c);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--c) 26%, transparent), 0 6px 18px -10px color-mix(in srgb, var(--c) 70%, transparent);
  transition:transform .22s cubic-bezier(.2,.8,.2,1);}
.ico svg{width:19px; height:19px;}
a.bcard:hover .ico{transform:scale(1.06) rotate(-3deg);}
.bcard-num{font-family:var(--mono); font-size:10px; font-weight:500; color:var(--muted); letter-spacing:.05em;}
.bcard-body{margin-top:14px;}
.bcard-title{font-family:var(--display); font-size:16px; font-weight:600; letter-spacing:-.01em; word-spacing:.08em; color:var(--text);}
.bcard-desc{margin-top:5px; font-size:12.3px; line-height:1.5; color:var(--text-2);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;}
.bcard-foot{display:flex; align-items:center; justify-content:space-between; margin-top:16px;
  padding-top:12px; border-top:1px solid var(--border);}
.bcard-type{font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}

/* card "Bientôt" : verrouillée, hachurée */
.bcard-soon{cursor:default;}
.bcard-soon .ico, .bcard-soon .bcard-title, .bcard-soon .bcard-num{opacity:.6;}
.bcard-soon .bcard-desc{opacity:.5;}
.bcard-soon::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(135deg, transparent 0 8px, color-mix(in srgb, var(--bg) 50%, transparent) 8px 9px);
  opacity:.35;}

/* ============================================================================
   PILLS d'état
   ============================================================================ */
.pill{display:inline-flex; align-items:center; gap:6px; padding:3px 10px; border-radius:var(--radius-pill);
  font-family:var(--mono); font-size:9.5px; font-weight:500; letter-spacing:.07em; text-transform:uppercase;
  color:var(--text-2); background:var(--surface-2); box-shadow:inset 0 0 0 1px var(--border); white-space:nowrap;}
.pill.on{color:var(--success); background:color-mix(in srgb, var(--success) 13%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--success) 28%, transparent);}
.pill.on::before{content:""; width:5px; height:5px; border-radius:50%; background:var(--success);
  box-shadow:0 0 8px 0 var(--success);}
.pill.off{color:var(--danger); background:color-mix(in srgb, var(--danger) 12%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--danger) 26%, transparent);}
.pill.off::before{content:""; width:5px; height:5px; border-radius:50%; background:var(--danger);
  box-shadow:0 0 8px 0 var(--danger);}
.pill-soon{display:inline-flex; align-items:center; padding:3px 10px; border-radius:var(--radius-pill);
  font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-2); background:var(--surface-2); box-shadow:inset 0 0 0 1px var(--border);}

/* ============================================================================
   PAGES INTERNES — en-tête de page + cartes conteneur
   ============================================================================ */
.page-head{padding:10px 2px 14px;}
.page-eyebrow{
  font-family:var(--mono); font-size:9.5px; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted); margin-bottom:7px;
  display:flex; align-items:center; gap:8px;
}
.page-eyebrow::before{content:""; width:18px; height:1px; background:color-mix(in srgb, var(--accent) 55%, transparent);}
.page-head h1{
  font-family:var(--display); font-size:24px; font-weight:600; letter-spacing:-.02em;
  word-spacing:.12em; line-height:1.15; color:var(--text);
}
.page-head h1 em{font-style:normal;
  background:linear-gradient(110deg, var(--accent-soft) 0%, var(--accent) 55%, var(--accent-2) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;}

.card{
  position:relative; display:block;
  background:linear-gradient(165deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 60%, var(--bg)) 100%);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:18px; margin-bottom:14px; overflow:hidden; isolation:isolate;
}
.card[style*="--c"]::before{
  content:""; position:absolute; top:16px; bottom:16px; left:0; width:3px; border-radius:3px;
  background:var(--c); opacity:.85;
}
.card[style*="--c"]{padding-left:21px;}
.card h2{
  font-family:var(--mono); font-size:10px; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--text-2); margin-bottom:12px;
  display:flex; align-items:center; gap:8px;
}
.card h2 .dot{width:7px; height:7px; border-radius:2.5px; flex-shrink:0;
  background:var(--c, var(--accent)); box-shadow:0 0 9px -1px var(--c, var(--accent));}
.card .hint{color:var(--muted); font-size:12px; margin-top:8px;}
.card .hint a{color:var(--accent); text-decoration:none;}

.big{font-family:var(--display); font-size:36px; font-weight:600; letter-spacing:-.02em; line-height:1.05;}
.big.accent{
  background:linear-gradient(110deg, var(--accent-soft) 0%, var(--accent) 55%, var(--accent-2) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;}
.ok{color:var(--success);}
.bad{color:var(--danger);}
.muted{color:var(--muted);}
.statlabel{font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); margin-top:4px;}
.row{display:flex; gap:12px; align-items:center; flex-wrap:wrap;}
.spread{justify-content:space-between;}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px;}
.grid2 > .card{margin-bottom:0;}

/* ============================================================================
   FORMULAIRES
   ============================================================================ */
label.field{display:block; margin-bottom:14px;}
label.field span{
  display:block; font-family:var(--mono); font-size:9.5px; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:7px;
}
input[type="number"], input[type="date"], textarea{
  width:100%; background:var(--bg-2); color:var(--text);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:12px 13px; font-size:15px; font-family:var(--body);
  transition:border-color .16s ease, box-shadow .16s ease;
}
textarea{min-height:88px; resize:vertical; line-height:1.5;}
input:focus, textarea:focus{outline:none; border-color:color-mix(in srgb, var(--accent) 60%, var(--border));
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);}
input::placeholder, textarea::placeholder{color:color-mix(in srgb, var(--muted) 60%, transparent);}

.toggle{display:flex; align-items:center; gap:11px; padding:11px 0; cursor:pointer;
  -webkit-user-select:none; user-select:none; font-size:14px; color:var(--text-2);}
.toggle input{width:21px; height:21px; flex-shrink:0; accent-color:var(--accent); cursor:pointer;}
.toggle strong{color:var(--text);}

button.primary{
  width:100%; min-height:50px; margin-top:6px;
  font-family:var(--body); font-weight:700; font-size:15px; letter-spacing:.01em;
  color:#fff; cursor:pointer;
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, #fff) 0%, var(--accent) 100%);
  border:1px solid color-mix(in srgb, var(--accent) 70%, var(--border-strong));
  border-radius:var(--radius-sm);
  box-shadow:0 10px 28px -14px color-mix(in srgb, var(--accent) 85%, transparent);
  transition:transform .16s ease, box-shadow .16s ease, filter .16s ease;
  -webkit-appearance:none; appearance:none;
}
button.primary:hover{filter:brightness(1.07);}
button.primary:active{transform:translateY(1px);}
button.primary:focus-visible{outline:2px solid var(--accent-2); outline-offset:2px;}
button.primary[disabled]{opacity:.5; cursor:default;}

/* ============================================================================
   BARRES / HISTORIQUES / CHART / TOAST
   ============================================================================ */
.bar{height:8px; background:var(--bg-2); border:1px solid var(--border); border-radius:6px; overflow:hidden;}
.bar > i{display:block; height:100%; border-radius:6px;
  background:linear-gradient(90deg, color-mix(in srgb, var(--c, var(--accent)) 70%, var(--bg)) 0%, var(--c, var(--accent)) 100%);
  box-shadow:0 0 10px -2px var(--c, var(--accent));
  transition:width .5s cubic-bezier(.2,.8,.2,1);}

ul.hist{list-style:none;}
ul.hist li{padding:11px 0; border-bottom:1px solid var(--border); font-size:13px; color:var(--text-2); line-height:1.5;}
ul.hist li:last-child{border-bottom:none; padding-bottom:2px;}
ul.hist .d{font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--muted);}
ul.hist .ok{color:var(--success); font-weight:600;}
ul.hist .bad{color:var(--danger); font-weight:600;}

svg.chart{width:100%; height:150px; display:block;}
.toast{
  position:fixed; left:50%; bottom:calc(94px + env(safe-area-inset-bottom, 0px));
  transform:translateX(-50%); z-index:60;
  background:var(--surface-2); color:var(--text); font-weight:600; font-size:13px;
  border:1px solid color-mix(in srgb, var(--success) 40%, var(--border-strong));
  box-shadow:0 12px 34px -14px rgba(0,0,0,.9), 0 0 18px -8px var(--success);
  padding:11px 22px; border-radius:var(--radius-pill); white-space:nowrap;
  opacity:0; transition:opacity .25s ease; pointer-events:none;
}
.toast.show{opacity:1;}

/* ============================================================================
   NAV BASSE — onglets SVG (mobile-first)
   ============================================================================ */
nav.tabs{
  position:fixed; bottom:0; left:0; right:0; z-index:40;
  display:flex; justify-content:center; gap:2px;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
  background:color-mix(in srgb, var(--bg-2) 88%, transparent);
  -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
}
nav.tabs a{
  flex:1; max-width:112px; text-align:center; padding:8px 4px 6px;
  color:var(--muted); text-decoration:none; border-radius:10px;
  font-family:var(--mono); font-size:8.5px; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:4px;
  transition:color .15s ease, background .15s ease;
}
nav.tabs a svg{width:19px; height:19px;}
nav.tabs a:hover{color:var(--text-2); background:var(--surface);}
nav.tabs a.active{color:var(--accent);
  background:color-mix(in srgb, var(--accent) 10%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);}

/* ============================================================================
   RACCOURCI HUB (pattern .rail-todo Split OS) — accès direct Notes
   ============================================================================ */
.quick{
  position:relative; display:flex; align-items:center; gap:11px; width:100%;
  margin:20px 0 0; padding:13px 14px; border-radius:13px;
  text-decoration:none; color:var(--text);
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 13%, var(--surface-2)) 0%, var(--surface-2) 100%);
  border:1px solid color-mix(in srgb, var(--accent) 34%, var(--border));
  transition:border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}
.quick::before{
  content:""; position:absolute; left:0; top:10px; bottom:10px; width:2.5px;
  border-radius:0 3px 3px 0; background:var(--accent); box-shadow:0 0 10px -1px var(--accent);
}
.quick:hover{
  border-color:color-mix(in srgb, var(--accent) 55%, var(--border-strong));
  box-shadow:0 8px 22px -14px color-mix(in srgb, var(--accent) 80%, transparent);
}
@media (hover:hover) and (pointer:fine){ .quick:hover{transform:translateY(-1px);} }
.quick-ico{
  width:30px; height:30px; flex-shrink:0; border-radius:9px;
  display:flex; align-items:center; justify-content:center; color:var(--accent);
  background:color-mix(in srgb, var(--accent) 16%, var(--surface));
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}
.quick-ico svg{width:16px; height:16px;}
.quick-txt{display:flex; flex-direction:column; gap:1px; min-width:0; flex:1;}
.quick-title{font-size:14px; font-weight:600; letter-spacing:-.005em; line-height:1.15;}
.quick-sub{font-family:var(--mono); font-size:8.5px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}
.quick-count{
  flex-shrink:0; min-width:22px; height:22px; padding:0 7px; border-radius:var(--radius-pill);
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.02em;
  color:var(--accent); background:color-mix(in srgb, var(--accent) 14%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 32%, transparent);
}

/* ============================================================================
   NOTES — liste (type Apple Notes, langage Perso OS)
   ============================================================================ */
.notes-bar{display:flex; gap:10px; margin-bottom:16px;}
.notes-search{
  flex:1; display:flex; align-items:center; gap:9px; padding:0 13px;
  background:var(--bg-2); border:1px solid var(--border); border-radius:var(--radius-sm);
  color:var(--muted);
}
.notes-search svg{flex-shrink:0;}
.notes-search input{
  flex:1; min-width:0; background:none; border:none; padding:12px 0;
  color:var(--text); font-size:15px; font-family:var(--body);
}
.notes-search input:focus{outline:none;}
.notes-search:focus-within{border-color:color-mix(in srgb, var(--accent) 60%, var(--border));}
.notes-new{
  width:46px; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  color:#fff; cursor:pointer; border-radius:var(--radius-sm);
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, #fff) 0%, var(--accent) 100%);
  border:1px solid color-mix(in srgb, var(--accent) 70%, var(--border-strong));
  box-shadow:0 8px 22px -12px color-mix(in srgb, var(--accent) 85%, transparent);
  transition:filter .16s ease, transform .16s ease;
  -webkit-appearance:none; appearance:none;
}
.notes-new:hover{filter:brightness(1.07);}
.notes-new:active{transform:translateY(1px);}

.notes-sec{
  font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted); margin:16px 2px 8px;
}
.notes-list{
  background:linear-gradient(165deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 60%, var(--bg)) 100%);
  border:1px solid var(--border); border-radius:var(--radius); overflow:hidden;
}
.note-row{
  display:block; padding:13px 16px; text-decoration:none; color:var(--text);
  border-bottom:1px solid var(--border); cursor:pointer;
  transition:background .14s ease;
}
.note-row:last-child{border-bottom:none;}
.note-row:hover{background:var(--surface-2);}
.note-title{
  font-weight:600; font-size:14.5px; letter-spacing:-.005em;
  display:flex; align-items:center; gap:7px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.note-pin{color:var(--warning); display:inline-flex; flex-shrink:0;}
.note-meta{
  display:flex; align-items:center; gap:8px; margin-top:3px; min-width:0;
}
.note-date{font-family:var(--mono); font-size:10px; letter-spacing:.04em; color:var(--accent); flex-shrink:0;}
.note-snippet{font-size:12.5px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; min-width:0;}
.note-chip{
  flex-shrink:0; font-family:var(--mono); font-size:8.5px; font-weight:500;
  letter-spacing:.08em; text-transform:uppercase; color:var(--text-2);
  padding:2px 7px; border-radius:var(--radius-pill);
  background:var(--surface-2); box-shadow:inset 0 0 0 1px var(--border);
}
.notes-empty{color:var(--muted); font-size:13px; text-align:center; padding:30px 0;}

/* Sélecteur de vue Notes / Archive / Corbeille */
.vues{display:flex; gap:8px; margin-bottom:4px;}
.vues a{
  padding:6px 13px; border-radius:var(--radius-pill); cursor:pointer;
  font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); background:var(--surface); box-shadow:inset 0 0 0 1px var(--border);
  transition:color .14s ease, box-shadow .14s ease, background .14s ease;
}
.vues a:hover{color:var(--text-2);}
.vues a.active{color:var(--accent); background:color-mix(in srgb, var(--accent) 9%, var(--surface));
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 40%, var(--border));}

/* Filtre tag actif */
.filterbar{display:flex; align-items:center; gap:10px; margin:10px 2px 0;}
.filterbar[hidden]{display:none;}
.filter-clear{
  font-family:var(--mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--muted); background:none; border:none; cursor:pointer; padding:4px;
}
.filter-clear:hover{color:var(--text);}

/* Chips tags (#tag) */
.note-tags{display:flex; flex-wrap:wrap; gap:6px; margin-top:7px;}
.note-tag{
  font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.05em;
  color:var(--accent-2); padding:2px 8px; border-radius:var(--radius-pill);
  background:color-mix(in srgb, var(--accent) 9%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 26%, transparent);
  cursor:pointer; transition:background .14s ease;
}
.note-tag:hover, .note-tag.on{background:color-mix(in srgb, var(--accent) 18%, transparent);}

/* Surlignage des résultats FTS */
.note-snippet mark{
  background:color-mix(in srgb, var(--accent) 26%, transparent);
  color:var(--text); border-radius:3px; padding:0 2px;
}

/* FAB capture (pattern Keep) — au-dessus de la nav */
.fab{
  position:fixed; right:16px; bottom:calc(86px + env(safe-area-inset-bottom, 0px)); z-index:45;
  width:56px; height:56px; border-radius:18px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; cursor:pointer;
  background:linear-gradient(140deg, var(--accent) 0%, #2f56c4 100%);
  border:1px solid color-mix(in srgb, var(--accent) 70%, var(--border-strong));
  box-shadow:0 14px 34px -12px color-mix(in srgb, var(--accent) 90%, transparent), 0 4px 14px rgba(0,0,0,.5);
  transition:transform .16s ease, filter .16s ease;
  -webkit-appearance:none; appearance:none;
}
.fab:hover{filter:brightness(1.08);}
.fab:active{transform:scale(.96);}

/* ============================================================================
   NOTES — éditeur
   ============================================================================ */
.ed-bar{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:4px 0 12px;}
.ed-back{
  display:inline-flex; align-items:center; gap:7px; padding:8px 13px 8px 9px;
  color:var(--accent); font-size:14px; font-weight:600; font-family:var(--body);
  background:none; border:none; cursor:pointer; border-radius:9px;
}
.ed-back:hover{background:var(--surface);}
.ed-back svg{display:block;}
.ed-actions{display:flex; align-items:center; gap:8px;}
.ed-state{font-family:var(--mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}
.ed-btn{
  width:38px; height:38px; display:flex; align-items:center; justify-content:center;
  color:var(--text-2); cursor:pointer; border-radius:10px;
  background:var(--surface); border:1px solid var(--border);
  transition:color .15s ease, border-color .15s ease, background .15s ease;
  -webkit-appearance:none; appearance:none;
}
.ed-btn:hover{color:var(--text); border-color:var(--border-strong);}
.ed-btn.on{color:var(--warning); border-color:color-mix(in srgb, var(--warning) 45%, var(--border));
  background:color-mix(in srgb, var(--warning) 10%, var(--surface));}
.ed-btn.ed-danger:hover{color:var(--danger); border-color:color-mix(in srgb, var(--danger) 45%, var(--border));}
.ed-meta{font-family:var(--mono); font-size:9.5px; letter-spacing:.08em; color:var(--muted); padding:0 2px 10px;}
#edText{
  width:100%; min-height:calc(100vh - var(--topbar) - 220px);
  background:none; border:none; resize:none;
  color:var(--text); font-size:15.5px; line-height:1.65; font-family:var(--body);
}
#edText:focus{outline:none; box-shadow:none; border:none;}

/* ============================================================================
   READER
   ============================================================================ */
.docpick{display:flex; gap:8px; margin-bottom:16px;}
.docpick a{
  flex:1; text-align:center; padding:10px 6px; border-radius:var(--radius-sm);
  border:1px solid var(--border); background:var(--surface);
  color:var(--text-2); text-decoration:none;
  font-family:var(--mono); font-size:9.5px; font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  transition:color .15s ease, border-color .15s ease, background .15s ease;
}
.docpick a:hover{color:var(--text); border-color:var(--border-strong);}
.docpick a.active{color:var(--accent); border-color:color-mix(in srgb, var(--accent) 45%, var(--border));
  background:color-mix(in srgb, var(--accent) 9%, var(--surface));}

.md{font-size:14.5px;}
.md h1{font-family:var(--display); font-size:22px; font-weight:600; letter-spacing:-.015em;
  word-spacing:.12em; line-height:1.25; margin:20px 0 10px; color:var(--text);}
.md h2{font-family:var(--display); font-size:17px; font-weight:600; letter-spacing:-.01em;
  word-spacing:.12em; margin:26px 0 9px; color:var(--accent-2);}
.md h3{font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase; margin:18px 0 7px; color:var(--warning);}
.md p, .md li{margin-bottom:8px; color:var(--text-2);}
.md ul, .md ol{padding-left:20px; margin-bottom:10px;}
.md blockquote{border-left:3px solid var(--accent); padding:8px 14px; margin:14px 0;
  color:var(--text); background:color-mix(in srgb, var(--accent) 8%, transparent);
  border-radius:0 10px 10px 0;}
.md blockquote p{color:var(--text);}
.md strong{color:var(--text); font-weight:700;}
.md em{color:var(--accent-soft);}
.md hr{border:none; border-top:1px solid var(--border); margin:20px 0;}
.md table{width:100%; border-collapse:collapse; font-size:12.5px; margin:12px 0; display:block; overflow-x:auto;}
.md th{font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted);}
.md th, .md td{border:1px solid var(--border); padding:7px 9px; text-align:left;}
.md code{background:var(--surface-2); padding:1px 6px; border-radius:5px; font-family:var(--mono); font-size:.85em;}
.md a{color:var(--accent);}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  .bcard, .bar > i, button.primary, nav.tabs a{transition:none;}
}
