/* ============================================================================
   JARVIS scriptorium — design system "Scriptorium"
   Obsidiana quente sepia + ouro velho/ambar. Corpo serifado (Newsreader) para
   leitura longa noturna. Filete ambar de 2px como motivo unificador de orientacao.
   ============================================================================ */
:root{
  /* base — obsidiana quente, nao azul */
  --bg-0:#0c0a08; --bg-1:#13100c; --bg-2:#1b1712; --bg-3:#241e17; --bg-inset:#080705;
  /* linhas / bordas */
  --line-1:#2a231a; --line-2:#3a3022; --line-3:#4d3f29;
  /* texto — papel envelhecido, nunca branco puro */
  --ink:#ece3d4; --ink-strong:#fbf6ec; --ink-mut:#a89a82; --ink-faint:#6f6450;
  /* brand — ouro velho / ambar de luminaria */
  --gold:#c9a24b; --gold-bright:#e6c068; --amber:#d98b3a; --ember:#b5562f;
  /* acentos frios de apoio (parcimonia) */
  --sage:#7fa07a; --slate:#7c93a8;
  /* semanticos */
  --ok:#86b06f; --warn:#dba43c; --err:#cf6a52;
  /* sintaxe — paleta quente custom dessaturada (sem tema pronto / AI-slop) */
  --syn-base:#cdd6c0; --syn-key:#d98b3a; --syn-str:#9fae6a; --syn-num:#c9a24b; --syn-com:#6f6450; --syn-fn:#e6c068; --syn-punc:#a89a82;
  --syn-var:#d8b88a; --syn-attr:#c9a24b; --syn-type:#c49a78; --syn-meta:#8a7a5e; --syn-add:#86b06f; --syn-del:#cf6a52;
  /* tipografia */
  --disp:'Fraunces',Georgia,'Times New Roman',serif;
  --read:'Newsreader',Georgia,serif;
  --mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',monospace;
  /* medida / raio / sombra / glow */
  /* largura da coluna em rem (NAO em ch): fixa em px, nao escala com o zoom do texto,
     entao o zoom reduz/aumenta so o texto e a coluna segue aproveitando o painel */
  --measure:47rem; --measure-wide:62rem;
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:22px; --r-pill:999px;
  --shadow-card:0 1px 0 rgba(255,236,200,.03) inset, 0 18px 50px -28px rgba(0,0,0,.85);
  --shadow-pop:0 30px 80px -32px rgba(0,0,0,.9);
  --glow-gold:0 0 0 1px rgba(201,162,75,.22), 0 8px 28px -10px rgba(201,162,75,.28);
  --ease:cubic-bezier(.2,.7,.3,1);
  --radius:var(--r-lg);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(900px 600px at 85% -10%, rgba(217,139,58,.05), transparent 55%),
    radial-gradient(760px 560px at -6% 4%, rgba(201,162,75,.04), transparent 50%),
    var(--bg-0);
  color:var(--ink);font-family:var(--read);font-size:15px;line-height:1.6;min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
/* grain + vinheta de luminaria */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.025;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;box-shadow:inset 0 0 220px 40px rgba(0,0,0,.5)}
a{color:inherit;text-decoration:none}
b{color:var(--gold-bright);font-weight:600}
::selection{background:rgba(201,162,75,.25);color:var(--ink-strong)}
:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-1)}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--line-3)}

/* ---------- topbar ---------- */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:22px;padding:13px 24px;
  background:rgba(12,10,8,.85);backdrop-filter:blur(16px) saturate(120%);border-bottom:1px solid var(--line-1);
  transition:transform .25s ease}
.topbar.tb-hidden{transform:translateY(-100%)}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{display:grid;place-items:center;width:32px;height:32px;border-radius:9px;
  background:radial-gradient(circle at 30% 25%,#2a2014,#13100c);border:1px solid var(--line-3);
  color:var(--gold-bright);font-family:var(--disp);font-style:italic;font-weight:500;font-size:18px}
.brand-mark.big{width:54px;height:54px;border-radius:15px;font-size:30px}
.brand-name{font-family:var(--disp);font-weight:500;letter-spacing:.2px;font-size:16px;color:var(--ink-strong)}
.brand-name b{font-family:var(--mono);font-weight:400;font-size:12px;color:var(--ink-faint)}
.nav{display:flex;gap:2px;flex-wrap:wrap;flex:1}
.nav-tab{font-family:var(--disp);font-weight:500;font-size:14px;color:var(--ink-mut);padding:8px 12px;
  border-radius:0;transition:.18s var(--ease);white-space:nowrap;box-shadow:inset 0 -2px 0 transparent}
.nav-tab:hover{color:var(--ink);background:var(--bg-2)}
.nav-tab.on{color:var(--gold-bright);box-shadow:inset 0 -2px 0 var(--amber)}
.topbar-right{display:flex;align-items:center;gap:12px}
.who{color:var(--ink-faint);font-size:12px;font-family:var(--mono)}
.logout{padding:7px 13px;border-radius:var(--r-sm);font-size:12px;font-weight:500;color:var(--ink-mut);
  font-family:var(--mono);border:1px solid var(--line-2);transition:.18s var(--ease)}
.logout:hover{color:var(--ember);border-color:var(--ember)}

.page{max-width:1240px;margin:0 auto;padding:34px 24px 90px;position:relative;z-index:1}

/* ---------- login ---------- */
.login-body{display:grid;place-items:center;min-height:100vh;overflow:hidden;position:relative}
.login-orbits{position:fixed;inset:0;pointer-events:none;z-index:0}
.login-orbits i{position:absolute;border-radius:50%;filter:blur(70px);opacity:.4}
.login-orbits i:nth-child(1){width:480px;height:480px;background:#1a130a;top:-120px;right:-90px}
.login-orbits i:nth-child(2){width:420px;height:420px;background:#170d08;bottom:-130px;left:-80px}
.login-orbits i:nth-child(3){width:300px;height:300px;background:#1f1206;bottom:10%;right:14%;opacity:.3}
.login-wrap{position:relative;z-index:1;width:100%;max-width:404px;padding:24px}
.login-card{background:linear-gradient(180deg,var(--bg-1),var(--bg-inset));border:1px solid var(--line-2);
  border-top:1px solid var(--gold);border-radius:var(--r-xl);padding:42px 36px 30px;
  box-shadow:var(--shadow-pop),0 -1px 18px -8px rgba(201,162,75,.4);text-align:center}
.login-logo{display:flex;justify-content:center;margin-bottom:18px}
.login-title{font-family:var(--disp);font-weight:500;font-size:32px;letter-spacing:.2px;color:var(--ink-strong)}
.login-title b{font-style:italic;font-weight:500;color:var(--gold-bright)}
.login-sub{color:var(--ink-mut);font-size:14px;margin:8px 0 24px;font-family:var(--read)}
.login-err{background:rgba(207,106,82,.12);border:1px solid rgba(207,106,82,.4);color:#e89685;
  padding:9px 12px;border-radius:var(--r-md);font-size:13px;margin-bottom:16px}
.login-form{display:flex;flex-direction:column;gap:15px;text-align:left}
.field{display:flex;flex-direction:column;gap:6px}
.field-label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint)}
.field-input{background:var(--bg-inset);border:1px solid var(--line-2);border-radius:var(--r-md);
  padding:12px 14px;color:var(--ink);font-size:15px;font-family:var(--read);transition:.18s var(--ease)}
.field-input:focus{outline:none;border-color:var(--line-3);box-shadow:var(--glow-gold)}
.login-btn{margin-top:6px;padding:13px;border:none;border-radius:var(--r-md);cursor:pointer;
  background:linear-gradient(180deg,var(--gold-bright),var(--amber));color:var(--bg-0);
  font-family:var(--disp);font-weight:600;font-size:16px;transition:.18s var(--ease)}
.login-btn:hover{filter:brightness(1.06);box-shadow:var(--glow-gold);transform:translateY(-1px)}
.login-btn:active{transform:translateY(0)}
.login-foot{margin-top:18px;color:var(--ink-faint);font-size:12px;font-family:var(--mono)}

/* ---------- dashboard ---------- */
.hero{margin-bottom:34px}
.hero-live{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--sage);margin-bottom:16px}
.hero-live i{width:8px;height:8px;border-radius:50%;background:var(--sage);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(127,160,122,.5)}70%{box-shadow:0 0 0 9px rgba(127,160,122,0)}100%{box-shadow:0 0 0 0 rgba(127,160,122,0)}}
.hero-title{font-family:var(--disp);font-weight:500;font-size:52px;letter-spacing:-.01em;line-height:1.05;color:var(--ink-strong)}
.hero-title b{font-style:italic;font-weight:500;color:var(--gold-bright)}
.hero-sub{color:var(--ink-mut);font-size:17px;margin-top:10px;font-family:var(--read)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}
.card{position:relative;display:flex;flex-direction:column;gap:8px;
  background:linear-gradient(180deg,var(--bg-1),var(--bg-inset));border:1px solid var(--line-1);
  border-radius:var(--r-lg);padding:22px;transition:.18s var(--ease);overflow:hidden;min-height:196px}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--gold);opacity:0;transition:.18s var(--ease)}
.card:hover{transform:translateY(-3px);border-color:var(--line-3);box-shadow:var(--shadow-card)}
.card:hover::before{opacity:1}
.card-icon{width:42px;height:42px;color:var(--gold)}
.card-icon svg{width:100%;height:100%}
.card-tag{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.13em;color:var(--ink-faint)}
.card-title{font-family:var(--disp);font-size:21px;font-weight:600;margin-top:2px;color:var(--ink-strong)}
.card-desc{color:var(--ink-mut);font-size:14px;flex:1;font-family:var(--read);line-height:1.55}
.card-go{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--gold-bright);margin-top:6px;letter-spacing:.04em}
.accent-brand .card-icon{color:var(--gold)} .accent-brand::before{background:var(--gold)}
.accent-viol .card-icon{color:var(--amber)} .accent-viol::before{background:var(--amber)}
.accent-ok .card-icon{color:var(--sage)} .accent-ok::before{background:var(--sage)}
.accent-amber .card-icon{color:var(--ember)} .accent-amber::before{background:var(--ember)}

/* ---------- vault layout ---------- */
.vault-layout{display:grid;grid-template-columns:296px minmax(0,1fr);gap:18px;align-items:start}
.vault-layout.with-toc{grid-template-columns:296px minmax(0,1fr) 204px}
/* sidebar = carrossel de 2 telas full-height (swipe em qualquer area + dots fixos no rodape) */
.vault-side{position:sticky;top:78px;height:calc(100vh - 104px);background:var(--bg-1);border:1px solid var(--line-1);
  border-radius:var(--r-lg);padding:0;overflow:hidden;display:block}
.vc-track{display:flex;height:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  touch-action:pan-x;overscroll-behavior-x:contain;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}
.vc-track::-webkit-scrollbar{display:none}
.vc-screen{flex:0 0 100%;width:100%;height:100%;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;min-width:0}
.vc-screen-fixed{flex:0 0 auto;padding:14px 14px 10px;display:flex;flex-direction:column;gap:9px;border-bottom:1px solid var(--line-1);background:var(--bg-1)}
.vc-screen-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;touch-action:pan-y;overscroll-behavior-y:contain;
  -webkit-overflow-scrolling:touch;padding:8px 14px 56px;scrollbar-width:thin}
.vc-screen-scroll::-webkit-scrollbar{width:6px}
.vc-screen-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:6px}
.vc-screen-fixed #vaultSearch{width:100%;background:var(--bg-inset);border:1px solid var(--line-2);border-radius:var(--r-md);
  padding:10px 12px;color:var(--ink);font-size:13.5px;font-family:var(--read);transition:.18s var(--ease);-webkit-tap-highlight-color:transparent}
.vc-screen-fixed #vaultSearch:focus{outline:none;border-color:var(--line-3);box-shadow:var(--glow-gold)}
.vc-screen-fixed #vaultSearch::placeholder{color:var(--ink-faint)}
.vc-screen .vr-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-faint)}
.vc-recent{display:flex;flex-direction:column;gap:7px}
.vr-list{display:flex;flex-direction:column;gap:2px}
.vr-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 9px;border:1px solid transparent;border-radius:var(--r-sm);
  background:transparent;cursor:pointer;text-align:left;font-family:inherit;transition:.14s var(--ease)}
.vr-item:hover{background:var(--bg-2);border-color:var(--line-1)}
.vr-item .vr-ico{flex-shrink:0;height:15px;color:var(--gold)}
.vr-item .vr-ico svg{width:15px;height:15px}
.vr-item .vr-name{flex:1;min-width:0;font-family:var(--read);font-size:13px;line-height:1.3;color:var(--ink-mut);word-break:break-word}
.vr-item:hover .vr-name{color:var(--ink-strong)}
.vr-item .vr-time{flex-shrink:0;font-family:var(--mono);font-size:10px;color:var(--ink-faint)}
.vr-empty{font-family:var(--mono);font-size:11px;color:var(--ink-faint);padding:8px 2px}
.tree-item,.vr-item,.vc-dot{touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.tree-item:active,.vr-item:active{background:var(--bg-2)}
/* dots overlay fixos no rodape, com gradiente que funde no casco */
.vc-dots{position:absolute;left:0;right:0;bottom:0;z-index:5;display:flex;align-items:flex-end;justify-content:center;gap:10px;
  height:52px;padding-bottom:12px;pointer-events:none;background:linear-gradient(to top,var(--bg-1) 0%,rgba(19,16,12,.92) 45%,rgba(19,16,12,0) 100%)}
.vc-dot{pointer-events:auto;position:relative;width:34px;height:34px;display:grid;place-items:center;background:transparent;border:none;padding:0;cursor:pointer}
.vc-dot::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--line-3);transition:.22s var(--ease)}
.vc-dot.on::before{width:20px;height:7px;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--gold),var(--amber))}
.vc-dot:hover::before{background:var(--gold-bright)}
.vault-crumbs{font-family:var(--mono);font-size:12px;color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.vault-crumbs a{color:var(--ink-mut);transition:.15s}
.vault-crumbs a:hover{color:var(--gold-bright)}
.vault-crumbs .sep{color:var(--line-3)}
.vault-tree{margin:0;padding:0}
.tree-item{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:var(--r-sm);cursor:pointer;
  font-family:var(--read);font-size:14.5px;color:var(--ink-mut);transition:.15s var(--ease);user-select:none;
  box-shadow:inset 0 0 0 transparent}
.tree-item:hover{background:var(--bg-2);color:var(--ink)}
.tree-item.on[data-type="dir"]{color:var(--ink)}
.tree-item.on[data-type="file"]{color:var(--gold-bright);
  background:linear-gradient(90deg,rgba(201,162,75,.14),transparent 75%);box-shadow:inset 2px 0 var(--amber)}
.tree-item .ico{width:15px;height:15px;flex-shrink:0;opacity:.85}
.tree-item .ico-md{color:var(--gold);opacity:1}
.tree-item .nm{word-break:break-word}
.tree-children{margin-left:13px;border-left:1px solid var(--line-1);padding-left:5px}
.tree-meta{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--ink-faint);flex-shrink:0}

.vault-main{position:relative;background:var(--bg-1);border:1px solid var(--line-1);border-radius:var(--r-lg);
  height:calc(100vh - 104px);display:flex;flex-direction:column;overflow:hidden}
.read-progress{position:sticky;top:0;left:0;height:2px;width:0;z-index:5;
  background:linear-gradient(90deg,var(--gold),var(--amber));transition:width .08s linear}
.vault-doc-head{padding:16px 24px;border-bottom:1px solid var(--line-1);display:none;flex-wrap:wrap;align-items:center;gap:10px 12px}
.vault-doc-head.show{display:flex}
.vault-doc-head .dh-title{font-family:var(--disp);font-weight:500;font-size:17px;color:var(--ink-strong);flex:1 1 auto;min-width:0;overflow-wrap:anywhere;word-break:normal}
.vault-doc-head .dh-meta{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-faint);display:flex;gap:10px;flex-shrink:0}
.vault-doc-head .dh-dl{padding:6px 11px;border:1px solid var(--line-2);border-radius:var(--r-md);font-family:var(--mono);
  font-size:12px;color:var(--ink-mut);background:transparent;cursor:pointer;line-height:1.4;transition:.18s var(--ease)}
.vault-doc-head .dh-dl:hover{color:var(--gold-bright);border-color:var(--line-3)}
.vault-doc-head .dh-dl.ok{color:var(--ok);border-color:var(--ok)}
.vault-doc{--read-zoom:1;padding:28px 30px;overflow:auto;flex:1;scroll-behavior:smooth}
.vault-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:14px;color:var(--ink-faint);min-height:50vh}
.vault-empty-mark{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;font-family:var(--disp);
  font-style:italic;font-weight:500;font-size:30px;color:var(--gold-bright);
  background:radial-gradient(circle at 30% 25%,#2a2014,#13100c);border:1px solid var(--line-3);opacity:.7}
.vault-loading{color:var(--ink-mut);font-family:var(--mono);font-size:13px;padding:20px}

/* ---------- frontmatter — dossier strip ---------- */
.fm-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;
  background:var(--line-1);border:1px solid var(--line-1);border-radius:var(--r-md);overflow:hidden;margin:0 auto 32px;max-width:var(--measure-wide)}
.fm-strip .cell{background:var(--bg-1);padding:10px 14px}
.fm-strip .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-faint)}
.fm-strip .v{font-family:var(--read);font-size:14px;color:var(--ink);margin-top:3px;word-break:break-word}
.fm-strip .v .tag{display:inline-block;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:1px 8px;margin:1px 4px 1px 0;font-family:var(--mono);font-size:11.5px;color:var(--gold)}
.fm-strip .v.status-active{color:var(--sage)} .fm-strip .v.status-draft{color:var(--amber)}
.fm-strip .v.status-archived{color:var(--ink-faint)} .fm-strip .v.status-concluded{color:var(--gold-bright)}
.fm-raw{max-width:var(--measure-wide);margin:-20px auto 24px}
.fm-raw summary{cursor:pointer;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint);padding:6px 0}
.fm-raw pre{margin-top:8px;background:var(--bg-inset);color:var(--amber);font-family:var(--mono);font-size:12px;
  white-space:pre-wrap;line-height:1.55;padding:12px 14px;border-radius:var(--r-md)}

/* ---------- TOC ---------- */
.doc-toc{position:sticky;top:96px;align-self:start;width:220px;max-height:calc(100vh - 130px);overflow:auto;
  font-family:var(--read);font-size:13px;padding-left:14px;border-left:1px solid var(--line-1)}
.doc-toc .toc-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-faint);margin-bottom:12px}
.doc-toc a{display:block;padding:4px 0 4px 10px;margin-left:-14px;color:var(--ink-faint);border-left:2px solid transparent;line-height:1.4;transition:.18s var(--ease)}
.doc-toc a.h3{padding-left:24px;font-size:.92em}
.doc-toc a:hover{color:var(--ink-mut)}
.doc-toc a.active{color:var(--gold-bright);border-left-color:var(--amber)}
.doc-top{position:fixed;right:18px;bottom:66px;width:40px;height:40px;border-radius:var(--r-pill);display:none;
  place-items:center;background:var(--bg-2);border:1px solid var(--line-3);color:var(--gold);cursor:pointer;
  box-shadow:var(--shadow-card);transition:.18s var(--ease);z-index:20}
.doc-top.show{display:grid}
.doc-top:hover{color:var(--gold-bright);transform:translateY(-2px)}

/* ---------- controle de zoom de leitura (canto inferior direito) ---------- */
.read-zoom{position:fixed;right:18px;bottom:18px;z-index:21;display:none;align-items:center;gap:2px;padding:4px;
  border-radius:var(--r-pill);background:rgba(27,23,18,.92);border:1px solid var(--line-3);box-shadow:var(--shadow-card);
  backdrop-filter:blur(10px) saturate(120%);font-family:var(--mono);transition:.18s var(--ease)}
.read-zoom.show{display:inline-flex}
.read-zoom{touch-action:manipulation}
.read-zoom button{display:grid;place-items:center;height:28px;background:transparent;border:none;color:var(--ink-mut);
  cursor:pointer;font-family:var(--mono);border-radius:var(--r-pill);transition:.15s var(--ease);
  touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}
.read-zoom .rz-step{width:28px;font-size:17px;line-height:1}
.read-zoom .rz-val{min-width:48px;padding:0 6px;font-size:12px;font-weight:500;color:var(--gold);letter-spacing:.02em;font-variant-numeric:tabular-nums}
.read-zoom button:hover:not(:disabled){color:var(--gold-bright);background:var(--bg-3)}
.read-zoom button:disabled{opacity:.3;cursor:default}
.read-zoom .rz-sep{width:1px;height:14px;background:var(--line-2);margin:0 1px;flex-shrink:0}
@media(max-width:880px){.read-zoom{right:12px;bottom:12px}.doc-top{right:12px;bottom:60px}}

/* ---------- popover de link no documento (ver URL + copiar / abrir em nova guia) ---------- */
.link-pop-backdrop{position:fixed;inset:0;z-index:58}
.link-pop-backdrop.dim{background:rgba(8,6,4,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.link-pop{position:fixed;top:0;left:0;z-index:60;max-width:min(384px,calc(100vw - 20px));
  opacity:0;transform:translateY(-4px) scale(.985);transition:opacity .16s var(--ease),transform .16s var(--ease)}
.link-pop.show{opacity:1;transform:none}
.link-pop .lp-card{background:var(--bg-2);border:1px solid var(--line-3);border-radius:var(--r-lg);
  box-shadow:var(--shadow-pop);padding:12px;display:flex;flex-direction:column;gap:11px}
.lp-head{display:flex;align-items:center;gap:8px}
.lp-kind{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--gold)}
.lp-x{margin-left:auto;width:26px;height:26px;display:grid;place-items:center;background:transparent;border:none;
  color:var(--ink-faint);font-size:21px;line-height:1;cursor:pointer;border-radius:var(--r-sm);transition:.15s var(--ease)}
.lp-x:hover{color:var(--ink-strong);background:var(--bg-3)}
.lp-url{font-family:var(--mono);font-size:12px;line-height:1.5;color:var(--ink-mut);background:var(--bg-inset);
  border:1px solid var(--line-1);border-radius:var(--r-md);padding:8px 10px;overflow-wrap:anywhere;word-break:break-word;
  max-height:104px;overflow-y:auto;user-select:all;-webkit-user-select:all}
.lp-actions{display:flex;gap:8px}
.lp-btn{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:7px;padding:10px 8px;
  border-radius:var(--r-md);font-family:var(--read);font-size:13px;line-height:1.2;cursor:pointer;border:1px solid var(--line-2);
  transition:.15s var(--ease);-webkit-tap-highlight-color:transparent;white-space:nowrap}
.lp-btn svg{width:15px;height:15px;flex-shrink:0}
.lp-copy{background:transparent;color:var(--ink-mut)}
.lp-copy:hover{color:var(--gold-bright);border-color:var(--line-3)}
.lp-copy.ok{color:var(--ok);border-color:var(--ok)}
.lp-open{background:linear-gradient(180deg,var(--gold),var(--amber));color:#1a1410;border-color:transparent;font-weight:600}
.lp-open:hover{filter:brightness(1.07)}
.lp-open:active{filter:brightness(.96)}
@media(max-width:640px){
  .link-pop.sheet{top:auto;left:0;right:0;bottom:0;max-width:none;transform:translateY(100%)}
  .link-pop.sheet.show{transform:none}
  .link-pop.sheet .lp-card{border-radius:var(--r-lg) var(--r-lg) 0 0;border-bottom:none;
    padding:16px 16px calc(16px + env(safe-area-inset-bottom,0px))}
  .link-pop.sheet .lp-url{font-size:12.5px;max-height:140px}
  .link-pop.sheet .lp-btn{padding:13px 10px;font-size:14px}
}

/* ============================================================================
   .md — corpo de leitura (o coracao)
   ============================================================================ */
.md{font-family:var(--read);font-size:calc(17px * var(--read-zoom, 1));line-height:1.75;color:var(--ink);max-width:var(--measure);
  margin-inline:auto;font-feature-settings:"liga" 1,"onum" 1,"kern" 1;text-rendering:optimizeLegibility;animation:doc-in .22s ease}
@keyframes doc-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.md>h1,.md>h2,.md>h3,.md>h4,.md>h5,.md>h6,.md h1,.md h2,.md h3,.md h4,.md h5,.md h6{
  font-family:var(--disp);color:var(--ink-strong);letter-spacing:-.01em;text-wrap:balance;scroll-margin-top:88px;position:relative}
.md h1{font-size:2.45em;font-weight:500;margin:0 0 .5em;padding-bottom:.3em;border-bottom:1px solid var(--line-2);line-height:1.12}
.md h2{font-size:1.75em;font-weight:500;margin:2.2em 0 .55em;line-height:1.12}
.md h2::before{content:"";position:absolute;left:-1.2rem;top:.18em;width:3px;height:.72em;background:var(--amber);border-radius:1px}
.md h3{font-size:1.35em;font-weight:600;color:var(--gold-bright);margin:1.7em 0 .45em;line-height:1.25}
.md h4{font-size:1.12em;font-weight:600;color:var(--ink-strong);margin:1.4em 0 .4em;line-height:1.25}
.md h5{font-size:1em;font-weight:500;font-style:italic;color:var(--ink-mut);margin:1.3em 0 .3em}
.md h6{font-family:var(--mono);font-size:.76em;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint);margin:1.2em 0 .3em}
.md .anchor{position:absolute;left:-1.5em;top:.05em;color:var(--line-3);font-weight:400;opacity:0;transition:.15s;padding-right:.3em;text-decoration:none}
.md h1:hover .anchor,.md h2:hover .anchor,.md h3:hover .anchor,.md h4:hover .anchor{opacity:1}
.md .anchor:hover{color:var(--gold-bright)}
.md p{margin:0 0 1.15em}
.md>h1+p{font-size:19px;color:var(--ink-strong);line-height:1.6}
.md strong{color:var(--ink-strong);font-weight:600}
.md em{font-style:italic}
.md code{font-family:var(--mono);font-size:.88em;color:var(--amber);background:var(--bg-inset);
  border:1px solid var(--line-1);border-radius:var(--r-sm);padding:.1em .42em;font-feature-settings:"liga" 0;word-break:break-word}
.md pre{position:relative;margin:1.5em 0;max-width:var(--measure-wide);background:var(--bg-inset);
  border:1px solid var(--line-2);border-radius:var(--r-md);padding:0;overflow:hidden;box-shadow:inset 0 1px 0 rgba(0,0,0,.4)}
.md pre::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--amber))}
.md pre code{display:block;padding:16px 18px;overflow-x:auto;font-family:var(--mono);font-size:.8em;
  line-height:1.6;color:var(--syn-base);background:none;border:none;-moz-tab-size:2;tab-size:2}
.md pre[data-lang]::before{content:attr(data-lang);display:block;padding:6px 14px;font-family:var(--mono);font-size:10.5px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint);background:var(--bg-1);border-bottom:1px solid var(--line-1)}
.md .code-copy{position:absolute;top:5px;right:8px;font-family:var(--mono);font-size:11px;color:var(--ink-faint);
  background:transparent;border:1px solid var(--line-1);border-radius:var(--r-sm);padding:2px 8px;cursor:pointer;opacity:0;transition:.15s;z-index:2}
.md pre:hover .code-copy{opacity:1}
.md .code-copy:hover{color:var(--gold-bright);border-color:var(--line-3)}
.md .code-copy.ok{color:var(--ok);border-color:var(--ok);opacity:1}
/* syntax highlighting (highlight.js -> vars de marca) */
.md pre code.hljs{color:var(--syn-base)}
.md .hljs-comment,.md .hljs-quote{color:var(--syn-com);font-style:italic}
.md .hljs-keyword,.md .hljs-selector-tag,.md .hljs-operator,.md .hljs-literal,.md .hljs-section{color:var(--syn-key)}
.md .hljs-string,.md .hljs-regexp,.md .hljs-char.escape_,.md .hljs-meta .hljs-string{color:var(--syn-str)}
.md .hljs-number,.md .hljs-symbol,.md .hljs-bullet{color:var(--syn-num)}
.md .hljs-title,.md .hljs-title.function_,.md .hljs-title.class_{color:var(--syn-fn)}
.md .hljs-variable,.md .hljs-params,.md .hljs-template-variable{color:var(--syn-var)}
.md .hljs-attr,.md .hljs-attribute,.md .hljs-property,.md .hljs-selector-attr,.md .hljs-selector-pseudo,.md .hljs-selector-class,.md .hljs-selector-id{color:var(--syn-attr)}
.md .hljs-type,.md .hljs-built_in,.md .hljs-class .hljs-title,.md .hljs-builtin-name,.md .hljs-name{color:var(--syn-type)}
.md .hljs-punctuation,.md .hljs-tag{color:var(--syn-punc)}
.md .hljs-meta,.md .hljs-comment.doctag,.md .hljs-meta .hljs-keyword{color:var(--syn-meta)}
.md .hljs-addition{color:var(--syn-add);background:rgba(134,176,111,.08)}
.md .hljs-deletion{color:var(--syn-del);background:rgba(207,106,82,.08)}
.md .hljs-emphasis{font-style:italic}
.md .hljs-strong{font-weight:600;color:var(--ink-strong)}
.md .hljs-link{color:var(--gold-bright);text-decoration:underline}
.md .md-tablewrap{overflow-x:auto;margin:1.5em 0;max-width:var(--measure-wide);border:1px solid var(--line-1);border-radius:var(--r-md)}
.md table{border-collapse:separate;border-spacing:0;width:100%;font-family:var(--read);font-size:.85em}
.md thead th{position:sticky;top:0;z-index:1;background:var(--bg-3);color:var(--ink-strong);font-family:var(--disp);
  font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:10px 14px;border-bottom:2px solid var(--line-3)}
.md td{padding:9px 14px;border-bottom:1px solid var(--line-1);color:var(--ink)}
.md td:first-child{color:var(--ink-strong)}
.md tbody tr:nth-child(even){background:rgba(201,162,75,.035)}
.md tbody tr:hover{background:var(--bg-2)}
.md td,.md th{font-variant-numeric:tabular-nums}
.md blockquote{margin:1.5em 0;padding:.6em 1.2em;border-left:3px solid var(--gold);
  background:linear-gradient(90deg,rgba(201,162,75,.06),transparent 70%);color:var(--ink-mut);font-style:italic}
.md blockquote p{margin:.4em 0}
.md blockquote strong{color:var(--gold-bright);font-style:normal}
.md ul{list-style:none;padding-left:1.5em;margin:0 0 1.15em}
.md ul>li{position:relative;margin:.4em 0;line-height:1.7}
.md ul>li::before{content:"◆";position:absolute;left:-1.2em;top:.05em;font-size:.6em;color:var(--gold)}
.md ol{list-style:none;counter-reset:li;padding-left:1.6em;margin:0 0 1.15em}
.md ol>li{counter-increment:li;position:relative;margin:.4em 0;line-height:1.7}
.md ol>li::before{content:counter(li)".";position:absolute;left:-1.7em;width:1.4em;text-align:right;font-family:var(--mono);font-size:.85em;color:var(--gold-bright)}
.md li>ul,.md li>ol{margin:.3em 0}
.md ul ul>li::before{content:"·";color:var(--ink-faint)}
.md a{color:var(--gold-bright);text-decoration:underline;text-decoration-color:var(--line-3);
  text-underline-offset:3px;text-decoration-thickness:1px;transition:.12s}
.md a:hover{text-decoration-color:var(--gold-bright);background:rgba(230,192,104,.08);border-radius:3px}
.md a[href^="http"]::after{content:"↗";font-size:.7em;margin-left:.15em;color:var(--ink-faint);vertical-align:.3em}
.md a.wikilink{color:var(--slate);text-decoration-color:rgba(124,147,168,.4)}
.md a.wikilink::before{content:"↳ ";color:var(--slate)}
.md a.wikilink::after{content:none}
.md img{display:block;max-width:100%;margin:1.5em auto;border-radius:var(--r-md);border:1px solid var(--line-1);box-shadow:var(--shadow-card)}
.md img+em{display:block;text-align:center;font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin-top:-.8em}
.md hr{border:none;height:1px;width:40%;margin:2.6em auto;background:linear-gradient(90deg,transparent,var(--line-3),transparent)}

/* ---------- viewers nao-md ---------- */
.codeblock{background:var(--bg-inset);border:1px solid var(--line-2);border-radius:var(--r-md);padding:16px;
  font-family:var(--mono);font-size:calc(13px * var(--read-zoom,1));color:var(--syn-base);white-space:pre-wrap;overflow:auto;line-height:1.6}
.vault-img{max-width:100%;border-radius:var(--r-md);border:1px solid var(--line-1);display:block;margin:0 auto}
.vault-pdf{width:100%;height:calc(100vh - 200px);border:1px solid var(--line-1);border-radius:var(--r-md)}
.vault-binary{text-align:center;padding:50px 20px;color:var(--ink-mut);font-family:var(--read)}
.vault-binary a{display:inline-block;margin-top:14px;padding:10px 18px;border-radius:var(--r-md);
  background:linear-gradient(180deg,var(--gold-bright),var(--amber));color:var(--bg-0);font-family:var(--disp);font-weight:600}

/* ---------- busca ---------- */
.search-results{display:flex;flex-direction:column;gap:2px;overflow:auto;flex:1}
.search-results .sr-empty{color:var(--ink-faint);font-family:var(--mono);font-size:12px;padding:10px}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
@media(max-width:1180px){.doc-toc{display:none}.vault-layout.with-toc{grid-template-columns:320px minmax(0,1fr)}}
@media(max-width:880px){
  .page{padding:20px 8px 70px}
  .vault-layout,.vault-layout.with-toc{grid-template-columns:1fr;gap:12px}
  .vault-side{position:relative;padding:0;height:70vh;height:70svh;min-height:420px;max-height:calc(100svh - 96px)}
  .vc-screen-fixed{padding:12px 12px 9px}
  .vc-screen-scroll{padding:8px 10px 56px}
  .vr-item{padding:11px 10px}
  .tree-item{padding:10px 8px}
  .vault-main{height:auto;min-height:70vh}
  .vault-doc-head{align-items:flex-start;padding:14px 14px}
  .vault-doc-head .dh-title{flex:1 1 100%;font-size:16px}
  .vault-doc-head .dh-meta{margin-left:0;flex-wrap:wrap}
  .nav{order:3;width:100%}
  .topbar{flex-wrap:wrap;padding:11px 12px}
  .hero-title{font-size:38px}
  .vault-doc{padding:16px 12px}
}
@media print{
  .topbar,.vault-side,.doc-toc,.doc-top,.read-progress,.read-zoom,.code-copy,.anchor,.fm-raw,.vault-doc-head .dh-dl{display:none!important}
  body::before,body::after{display:none!important}
  body{background:#fff!important;color:#111!important}
  .page{max-width:none;padding:0}
  .vault-layout,.vault-layout.with-toc{display:block}
  .vault-main{height:auto!important;overflow:visible!important;border:none;background:#fff}
  .vault-doc{height:auto!important;overflow:visible!important;padding:0}
  .vault-doc-head{border-color:#ccc}
  .md{max-width:none;font-size:12pt;color:#111!important}
  .md *{color:#111!important;background:transparent!important}
  .md a{color:#1a4f8a!important;text-decoration:underline}
  .md a[href^="http"]::after{content:" (" attr(href) ")";font-size:.8em;color:#555}
  .md h1,.md h2,.md h3{break-after:avoid}
  .md pre,.md table,.md blockquote,.md img,.md .md-tablewrap{break-inside:avoid;border:1px solid #ccc}
  .fm-strip,.fm-strip .cell{border-color:#ccc;background:#fff!important}
}
