/* ===========================================================
   Wildcat Wonder Studio — application chrome / design system
   (the newspaper look lives in paper.css)
   =========================================================== */
:root{
  /* brand (matches the paper) */
  --brand:#215E99; --brand-600:#1b4f81; --brand-700:#163f66; --brand-50:#eef4fb; --brand-100:#dde9f6;
  --yellow:#FFD400;
  /* accents — single source of truth; muted variants are overridden in body.dark */
  --accent-coral:#E97132; --accent-gold:#caa900;
  --warn-bg:#fff4e9; --warn-line:#f4d9bd; --warn-ink:#9a5418;
  /* neutrals */
  --ink:#15202b; --muted:#5d6b79; --faint:#8b97a4;
  --line:#e4dfd2; --line-2:#d8d2c3;
  --bg:#f3f1eb; --bg-2:#ebe7dc; --panel:#ffffff; --panel-2:#faf8f2;
  /* type + misc */
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --radius:11px; --radius-sm:8px; --radius-lg:16px;
  /* 8-pt spacing scale */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px;
  --shadow-sm:0 1px 2px rgba(40,33,24,.07);
  --shadow:0 2px 6px rgba(40,33,24,.08),0 10px 26px rgba(40,33,24,.07);
  --shadow-lg:0 14px 44px rgba(40,33,24,.16);
  --ease:cubic-bezier(.2,.7,.2,1);
  font-synthesis:none;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{height:100%}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  display:flex;flex-direction:column;overflow:hidden;
}
button{font-family:inherit}
h2{font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);margin:0 0 .55rem}
h3{margin:0}
[data-ico]{display:inline-flex;align-items:center;justify-content:center}
[data-ico] svg{width:1em;height:1em}
.btn [data-ico],.tab [data-ico]{font-size:15px;margin-right:.1rem}

/* ---------- top bar ---------- */
.appbar{
  display:flex;align-items:center;gap:1.1rem;padding:.62rem 1.05rem;
  background:linear-gradient(180deg,#fff,#fbf9f4);
  border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(18,38,63,.03);
  position:relative;z-index:60;flex:none;
}
.appbar-brand{display:flex;align-items:center;gap:.6rem;min-width:200px}
.appbar-logo{height:42px;width:auto;display:block;filter:drop-shadow(0 1px 1px rgba(0,0,0,.08))}
.appbar-title{font-weight:700;font-size:1.12rem;letter-spacing:-.01em}
.appbar-title span{color:var(--brand)}
.appbar-sub{font-size:.72rem;color:var(--muted);margin-top:-1px}

.tabs{display:flex;gap:.3rem;margin:0 auto;background:var(--bg-2);padding:.25rem;border-radius:12px}
.tab{
  display:flex;align-items:center;gap:.45rem;border:none;background:transparent;color:var(--muted);
  padding:.42rem .85rem;border-radius:9px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .15s var(--ease);
}
.tab:hover{color:var(--ink);background:rgba(255,255,255,.6)}
.tab.is-active{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm);font-weight:700}
.tab-num{display:none}
.tab-ico{color:inherit}
.tab.is-active .tab-ico{color:var(--brand)}

.appbar-actions{display:flex;align-items:center;gap:.4rem}
.divider-v{width:1px;height:24px;background:var(--line-2);margin:0 .2rem}
.save-state{display:flex;align-items:center;gap:.35rem;font-size:.74rem;color:var(--muted);min-width:64px}
.save-state .dot{width:7px;height:7px;border-radius:50%;background:#39b36a;box-shadow:0 0 0 3px rgba(57,179,106,.16)}
.save-state.saving .dot{background:#d8a200;box-shadow:0 0 0 3px rgba(216,162,0,.16)}
.save-state.warn{color:#b4690e}.save-state.warn .dot{background:#e0820f;box-shadow:0 0 0 3px rgba(224,130,15,.18)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.35rem;border:1px solid var(--line-2);background:#fff;color:var(--ink);
  padding:var(--s-2) var(--s-3);border-radius:9px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .14s var(--ease);white-space:nowrap;
}
.btn:hover{border-color:#bcc8d6;background:var(--panel-2);transform:translateY(-1px)}
.btn:active{transform:scale(.97)}
.tab:active,.chip:active{transform:scale(.97)}
.btn:focus-visible,.tab:focus-visible,.chip:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
/* editorial headline face (Fraunces) — titles only, never body/UI text */
.appbar-title,.empty-state h3,.modal-head h3,.read-h,.login-title,.input.title-input{font-family:var(--display)}
/* tactile card hover */
.tpl-card,.sub-card{transition:border-color .12s var(--ease),box-shadow .14s var(--ease)}
.tpl-card:hover,.sub-card:hover{border-color:var(--line-2);box-shadow:var(--shadow)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 1px 2px rgba(33,94,153,.3)}
.btn-primary:hover{background:var(--brand-600);border-color:var(--brand-600)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--bg-2);color:var(--ink);border-color:transparent}
.btn-sm{padding:.32rem .55rem;font-size:.78rem}
.btn-danger{color:#c0392b;border-color:#ecc9c5;background:#fff}
.btn-danger:hover{background:#fdf3f1;border-color:#e0a89f}
.btn-split{border-left:none;border-top-left-radius:0;border-bottom-left-radius:0;padding-left:.4rem;padding-right:.4rem}
.addwrap{display:flex;position:relative}
.addwrap .btn-primary{border-top-right-radius:0;border-bottom-right-radius:0}
.icon-btn{border:none;background:transparent;color:var(--muted);font-size:1rem;cursor:pointer;padding:.25rem .4rem;border-radius:7px;line-height:1}
.icon-btn:hover{background:var(--bg-2);color:var(--ink)}
.link{background:none;border:none;color:var(--brand);font-weight:600;cursor:pointer;padding:0;text-decoration:underline;font-size:inherit}

/* dropdown menu (templates) */
.menu{position:absolute;top:calc(100% + 6px);right:0;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:.35rem;z-index:80}
.menu-item{display:flex;flex-direction:column;gap:1px;padding:.5rem .6rem;border-radius:8px;cursor:pointer}
.menu-item:hover{background:var(--brand-50)}
.menu-item b{font-size:.84rem;font-weight:600}
.menu-item small{font-size:.72rem;color:var(--muted)}
.menu-sep{height:1px;background:var(--line);margin:.3rem .2rem}

/* ---------- layout ---------- */
.app-shell{flex:1;min-height:0;display:flex;flex-direction:column}
.view{flex:1;min-height:0;display:flex}

/* ---------- sidebar ---------- */
.sidebar{width:var(--ww-sidebar-w,296px);flex:none;border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-height:0}
.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem .9rem .55rem}
.sidebar-title{font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:.45rem}
.count-pill{font-size:.7rem;font-weight:700;color:var(--muted);background:var(--bg-2);border-radius:20px;padding:.05rem .45rem}
.search-wrap{position:relative;margin:0 .9rem .5rem}
.search-ico{position:absolute;left:.55rem;top:50%;transform:translateY(-50%);color:var(--faint);font-size:14px}
.search{width:100%;border:1px solid var(--line-2);border-radius:9px;padding:.42rem .6rem .42rem 1.9rem;font-size:.84rem;background:var(--panel-2);color:var(--ink)}
.search:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px var(--brand-100)}
.article-list{list-style:none;margin:0;padding:.1rem .55rem 1rem;overflow:auto;flex:1}
.article-row{display:flex;gap:.55rem;align-items:flex-start;padding:.55rem .6rem;border-radius:9px;cursor:pointer;border:1px solid transparent;transition:background .12s}
.article-row:hover{background:var(--panel-2)}
.article-row.is-active{background:var(--brand-50);border-color:var(--brand-100)}
.article-row .sec-dot{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:none;box-shadow:0 0 0 2px #fff}
.article-row .ar-main{min-width:0;flex:1}
.article-row .ar-title{font-weight:600;font-size:.86rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.article-row .ar-meta{font-size:.72rem;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ar-badge{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#fff;background:var(--faint);border-radius:5px;padding:2px 5px;align-self:center}
.badge-lead{background:var(--accent-coral)}.badge-note{background:var(--accent-gold);color:#2a2600}.badge-off{background:#b3bdc8}
.sidebar-foot{padding:.5rem .9rem;border-top:1px solid var(--line);font-size:.72rem;color:var(--faint)}
.hint{font-size:.74rem;color:var(--muted);line-height:1.5;margin:.15rem 0 .5rem}

/* ---------- editor (two-pane) ---------- */
.editor{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.empty-state{margin:auto;text-align:center;color:var(--muted);padding:2rem}
.empty-state img{width:120px;opacity:.6;margin-bottom:.9rem;filter:drop-shadow(0 2px 4px rgba(40,33,24,.1))}
.empty-state h3{font-size:1.35rem;margin-bottom:.25rem;color:var(--ink)}
.empty-sub{max-width:300px;margin:.15rem auto 1.15rem;color:var(--muted);font-size:.9rem;line-height:1.5}
.editor-split{flex:1;display:flex;min-height:0}
.editor-form{flex:1;min-width:300px;overflow:auto;padding:var(--s-5) var(--s-5) var(--s-8);max-width:none}
.editor-preview{flex-grow:0;flex-shrink:1;flex-basis:var(--ww-preview-w,460px);min-width:0;border-left:1px solid var(--line);background:var(--bg-2);display:flex;flex-direction:column;min-height:0}
.ep-head{display:flex;justify-content:space-between;align-items:center;padding:var(--s-2) var(--s-3);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);border-bottom:1px solid var(--line)}
.ep-hint{font-weight:600;text-transform:none;letter-spacing:0;color:var(--muted)}
.ep-stage{flex:1;overflow:auto;padding:var(--s-4);display:flex;justify-content:center}
/* ---- draggable column dividers ---- */
.gutter-col{flex:0 0 9px;align-self:stretch;position:relative;cursor:col-resize;background:transparent;touch-action:none;z-index:6;margin:0 -1px}
.gutter-col::before{content:"";position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translateX(-50%);background:transparent;border-radius:2px;transition:background .12s,width .12s}
.gutter-col:hover::before,.gutter-col.dragging::before{background:var(--brand);width:3px}
.gutter-col::after{content:"⋮";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:13px;line-height:1;color:transparent;transition:color .12s}
.gutter-col:hover::after,.gutter-col.dragging::after{color:var(--brand)}
body.resizing-col{cursor:col-resize;-webkit-user-select:none;user-select:none}

/* fields */
.field{margin-bottom:var(--s-4)}
.field>label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.35rem}
.field .sub{font-weight:500;text-transform:none;letter-spacing:0;color:var(--faint)}
.input,.select,.textarea{width:100%;border:1px solid var(--line-2);border-radius:9px;padding:.55rem .7rem;font-size:.92rem;color:var(--ink);background:#fff;font-family:inherit;transition:border .12s,box-shadow .12s}
.input:focus,.select:focus,.textarea:focus,.rt:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-100)}
.input.title-input{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;padding:.5rem .7rem}
.row{display:flex;gap:var(--s-3);flex-wrap:wrap}
.row>.field{flex:1;min-width:140px}
.editor-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.1rem}
.editor-head .ehtitle{font-size:.74rem;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;font-weight:700}

/* rich text */
.rt-toolbar{display:flex;flex-wrap:wrap;gap:.15rem;border:1px solid var(--line-2);border-bottom:none;border-radius:9px 9px 0 0;padding:.3rem;background:var(--panel-2);position:sticky;top:0;z-index:2}
.rt-toolbar button{border:1px solid transparent;background:transparent;border-radius:7px;padding:.3rem .5rem;font-size:.82rem;cursor:pointer;color:var(--ink);min-width:30px;font-weight:600}
.rt-toolbar button:hover{background:#e7eef6}
.rt-toolbar .sep{width:1px;background:var(--line-2);margin:3px 3px}
.rt{min-height:230px;border:1px solid var(--line-2);border-radius:0 0 9px 9px;padding:.85rem .95rem;font-size:.95rem;line-height:1.6;background:#fff;overflow:auto}
.rt p{margin:0 0 .7em}.rt h3{font-size:1.02rem;margin:.2em 0 .4em}
.rt blockquote{border-left:3px solid var(--accent-coral);margin:.6em 0;padding:.1em .8em;color:#444;font-style:italic}
.ww-jump{margin:.7em 0;padding:.4em .7em;border:1px dashed var(--accent-coral);border-radius:8px;background:#fff4ec;color:#b85a2c;font-size:.78rem;font-weight:700;text-align:center;letter-spacing:.01em;-webkit-user-select:none;user-select:none}
body.dark .ww-jump{background:#2a2012;border-color:#7a4a28;color:#e8b07a}
.wordcount{display:flex;gap:.8rem;font-size:.72rem;color:var(--faint);margin-top:.35rem}
.wordcount b{color:var(--muted);font-weight:600}

/* segmented control */
.seg{display:inline-flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden;background:#fff}
.seg button{border:none;background:#fff;padding:.44rem .65rem;font-size:.8rem;cursor:pointer;color:var(--muted);border-right:1px solid var(--line);font-weight:600;transition:all .12s}
.seg button:last-child{border-right:none}
.seg button:hover{background:var(--panel-2)}
.seg button.on{background:var(--brand);color:#fff}
.checks{display:flex;flex-direction:column;gap:.5rem}
.check{display:flex;align-items:center;gap:.5rem;font-size:.86rem;color:var(--ink);cursor:pointer}
.check input{width:16px;height:16px;accent-color:var(--brand)}

/* collapsible panel */
.panel{border:1px solid var(--line);border-radius:11px;margin-bottom:1.05rem;overflow:hidden;background:var(--panel-2)}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:.6rem .8rem;cursor:pointer;font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);user-select:none}
.panel-head .chev{transition:transform .15s var(--ease);color:var(--faint)}
.panel.open .panel-head .chev{transform:rotate(90deg)}
.panel-body{padding:.2rem .8rem .9rem;display:none}
.panel.open .panel-body{display:block}

/* byline chips */
.bylinebox{border:1px solid var(--line-2);border-radius:9px;background:#fff;padding:.35rem;display:flex;flex-wrap:wrap;gap:.3rem;align-items:center;min-height:42px}
.bylinebox:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-100)}
.tok{display:inline-flex;align-items:center;gap:.3rem;background:var(--brand-50);border:1px solid var(--brand-100);color:var(--brand-700);border-radius:20px;padding:.18rem .25rem .18rem .6rem;font-size:.82rem;font-weight:600}
.tok.guest{background:#fff4e9;border-color:#f4d9bd;color:#9a5418}
.tok .x{cursor:pointer;font-size:.9rem;line-height:1;color:inherit;opacity:.6;padding:0 .15rem}
.tok .x:hover{opacity:1}
.byline-add{position:relative;flex:1;min-width:120px}
.byline-input{border:none;outline:none;font-size:.88rem;width:100%;padding:.25rem;background:transparent;color:var(--ink)}
.byline-pop{position:absolute;top:calc(100% + 4px);left:0;min-width:220px;max-height:240px;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);z-index:80;padding:.25rem}
.byline-opt{padding:.4rem .55rem;border-radius:7px;cursor:pointer;font-size:.85rem;display:flex;justify-content:space-between;gap:.5rem}
.byline-opt:hover,.byline-opt.hl{background:var(--brand-50)}
.byline-opt small{color:var(--faint)}
.byline-opt.add-guest{color:var(--brand);font-weight:600;border-top:1px solid var(--line);border-radius:0;margin-top:.2rem}

/* images */
.img-grid{display:flex;flex-direction:column;gap:.5rem}
.img-drop{border:2px dashed #c2d0e0;border-radius:11px;padding:1rem;text-align:center;color:var(--muted);font-size:.84rem;cursor:pointer;background:var(--panel-2);transition:all .12s}
.img-drop:hover{border-color:var(--brand);color:var(--brand)}
.img-drop.drag{background:var(--brand-50);border-color:var(--brand);color:var(--brand)}
.img-item{display:flex;gap:.7rem;align-items:flex-start;border:1px solid var(--line);border-radius:11px;padding:var(--s-2);background:#fff}
.img-item img{width:92px;height:66px;object-fit:cover;border-radius:7px;flex:none;background:#eef1f5}
.img-item .img-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:.35rem}
.img-item .row{gap:.4rem}
.img-item .mini{font-size:.7rem;color:var(--muted);display:flex;align-items:center;gap:.25rem}
.img-item .input{padding:.34rem .5rem;font-size:.82rem}
.img-item .select{padding:.34rem .4rem;font-size:.8rem}
.photo-lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.5rem}
.photo-lib-thumb{width:100%;height:74px;object-fit:cover;border-radius:8px;cursor:pointer;border:1px solid var(--line);background:var(--bg-2)}
.photo-lib-thumb:hover{outline:2px solid var(--brand);outline-offset:1px}
.crop-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.8rem}
.crop-controls .mini{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--muted)}
.crop-controls input[type=range]{width:120px}
.tpl-card{border:1px solid var(--line);border-radius:11px;padding:var(--s-3) var(--s-3);margin-bottom:var(--s-3);background:var(--panel-2)}
.tpl-head{display:flex;gap:.5rem;align-items:center;margin-bottom:.55rem}
.tpl-head .input{flex:1;font-weight:600}
.tpl-card .field{margin-bottom:.5rem}
.tpl-card .row{gap:.5rem}
/* Recurring-features modal is narrow — keep Section / Size / Color from
   overflowing. Section takes its own line; the two segmented pickers fill
   the line below and shrink to fit so no button ever gets clipped. */
.tpl-controls>.field{min-width:0}
.tpl-controls>.field:first-child{flex-basis:100%}
.tpl-controls .seg{display:flex;width:100%}
.tpl-controls .seg button{flex:1;min-width:0;padding-left:.3rem;padding-right:.3rem}

/* ---------- arrange ---------- */
.arrange-wrap{flex:1;display:flex;min-height:0}
.arrange-meta{width:var(--ww-meta-w,354px);flex:none;border-right:1px solid var(--line);background:var(--panel);padding:var(--s-4) var(--s-4) var(--s-7);overflow:auto}
.meta-form .field{margin-bottom:.7rem}.meta-form .row{gap:.6rem}

/* header style picker */
.header-picker{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.hp-opt{border:1.5px solid var(--line-2);border-radius:11px;padding:.4rem;cursor:pointer;background:#fff;transition:all .14s;text-align:center}
.hp-opt:hover{border-color:#b6c4d4;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.hp-opt.on{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-100)}
.hp-thumb{height:62px;border-radius:7px;overflow:hidden;background:var(--panel-2);display:flex;align-items:center;justify-content:center;margin-bottom:.35rem;border:1px solid var(--line)}
.hp-name{font-size:.76rem;font-weight:700;color:var(--ink)}
/* miniature nameplate thumbnails (pure CSS) */
.hpm{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:5px}
.hpm .l{font:800 8px/1 Arial;color:#215E99;letter-spacing:-.3px}
.hpm .bar{width:100%;height:8px;background:#215E99;border-radius:2px}
.hpm .rule{width:100%;height:0;border-top:1.5px solid #215E99}
.hpm .tiny{font:700 5px/1 Arial;color:#5d6b79;letter-spacing:.3px}
.hpm.b-bold{background:#215E99}.hpm.b-bold .l{color:#fff}.hpm.b-bold .tiny{color:#dbe8f6}
.hpm .frame{border:1.5px double #215E99;border-radius:3px;padding:3px 8px;display:flex;align-items:center;justify-content:center}

/* toggles */
.toggle-list{display:flex;flex-direction:column;gap:.5rem}
.toggle{display:flex;gap:.6rem;align-items:flex-start;padding:var(--s-2) var(--s-3);border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;transition:border .12s}
.toggle:hover{border-color:var(--line-2)}
.toggle input{width:17px;height:17px;margin-top:1px;flex:none;accent-color:var(--brand)}
.toggle .t-main{font-size:.83rem;font-weight:600}
.toggle .t-sub{font-size:.73rem;color:var(--muted);margin-top:1px;line-height:1.4}

/* running order */
.arrange-order{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.arrange-order-head{padding:var(--s-4) var(--s-5) var(--s-1)}
.arrange-order-head h2{margin-bottom:.3rem}
.order-list{list-style:none;margin:0;padding:var(--s-2) var(--s-5) var(--s-7);overflow:auto;flex:1}
.order-sec{display:flex;align-items:center;gap:.5rem;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin:1.1rem 0 .4rem;padding-top:.75rem;border-top:1px dashed var(--line-2)}
.order-sec:first-child{border-top:none;margin-top:.2rem;padding-top:0}
.order-sec .sline{flex:1;height:2px;border-radius:2px;opacity:.5}
.order-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .65rem;border:1px solid var(--line-2);border-radius:10px;background:#fff;margin-bottom:.45rem;cursor:grab;box-shadow:var(--shadow-sm);transition:box-shadow .12s,transform .06s}
.order-item:hover{box-shadow:var(--shadow)}
.order-item.dragging{opacity:.4}
.order-item.drop-before{box-shadow:0 -3px 0 var(--brand)}
.order-item.drop-after{box-shadow:0 3px 0 var(--brand)}
.order-item .grip{color:#b3c0cf;font-size:1rem;flex:none;cursor:grab;letter-spacing:-2px}
.pagechip{font-size:.66rem;font-weight:800;color:#fff;background:var(--brand);border-radius:6px;padding:.16rem .4rem;flex:none;min-width:30px;text-align:center}
.pagechip.split{background:var(--accent-coral)}
.order-item .oi-main{flex:1;min-width:0}
.order-item .oi-title{font-weight:600;font-size:.86rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.order-item .oi-meta{font-size:.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.order-item .oi-ctrls{display:flex;align-items:center;gap:.3rem;flex:none}
.chip{font-size:.68rem;font-weight:700;border:1px solid var(--line-2);border-radius:20px;padding:.18rem .52rem;background:#fff;color:var(--muted);cursor:pointer;white-space:nowrap;transition:all .12s}
.chip:hover{border-color:#b6c4d4}
.chip.on{background:var(--brand);border-color:var(--brand);color:#fff}
.chip.note.on{background:var(--accent-gold);border-color:var(--accent-gold);color:#241f00}

/* ---------- modal ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(20,35,52,.45);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:200;padding:2rem}
.modal{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:560px;max-width:100%;max-height:86vh;display:flex;flex-direction:column;animation:pop .16s var(--ease)}
@keyframes pop{from{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--line)}
.modal-head h3{font-size:1.05rem;font-weight:700}
.modal-body{padding:var(--s-4) var(--s-5);overflow:auto}
.modal-foot{padding:var(--s-3) var(--s-5);border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:.6rem}
.modal-foot .right{display:flex;gap:.5rem;margin-left:auto}
.roster-row,.sec-row{display:flex;align-items:center;gap:.55rem;padding:.4rem 0;border-bottom:1px solid var(--line)}
.roster-row .grip,.sec-row .grip{color:#bcc8d6;cursor:grab}
.roster-row .input{flex:1}.roster-row .grade{width:96px;flex:none}
.sec-row{display:flex;flex-direction:column;gap:.45rem;padding:.6rem .65rem;border:1px solid var(--line);border-radius:11px;background:var(--panel-2);margin-bottom:.55rem}
.sec-row-top{display:flex;align-items:center;gap:.55rem}
.sec-row-top .input{flex:1}
.sec-swatch{width:30px;height:30px;border-radius:8px;flex:none;border:1px solid rgba(0,0,0,.18);cursor:pointer;position:relative;padding:0;box-shadow:inset 0 0 0 2px #fff;transition:transform .08s}
.sec-swatch:hover{transform:scale(1.06)}
.sec-swatch::after{content:"▾";position:absolute;right:-3px;bottom:-4px;font-size:10px;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:6px;line-height:1;padding:0 1px}
.sec-presets{display:flex;flex-wrap:wrap;gap:.3rem;padding-left:calc(30px + .55rem)}
.sec-chip{width:20px;height:20px;border-radius:6px;border:1px solid rgba(0,0,0,.14);cursor:pointer;padding:0;transition:transform .08s}
.sec-chip:hover{transform:scale(1.12)}
.sec-chip.on{box-shadow:0 0 0 2px var(--panel),0 0 0 4px var(--ink)}
.bulk{width:100%;min-height:80px}
.muted-note{font-size:.78rem;color:var(--muted);margin:.2rem 0 .6rem}

/* ---------- toasts ---------- */
.toasts{position:fixed;bottom:1.1rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:.5rem;z-index:300;align-items:center}
.toast{background:#16202b;color:#fff;padding:.6rem 1rem;border-radius:10px;font-size:.84rem;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.5rem;animation:toastin .2s var(--ease)}
.toast.ok{background:#1d7a45}.toast.err{background:#b23b32}
@keyframes toastin{from{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}

/* ---------- preview bar ---------- */
#view-preview{flex-direction:column}
.preview-bar{display:flex;align-items:center;gap:1rem;padding:.6rem 1.2rem;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap;flex:none}
.preview-bar .pagecount{font-size:.8rem;color:var(--muted);font-weight:600}
.preview-bar .zoom{display:flex;align-items:center;gap:.45rem;font-size:.74rem;color:var(--muted)}
.preview-bar .zoom-val{min-width:34px}
.preview-bar .print-tip{font-size:.72rem;color:var(--muted);margin-left:auto;max-width:420px;line-height:1.35}
.preview-bar .print-tip b{color:var(--ink)}
.preview-scroll{flex:1;overflow:auto;background:#566173;padding:1.6rem 0;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:18px 18px}

.measure-host{position:fixed;left:-99999px;top:0;width:7.5in;visibility:hidden;pointer-events:none;z-index:-1}

/* command palette (Ctrl-K) */
.cmdk-backdrop{position:fixed;inset:0;background:rgba(20,35,52,.4);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;z-index:250;padding-top:11vh}
.cmdk{width:560px;max-width:92vw;background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;animation:pop .14s var(--ease)}
.cmdk-input{width:100%;border:none;border-bottom:1px solid var(--line);padding:.9rem 1.1rem;font-size:1rem;outline:none;color:var(--ink);font-family:inherit}
.cmdk-list{max-height:360px;overflow:auto;padding:.35rem}
.cmdk-item{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.55rem .7rem;border-radius:8px;cursor:pointer;font-size:.88rem}
.cmdk-item.hl{background:var(--brand-50)}
.cmdk-empty{padding:1.2rem;text-align:center;color:var(--faint);font-size:.85rem}

/* typo flags + page-fill warnings */
.typo-flags{margin-top:.4rem;display:flex;flex-direction:column;gap:.3rem}
.typo-flag{font-size:.78rem;color:var(--warn-ink);background:var(--warn-bg);border:1px solid var(--warn-line);border-radius:8px;padding:.35rem .55rem}
.fill-warns{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.6rem}
.fill-warn{font-size:.78rem;color:var(--warn-ink);background:var(--warn-bg);border:1px solid var(--warn-line);border-radius:9px;padding:.45rem .65rem}

/* ---------- dark mode (app chrome only — the paper stays white) ---------- */
body.dark{
  --ink:#e7edf4;--muted:#9fb0c1;--faint:#76879a;
  --line:#28323d;--line-2:#36434f;
  --bg:#0f161d;--bg-2:#18222c;--panel:#161f28;--panel-2:#1d2832;
  --brand-50:#16273a;--brand-100:#20354c;
  --accent-coral:#b85a2c; --accent-gold:#9c8420;
  --warn-bg:#2a2012; --warn-line:#4a3a22; --warn-ink:#e8b07a;
}
body.dark .appbar{background:#141d26}
body.dark .tab.is-active{background:var(--panel-2);color:#cfe0f2}
body.dark .btn{background:var(--panel-2);color:var(--ink)}
body.dark .btn-ghost{background:transparent}
body.dark .btn:hover{background:#28333f;border-color:#3a4754}
body.dark .btn-primary{color:#fff}
body.dark .seg,body.dark .seg button{background:var(--panel-2);color:var(--muted)}
body.dark .input,body.dark .select,body.dark .textarea,body.dark .search,body.dark .rt,body.dark .bylinebox,
body.dark .menu,body.dark .img-item,body.dark .order-item,body.dark .toggle,body.dark .hp-opt,
body.dark .modal,body.dark .cmdk,body.dark .cmdk-input,body.dark .panel{background:var(--panel-2);color:var(--ink)}
body.dark .rt-toolbar,body.dark .img-drop,body.dark .hp-thumb{background:var(--panel)}
body.dark .rt-toolbar button{color:var(--ink)}
body.dark .rt-toolbar button:hover{background:#28333f}
body.dark .modal-head,body.dark .modal-foot{border-color:var(--line)}
body.dark .chip{background:var(--panel-2);color:var(--muted)}
body.dark .tok{background:#16324d;border-color:#245074;color:#bcd9f5}
body.dark .tok.guest{background:#3a2a16;border-color:#5a4424;color:#e8c79a}
body.dark .empty-state img{opacity:.42}
/* accent fills (badges, page-chips, sub-badge, notice boxes) auto-mute in dark
   via the --accent-* / --warn-* token overrides above; only blockquote text needs a nudge */
body.dark .rt blockquote{color:var(--muted)}

/* ---------- editor sign-in (hosted) ---------- */
.login-overlay{position:fixed;inset:0;background:linear-gradient(160deg,#1b3a5e,#0f2742);display:flex;align-items:center;justify-content:center;z-index:400;padding:1.5rem}
.login-card{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:2rem 1.8rem;width:340px;max-width:100%;text-align:center}
.login-logo{height:84px;width:auto;margin-bottom:.6rem}
.login-title{font-weight:800;font-size:1.2rem;color:#15202b}
.login-sub{color:#5d6b79;font-size:.85rem;margin:.1rem 0 1rem}
.login-overlay .login-card .input{margin-bottom:.6rem;text-align:center;background:#fff;color:#15202b;border-color:#d6dee7}
.login-err{color:#c0392b;font-size:.8rem;min-height:1.1em;margin-bottom:.5rem}

/* ---------- public read mode (parents) ---------- */
body.read-mode .appbar,body.read-mode #view-articles,body.read-mode #view-arrange,body.read-mode .preview-bar{display:none !important}
body.read-mode #view-preview{display:block}
body.read-mode.read-index .app-shell{display:none}
.read-bar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:1rem;justify-content:space-between;padding:.6rem 1rem;background:var(--brand);color:#fff}
.read-bar .read-home{color:#fff;text-decoration:none;font-weight:600;font-size:.85rem;opacity:.92}
.read-bar .read-home:hover{opacity:1;text-decoration:underline}
.read-bar .read-title{font-weight:800;font-size:.95rem;text-align:center;flex:1}
.read-bar .btn-primary{background:#fff;color:var(--brand);border-color:#fff}
.read-root{max-width:620px;margin:0 auto;padding:3rem 1.2rem;text-align:center}
.read-back{position:fixed;top:1rem;left:1.1rem;z-index:10;display:inline-flex;align-items:center;gap:.35rem;color:var(--brand);text-decoration:none;font-weight:700;font-size:.85rem;background:#fff;border:1px solid var(--line);border-radius:30px;padding:.42rem .9rem;box-shadow:var(--shadow-sm);transition:transform .08s var(--ease),box-shadow .12s}
.read-back:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.read-logo{height:120px;width:auto}
.read-h{font-weight:800;font-size:1.6rem;margin-top:.4rem;color:var(--ink)}
.read-sub{color:var(--muted);margin-bottom:1.6rem}
.read-list{display:flex;flex-direction:column;gap:.5rem;text-align:left}
.read-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;background:#fff;border:1px solid var(--line);border-radius:11px;text-decoration:none;color:var(--ink);box-shadow:var(--shadow-sm)}
.read-item:hover{border-color:var(--brand);box-shadow:var(--shadow)}
.read-item .ri-title{font-weight:600}
.read-item .ri-tag{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#fff;background:var(--brand);border-radius:20px;padding:.2rem .6rem}
.read-empty{color:var(--muted);padding:1.5rem;text-align:center}

/* ---------- submissions inbox + publish ---------- */
.sub-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--accent-coral);color:#fff;font-size:.66rem;font-weight:800;margin-left:.35rem}
#btnPublish.is-pub{color:#1d7a45}
.sub-settings{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.6rem;padding-bottom:.8rem;margin-bottom:.8rem;border-bottom:1px solid var(--line)}
.sub-settings .field{margin:0}
.sub-card{border:1px solid var(--line);border-radius:11px;padding:var(--s-3) var(--s-3);margin-bottom:var(--s-2);background:var(--panel-2)}
.sub-title{font-weight:700}
.sub-meta{font-size:.76rem;color:var(--muted);margin:.1rem 0 .4rem}
.sub-body{font-size:.84rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;padding:.5rem .6rem;max-height:130px;overflow:auto;white-space:pre-wrap;line-height:1.45}
.sub-photo{display:block;max-width:180px;max-height:140px;width:auto;border-radius:9px;border:1px solid var(--line);margin-top:.55rem;object-fit:cover}
.sub-actions{display:flex;gap:.5rem;margin-top:.5rem}

/* ---------- print ---------- */
@media print{
  .appbar,.sidebar,.editor,#view-articles,#view-arrange,.preview-bar,.modal-backdrop,.toasts,.read-bar{display:none !important}
  .app-shell,.view,#view-preview{display:block;height:auto;overflow:visible}
  .preview-scroll{overflow:visible;background:none;padding:0}
  body{background:none;overflow:visible;display:block}
}

/* ---------- mobile / small screens (phone-useful: view issues, review submissions, write) ---------- */
.btn-burger{display:none;align-items:center;justify-content:center;width:42px;height:38px;flex:none;border:1px solid var(--line-2);background:#fff;border-radius:10px;font-size:1.25rem;line-height:1;cursor:pointer;color:var(--ink)}
.btn-burger:active{transform:scale(.96)}
@media (max-width:760px){
  .appbar{flex-wrap:wrap;gap:.5rem;padding:.5rem .7rem;position:relative}
  .appbar-brand{min-width:0;flex:1;gap:.5rem}
  .appbar-logo{height:34px}
  .appbar-title{font-size:.98rem}
  .appbar-sub{font-size:.66rem}
  .btn-burger{display:inline-flex;order:2}
  .tabs{order:3;flex-basis:100%;margin:0;justify-content:center}
  .tab{flex:1;justify-content:center;padding:.45rem .3rem}
  .tab-label{font-size:.82rem}
  .appbar-actions{order:4;position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:.4rem;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:.7rem;z-index:80;max-height:78vh;overflow:auto}
  body.nav-open .appbar-actions{display:flex}
  .appbar-actions .btn{width:100%;justify-content:center;padding:.72rem}
  .appbar-actions .divider-v{display:none}
  .appbar-actions .save-state{justify-content:center;min-width:0;padding:.25rem 0}
  .gutter-col{display:none !important}
  #view-articles.view{flex-direction:column}
  #view-articles .sidebar{width:auto !important;max-height:40vh;border-right:none;border-bottom:1px solid var(--line)}
  .editor-split{flex-direction:column}
  .editor-form{min-width:0 !important;max-width:none;padding:1rem 1rem 3rem}
  .editor-preview{display:none !important}
  .arrange-wrap{flex-direction:column}
  .arrange-meta{width:auto !important;flex:none;max-height:46vh;border-right:none;border-bottom:1px solid var(--line)}
  .modal-backdrop{padding:.5rem}
  .modal{width:100%;max-width:100%;max-height:94vh}
  .modal-body{padding:1rem}
  .input,.select,.textarea,.search,.rt,textarea{font-size:16px}
}
