*{box-sizing:border-box;margin:0;padding:0}
/* Versyr design tokens — see brand/Versyr Design System/colors_and_type.css for the source spec.
   D1: additive expansion of :root. --border2 is kept for back-compat; --border-2 is the new canonical name. */
:root{
  /* Core palette */
  --ink:#0A090C;--deep:#0A090C;--surface:#151217;--panel:#1C1520;
  --ember:#C8923A;--blood:#7A1414;
  --parchment:#F2EDE4;--parchment-body:#C8C0AE;
  --muted:#7A7068;--muted-dim:rgba(237,224,204,.65);--muted-dimmer:rgba(237,224,204,.45);
  /* Borders */
  --border:rgba(122,20,20,0.25);--border2:rgba(122,20,20,0.45);
  --border-2:rgba(122,20,20,0.45);--border-3:rgba(200,146,58,0.2);--border-soft:rgba(122,20,20,0.08);
  /* State colours (chips / status) */
  --ok:#7fcf7f;--ok-bg:rgba(42,92,42,.2);--ok-border:rgba(42,92,42,.4);
  --warn:#cfb060;--warn-bg:rgba(90,80,20,.15);--warn-border:rgba(90,80,20,.4);
  --error:#cf7070;--error-bg:rgba(122,20,20,.2);--error-border:rgba(122,20,20,.4);
  --info:#7aadcf;--info-bg:rgba(20,50,80,.2);--info-border:rgba(20,80,120,.3);
  --legendary:#cfb060;--uncommon:#7fcf7f;--rare:#7aadcf;--very-rare:#b07acf;
  /* Fonts */
  --font-display:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --font-body:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'DM Mono','SF Mono',Consolas,monospace;
  /* Type scale */
  --display-hero-size:72px;--display-hero-weight:300;--display-hero-ls:-0.02em;
  --h1-size:38px;--h1-weight:300;--h1-ls:-0.01em;
  --h2-size:22px;--h2-weight:300;--h2-ls:-0.005em;
  --h3-size:18px;--h3-weight:300;--h3-ls:-0.005em;
  --body-narrative-size:15px;--body-ui-size:13px;--pull-quote-size:24px;
  --label-size:10px;--label-ls:0.18em;
  --button-size:9px;--button-ls:0.12em;
  --nav-size:9px;--nav-ls:0.15em;
  --meta-size:10px;--meta-ls:0.15em;
  --chapter-size:10px;--chapter-ls:0.2em;
  /* Spacing */
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;
  --space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;
  /* Radii */
  --radius-sharp:1px;--radius-sm:2px;--radius-md:3px;--radius-round:50%;
  /* Elevation (depth is surface-step first, shadow rarely) */
  --shadow-modal:0 8px 40px rgba(0,0,0,.70);--shadow-lift:0 4px 20px rgba(0,0,0,.50);
  /* Motion */
  --t-fast:120ms ease;--t-base:150ms ease;--t-slow:200ms ease;
  /* Breakpoints + touch targets (consumed in D2) */
  --bp-phone:430px;--bp-tablet:834px;--bp-laptop:1200px;
  --touch-min:44px;--touch-ok:48px;
}
/* D2 — responsive token overrides. Display shrinks on small screens, narrative body grows,
   DM Mono labels tighten. Spec: colors_and_type.css @media blocks. Pure token layer —
   existing hardcoded sizes are unaffected until each rule is migrated to var(--...). */
@media (max-width:640px){
  :root{
    --display-hero-size:40px;
    --h1-size:26px;--h2-size:20px;--h3-size:17px;
    --pull-quote-size:18px;
    --body-narrative-size:17px;--body-ui-size:15px;
    --label-size:9px;--label-ls:0.16em;
    --button-size:10px;--button-ls:0.1em;
    --nav-size:9px;--meta-size:9px;--chapter-size:10px;
    --space-7:32px;--space-8:48px;--space-9:64px;
  }
}
@media (min-width:641px) and (max-width:1023px){
  :root{
    --display-hero-size:56px;
    --h1-size:32px;
    --body-narrative-size:16px;
  }
}
html[data-theme="light"]{--blood:#8A1A1A;--ember:#C8923A;--ink:#F5EFE3;--deep:#F5EFE3;--surface:#EDE4D0;--panel:#F8F2E4;--parchment:#1F1612;--parchment-body:#3A2E26;--muted:#6B5A3E;--border:rgba(138,26,26,0.25);--border2:rgba(138,26,26,0.5);--border-2:rgba(138,26,26,0.5)}
html[data-theme="hc"]{--blood:#FFFFFF;--ember:#FFEC00;--ink:#000000;--deep:#000000;--surface:#000000;--panel:#0A0A0A;--parchment:#FFFFFF;--parchment-body:#FFFFFF;--muted:#CCCCCC;--border:#FFFFFF;--border2:#FFFFFF;--border-2:#FFFFFF}
html[data-theme="hc"] .site-header::after,html[data-theme="hc"] .login-box::before{display:none}
html[data-theme="hc"] .cms-nav-item.active{border-left-color:#FFEC00 !important;background:#1A1A1A}
html[data-theme="hc"] .btn{border-width:2px}
html[data-theme="hc"] input,html[data-theme="hc"] textarea,html[data-theme="hc"] select{border-width:2px !important;background:#000 !important;color:#FFF !important}
html[data-theme="light"] body{color:var(--parchment)}
html[data-theme="light"] .cms-main{background:linear-gradient(160deg,#F8F2E4 0%,#EDE4D0 50%,#E0D4B8 100%)}
html[data-theme="light"] textarea,html[data-theme="light"] input[type=text],html[data-theme="light"] input[type=password],html[data-theme="light"] input[type=email],html[data-theme="light"] select{background:rgba(255,255,255,.6);color:var(--parchment)}
html[data-theme="light"] .output-box,html[data-theme="light"] .prompt-out{background:rgba(255,255,255,.5);color:var(--parchment)}
html[data-theme="light"] select option{background:#F8F2E4;color:#1F1612}
/* Light-theme text-color overrides — dark-theme hardcoded parchment (#C8C0AE / rgba(237,224,204,.X)) becomes unreadable on light bg. #3A2E26 is the Versyr 'quiet' brown-ink body colour on parchment. */
html[data-theme="light"] .post-body{color:#3A2E26}
html[data-theme="light"] .post-card-excerpt{color:rgba(58,46,38,.85)}
html[data-theme="light"] .char-pill{color:rgba(58,46,38,.85)}
html[data-theme="light"] .loot-item-desc{color:rgba(58,46,38,.85)}
html[data-theme="light"] .style-ref{color:rgba(58,46,38,.85)}
html[data-theme="light"] .lightbox-detail{color:rgba(58,46,38,.85)}
/* Primary buttons — --parchment semantically flips to dark on light theme, but solid scarlet bg needs light text for contrast. */
html[data-theme="light"] .btn.primary,html[data-theme="light"] .btn.primary:hover{color:#F5EFE3}
html[data-theme="light"] .btn:hover{color:#F5EFE3}
/* D1 brand primitives — Versyr wordmark (italic-ember "syr") + the signature 2px accent gradient bar. */
.versyr-wordmark{font-family:var(--font-display);font-weight:300;letter-spacing:-0.01em;color:var(--parchment)}
.versyr-wordmark em{font-style:italic;color:var(--ember)}
.v-accent-bar{height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
html{scroll-behavior:smooth}
body{background:var(--deep);font-family:'Outfit',sans-serif;color:var(--parchment);min-height:100vh}
/* HEADER */
.site-header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.site-header::after{content:'';display:block;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.header-inner{max-width:1100px;margin:0 auto;padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.site-brand{cursor:pointer}
.site-brand-name{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:300;letter-spacing:-0.005em;color:var(--parchment)}
.versyr-attribution{display:block;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:0.25em;text-transform:uppercase;color:#7A7068;margin-top:2px}
/* V monogram — hidden on desktop, shown in place of the campaign name at ≤1023px.
   Italic Cormorant V in ember matches the brand-identity spec for the favicon/watermark monogram. */
.site-brand-mono{display:none;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:26px;font-weight:500;color:var(--ember);line-height:1;letter-spacing:-0.02em}
.header-nav{display:flex;align-items:center;gap:1.5rem}
.nav-link{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);cursor:pointer;border:none;background:none;padding:.2rem 0;transition:color .15s}
.nav-link:hover,.nav-link.active{color:var(--ember)}
.public-hamburger{display:none;width:40px;height:40px;border-radius:2px;background:transparent;border:1px solid rgba(200,146,58,0.25);color:var(--ember);font-size:20px;font-family:var(--font-mono);cursor:pointer;padding:0;line-height:1;margin-right:.5rem}
.public-hamburger:hover,.public-hamburger:focus-visible{border-color:var(--ember);background:rgba(122,20,20,0.1);outline:none}
@media(max-width:1023px){
  body[data-view="blog"] .public-hamburger,
  body[data-view="post"] .public-hamburger,
  body[data-view="login"] .public-hamburger,
  body[data-view="gallery"] .public-hamburger{display:inline-flex;align-items:center;justify-content:center}
}
@media(max-width:640px){.public-hamburger{width:36px;height:36px;font-size:18px}}
.view-switch{font-family:var(--font-mono);font-size:16px;color:var(--ember);cursor:pointer;border:1px solid rgba(200,146,58,0.25);padding:0;width:40px;height:40px;border-radius:2px;background:transparent;display:inline-flex;align-items:center;justify-content:center}
.view-switch:hover,.view-switch:focus-visible{border-color:var(--ember);background:rgba(122,20,20,0.1);outline:none}
@media(max-width:640px){.view-switch{width:36px;height:36px;font-size:15px}}
.header-icon-btn{background:none;border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:3px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;padding:0;transition:all .15s;line-height:1}
.header-icon-btn:hover{color:var(--ember);border-color:var(--blood);background:rgba(122,20,20,.1)}
.header-icon-btn.bug{color:#cf7070}
.header-icon-btn.bug:hover{color:#e08080;border-color:#8A2020}
/* Avatar — sits inside the header on desktop (flexed at the right end of
   header-nav with the brand + nav-links). Tablet override below
   re-positions it as a fixed top-right floater since the header itself
   is hidden at that breakpoint. */
.user-avatar{display:inline-block;width:40px;height:40px;border-radius:50%;background:var(--ink);border:2px solid rgba(200,146,58,0.35);cursor:pointer;padding:0;background-size:cover;background-position:center;background-repeat:no-repeat;transition:border-color .15s}
.user-avatar:hover,.user-avatar:focus-visible{border-color:var(--ember);outline:none}
.user-avatar.user-avatar-anonymous{background-color:rgba(122,20,20,.18);border-color:rgba(122,108,88,.35);opacity:.85}
.user-avatar.user-avatar-anonymous:hover,.user-avatar.user-avatar-anonymous:focus-visible{border-color:var(--ember);opacity:1}
@media(max-width:640px){.user-avatar{width:36px;height:36px}}
.sync-dot{width:6px;height:6px;border-radius:50%;background:#555;display:inline-block;margin-left:4px;transition:background .3s}
.sync-dot.ok{background:#4CAF50}
.campaign-badge{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);border-radius:2px;padding:.2rem .5rem;display:none;white-space:nowrap}
.campaign-badge.visible{display:inline-block}
/* VIEWS */
#view-blog,#view-post,#view-cms,#view-login{display:none}
#view-blog{display:block}
/* BLOG */
.blog-hero{max-width:1100px;margin:0 auto;padding:3rem 2rem 2rem;display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;border-bottom:1px solid var(--border)}
.hero-text h1{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:var(--ember);letter-spacing:-0.01em;line-height:1.2}
.hero-text p{font-family:'DM Mono',serif;font-size:10px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-top:.5rem}
.hero-meta{font-family:'DM Mono',serif;font-size:10px;letter-spacing:.1em;color:var(--muted);text-align:right;line-height:1.8}
.hero-meta strong{color:var(--ember)}
.blog-layout{max-width:1100px;margin:0 auto;padding:2rem;display:grid;grid-template-columns:1fr 280px;gap:3rem}
.post-card{border-bottom:1px solid var(--border);padding:1.75rem 0;cursor:pointer;transition:border-color .15s}
.post-card:hover{border-bottom-color:var(--blood)}
.post-card:first-child{padding-top:0}
.post-card-num{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.2em;color:var(--blood);text-transform:uppercase}
.post-card-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:300;color:var(--parchment);letter-spacing:-0.01em;line-height:1.25;margin-top:.2rem;transition:color .15s}
.post-card:hover .post-card-title{color:var(--ember)}
.post-card-meta{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-top:.2rem}
.post-card-excerpt{font-size:var(--body-ui-size);color:var(--muted-dim);line-height:1.75;margin-top:.5rem}
.post-card-img{width:100%;height:160px;object-fit:cover;border:1px solid var(--border);margin-top:.75rem;filter:brightness(.85) sepia(.15)}
.sidebar-title{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.2em;color:var(--blood);text-transform:uppercase;margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}
.sidebar-widget{margin-bottom:2rem}
.sidebar-link{display:block;font-family:'DM Mono',serif;font-size:10px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;padding:.35rem 0;cursor:pointer;transition:color .15s;border-bottom:1px solid rgba(122,20,20,.08)}
.sidebar-link:hover{color:var(--ember)}
.char-pill{font-size:12px;color:rgba(237,224,204,.7);padding:.2rem 0;border-bottom:1px solid rgba(122,20,20,.08)}
.char-pill strong{color:var(--ember);font-style:normal;font-family:'DM Mono',serif;font-size:9px;letter-spacing:.06em;text-transform:uppercase;display:block}
/* CHRONICLE BRAND */
.site-footer{max-width:1100px;margin:0 auto;padding:2rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);margin-top:2rem}
.site-footer-brand{font-family:'Cormorant Garamond',serif;font-size:13px;font-style:italic;color:var(--ember)}
.site-footer-meta{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:#7A7068;text-align:right;line-height:2}
.site-footer-meta a{color:#7A7068;text-decoration:none}.site-footer-meta a:hover{color:var(--ember)}
.chron-brand-bar{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid rgba(200,146,58,0.2);margin-bottom:1.5rem}
.chron-campaign{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:300;color:var(--parchment);letter-spacing:-0.01em}
.chron-attribution{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:#7A7068}
.chron-attribution em{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:11px;color:var(--ember);text-transform:none;letter-spacing:0}
.chron-footer{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid rgba(200,146,58,0.15);display:flex;justify-content:space-between;align-items:center;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:#7A7068}
.chron-footer em{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:11px;color:var(--ember);text-transform:none;letter-spacing:0}
/* SINGLE POST */
.post-view{max-width:780px;margin:0 auto;padding:2rem 2rem 4rem;position:relative}
.post-view::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.post-gallery-section{margin:2.5rem 0 1.5rem;position:relative}
.post-gallery-accent{height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent);margin:0 0 1rem}
.post-gallery-heading{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:22px;color:var(--ember);margin:0 0 1rem;letter-spacing:.02em}
.post-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.post-gallery-card{display:block;cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:rgba(0,0,0,.25);transition:border-color .12s ease}
.post-gallery-card:hover{border-color:var(--ember)}
.post-gallery-card img{display:block;width:100%;height:160px;object-fit:cover;filter:brightness(.95) sepia(.05);margin:0;border:none;border-radius:0}
.post-gallery-caption{display:block;padding:.5rem .65rem;font-family:'DM Mono',ui-monospace,monospace;font-size:10px;letter-spacing:.04em;color:rgba(237,224,204,.8);background:rgba(0,0,0,.4);border-top:1px solid rgba(200,146,58,.15);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:768px){.post-gallery-grid{grid-template-columns:repeat(2,1fr)}.post-gallery-card img{height:140px}}
@media(max-width:480px){.post-gallery-grid{grid-template-columns:1fr}.post-gallery-card img{height:200px}}
.post-back{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;margin-bottom:1.5rem;transition:color .15s;border:none;background:none}
.post-back:hover{color:var(--ember)}
.post-header-img{width:100%;max-height:400px;object-fit:cover;border:1px solid var(--border);margin-bottom:2rem;filter:brightness(.8) sepia(.2)}
.post-num{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.2em;color:var(--blood);text-transform:uppercase;margin-bottom:.4rem}
.post-title{font-family:var(--font-display);font-size:var(--h1-size);font-weight:var(--h1-weight);color:var(--ember);letter-spacing:var(--h1-ls);line-height:1.1;margin-bottom:.5rem}
.post-date{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.post-body{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:400;line-height:1.85;color:#C8C0AE}
/* Inline images in chronicle / post bodies — unbounded width on a markdown <img>
   can make the page body wider than the viewport and overflow the sticky header.
   Clamp every body-embedded image to the text column width. */
.post-body img,.post-view img,.chron-body img{max-width:100%;height:auto;display:block;margin:1.25rem auto;border:1px solid var(--border);border-radius:var(--radius-sm);filter:brightness(.92) sepia(.08)}
.post-body p{margin-bottom:1.4rem}
.post-body h2{font-family:'DM Mono',serif;font-size:14px;letter-spacing:.12em;color:var(--ember);text-transform:uppercase;margin:2rem 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}
.post-body h3{font-family:'DM Mono',serif;font-size:12px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin:1.5rem 0 .5rem}
.post-body em{color:var(--muted);font-style:italic}
.post-body strong{color:var(--ember)}
.post-nav{display:flex;justify-content:space-between;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.post-nav-btn{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .15s;border:none;background:none}
.post-nav-btn:hover{color:var(--ember)}
/* LOGIN */
.login-screen{min-height:calc(100vh - 53px);display:flex;align-items:center;justify-content:center;padding:2rem}
.login-box{background:var(--panel);border:1px solid var(--border2);border-radius:3px;padding:2.5rem;width:100%;max-width:420px;position:relative}
.login-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.login-title{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ember);margin-bottom:.3rem;text-align:center}
.login-sub{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:2rem;text-align:center}
.login-error{background:rgba(122,20,20,.2);border:1px solid rgba(122,20,20,.4);border-radius:2px;padding:.6rem .85rem;font-size:12px;color:#cf7070;margin-bottom:1rem;display:none;font-family:'DM Mono',serif;letter-spacing:.05em}
/* CMS */
.cms-wrap{display:grid;grid-template-columns:210px 1fr;min-height:calc(100vh - 53px)}
.cms-sidebar{background:var(--surface);border-right:1px solid var(--border);padding:.5rem 0;overflow-y:auto}
.cms-user-bar{padding:.75rem 1rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}
.cms-user-name{font-family:'DM Mono',serif;font-size:10px;color:var(--ember)}
.cms-user-role{font-family:'DM Mono',serif;font-size:8px;color:var(--muted);letter-spacing:.06em;margin-top:2px}
.cms-sidebar-label{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.25em;color:var(--blood);text-transform:uppercase;padding:.5rem 1rem .2rem}
.cms-nav-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 1rem;cursor:pointer;font-family:'DM Mono',serif;font-size:9px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;border-left:2px solid transparent;transition:all .12s;border:none;background:none;width:100%;text-align:left}
.cms-nav-item:hover{color:var(--parchment);background:rgba(122,20,20,.1)}
.cms-nav-item.active{color:var(--ember);border-left-color:var(--ember);background:rgba(122,20,20,.12)}
.cms-divider{border:none;border-top:1px solid var(--border);margin:.3rem 0}
.cms-divider.cms-subdivider{margin:.2rem 1rem;opacity:.55}
.cms-main{overflow-y:auto;background:linear-gradient(160deg,#0E0606 0%,#120808 50%,#0A0505 100%);padding:1.5rem 2rem;max-width:900px}
.cms-page{display:none}.cms-page.active{display:block}
.cms-page-title{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--ember);letter-spacing:.08em;margin-bottom:.2rem}
.cms-page-sub{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:1.5rem}
/* FORMS */
.field{margin-bottom:1rem}
.field-label{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.18em;color:var(--blood);text-transform:uppercase;margin-bottom:.35rem;display:block}
textarea,input[type=text],input[type=password],input[type=email],select{width:100%;background:rgba(0,0,0,.45);border:1px solid var(--border);border-radius:2px;color:var(--parchment);font-family:'Outfit',sans-serif;font-size:13px;padding:.6rem .75rem;outline:none;transition:border-color .2s;resize:vertical}
textarea:focus,input:focus,select:focus{border-color:var(--blood);background:rgba(122,20,20,.08)}
select option{background:#160A0A;color:var(--parchment)}
select optgroup{background:#0A0506;color:var(--ember);font-family:'DM Mono',serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-style:normal;font-weight:500;padding:.25rem 0}
select optgroup option{color:var(--parchment);font-style:normal;font-family:'Outfit',sans-serif;font-size:13px;letter-spacing:0;text-transform:none;font-weight:400}
html[data-theme="light"] select option{background:#F8F2E4;color:var(--parchment)}
html[data-theme="light"] select optgroup{background:#EDE4D0;color:#8A1A1A}
html[data-theme="light"] select optgroup option{color:#1F1612}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}
/* BUTTONS */
.btn{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1.1rem;border:1px solid var(--blood);background:rgba(122,20,20,.15);color:var(--ember);cursor:pointer;border-radius:2px;transition:all .2s}
.btn:hover{background:rgba(122,20,20,.35);color:var(--parchment)}
.btn.primary{background:var(--blood);color:var(--parchment);border-color:#C03030}.btn.primary:hover{background:#8A1818}
.btn.sm{font-size:8px;padding:.35rem .65rem}
.btn.danger{border-color:#5A1414;color:#C05050}.btn.danger:hover{background:rgba(90,20,20,.3)}
.btn-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem;align-items:center}
/* OUTPUT */
.output-box{background:rgba(0,0,0,.55);border:1px solid var(--border);border-radius:2px;padding:1rem;min-height:140px;font-size:13px;line-height:1.85;color:var(--parchment);white-space:pre-wrap;font-family:'Cormorant Garamond',serif}
.output-box em{color:var(--muted);font-style:italic}
.loading-text{color:var(--ember);font-style:italic;animation:pulse 1.4s infinite}
.prompt-out{background:rgba(0,0,0,.55);border:1px solid var(--border);border-radius:2px;padding:.85rem 1rem;font-family:monospace;font-size:11px;line-height:1.7;color:#C8C0B0;white-space:pre-wrap;min-height:80px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes spin{to{transform:rotate(360deg)}}
/* LOOTBOX */
.loot-input-area{background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:3px;padding:1rem;margin-bottom:1rem}
.voice-btn{display:flex;align-items:center;gap:.5rem;padding:.55rem 1rem;background:rgba(122,20,20,.2);border:1px solid var(--blood);border-radius:20px;color:var(--ember);font-family:'DM Mono',serif;font-size:9px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.voice-btn:hover{background:rgba(122,20,20,.4)}
.voice-btn.recording{background:rgba(180,20,20,.5);border-color:#E03030;animation:pulse-red 1s infinite}
.voice-btn .mic-icon{font-size:16px}
@keyframes pulse-red{0%,100%{box-shadow:0 0 0 0 rgba(180,20,20,.4)}50%{box-shadow:0 0 0 8px rgba(180,20,20,0)}}
.loot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.65rem;margin-top:.65rem}
.loot-card{background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:2px;padding:.85rem;position:relative;transition:border-color .15s}
.loot-card:hover{border-color:rgba(122,20,20,.5)}
.loot-card.assigned{border-left:3px solid var(--ember)}
.loot-card.group{border-left:3px solid rgba(80,80,150,.7)}
.loot-item-name{font-family:'DM Mono',serif;font-size:11px;color:var(--ember);letter-spacing:.06em;margin-bottom:.2rem}
.loot-item-type{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:.35rem}
.loot-item-desc{font-size:11px;color:rgba(237,224,204,.6);line-height:1.5;margin-bottom:.5rem}
.loot-item-meta{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}
.loot-meta-pill{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.06em;padding:.15rem .4rem;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:1px;color:var(--muted)}
.loot-meta-pill.gold{color:#cfb060;border-color:rgba(150,110,30,.4)}
.loot-meta-pill.owner{color:#7aadcf;border-color:rgba(20,80,120,.4)}
.loot-owner-row{display:flex;align-items:center;gap:.4rem;margin-top:.4rem;flex-wrap:wrap}
.owner-chip{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.2rem .45rem;border:1px solid var(--border);border-radius:1px;cursor:pointer;transition:all .12s;text-transform:uppercase;background:rgba(0,0,0,.2);color:var(--muted)}
.owner-chip:hover{border-color:var(--blood);color:var(--ember)}
.owner-chip.active{background:rgba(122,20,20,.3);border-color:var(--ember);color:var(--ember)}
.owner-chip.group-chip{color:rgba(120,120,200,.8);border-color:rgba(80,80,150,.4)}
.owner-chip.group-chip.active{background:rgba(60,60,140,.3);border-color:rgba(120,120,200,.6);color:rgba(160,160,255,.9)}
.loot-del-btn{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:rgba(122,20,20,.4);cursor:pointer;font-size:12px;transition:color .15s;padding:.1rem .3rem}
.loot-del-btn:hover{color:#cf7070}
.loot-value-bar{display:flex;gap:1.5rem;padding:.75rem 1rem;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:2px;margin-bottom:1rem;flex-wrap:wrap}
.loot-val-item{text-align:center}
.loot-val-num{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ember)}
.loot-val-label{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-top:2px}
.loot-filter-row{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.75rem}
.loot-filter-btn{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.08em;padding:.25rem .65rem;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;border-radius:1px;text-transform:uppercase;transition:all .12s}
.loot-filter-btn:hover,.loot-filter-btn.active{color:var(--ember);border-color:var(--blood);background:rgba(122,20,20,.15)}
.loot-controls-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px dashed rgba(122,20,20,.15)}
.loot-controls-row select{font-family:'DM Mono',monospace;font-size:9px;background:var(--surface);border:1px solid var(--border);color:var(--parchment);padding:.25rem .4rem;border-radius:1px;text-transform:uppercase;letter-spacing:.06em}
.loot-controls-row label{font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.3rem;cursor:pointer}
.loot-controls-spacer{flex:1}
.loot-table{width:100%;border-collapse:collapse;font-size:11px;margin-top:.5rem}
.loot-table th{font-family:'DM Mono',monospace;font-size:8px;color:var(--ember);text-transform:uppercase;letter-spacing:.1em;text-align:left;padding:.5rem .4rem;border-bottom:1px solid var(--blood);background:rgba(0,0,0,.3);position:sticky;top:0}
.loot-table td{padding:.45rem .4rem;border-bottom:1px solid rgba(122,20,20,.08);color:var(--parchment);vertical-align:middle}
.loot-table tr:hover td{background:rgba(122,20,20,.06)}
.loot-table .lt-qty{font-family:'DM Mono',monospace;color:var(--muted);width:40px}
.loot-table .lt-name{font-family:'Cormorant Garamond',serif;font-size:13px}
.loot-table .lt-val{font-family:'DM Mono',monospace;color:#cfb060;text-align:right;white-space:nowrap}
.loot-table .lt-type,.loot-table .lt-owner{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.loot-table .lt-actions{white-space:nowrap;text-align:right}
.loot-table .lt-actions button{background:none;border:none;color:var(--muted);cursor:pointer;padding:.15rem .3rem;font-size:10px;margin-left:.2rem}
.loot-table .lt-actions button:hover{color:var(--ember)}
.nethys-badge{display:inline-flex;align-items:center;gap:.25rem;font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.1rem .35rem;background:rgba(30,60,30,.3);border:1px solid rgba(42,92,42,.3);border-radius:1px;color:#7fcf7f;text-decoration:none;cursor:pointer}
.nethys-badge:hover{background:rgba(30,60,30,.5)}
.rarity-common{color:var(--parchment)}
.rarity-uncommon{color:#7fcf7f}
.rarity-rare{color:#7aadcf}
.rarity-very-rare{color:#b07acf}
.rarity-legendary{color:#cfb060}
.parse-status{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.1em;padding:.4rem .75rem;border-radius:2px;margin-top:.5rem;display:none}
.parse-status.ok{background:rgba(42,92,42,.2);border:1px solid rgba(42,92,42,.3);color:#7fcf7f;display:block}
.parse-status.err{background:rgba(90,20,20,.2);border:1px solid rgba(90,20,20,.3);color:#cf7070;display:block}
/* CHATBOT */
.chat-widget{position:fixed;bottom:1.5rem;right:1.5rem;z-index:150}
.chat-toggle{width:52px;height:52px;border-radius:50%;background:#0A0507;border:1px solid rgba(200,146,58,.45);color:var(--parchment);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.55);transition:all .2s;position:relative;overflow:hidden}
.chat-toggle:hover{background:#14080C;border-color:rgba(200,146,58,.75);transform:scale(1.05)}
/* Arcane weave — replaces the crystal-ball emoji. Noise-field swarm of nodes with thin
   ember↔blood connections, slow palette cycle. Subtle on the toggle, ambient in the panel. */
.oracle-weave{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;display:block}
.oracle-weave.toggle-weave{border-radius:50%}
.oracle-weave.panel-weave{z-index:0;opacity:.35}
.chat-panel{position:fixed;bottom:5rem;right:1.5rem;width:380px;height:560px;background:#0F0A13;border:1px solid var(--border2);border-radius:4px;display:none;flex-direction:column;box-shadow:0 8px 40px rgba(0,0,0,.7);z-index:150;overflow:hidden;isolation:isolate}
.chat-panel>.chat-header,.chat-panel>.chat-messages,.chat-panel>.chat-input-row{position:relative;z-index:1}
.chat-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.chat-panel.open{display:flex}
.chat-header{padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.chat-header-title{font-family:'Cormorant Garamond',serif;font-size:11px;color:var(--ember);letter-spacing:.06em}
.chat-header-sub{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-top:1px}
.chat-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:.1rem .3rem;transition:color .15s}
.chat-close:hover{color:var(--parchment)}
.chat-messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.6rem}
.chat-msg{display:flex;gap:.5rem;align-items:flex-start}
.chat-msg.user{flex-direction:row-reverse}
.chat-bubble{max-width:88%;padding:.55rem .8rem;border-radius:3px;font-size:12px;line-height:1.65;position:relative}
.chat-msg.bot .chat-bubble{background:rgba(0,0,0,.4);border:1px solid var(--border);color:var(--parchment);border-radius:2px 8px 8px 2px}
.chat-msg.user .chat-bubble{background:rgba(122,20,20,.25);border:1px solid rgba(122,20,20,.4);color:var(--parchment);border-radius:8px 2px 2px 8px}
.chat-msg.bot .chat-avatar{font-size:16px;flex-shrink:0;margin-top:2px}
.chat-msg.user .chat-avatar{font-size:14px;flex-shrink:0;margin-top:2px;color:var(--muted)}
.chat-disclaimer{margin-top:.4rem;padding:.3rem .5rem;background:rgba(90,80,20,.15);border:1px solid rgba(90,80,20,.3);border-radius:2px;font-family:'DM Mono',serif;font-size:8px;letter-spacing:.05em;color:#cfb060;line-height:1.5}
.chat-disclaimer.forbidden{background:rgba(90,20,20,.15);border-color:rgba(122,20,20,.35);color:#cf7070}
.chat-input-row{padding:.6rem .75rem;border-top:1px solid var(--border);display:flex;gap:.4rem;flex-shrink:0}
.chat-input{flex:1;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:2px;color:var(--parchment);font-family:'Cormorant Garamond',serif;font-size:12px;padding:.45rem .65rem;outline:none;resize:none;height:38px;line-height:1.4}
.chat-input:focus{border-color:var(--blood)}
.chat-send{background:var(--blood);border:none;color:var(--parchment);cursor:pointer;border-radius:2px;padding:.45rem .75rem;font-family:'DM Mono',serif;font-size:9px;letter-spacing:.08em;text-transform:uppercase;transition:background .15s;flex-shrink:0}
.chat-send:hover{background:#8A1818}
.chat-send:disabled{opacity:.4;cursor:not-allowed}
.chat-typing{display:flex;gap:4px;align-items:center;padding:.4rem .6rem}
.chat-dot{width:5px;height:5px;border-radius:50%;background:var(--muted);animation:chatdot 1.2s infinite}
.chat-dot:nth-child(2){animation-delay:.2s}
.chat-dot:nth-child(3){animation-delay:.4s}
@keyframes chatdot{0%,60%,100%{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}
.chat-empty{text-align:center;padding:2rem 1rem;color:var(--muted);font-size:11px;font-style:italic;line-height:1.7}
.chat-suggestion{display:inline-block;font-family:'DM Mono',serif;font-size:8px;letter-spacing:.06em;padding:.25rem .55rem;border:1px solid var(--border);border-radius:1px;color:var(--muted);cursor:pointer;margin:.15rem;transition:all .12s;text-transform:uppercase;background:rgba(0,0,0,.2)}
.chat-suggestion:hover{color:var(--ember);border-color:var(--blood);background:rgba(122,20,20,.15)}
@media(max-width:440px){.chat-panel{width:calc(100vw - 2rem);right:1rem;bottom:4.5rem}}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin-top:.75rem}
.gallery-card{background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:2px;overflow:hidden;cursor:pointer;transition:border-color .15s;position:relative}
.gallery-card-session-pill{position:absolute;top:.4rem;left:.4rem;font-family:'DM Mono',ui-monospace,monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:.18rem .5rem;background:rgba(122,20,20,.85);color:#EDE0CC;border-radius:2px;z-index:2;pointer-events:none;max-width:calc(100% - .8rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gallery-card-session-pill.is-generisch{background:rgba(0,0,0,.6);color:rgba(237,224,204,.65)}
.gallery-card:hover{border-color:var(--blood)}
.gallery-card img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;filter:brightness(.9);transition:filter .2s}
.gallery-card:hover img{filter:brightness(1)}
.gallery-card-body{padding:.6rem .75rem}
.gallery-card-title{font-family:'DM Mono',serif;font-size:10px;color:var(--ember);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gallery-card-meta{font-family:'DM Mono',serif;font-size:8px;color:var(--muted);letter-spacing:.04em;margin-top:.2rem}
.gallery-card-tags{display:flex;gap:.25rem;flex-wrap:wrap;margin-top:.35rem}
.gallery-tag{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.05em;padding:.1rem .3rem;background:rgba(122,20,20,.2);border:1px solid var(--border);border-radius:1px;color:var(--muted);text-transform:uppercase}
.gallery-tag.char{color:#7aadcf;border-color:rgba(20,80,120,.3);background:rgba(20,50,80,.2)}
/* Edit / delete buttons on each gallery card. Default: visible — touch
   devices have no hover state, so hover-only would hide these from the
   primary userbase (Android Chrome). The @media (hover: hover) block
   below restores the original "show on hover" behaviour for desktop so
   the grid stays clean when not actively interacted with. */
.gallery-card-del{position:absolute;top:.4rem;right:.4rem;background:rgba(0,0,0,.6);border:none;color:rgba(207,112,112,.85);cursor:pointer;font-size:11px;width:22px;height:22px;border-radius:1px;display:flex;align-items:center;justify-content:center;transition:opacity .15s;opacity:1;z-index:3}
.gallery-card-edit{position:absolute;top:.4rem;right:2rem;background:rgba(0,0,0,.6);border:none;color:rgba(200,146,58,.9);cursor:pointer;font-size:11px;width:22px;height:22px;border-radius:1px;display:flex;align-items:center;justify-content:center;transition:opacity .15s;opacity:1;z-index:3}
@media (hover: hover) {
  .gallery-card-del,
  .gallery-card-edit { opacity: 0; }
  .gallery-card:hover .gallery-card-del,
  .gallery-card:hover .gallery-card-edit { opacity: 1; }
}
.gallery-card-chronicle-pill{position:absolute;top:1.85rem;left:.4rem;font-family:'DM Mono',ui-monospace,monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:.14rem .42rem;background:rgba(200,146,58,.85);color:#0A090C;border-radius:2px;z-index:2;pointer-events:none;max-width:calc(100% - .8rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.composer-attach-heading{font-family:'DM Mono',ui-monospace,monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--blood);margin:1rem 0 .5rem;display:flex;align-items:center;gap:.5rem}
.composer-attach-heading:first-child{margin-top:0}
.composer-attach-count{background:rgba(122,20,20,.4);color:rgba(237,224,204,.85);padding:.1rem .45rem;border-radius:8px;font-size:9px;letter-spacing:.04em}
.composer-attach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;margin-bottom:.5rem}
.composer-attach-card{position:relative;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:2px;overflow:hidden;cursor:pointer;transition:border-color .12s,opacity .12s}
.composer-attach-card:hover{border-color:var(--ember)}
.composer-attach-card.status-attached{border-color:var(--ember);box-shadow:inset 0 0 0 1px var(--ember)}
.composer-attach-card.status-suggested{border-color:rgba(200,146,58,.5)}
.composer-attach-card.status-elsewhere{opacity:.6}
.composer-attach-card.status-elsewhere:hover{opacity:1}
.composer-attach-card img{display:block;width:100%;height:120px;object-fit:cover;filter:brightness(.95) sepia(.05)}
.composer-attach-card-info{padding:.4rem .55rem}
.composer-attach-card-title{font-family:var(--font-display);font-size:13px;color:var(--parchment);margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.composer-attach-card-meta{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.3rem}
.composer-attach-pill{font-family:'DM Mono',ui-monospace,monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:.1rem .35rem;background:rgba(122,20,20,.5);color:rgba(237,224,204,.8);border-radius:2px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.composer-attach-pill.is-warning{background:rgba(200,146,58,.4);color:#0A090C}
.composer-attach-card-status{font-family:'DM Mono',ui-monospace,monospace;font-size:9px;letter-spacing:.06em;color:rgba(237,224,204,.55);text-transform:uppercase}
.composer-attach-card.status-attached .composer-attach-card-status{color:var(--ember)}
.composer-attach-card.status-suggested .composer-attach-card-status{color:rgba(200,146,58,.85)}
.gallery-card-del:hover{background:rgba(90,20,20,.7);color:#cf7070}
.gallery-private-badge{position:absolute;top:.4rem;left:.4rem;font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.15rem .4rem;background:rgba(0,0,0,.7);border:1px solid rgba(122,20,20,.4);border-radius:1px;color:var(--muted);text-transform:uppercase}
/* LIGHTBOX */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:300;display:none;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}
.lightbox-overlay.open{display:flex}
.lightbox-img{max-width:100%;max-height:70vh;object-fit:contain;border:1px solid var(--border);display:block}
.lightbox-info{width:100%;max-width:900px;margin-top:1rem;display:flex;gap:1.5rem;align-items:flex-start}
.lightbox-title{font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--ember);margin-bottom:.3rem}
.lightbox-detail{font-size:11px;color:rgba(237,224,204,.6);line-height:1.7;flex:1}
.lightbox-actions{display:flex;gap:.5rem;flex-shrink:0;flex-direction:column}
.lightbox-close{position:fixed;top:1rem;right:1.25rem;background:none;border:none;color:var(--muted);cursor:pointer;font-size:20px;z-index:301}
.lightbox-close:hover{color:var(--parchment)}
.lightbox-prompt{font-family:monospace;font-size:10px;color:var(--muted);background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:2px;padding:.5rem .75rem;margin-top:.5rem;line-height:1.6;word-break:break-all;max-height:80px;overflow-y:auto}
/* GALLERY FILTERS */
.gallery-filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:.75rem}
.gallery-search{flex:1;min-width:160px;max-width:280px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:2px;color:var(--parchment);font-family:'Cormorant Garamond',serif;font-size:12px;padding:.4rem .65rem;outline:none}
.gallery-search:focus{border-color:var(--blood)}
.gallery-count{font-family:'DM Mono',serif;font-size:9px;color:var(--muted);letter-spacing:.08em;margin-left:auto}
/* UPLOAD DIALOG */
.upload-meta-form{background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:2px;padding:1rem;margin-top:.75rem}
.upload-preview-img{width:100%;max-height:200px;object-fit:cover;border:1px solid var(--border);display:block;margin-bottom:.75rem;filter:brightness(.85)}
/* PUBLIC BLOG GALLERY */
.pub-gallery-grid{max-width:1100px;margin:0 auto;padding:2rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.pub-gallery-card{cursor:pointer;overflow:hidden;border:1px solid var(--border);border-radius:2px;background:var(--panel);transition:border-color .15s;position:relative}
.pub-gallery-card:hover{border-color:var(--blood)}
.pub-gallery-card img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;filter:brightness(.85) sepia(.08);transition:filter .2s}
.pub-gallery-card:hover img{filter:brightness(1) sepia(0)}
.pub-gallery-card-info{padding:.6rem .75rem}
.pub-gallery-card-title{font-family:'DM Mono',serif;font-size:10px;color:var(--ember);letter-spacing:.06em;text-transform:uppercase}
.pub-gallery-card-tags{margin-top:.3rem;display:flex;gap:.25rem;flex-wrap:wrap}

/* SESSION ROOM */
.session-banner{padding:1rem 1.25rem;border-radius:3px;margin-bottom:1rem;position:relative;border:1px solid}
.session-banner.open{background:rgba(20,60,20,.25);border-color:rgba(42,92,42,.5)}
.session-banner.closed{background:rgba(90,80,20,.15);border-color:rgba(90,80,20,.4)}
.session-banner.none{background:rgba(0,0,0,.3);border-color:var(--border)}
.session-status-dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:.5rem;vertical-align:middle}
.session-status-dot.open{background:#4CAF50;animation:pulse 1.5s infinite}
.session-status-dot.closed{background:#cfb060}
.session-status-dot.none{background:#555}
.session-title-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.session-label{font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--ember)}
.session-meta{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-top:.2rem}
.note-grid{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}
.note-card{background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:2px;padding:.75rem 1rem;position:relative}
.note-card:hover{border-color:rgba(122,20,20,.4)}
.note-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}
.note-author{font-family:'DM Mono',serif;font-size:9px;letter-spacing:.08em;color:var(--ember);text-transform:uppercase}
.note-char{font-family:'DM Mono',serif;font-size:8px;color:var(--muted);margin-left:.5rem}
.note-time{font-family:'DM Mono',serif;font-size:8px;color:rgba(122,100,72,.4)}
.note-text{font-size:12px;line-height:1.7;color:var(--parchment)}
.note-tags{display:flex;gap:.3rem;flex-wrap:wrap;margin-top:.4rem}
.note-tag{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.1rem .35rem;background:rgba(122,20,20,.18);border:1px solid var(--border);border-radius:1px;color:var(--muted);text-transform:uppercase}
.note-del{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:rgba(122,20,20,.35);cursor:pointer;font-size:11px;transition:color .15s}
.note-del:hover{color:#cf7070}
.gap-card{background:rgba(90,80,20,.12);border:1px solid rgba(90,80,20,.3);border-radius:2px;padding:.75rem 1rem;margin-bottom:.5rem}
.gap-question{font-family:'DM Mono',serif;font-size:10px;color:#cfb060;letter-spacing:.05em;margin-bottom:.4rem}
.gap-type{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:.3rem}
.feedback-progress{background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:2px;padding:.75rem 1rem;margin-bottom:1rem;font-family:'DM Mono',serif;font-size:9px;color:var(--muted)}
.session-phase{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.15em;text-transform:uppercase;padding:.2rem .6rem;border-radius:1px;display:inline-block;margin-bottom:.5rem}
.phase-open{background:rgba(42,92,42,.3);color:#7fcf7f;border:1px solid rgba(42,92,42,.4)}
.phase-closed{background:rgba(90,80,20,.3);color:#cfb060;border:1px solid rgba(90,80,20,.4)}
.phase-reviewing{background:rgba(20,50,80,.3);color:#7aadcf;border:1px solid rgba(20,80,120,.3)}
.phase-published{background:rgba(122,20,20,.3);color:var(--ember);border:1px solid var(--border)}
.contributors-bar{display:flex;gap:.35rem;flex-wrap:wrap;margin:.5rem 0}
.contributor-chip{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.15rem .4rem;background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:1px;color:var(--muted);text-transform:uppercase}
.contributor-chip.has-notes{color:var(--ember);border-color:rgba(122,20,20,.4)}
.session-history-item{padding:.5rem .65rem;border-bottom:1px solid rgba(122,20,20,.08);display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:background .1s}
.session-history-item:hover{background:rgba(122,20,20,.06)}
.shi-num{font-family:'DM Mono',serif;font-size:10px;color:var(--ember);min-width:35px}
.shi-title{font-size:11px;color:var(--parchment);flex:1}
.shi-meta{font-family:'DM Mono',serif;font-size:8px;color:var(--muted)}
.shi-del-btn{margin-left:auto;background:none;border:none;color:var(--muted);font-size:9px;cursor:pointer;padding:.15rem .3rem;border-radius:2px;line-height:1;flex-shrink:0}.shi-del-btn:hover{color:#c0392b;background:rgba(192,57,43,.12)}


.out-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.copy-btn{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.1em;padding:.25rem .6rem;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;border-radius:2px;text-transform:uppercase;transition:all .12s}
.copy-btn:hover{color:var(--ember);border-color:var(--blood)}
hr.div{border:none;border-top:1px solid var(--border);margin:1.1rem 0}
/* CHIPS */
.chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.35rem}
.chip,.tone-chip{padding:.25rem .6rem;background:rgba(122,20,20,.18);border:1px solid var(--border);border-radius:2px;font-family:'DM Mono',serif;font-size:8px;letter-spacing:.08em;color:var(--muted);cursor:pointer;transition:all .12s;text-transform:uppercase}
.chip:hover,.chip.active,.tone-chip:hover,.tone-chip.active{color:var(--ember);border-color:var(--blood);background:rgba(122,20,20,.3)}
.tone-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem;margin-top:.35rem}
/* ENTRY CARDS */
.entry-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.55rem;margin-top:.65rem}
/* CHARACTER SHEET (PF1e first; multi-system-ready). Brand-aligned port of
   brand/clarissa_charsheet.html — Cormorant Garamond + DM Mono + Outfit,
   ember/blood/parchment palette, 2px gradient accent on every panel top. */
.cs-header{background:var(--surface);border-bottom:1px solid var(--border2);position:relative;padding:1.5rem 1.25rem 1.25rem;margin:-1rem -1rem 1rem;overflow:hidden}
.cs-header::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.cs-header-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.cs-identity{display:flex;align-items:center;gap:1rem}
.cs-name{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(22px,4vw,32px);color:var(--ember);letter-spacing:.01em;line-height:1.2}
.cs-sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-top:.3rem}
.cs-header-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.cs-header-stats{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:1rem}
.cs-hstat{background:rgba(0,0,0,.4);border:1px solid var(--border2);border-radius:2px;padding:.45rem .75rem;text-align:center;min-width:72px}
.cs-hstat-num{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:22px;color:var(--ember);line-height:1}
.cs-hstat-label{font-family:var(--font-mono);font-size:8px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-top:3px}
.cs-hstat.hp .cs-hstat-num{color:#cf7070}
.cs-hp-tracker{display:flex;gap:.3rem;justify-content:center;margin-top:.3rem}
.cs-hp-btn{background:rgba(122,20,20,.3);border:1px solid var(--blood);border-radius:2px;color:var(--parchment);font-size:14px;width:24px;height:24px;cursor:pointer;font-family:var(--font-mono);display:inline-flex;align-items:center;justify-content:center;line-height:1}
.cs-hp-btn:hover{background:rgba(122,20,20,.6)}
.cs-mini{font-family:var(--font-mono);font-size:8px;color:var(--muted);letter-spacing:.06em;margin-top:.2rem}
.cs-body{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:899px){.cs-body{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.cs-body{grid-template-columns:1fr}}
.cs-col-full{grid-column:1/-1}
.cs-col-2{grid-column:span 2}
@media(max-width:899px){.cs-col-2{grid-column:1/-1}}
.cs-panel{background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:2px;padding:.75rem .9rem;position:relative}
.cs-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,146,58,.4),transparent)}
.cs-panel-title{font-family:var(--font-mono);font-size:9px;letter-spacing:.22em;color:var(--blood);text-transform:uppercase;margin-bottom:.55rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}
.cs-attr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
.cs-attr-box{text-align:center;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:2px;padding:.4rem .3rem}
.cs-attr-name{font-family:var(--font-mono);font-size:8px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase}
.cs-attr-score{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:20px;color:var(--parchment);line-height:1.1}
.cs-attr-mod{font-family:var(--font-mono);font-size:10px;color:var(--ember);letter-spacing:.05em}
.cs-row{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;border-bottom:1px solid rgba(122,20,20,.08)}
.cs-row:last-child{border:none}
.cs-row-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.cs-save-val{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:16px}
.cs-save-val.good{color:#7fcf7f}
.cs-save-val.bad{color:#cf7070}
.cs-trait-pill{display:inline-block;font-family:var(--font-mono);font-size:8px;letter-spacing:.08em;padding:.18rem .55rem;background:rgba(122,20,20,.2);border:1px solid var(--border);border-radius:1px;color:var(--muted);text-transform:uppercase;margin:.12rem .08rem}
.cs-lang-wrap{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.3rem}
.cs-lang-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;color:var(--muted);padding:.13rem .45rem;border:1px solid var(--border);border-radius:1px;text-transform:uppercase}
.cs-bab{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:20px;color:var(--parchment)}
.cs-weapon{padding:.4rem 0;border-bottom:1px solid rgba(122,20,20,.08)}
.cs-weapon:last-child{border:none}
.cs-weapon-name{font-family:var(--font-mono);font-size:11px;color:var(--ember);letter-spacing:.05em}
.cs-weapon-stats{font-family:var(--font-mono);font-size:9px;color:var(--muted);letter-spacing:.06em;margin-top:2px;text-transform:uppercase}
.cs-sneak{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:20px;color:#cf7070}
.cs-sneak-note{font-size:10px;color:var(--muted);margin-top:2px;font-style:italic}
.cs-spells-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0 1.5rem}
.cs-spell-header{font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;color:#8f6abf;text-transform:uppercase;margin:.5rem 0 .3rem;display:flex;align-items:center;gap:.5rem}
.cs-spell-lvlnum{background:rgba(143,106,191,.2);border:1px solid rgba(143,106,191,.3);border-radius:1px;padding:.08rem .35rem;font-size:8px;color:#8f6abf}
.cs-slots{display:flex;gap:4px;margin-left:auto}
.cs-slot{width:11px;height:11px;border-radius:50%;border:1px solid #8f6abf;cursor:pointer;background:rgba(143,106,191,.3)}
.cs-slot.used{background:rgba(0,0,0,.4);border-color:rgba(143,106,191,.2)}
.cs-spell-list{margin-bottom:.4rem}
.cs-spell-entry{display:flex;align-items:baseline;gap:.5rem;padding:.18rem 0;border-bottom:1px solid rgba(143,106,191,.07)}
.cs-spell-entry:last-child{border:none}
.cs-spell-link{font-family:var(--font-mono);font-size:10px;color:#8f6abf;letter-spacing:.04em;text-decoration:none}
.cs-spell-link:hover{color:#c4a0ef;text-decoration:underline}
.cs-spell-dc{font-family:var(--font-mono);font-size:8px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-left:auto}
.cs-spell-src{font-size:8px;color:rgba(143,106,191,.5);margin-left:.2rem;font-style:italic}
.cs-perf-tracker{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem;flex-wrap:wrap}
.cs-perf-row{display:flex;align-items:center;gap:.4rem;margin-top:.2rem}
.cs-perf-cur{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:24px;color:#cfb060;min-width:30px;text-align:center}
.cs-perf-max{font-family:var(--font-mono);font-size:9px;color:var(--muted)}
.cs-perf-dots{display:flex;flex-wrap:wrap;gap:3px;margin-left:auto;max-width:220px}
.cs-perf-dot{width:9px;height:9px;border-radius:50%;border:1px solid rgba(207,176,96,.4);cursor:pointer;background:rgba(207,176,96,.25)}
.cs-perf-dot.used{background:rgba(0,0,0,.4);border-color:rgba(207,176,96,.12)}
.cs-skill-name{font-family:var(--font-body);font-size:11px;color:rgba(237,224,204,.8);flex:1}
.cs-skill-name.cs-trained{color:var(--parchment)}
.cs-skill-name.cs-cs{color:var(--ember);font-family:var(--font-mono);font-size:10px;letter-spacing:.04em}
.cs-skill-val{font-family:var(--font-mono);font-size:11px;color:var(--ember);text-align:right;min-width:28px}
.cs-ability{padding:.35rem 0;border-bottom:1px solid rgba(122,20,20,.08)}
.cs-ability:last-child{border:none}
.cs-ability-name{font-family:var(--font-mono);font-size:10px;color:var(--ember);letter-spacing:.05em}
.cs-ability-desc{font-size:11px;color:rgba(237,224,204,.65);line-height:1.5;margin-top:.2rem}
details.cs-ability{padding:.35rem 0}
details.cs-ability>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:10px;color:var(--ember);letter-spacing:.05em}
details.cs-ability>summary::-webkit-details-marker{display:none}
details.cs-ability>summary::before{content:'▸';font-size:9px;color:var(--ember);transition:transform .15s ease;flex:none;width:.7em;display:inline-block}
details.cs-ability[open]>summary::before{transform:rotate(90deg)}
details.cs-ability>.cs-ability-desc{margin-top:.3rem;padding-left:1.1em}
.cs-gear-list{font-size:11px;color:rgba(237,224,204,.7);line-height:1.7;list-style:none;padding:0}
.cs-gear-list li{padding:.05rem 0;border-bottom:1px solid rgba(122,20,20,.05)}
.cs-gear-list li:last-child{border:none}
.cs-gear-list li::before{content:'◆';color:var(--blood);font-size:7px;margin-right:.4rem}
.cs-coins{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:16px;color:#cfb060;margin-top:.5rem;border-top:1px solid var(--border);padding-top:.4rem}
.cs-klang-row{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;color:rgba(237,224,204,.85);padding:.3rem 0;cursor:pointer}
.cs-klang-row input{cursor:pointer}
.cs-edit-shell{padding:.25rem}
.cs-edit-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:.65rem;border-bottom:1px solid var(--border)}
.cs-edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.cs-edit-section{background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:2px;padding:.65rem .85rem;margin:0;display:flex;flex-direction:column;gap:.45rem;min-width:0}
.cs-edit-section legend{font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;color:var(--blood);text-transform:uppercase;padding:0 .4rem}
.cs-edit-full{grid-column:1/-1}
.cs-field{display:flex;flex-direction:column;gap:.2rem}
.cs-field-full{flex:1 1 100%}
.cs-field-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.cs-field input,.cs-field textarea{font-family:var(--font-body);font-size:13px;background:rgba(0,0,0,.45);border:1px solid var(--border);color:var(--parchment);padding:.4rem .55rem;border-radius:2px;width:100%;box-sizing:border-box}
.cs-field input[type="number"]{font-family:var(--font-mono)}
.cs-field textarea{font-family:var(--font-mono);font-size:11px;line-height:1.5;resize:vertical;min-height:60px}
.cs-field input:focus,.cs-field textarea:focus{outline:none;border-color:var(--ember)}
/* Structured array editors — replace JSON textareas with proper rows/cards.
   Each array path (skills/weapons/feats/specialAbilities/spells/classes) gets
   inline +/× controls and field-level binding. */
.cs-rows{display:flex;flex-direction:column;gap:.4rem}
.cs-row-edit{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.cs-row-edit input,.cs-row-edit select,.cs-row-edit textarea{font-family:var(--font-body);font-size:12px;background:rgba(0,0,0,.45);border:1px solid var(--border);color:var(--parchment);padding:.35rem .5rem;border-radius:2px;flex:1;min-width:60px}
.cs-row-edit input[type="number"]{font-family:var(--font-mono);max-width:80px;flex:0 0 auto}
.cs-row-edit input[type="checkbox"]{flex:0 0 auto;width:auto;cursor:pointer}
.cs-row-edit select{font-family:var(--font-mono);max-width:90px;flex:0 0 auto;cursor:pointer}
.cs-row-edit input:focus,.cs-row-edit select:focus,.cs-row-edit textarea:focus{outline:none;border-color:var(--ember)}
.cs-row-classes input:nth-child(1){flex:2}
.cs-row-classes input:nth-child(2){flex:2}
.cs-row-skills{display:grid;grid-template-columns:2fr 60px 70px 40px 60px 32px;gap:.4rem;align-items:center}
.cs-row-skills.cs-row-headers{font-family:var(--font-mono);font-size:8px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;padding-bottom:.2rem;border-bottom:1px solid var(--border)}
.cs-row-skills input,.cs-row-skills select{flex:none;width:100%;max-width:none;min-width:0;box-sizing:border-box;padding:.3rem .4rem;font-size:11px}
.cs-row-skills input[type="checkbox"]{width:auto;justify-self:center}
@media(max-width:640px){.cs-row-skills{grid-template-columns:1fr 50px 60px 36px 50px 32px}}
.cs-card-edit{background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:2px;padding:.45rem .55rem;display:flex;flex-direction:column;gap:.35rem}
.cs-row-weapon-top input,.cs-row-name-top input{flex:1}
.cs-row-weapon-bot{flex-wrap:wrap}
.cs-row-weapon-bot input{min-width:100px}
.cs-card-edit textarea{font-family:var(--font-body);font-size:12px;background:rgba(0,0,0,.45);border:1px solid var(--border);color:var(--parchment);padding:.35rem .5rem;border-radius:2px;width:100%;box-sizing:border-box;resize:vertical}
.cs-row-spell-header{flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:.35rem;margin-bottom:.2rem}
.cs-row-spell-entry input{font-size:11px;padding:.25rem .4rem}
.cs-row-add{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;background:transparent;border:1px dashed var(--border2);color:var(--ember);padding:.4rem .65rem;border-radius:2px;cursor:pointer;margin-top:.2rem;align-self:flex-start}
.cs-row-add:hover{background:rgba(122,20,20,.12);border-color:var(--ember)}
.cs-row-del{font-family:var(--font-mono);font-size:13px;background:transparent;border:1px solid var(--border);color:#cf7070;width:26px;height:26px;border-radius:2px;cursor:pointer;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;line-height:1;padding:0}
.cs-row-del:hover{background:rgba(207,112,112,.15);border-color:#cf7070}
.cs-spell-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.cs-spell-meta .cs-field{flex:1;min-width:140px}
/* Klangregie cue toast — fixed top-right, GM-confirmed Atmosphäre trigger. */
.klang-cue-host{position:fixed;top:1rem;right:1rem;z-index:250;display:flex;flex-direction:column;gap:.5rem;max-width:360px}
.klang-cue{background:var(--panel);border:1px solid var(--border2);border-radius:3px;padding:.75rem .85rem;display:flex;align-items:center;gap:.65rem;position:relative}
.klang-cue::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.klang-cue-icon{font-size:18px;color:var(--ember);font-family:var(--font-mono);line-height:1}
.klang-cue-body{flex:1;min-width:0}
.klang-cue-title{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--ember);text-transform:uppercase}
.klang-cue-detail{font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--parchment);margin-top:.2rem}
.klang-cue-actions{display:flex;flex-direction:column;gap:.3rem}
@media(max-width:640px){.klang-cue-host{left:1rem;right:1rem;max-width:none;top:.5rem}}
.entry-card{background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:2px;padding:.65rem .85rem;cursor:pointer;transition:border-color .12s;position:relative}
.entry-card:hover{border-color:var(--blood)}
.ec-name{font-family:'DM Mono',serif;font-size:10px;color:var(--ember);letter-spacing:.08em;text-transform:uppercase}
.ec-role{font-size:11px;color:var(--muted);margin-top:.15rem}
.ec-status{display:inline-block;font-family:'DM Mono',serif;font-size:7px;letter-spacing:.08em;padding:.1rem .35rem;border-radius:1px;margin-top:.25rem;text-transform:uppercase}
/* Card layout — text on the left, square thumbnail on the right (when an
   image exists). Cards without images stay text-only. min-width:0 on the
   text column lets long names ellipsis-truncate within the row. */
.ec-body{display:flex;gap:.65rem;align-items:flex-start}
.ec-text{flex:1;min-width:0}
.ec-thumb{width:64px;height:64px;flex-shrink:0;border:1px solid var(--border);border-radius:1px;overflow:hidden;background:rgba(0,0,0,.4);filter:brightness(.9) sepia(.08)}
.ec-thumb img{width:100%;height:100%;display:block}
/* Modal-side focal-point editor: click on the image preview to set what
   gets centered in the entity-card thumbnail. The dot follows the click. */
.ec-focal-edit{position:relative;cursor:crosshair;display:inline-block;max-width:100%}
.ec-focal-edit img{display:block;max-width:100%;max-height:160px;border:1px solid var(--border);border-radius:1px}
.ec-focal-dot{position:absolute;width:14px;height:14px;border-radius:50%;background:rgba(200,146,58,.85);border:2px solid #0A0507;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 0 1px rgba(200,146,58,.4)}
.ec-focal-hint{font-family:'DM Mono',serif;font-size:8px;color:var(--muted);letter-spacing:.04em;margin-top:.3rem}
.status-aktiv{background:rgba(42,92,42,.3);color:#7fcf7f;border:1px solid rgba(42,92,42,.4)}
.status-unbekannt{background:rgba(90,80,20,.3);color:#cfb84f;border:1px solid rgba(90,80,20,.4)}
.status-tot{background:rgba(90,20,20,.3);color:#cf7070;border:1px solid rgba(90,20,20,.4)}
.status-flüchtig{background:rgba(40,40,90,.3);color:#8080cf;border:1px solid rgba(40,40,90,.4)}
/* TABLES */
.data-table{width:100%;border-collapse:collapse;font-size:11px;margin-top:.65rem}
.data-table th{font-family:'DM Mono',serif;font-size:8px;letter-spacing:.12em;color:var(--blood);text-transform:uppercase;text-align:left;padding:.35rem .5rem;border-bottom:1px solid var(--border)}
.data-table td{padding:.45rem .5rem;border-bottom:1px solid rgba(122,20,20,.08);color:var(--parchment);vertical-align:middle}
.data-table tr:hover td{background:rgba(122,20,20,.05)}
.sess-num{font-family:'DM Mono',serif;color:var(--ember);font-size:10px}
.post-reorder-cell{white-space:nowrap;display:flex;flex-direction:column;gap:.15rem;align-items:center}
.post-reorder-btn{font-family:'DM Mono',ui-monospace,monospace;font-size:11px;line-height:1;padding:.18rem .42rem;background:transparent;border:1px solid var(--border);color:var(--ember);cursor:pointer;border-radius:2px;transition:border-color .12s,color .12s}
.post-reorder-btn:hover:not([disabled]){border-color:var(--ember);color:var(--parchment);background:rgba(200,146,58,.1)}
.post-reorder-btn[disabled]{opacity:.3;cursor:not-allowed}
.drag-handle{display:inline-block;color:var(--muted);cursor:grab;font-size:11px;padding:.05rem .25rem;letter-spacing:-.05em;font-family:'DM Mono',ui-monospace,monospace;user-select:none;line-height:1}
.drag-handle:hover{color:var(--ember)}
.post-row{transition:opacity .12s}
.post-row.is-dragging{opacity:.35}
.post-row.drop-above td{box-shadow:inset 0 2px 0 var(--ember)}
.post-row.drop-below td{box-shadow:inset 0 -2px 0 var(--ember)}
/* Orte & Fraktionen kind badges (place vs org) */
.ec-kind-place{color:var(--ember);border-color:rgba(200,146,58,.4);background:rgba(200,146,58,.08)}
.ec-kind-org  {color:var(--blood); border-color:rgba(122,20,20,.4); background:rgba(122,20,20,.08)}
/* npcs-table-wrap / orte-table-wrap reuse data-table styles; just ensure the
   wrapper itself doesn't keep entry-grid's grid layout when toggled. */
.npcs-table-wrap, .orte-table-wrap{display:block}
.badge-pub{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.1rem .35rem;background:rgba(42,92,42,.3);color:#7fcf7f;border:1px solid rgba(42,92,42,.4);border-radius:1px;text-transform:uppercase}
.badge-draft{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.06em;padding:.1rem .35rem;background:rgba(90,80,20,.3);color:#cfb84f;border:1px solid rgba(90,80,20,.4);border-radius:1px;text-transform:uppercase}
/* ROLE BADGES */
.role-badge{font-family:'DM Mono',serif;font-size:7px;letter-spacing:.08em;padding:.15rem .4rem;border-radius:1px;text-transform:uppercase}
.role-admin{background:rgba(122,20,20,.3);color:var(--ember);border:1px solid var(--border)}
.role-master{background:rgba(80,60,20,.3);color:#cfb060;border:1px solid rgba(80,60,20,.3)}
.role-player{background:rgba(20,50,80,.3);color:#7aadcf;border:1px solid rgba(20,80,120,.3)}
/* POST STATUS */
.post-status-bar{display:flex;gap:.5rem;align-items:center;padding:.5rem .75rem;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:2px;margin-bottom:1rem;font-family:'DM Mono',serif;font-size:9px;letter-spacing:.1em;color:var(--muted)}
/* INFO/WARN BOXES */
.info-box{background:rgba(20,60,20,.2);border:1px solid rgba(42,92,42,.3);border-radius:2px;padding:.65rem .85rem;font-size:11px;line-height:1.7;color:rgba(127,207,127,.8);margin-bottom:1rem}
.warn-box{background:rgba(90,80,20,.15);border:1px solid rgba(90,80,20,.35);border-radius:2px;padding:.65rem .85rem;font-size:11px;line-height:1.7;color:#cfb84f;margin-bottom:1rem}
.style-ref{background:rgba(122,20,20,.08);border:1px solid var(--border);border-radius:2px;padding:.65rem .85rem;margin-bottom:.75rem;font-size:11px;line-height:1.7;color:rgba(237,224,204,.7)}
.style-ref strong{color:var(--ember);font-family:'DM Mono',serif;font-size:8px;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:.2rem}
/* ACTIVITY */
.activity-item{display:flex;gap:.5rem;align-items:flex-start;padding:.45rem .65rem;border-bottom:1px solid rgba(122,20,20,.08);font-size:11px}
.activity-user{font-family:'DM Mono',serif;font-size:8px;color:var(--ember);letter-spacing:.06em;flex-shrink:0;min-width:65px;margin-top:1px}
.activity-text{color:var(--muted);flex:1}
.activity-time{font-size:9px;color:rgba(122,100,72,.45);flex-shrink:0}
/* CHECK ITEMS */
.check-item{display:flex;gap:.5rem;align-items:flex-start;padding:.5rem .65rem;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:2px;margin-bottom:.35rem;font-size:11px;line-height:1.6}
.check-ok{border-left:2px solid #2A5C2A}.check-warn{border-left:2px solid #9A8A20}.check-err{border-left:2px solid #7A2020}
/* POST PREVIEW */
.post-preview-wrap{background:var(--panel);border:1px solid var(--border2);border-radius:3px;padding:2rem;margin-top:1rem;position:relative}
.post-preview-wrap::before{content:'VORSCHAU';position:absolute;top:.5rem;right:.75rem;font-family:'DM Mono',serif;font-size:8px;letter-spacing:.15em;color:var(--blood);text-transform:uppercase}
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:200;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal-box{background:var(--panel);border:1px solid var(--border2);border-radius:3px;padding:1.5rem;width:100%;max-width:500px;max-height:88vh;overflow-y:auto;position:relative}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--ember);margin-bottom:1rem}
.modal-close{position:absolute;top:.65rem;right:.75rem;background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px}.modal-close:hover{color:var(--parchment)}
/* ACTION-SHEET — bottom-sheet on phone, centred dialog on ≥641px. Reused by
   composer chip editors and Publish sheet. Will also host swipe-dismiss in D5.1. */
/* Always rendered so the inner transform transition can fire. opacity + pointer-
   events gate interactivity; backdrop + sheet slide together. */
.action-sheet-overlay{position:fixed;inset:0;background:rgba(10,9,12,0.72);display:flex;align-items:flex-end;justify-content:center;padding:0;z-index:200;opacity:0;pointer-events:none;transition:opacity .22s ease-out}
.action-sheet-overlay.open{opacity:1;pointer-events:auto}
.action-sheet{width:min(520px,100%);background:var(--panel);padding:1rem 1.25rem calc(2rem + env(safe-area-inset-bottom,0px));border-radius:18px 18px 0 0;transform:translateY(100%);transition:transform .22s ease-out;position:relative}
.action-sheet-overlay.open .action-sheet{transform:translateY(0)}
.action-sheet::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent);border-radius:18px 18px 0 0}
.action-sheet-grab{width:36px;height:4px;border-radius:2px;background:rgba(242,237,228,0.28);margin:0 auto .75rem;touch-action:none}
.action-sheet-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:22px;color:var(--ember);margin:0 0 .75rem}
.action-sheet-body{display:flex;flex-direction:column;gap:.5rem}
.action-sheet-body button{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.15em;padding:.75rem 1rem;background:transparent;border:1px solid rgba(200,146,58,0.35);color:var(--parchment);border-radius:10px;cursor:pointer;text-align:left}
.action-sheet-body button.primary{background:var(--blood);border-color:var(--blood)}
.public-nav-item{display:flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.18em;padding:.85rem 1rem;background:transparent;border:1px solid rgba(200,146,58,0.25);color:var(--parchment);border-radius:2px;cursor:pointer;text-align:left;min-height:48px}
.public-nav-item:hover,.public-nav-item:focus-visible{border-color:var(--ember);outline:none}
.public-nav-item .g{font-size:16px;color:var(--ember);width:20px;text-align:center}
.action-sheet-body input[type="text"],.action-sheet-body input[type="date"]{font-family:var(--font-mono);font-size:13px;padding:.625rem .75rem;background:transparent;border:1px solid rgba(200,146,58,0.35);color:var(--parchment);border-radius:8px;width:100%;box-sizing:border-box}
@media(min-width:641px){
  .action-sheet-overlay{align-items:center;padding:1rem}
  .action-sheet{border-radius:12px;border:2px solid var(--ember);padding-bottom:1rem}
  .action-sheet::before{border-radius:12px 12px 0 0}
  .action-sheet-grab{display:none}
}
/* HOME DRAWER (phone-only, CMS view only). Left-edge slide-in, swipe-dismiss
   via attachSwipeDismiss (axis=x, edge=left). Accent bar at top, panel bg. */
.home-drawer-backdrop{display:none;position:fixed;inset:0;background:rgba(10,9,12,0.6);z-index:140}
.home-drawer-backdrop.open{display:block}
.home-drawer{position:fixed;top:0;bottom:0;left:0;width:min(280px,82vw);background:var(--panel);border-right:1px solid var(--border2);z-index:141;transform:translateX(-100%);transition:transform .22s ease-out;padding:1rem .75rem calc(1rem + env(safe-area-inset-bottom,0px));overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}
.home-drawer::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.home-drawer.open{transform:translateX(0)}
.home-drawer-grab{width:4px;height:36px;border-radius:2px;background:rgba(242,237,228,0.28);position:absolute;top:50%;right:.5rem;transform:translateY(-50%);touch-action:none}
.home-drawer-head{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);padding:.5rem 0 1rem .25rem}
.home-drawer-nav{display:flex;flex-direction:column;gap:.5rem}
.home-drawer-item{display:flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.18em;padding:.75rem;background:transparent;border:1px solid rgba(200,146,58,0.25);color:var(--parchment);border-radius:2px;text-align:left;cursor:pointer}
.home-drawer-item:hover,.home-drawer-item:focus-visible{border-color:var(--ember);outline:none}
.home-drawer-item .g{font-size:16px;color:var(--ember);width:20px;text-align:center}
.home-drawer-footer{margin-top:auto;padding:.75rem 0 0;text-align:center}
.home-drawer-footer-link{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);background:transparent;border:none;cursor:pointer;padding:.5rem}
.home-drawer-footer-link:hover,.home-drawer-footer-link:focus-visible{color:var(--ember);outline:none}
/* Phone + CMS view only. Other breakpoints/views hide the drawer absolutely. */
@media(min-width:641px){.home-drawer,.home-drawer-backdrop{display:none !important}}
body:not([data-view="cms"]) .home-drawer,
body:not([data-view="cms"]) .home-drawer-backdrop{display:none !important}
/* USER MENU — right-anchored dropdown from the avatar. Accent bar on top edge.
   3px radius matches the brand's elevated-panel convention. No shadow. */
.user-menu{display:none;position:fixed;top:3.5rem;right:1rem;min-width:240px;background:var(--panel);border:1px solid var(--border2);border-radius:3px;z-index:210;padding:0;overflow:hidden}
.user-menu.open{display:block}
.user-menu::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
.user-menu-head{padding:1rem 1rem .65rem}
.user-menu-name{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:400;color:var(--parchment);letter-spacing:0.01em}
.user-menu-name .role{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.15em;color:var(--muted);margin-left:.5rem}
.user-menu-email{font-family:'Outfit',sans-serif;font-size:11px;color:var(--muted);line-height:1.3;margin-top:.25rem;word-break:break-all}
.user-menu-campaign{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.18em;color:var(--ember);line-height:1.3;margin-top:.5rem}
.user-menu-divider{height:1px;background:var(--border);margin:0}
.user-menu-body{display:flex;flex-direction:column;padding:.5rem 0}
.user-menu-item{display:flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.15em;color:var(--parchment);padding:.65rem 1rem;background:transparent;border:none;cursor:pointer;text-align:left;width:100%}
.user-menu-item:hover,.user-menu-item:focus-visible{background:rgba(122,20,20,0.12);color:var(--ember);outline:none}
.user-menu-item .g{font-size:13px;color:var(--ember);width:16px;text-align:center}
.user-menu-item.danger{color:#cf7070}
.user-menu-item.danger .g{color:#cf7070}
.user-menu-section{font-family:var(--font-mono);font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);padding:.65rem 1rem .35rem;border-top:1px solid var(--border);margin-top:.25rem}
.user-menu-item:disabled{cursor:default}
.user-menu-item:disabled:hover{background:transparent;color:var(--parchment)}
.bug-count-pill{background:#7A1414;color:#EDE0CC;padding:0 .35rem;border-radius:8px;font-size:9px;margin-left:.4rem;font-weight:600}
@media(max-width:640px){.user-menu{top:3.25rem;right:.5rem;min-width:220px}}
/* TOOLTIP (D5.3) — single reused node. Long-press on touch (500ms), hover on desktop. */
.tooltip{position:fixed;display:none;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.15em;padding:.375rem .625rem;background:var(--ink,#0A090C);color:var(--parchment);border:1px solid var(--ember);border-radius:6px;z-index:400;pointer-events:none;white-space:nowrap;max-width:260px;overflow:hidden;text-overflow:ellipsis}
.tooltip.visible{display:block}
/* Toast stack — issue #62. Stacks at top-right, transient, dismissable.
   Pointer-events:none on the stack so clicks pass through; pointer-events:auto
   on the individual toast so the close button works. */
.toast-stack{position:fixed;top:1rem;right:1rem;z-index:500;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;max-width:min(420px,calc(100vw - 2rem))}
.toast{pointer-events:auto;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;padding:.75rem 1rem .75rem .9rem;background:var(--panel);border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--parchment);box-shadow:var(--shadow-lift);display:flex;align-items:flex-start;gap:.6rem;animation:toast-slide-in .18s ease-out}
.toast.toast-error{border-left:3px solid var(--error);background:var(--error-bg)}
.toast.toast-warn {border-left:3px solid var(--warn);background:var(--warn-bg)}
.toast.toast-info {border-left:3px solid var(--info);background:var(--info-bg)}
.toast-msg{flex:1;line-height:1.45;word-break:break-word}
.toast-close{background:transparent;border:none;color:var(--parchment);cursor:pointer;font-size:14px;line-height:1;padding:.1rem .35rem;opacity:.6;transition:opacity .12s}
.toast-close:hover{opacity:1}
.toast.toast-out{animation:toast-slide-out .18s ease-in forwards}
@keyframes toast-slide-in {from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes toast-slide-out {from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}
@media(max-width:640px){.toast-stack{top:auto;bottom:5rem;left:1rem;right:1rem;max-width:none}.toast{font-size:12px}}
/* Suppress iOS Safari's native long-press callout on elements that already
   trigger our custom tooltip. Non-tooltipped elements keep default behaviour. */
[data-tip]{-webkit-touch-callout:none}
/* PULL-TO-REFRESH (D5.2) — phone-only indicator sits at the top of .cms-main, follows
   the drag, fires reloadCampaign() past 90px. Guarded against kb-open + scroll mid-list. */
.ptr-indicator{display:none;align-items:center;gap:.5rem;justify-content:center;padding:.75rem 0;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.18em;color:var(--ember);transform:translateY(0);transition:transform .2s ease-out}
.ptr-indicator.visible{display:flex}
.ptr-spinner{width:14px;height:14px;border:2px solid var(--ember);border-top-color:transparent;border-radius:50%;animation:ptr-spin .8s linear infinite}
@keyframes ptr-spin{to{transform:rotate(360deg)}}
@media(min-width:641px){.ptr-indicator{display:none !important}}
.empty-state{padding:3rem 1rem;text-align:center;color:var(--muted);font-size:13px;font-style:italic}
::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--blood);border-radius:2px}
@media(max-width:700px){.blog-layout{grid-template-columns:1fr}.blog-sidebar{display:none}}
@media(max-width:640px){
  html,body{overflow-x:clip;max-width:100vw}
  .cms-wrap{grid-template-columns:1fr}
  .cms-sidebar{display:none}
  .cms-main{padding:1rem 1rem 72px;max-width:100%}
  .post-view{padding:1rem 1.375rem 2rem}
  .post-body{font-size:17px;line-height:1.75}
  .post-body p{margin-bottom:1.1rem}
  .post-title{margin-bottom:1rem}
  .header-inner{padding:.75rem 1rem}
  .modal-box{max-width:calc(100vw - 2rem)}
  /* D4a — Oracle full-screen takeover. Chat toggle sits above the bottom nav;
     the open panel covers the whole viewport with panel-surface + accent rule. */
  .chat-widget{bottom:calc(72px + env(safe-area-inset-bottom,0px));right:1rem}
  .chat-panel.open{position:fixed;inset:0;width:100%;height:100%;max-width:none;border:none;border-radius:0;box-shadow:none;z-index:200;padding-bottom:env(safe-area-inset-bottom,0px)}
  .chat-panel.open .chat-header{padding:1rem 1.25rem}
  .chat-panel.open .chat-close{font-size:20px;padding:.35rem .6rem}
  .chat-panel.open .chat-input-row{padding:.85rem 1rem;align-items:center;gap:.6rem}
  .chat-panel.open .chat-input{border-radius:20px;font-size:14px;height:44px;padding:.6rem 1.1rem;line-height:1.4}
  .chat-panel.open .chat-send{border-radius:50%;width:44px;height:44px;padding:0;background:var(--ember);color:var(--deep);font-size:0;letter-spacing:0;display:flex;align-items:center;justify-content:center;position:relative}
  .chat-panel.open .chat-send::after{content:'↑';font-family:var(--font-body);font-size:22px;font-weight:600;line-height:1;color:var(--deep)}
  .chat-panel.open .chat-send:hover{background:#D8A048}
  .chat-panel.open .chat-send:disabled{background:rgba(200,146,58,.35)}
  /* D4b reader chrome: when viewing a chronicle on phone, strip the header to
     brand only. Header-nav chrome (bug/theme/cms buttons, campaign badge)
     would crowd a novel-mode reader and pulls attention from the prose. */
  body[data-view="post"] .header-nav,
  body[data-view="post"] .campaign-badge,
  body[data-view="post"] .versyr-attribution{display:none}
  body[data-view="post"] .site-brand-name{font-size:15px}
  /* Phone header — bottom-nav already covers navigation for logged-in users,
     so the 5 top text nav-links + campaign-badge are redundant and push the
     header off-screen at 300-400px widths. Keep only CMS entry + icon buttons. */
  .header-nav .nav-link{display:none}
  .campaign-badge.visible{display:none}
  /* D4c phone composer: title becomes the page, body prose has no chrome.
     Field labels survive on meta rows to keep form structure readable —
     full chip-row meta + action-sheet Publish deferred to a follow-up. */
  #cms-editor > .cms-page-title,#cms-editor > .cms-page-sub{display:none}
  #cms-editor .field:has(#ed-title) .field-label{display:none}
  #cms-editor #ed-title{font-family:var(--font-display);font-size:22px;font-weight:300;letter-spacing:-0.01em;color:var(--ember);background:transparent;border:none;padding:0.25rem 0;border-bottom:1px solid var(--border-soft)}
  #cms-editor #ed-title::placeholder{color:rgba(200,146,58,0.35);font-style:italic}
  #cms-editor .field:has(#ed-body) .field-label{font-size:8px;color:var(--muted);margin-bottom:0.3rem}
  #cms-editor #ed-body{background:transparent;border:none;border-top:1px solid var(--border-soft);border-radius:0;padding:0.75rem 0;font-family:var(--font-display);font-size:16px;line-height:1.7;color:var(--parchment-body)}
  #cms-editor #ed-body:focus{border-color:var(--border-2)}
  /* Phone-only chip-row meta. Inline num/datum/chars/loc rows + the
     post-status-bar collapse into tappable chips above the title. */
  body[data-view="compose"] #cms-editor .row2:has(#ed-num),
  body[data-view="compose"] #cms-editor .row2:has(#ed-chars),
  body[data-view="compose"] #cms-editor .post-status-bar{display:none}
  body[data-view="compose"] .composer-chip-row{display:flex;gap:.5rem;flex-wrap:wrap;padding:.5rem 0;border-bottom:1px solid rgba(200,146,58,0.15);margin-bottom:.75rem}
  body[data-view="compose"] .composer-chip-row .chip{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.15em;padding:.375rem .75rem;border:1px solid var(--ember);background:transparent;color:var(--parchment);border-radius:999px;cursor:pointer;line-height:1.4}
  body[data-view="compose"] .composer-chip-row .chip[aria-pressed="true"]{background:var(--blood);border-color:var(--blood)}
  /* Phone: floating Save in the header-right corner, visible while the soft
     keyboard is open (bottom-nav hides via body.kb-open but header doesn't). */
  body[data-view="compose"] .composer-header-save{display:block;position:fixed;top:.5rem;right:.75rem;z-index:130;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.18em;padding:.5rem .9rem;background:var(--blood);color:var(--parchment);border:none;border-radius:999px;cursor:pointer}
  body[data-view="compose"] #cms-editor .btn-row .btn.primary{display:none}
  body[data-view="compose"] .header-inner{padding-right:6rem}
}
.composer-chip-row{display:none}
.composer-header-save{display:none}
/* D3 — phone bottom nav. 5 tabs + swipe-up world sheet. Fixed position, safe-area aware. */
.cms-mobile-nav,.cms-mobile-world-sheet,.cms-mobile-world-backdrop{display:none}
@media(max-width:640px){
  .cms-mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border-2);align-items:center;justify-content:space-around;padding:0 8px 0;padding-bottom:env(safe-area-inset-bottom,0px);z-index:120;min-height:60px}
  .cms-mobile-nav::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
  .cms-mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:var(--touch-min);min-height:var(--touch-min);justify-content:center;background:none;border:none;cursor:pointer;color:var(--muted);transition:color var(--t-fast);padding:6px 4px}
  .cms-mobile-nav-item .g{font-size:18px;line-height:1;color:inherit}
  .cms-mobile-nav-item .t{font-family:var(--font-mono);font-size:7px;letter-spacing:0.12em;color:inherit;text-transform:uppercase}
  .cms-mobile-nav-item.active{color:var(--ember)}
  /* Always render on phone so the transform transition can fire. Non-phone
     widths keep the base display:none at line ~621. */
  .cms-mobile-world-sheet{position:fixed;bottom:60px;left:0;right:0;background:var(--panel);border-top:1px solid var(--border-2);padding:1rem 1rem calc(1rem + env(safe-area-inset-bottom,0px));z-index:119;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));display:block;transform:translateY(calc(100% + 60px + env(safe-area-inset-bottom,0px) - var(--vv-hidden,0px)));transition:transform .22s ease-out}
  .cms-mobile-world-sheet.open{transform:translateY(calc(var(--vv-hidden,0px) * -1))}
  .cms-mobile-world-sheet::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ember),var(--blood),var(--ember),transparent)}
  .cms-mobile-world-grab{width:32px;height:3px;background:var(--muted);border-radius:2px;margin:0 auto 0.75rem;opacity:0.5}
  .cms-mobile-world-item{display:flex;align-items:center;gap:0.75rem;padding:0.8rem 1rem;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--parchment);font-family:var(--font-mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;width:100%;text-align:left;margin-bottom:0.5rem;transition:border-color var(--t-fast)}
  .cms-mobile-world-item:hover{border-color:var(--blood)}
  .cms-mobile-world-item .g{font-size:16px;color:var(--ember)}
  .cms-mobile-world-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:118;display:block;opacity:0;pointer-events:none;transition:opacity .22s ease-out;transform:translateY(calc(var(--vv-hidden,0px) * -1))}
  .cms-mobile-world-backdrop.open{opacity:1;pointer-events:auto}
  /* Keyboard-open state: soft keyboard + fixed bottom-nav together squeezed the
     Charaktere / Schauplatz inputs off-screen (bug-1776892913088, reporter Maxi).
     Hide the nav while a field is focused, and reduce bottom padding so the form
     end has room to scroll into view above the keyboard. */
  body.kb-open .cms-mobile-nav{display:none}
  body.kb-open .cms-main{padding-bottom:1rem}
  /* Bottom nav is a CMS surface (Home/Chron./Write/World/Oracle all route into
     the CMS). Hide it on blog, post, and login views so public visitors don't
     see dead targets — on public views cmsShow is never called and clicking a
     tab just silently toggled state without changing anything visible. */
  body[data-view="blog"] .cms-mobile-nav,
  body[data-view="post"] .cms-mobile-nav,
  body[data-view="login"] .cms-mobile-nav{display:none}
  body[data-view="blog"] .cms-main,
  body[data-view="post"] .cms-main,
  body[data-view="login"] .cms-main{padding-bottom:1rem}
}
/* Compact header for tablet + phone (≤1023px). Desktop nav overflows on
   narrower viewports because the campaign name + attribution + 5 nav links +
   CMS button + icon buttons together exceed ~820px at 1.5rem gaps.
   Swap the text brand for the italic-ember V monogram and tighten nav gaps. */
@media (max-width:1023px){
  .site-brand-name,.versyr-attribution{display:none}
  .site-brand-mono{display:inline-block}
  .header-nav{gap:.6rem}
  .header-inner{padding:.75rem 1rem}
  .nav-link{font-size:8px;letter-spacing:.12em}
  /* Hide inline public nav on tablet + phone — the public hamburger (Task 7)
     carries Chroniken/NSCs/Charaktere/Orte/Galerie at those widths. */
  .header-nav .nav-link{display:none}
}
/* Tablet sidebar (641-1023px) — vertical icon+label tiles, sticky-scrollable.
   Replaces the prior icon-only rail (D3b) which made discoverability poor:
   labels are required for non-cryptic navigation, group headers are required
   to mirror the desktop structure. Vertical 2px ember→blood accent on the
   right edge stays. position:sticky + align-self:start so the sidebar stays
   pinned to the viewport while the main pane scrolls underneath; sidebar
   itself scrolls independently when its own content exceeds 100vh. */
@media (min-width:641px) and (max-width:1023px){
  .cms-wrap{grid-template-columns:140px 1fr;align-items:start}
  .cms-sidebar{padding:0.5rem 0 1rem;position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;overscroll-behavior:contain}
  .cms-sidebar::after{content:'';position:absolute;top:0;right:0;width:2px;height:100%;background:linear-gradient(180deg,transparent,var(--ember),var(--blood),var(--ember),transparent);pointer-events:none}
  .cms-user-bar{display:none}
  .cms-sidebar-label{display:block;text-align:center;font-size:8.5px;letter-spacing:.18em;padding:.5rem .25rem .35rem}
  .cms-nav-item{flex-direction:column;justify-content:flex-start;align-items:center;gap:.3rem;padding:.6rem .35rem;border-left:none;position:relative;text-align:center;min-height:64px}
  .cms-nav-item .nav-icon{font-size:22px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
  .cms-nav-item .nav-label{display:block;font-size:9.5px;letter-spacing:.06em;line-height:1.15;text-align:center;white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:24px}
  .cms-nav-item.active{border-left:none;background:rgba(122,20,20,.18)}
  .cms-nav-item.active::before{content:'';position:absolute;left:12px;right:12px;bottom:4px;height:2px;background:var(--ember)}
  .cms-nav-item:hover{background:rgba(122,20,20,.12)}
  .cms-divider{margin:.4rem auto;width:80%;border:none;border-top:1px solid var(--border)}
  .cms-divider.cms-subdivider{margin:.2rem auto;width:50%;opacity:.5}
  .cms-main{padding:1.25rem 1.5rem}

  /* Header retired on tablet — floating avatar (top-right) + hamburger
     (top-left, blog views only) replace it. Header element kept in flow
     as a transparent fixed overlay so its existing children (avatar +
     hamburger) keep their event handlers; brand + nav-links + sync-dot
     hidden. justify-content:space-between in .header-inner naturally
     parks hamburger at left and avatar at right with the brand collapsed. */
  .site-header{background:transparent;border:none;position:fixed;top:0;left:0;right:0;z-index:120;pointer-events:none}
  .site-header::after{display:none}
  .header-inner{padding:8px 12px;max-width:none}
  .site-brand,.header-nav .nav-link,.sync-dot{display:none}
  /* Hamburger and avatar both float as fixed corner buttons on tablet,
     symmetric to each other (40×40, 1.5rem from edge — matching the Oracle
     toggle's 1.5rem padding for visual consistency across the three corner
     icons: hamburger top-left, avatar top-right, oracle bottom-right). */
  .public-hamburger{pointer-events:auto;position:fixed;top:1.5rem;left:1.5rem;margin:0;z-index:130}
  .user-avatar{pointer-events:auto;position:fixed;top:1.5rem;right:1.5rem;width:40px;height:40px;margin:0;z-index:130}
  body[data-view="blog"] .public-hamburger,
  body[data-view="post"] .public-hamburger,
  body[data-view="login"] .public-hamburger,
  body[data-view="gallery"] .public-hamburger{display:inline-flex;align-items:center;justify-content:center}
  /* User-menu anchors below the now-floating avatar with a small gap. */
  .user-menu{top:calc(1.5rem + 40px + .5rem);right:1.5rem}

  /* Push primary content down on tablet so the floating buttons (top:1.5rem,
     40px tall = bottom edge at ~4rem) don't overlap headlines or sidebar
     content. Login screen is exempt — content is vertically centered, well
     below the corner buttons. */
  .blog-hero{padding-top:5rem}
  .cms-main{padding-top:4rem}
  .cms-sidebar{padding-top:3.5rem}
}
/* On desktop+phone, nav spans layout naturally. Give icon a tiny min-width so flex gap feels consistent. */
.cms-nav-item .nav-icon{display:inline-flex;align-items:center;justify-content:center;min-width:14px}

/* ── Character / NPC picker (image generator) ──────────────────────────
   Multi-select grid that replaces the comma-typed #img-chars input.
   Reused by future feature flows (involved-characters elsewhere) by
   mounting this DOM and calling openCharPicker(). */
.picker-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;min-height:0}
.picker-chips:empty{display:none}
.picker-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .5rem .25rem .65rem;background:rgba(200,146,58,.15);border:1px solid rgba(200,146,58,.4);border-radius:2px;font-family:'DM Mono',monospace;font-size:10px;color:var(--parchment);letter-spacing:.05em}
.picker-chip-x{background:none;border:none;color:var(--muted);font-size:14px;line-height:1;cursor:pointer;padding:0;margin:0;width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center}
.picker-chip-x:hover{color:var(--ember)}

.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem;max-height:60vh;overflow-y:auto;padding-right:.25rem}
.picker-section-head{grid-column:1/-1;font-family:'DM Mono',monospace;font-size:9px;color:var(--ember);text-transform:uppercase;letter-spacing:.18em;padding:.5rem 0 .15rem}
.picker-section-head:first-child{padding-top:0}

.picker-tile{position:relative;background:var(--deep);border:1px solid var(--border);border-radius:2px;padding:.6rem .5rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;cursor:pointer;transition:all var(--t-fast,120ms ease);text-align:center;color:var(--body);font-family:'Outfit',sans-serif}
.picker-tile:hover{border-color:rgba(200,146,58,.4);background:rgba(200,146,58,.06)}
.picker-tile.active{border-color:var(--blood);background:rgba(122,20,20,.18)}
.picker-tile.active .picker-tile-name{color:var(--ember)}

.picker-thumb{width:56px;height:56px;border-radius:50%;background-size:cover;background-position:center;background-color:rgba(0,0,0,.3);border:1px solid var(--border)}
.picker-thumb.mono{display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--ember);background-color:rgba(122,20,20,.2)}

.picker-tile-name{font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--parchment);line-height:1.15;font-weight:400}
.picker-tile-sub{font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;line-height:1.2;min-height:10px}

.picker-tag{position:absolute;top:.35rem;right:.35rem;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.12em;text-transform:uppercase;padding:.1rem .3rem;border:1px solid var(--border);border-radius:1px;color:var(--muted);background:rgba(0,0,0,.4)}
.picker-tag.pc{color:var(--ember);border-color:rgba(200,146,58,.4)}
.picker-tag.npc{color:var(--body);border-color:var(--border)}

.picker-footer{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}
.picker-count{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.picker-actions{display:flex;gap:.5rem}
