/* ═══════════════════════════════════════════════════════
   RESET & ROOT
   ═══════════════════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --ui-bg:#111016;--ui-bg2:#1a1822;--ui-bg3:#232030;--ui-border:#2e2b3a;
  --ui-text:#d0cde0;--ui-dim:#7a7890;--ui-accent:#a78bfa;--ui-accent2:#7c3aed;
  --ui-danger:#ef4444;--ui-success:#22c55e;--ui-warning:#f59e0b;
  --ui-radius:10px;--ui-radius-sm:6px;
  --font-ui:'Source Sans 3',system-ui,sans-serif;
}
html{font-size:16px}
body{background:var(--ui-bg);color:var(--ui-text);font-family:var(--font-ui);display:flex;flex-direction:column;height:100vh;overflow:hidden}
::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--ui-bg)}
::-webkit-scrollbar-thumb{background:var(--ui-border);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--ui-dim)}

/* ═══════════════════════════════════════════════════════
   TOOLBAR
   ═══════════════════════════════════════════════════════ */
.toolbar{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--ui-bg2);border-bottom:1px solid var(--ui-border);flex-wrap:wrap;z-index:100}
.tab-group{display:flex;background:var(--ui-bg);border-radius:var(--ui-radius);overflow:hidden;border:1px solid var(--ui-border)}
.tab-btn{padding:8px 20px;border:none;background:transparent;color:var(--ui-dim);cursor:pointer;font-family:var(--font-ui);font-size:14px;font-weight:600;transition:all .25s;letter-spacing:.3px;position:relative}
.tab-btn:hover{color:var(--ui-text);background:var(--ui-bg3)}
.tab-btn.active{color:#fff;background:var(--ui-accent2)}
.tab-btn.active::after{content:'';position:absolute;bottom:0;left:20%;right:20%;height:2px;background:#fff;border-radius:1px}
.spacer{flex:1}
.toolbar-sep{width:1px;height:24px;background:var(--ui-border);margin:0 4px}
.t-btn{padding:7px 16px;border:1px solid var(--ui-border);border-radius:var(--ui-radius-sm);background:transparent;color:var(--ui-dim);cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:600;transition:all .2s;display:flex;align-items:center;gap:6px}
.t-btn:hover{border-color:var(--ui-accent);color:var(--ui-accent);background:rgba(167,139,250,.06)}
.t-btn.success{border-color:var(--ui-success);color:var(--ui-success)}.t-btn.success:hover{background:rgba(34,197,94,.08)}
.t-btn.info{border-color:#60a5fa;color:#60a5fa}.t-btn.info:hover{background:rgba(96,165,250,.08)}
.t-btn.warn{border-color:var(--ui-warning);color:var(--ui-warning)}.t-btn.warn:hover{background:rgba(245,158,11,.08)}
.t-btn.active{border-color:var(--ui-accent);color:#fff;background:var(--ui-accent2)}
.sound-btn{font-size:18px;background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--ui-radius-sm);transition:all .2s;opacity:.5}
.sound-btn:hover{opacity:.8;background:var(--ui-bg3)}.sound-btn.on{opacity:1}
.zoom-controls{display:flex;align-items:center;gap:4px}
.zoom-controls input[type=range]{width:80px;accent-color:var(--ui-accent)}
.zoom-controls span{font-size:11px;color:var(--ui-dim);min-width:32px;text-align:center;font-family:'Share Tech Mono',monospace}

/* ═══════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════ */
.toast-container{position:fixed;top:60px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:var(--ui-radius);font-size:14px;font-weight:600;color:#fff;opacity:0;transform:translateX(40px);transition:all .35s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px rgba(0,0,0,.4);max-width:320px;pointer-events:none}
.toast.show{opacity:1;transform:translateX(0)}
.toast.success{background:linear-gradient(135deg,#059669,#10b981)}
.toast.info{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.toast.warn{background:linear-gradient(135deg,#d97706,#f59e0b);color:#000}
.toast.error{background:linear-gradient(135deg,#dc2626,#ef4444)}

/* ═══════════════════════════════════════════════════════
   KEYBOARD SHORTCUTS MODAL
   ═══════════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9998;display:none;align-items:center;justify-content:center;animation:fadeIn .2s ease}
.modal-overlay.show{display:flex}
.modal{background:var(--ui-bg2);border:1px solid var(--ui-border);border-radius:var(--ui-radius);padding:28px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;animation:scaleIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.modal h2{font-size:18px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.modal .close-modal{margin-left:auto;background:none;border:none;color:var(--ui-dim);cursor:pointer;font-size:20px;padding:4px 8px;border-radius:var(--ui-radius-sm)}
.modal .close-modal:hover{color:var(--ui-text);background:var(--ui-bg3)}
.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--ui-border)}
.shortcut-row:last-child{border-bottom:none}
.shortcut-key{display:inline-flex;gap:4px}
.shortcut-key kbd{background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:4px;padding:2px 8px;font-family:'Share Tech Mono',monospace;font-size:12px;color:var(--ui-accent)}

/* ═══════════════════════════════════════════════════════
   MAIN LAYOUT
   ═══════════════════════════════════════════════════════ */
.main-wrap{flex:1;display:flex;overflow:hidden;position:relative}
.panel{flex:1;overflow-y:auto;padding:24px;display:none;animation:fadeUp .3s ease}
.panel.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
/* side-by-side mode */
.main-wrap.split .panel[data-panel="edit"],.main-wrap.split .panel[data-panel="preview"]{display:block;flex:1;width:50%}
.main-wrap.split .panel[data-panel="design"]{display:none}

/* ═══════════════════════════════════════════════════════
   EDITOR CARDS
   ═══════════════════════════════════════════════════════ */
.editor{max-width:880px;margin:0 auto}
.ed-card{background:var(--ui-bg2);border:1px solid var(--ui-border);border-radius:var(--ui-radius);padding:20px;margin-bottom:16px;position:relative;transition:all .25s;animation:cardIn .3s ease backwards}
.ed-card:hover{border-color:rgba(167,139,250,.25)}
@keyframes cardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.ed-card.dragging{opacity:.5;border-color:var(--ui-accent)}
.ed-card.drag-over{border-color:var(--ui-accent);box-shadow:0 0 0 2px rgba(167,139,250,.3)}
.ed-card-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.ed-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--ui-bg3);border:1px solid var(--ui-border);flex-shrink:0}
.ed-card-label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--ui-dim);font-weight:700}
.ed-card-type{font-size:13px;color:var(--ui-accent);font-weight:600;margin-top:1px}
.ed-card-actions{display:flex;gap:4px;margin-left:auto;flex-shrink:0}
.ed-card-actions button{width:32px;height:32px;border-radius:var(--ui-radius-sm);border:1px solid var(--ui-border);background:transparent;color:var(--ui-dim);cursor:pointer;font-size:14px;transition:all .2s;display:flex;align-items:center;justify-content:center}
.ed-card-actions button:hover{border-color:var(--ui-accent);color:var(--ui-accent);background:var(--ui-bg3)}
.ed-card-actions .btn-remove:hover{border-color:var(--ui-danger);color:var(--ui-danger)}
.ed-card-actions .btn-dup:hover{border-color:var(--ui-success);color:var(--ui-success)}

/* divider & section header cards */
.ed-card.type-divider,.ed-card.type-section-header{padding:12px 20px}
.ed-card.type-divider .ed-card-header,.ed-card.type-section-header .ed-card-header{margin-bottom:8px}

.ed-row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.ed-field{flex:1;min-width:140px}.ed-field.full{min-width:100%;flex-basis:100%}
.ed-label{font-size:12px;color:var(--ui-dim);margin-bottom:4px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.ed-input,.ed-textarea,.ed-select{background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:var(--ui-radius-sm);color:var(--ui-text);padding:10px 14px;font-family:var(--font-ui);font-size:15px;width:100%;transition:border-color .2s,box-shadow .2s}
.ed-input:focus,.ed-textarea:focus,.ed-select:focus{outline:none;border-color:var(--ui-accent);box-shadow:0 0 0 3px rgba(167,139,250,.15)}
.ed-textarea{min-height:120px;resize:vertical;line-height:1.6}
.ed-select{cursor:pointer;padding-right:30px}
.ed-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--ui-dim);padding:8px 14px;border-radius:var(--ui-radius-sm);border:1px solid var(--ui-border);background:var(--ui-bg);transition:all .2s;user-select:none}
.ed-toggle:hover{border-color:var(--ui-accent);color:var(--ui-text)}
.ed-toggle.on{border-color:var(--ui-accent);color:var(--ui-accent);background:rgba(167,139,250,.08)}
.ed-toggle input{display:none}
.toggle-dot{width:36px;height:20px;border-radius:10px;background:var(--ui-border);position:relative;transition:background .2s;flex-shrink:0}
.toggle-dot::after{content:'';width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s}
.ed-toggle.on .toggle-dot{background:var(--ui-accent)}.ed-toggle.on .toggle-dot::after{transform:translateX(16px)}
.ed-thumb{max-height:100px;margin-top:8px;border-radius:var(--ui-radius-sm);border:1px solid var(--ui-border)}
.ed-file-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--ui-radius-sm);border:1px dashed var(--ui-border);background:var(--ui-bg);color:var(--ui-dim);cursor:pointer;font-size:13px;transition:all .2s;margin-top:4px}
.ed-file-btn:hover{border-color:var(--ui-accent);color:var(--ui-accent)}

/* add items panel */
.add-section{margin-bottom:16px}
.add-section-title{font-size:13px;font-weight:700;color:var(--ui-dim);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.add-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:8px}
.add-btn{padding:12px 14px;border-radius:var(--ui-radius);border:1px dashed var(--ui-border);background:transparent;color:var(--ui-dim);cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:600;transition:all .25s;display:flex;align-items:center;gap:8px;text-align:left}
.add-btn:hover{border-color:var(--ui-accent);color:var(--ui-accent);background:rgba(167,139,250,.04);transform:translateY(-1px);border-style:solid}
.add-btn .add-icon{font-size:18px}

/* ═══════════════════════════════════════════════════════
   DESIGN PANEL
   ═══════════════════════════════════════════════════════ */
.design-panel{max-width:880px;margin:0 auto}
.design-section{background:var(--ui-bg2);border:1px solid var(--ui-border);border-radius:var(--ui-radius);margin-bottom:16px;overflow:hidden;animation:cardIn .3s ease backwards}
.design-section-header{padding:16px 20px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:background .2s;user-select:none}
.design-section-header:hover{background:var(--ui-bg3)}
.design-section-header h3{font-size:15px;font-weight:700;flex:1}
.design-section-header .arrow{transition:transform .25s;color:var(--ui-dim);font-size:12px}
.design-section-header.open .arrow{transform:rotate(90deg)}
.design-section-body{padding:0 20px 20px;display:none}
.design-section-body.open{display:block;animation:fadeUp .25s ease}
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.theme-card{padding:14px;border-radius:var(--ui-radius);border:2px solid var(--ui-border);cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.theme-card:hover{border-color:var(--ui-dim);transform:translateY(-2px)}
.theme-card.selected{border-color:var(--ui-accent);box-shadow:0 0 0 3px rgba(167,139,250,.2)}
.theme-card .swatch{display:flex;gap:3px;margin-bottom:8px}
.theme-card .swatch span{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.1)}
.theme-card .tc-name{font-size:13px;font-weight:700;margin-bottom:2px}
.theme-card .tc-desc{font-size:11px;color:var(--ui-dim);line-height:1.3}
.color-row{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.color-row label{font-size:13px;font-weight:600;min-width:130px;color:var(--ui-dim)}
.color-input-wrap{display:flex;align-items:center;gap:8px}
.color-input-wrap input[type=color]{width:40px;height:32px;border:1px solid var(--ui-border);border-radius:var(--ui-radius-sm);cursor:pointer;background:var(--ui-bg);padding:2px}
.color-input-wrap input[type=text]{width:100px;background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:var(--ui-radius-sm);color:var(--ui-text);padding:6px 10px;font-family:'Share Tech Mono',monospace;font-size:13px}
.font-select-wrap{margin-bottom:10px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.font-select-wrap label{font-size:13px;font-weight:600;min-width:130px;color:var(--ui-dim)}
.font-select-wrap select{flex:1;min-width:200px;background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:var(--ui-radius-sm);color:var(--ui-text);padding:8px 12px;font-size:14px;cursor:pointer}
.font-preview{font-size:18px;padding:6px 0;color:var(--ui-text);margin-bottom:12px}
.bg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-bottom:12px}
.bg-option{aspect-ratio:4/3;border-radius:var(--ui-radius-sm);border:2px solid var(--ui-border);cursor:pointer;transition:all .25s;display:flex;align-items:flex-end;justify-content:center;padding:6px;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);text-transform:uppercase;letter-spacing:.5px;overflow:hidden;position:relative}
.bg-option:hover{border-color:var(--ui-dim);transform:scale(1.03)}
.bg-option.selected{border-color:var(--ui-accent);box-shadow:0 0 0 3px rgba(167,139,250,.2)}
.settings-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.settings-row label{font-size:13px;font-weight:600;min-width:140px;color:var(--ui-dim)}

/* ═══════════════════════════════════════════════════════
   NEWSPAPER PREVIEW
   ═══════════════════════════════════════════════════════ */
.np-wrap{display:flex;justify-content:center;padding-bottom:40px;transform-origin:top center;transition:transform .2s}
.newspaper{width:794px;position:relative;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.5);transition:all .3s}
.news-noise{position:absolute;inset:0;opacity:.05;pointer-events:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E")}
.news-stain{position:absolute;inset:0;pointer-events:none}
.news-decor{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}
.news-inner{padding:28px 36px 36px;position:relative;z-index:1}

/* masthead */
.mh-logo{display:block;max-height:80px;margin:0 auto 8px}
.mh-title{text-align:center;font-size:52px;font-weight:normal;letter-spacing:3px;line-height:1.1;margin-bottom:6px;text-transform:uppercase}
.mh-subtitle{text-align:center;font-size:12px;letter-spacing:3px;margin-bottom:6px;text-transform:uppercase}
.mh-rule{height:3px;margin-bottom:2px}
.mh-bar{display:flex;justify-content:center;padding:5px 0;margin-bottom:2px}
.mh-tag{display:flex;justify-content:center;width:100%;padding:4px 16px;font-size:12px;font-weight:bold;letter-spacing:1.5px}
.mh-sub{display:flex;justify-content:space-between;padding:3px 0 5px;font-size:10px;margin-bottom:18px}

/* article grid */
.art-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* article box */
.art-box{padding-top:10px;overflow:hidden}.art-box.full{grid-column:1/-1}
.art-headline{font-size:20px;font-weight:800;line-height:1.2;margin-bottom:3px;text-transform:uppercase}
.art-sub{font-size:12px;margin-bottom:6px;font-style:italic}
.art-body{font-size:13.5px;line-height:1.6;text-align:justify}
.art-body.two-col{column-count:2;column-gap:16px}
.art-body p{margin:0 0 8px}

/* image positions */
.art-img-top{width:100%;max-height:220px;object-fit:cover;margin-bottom:8px}
.art-img-left{width:42%;max-height:180px;object-fit:cover;float:left;margin:0 12px 8px 0}
.art-img-right{width:42%;max-height:180px;object-fit:cover;float:right;margin:0 0 8px 12px}
.art-img-bg-wrap{position:relative;padding:20px;margin-bottom:8px;min-height:120px;display:flex;align-items:flex-end}
.art-img-bg-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.art-img-bg-wrap .bg-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.2),rgba(0,0,0,.7))}
.art-img-bg-wrap .bg-content{position:relative;z-index:1;color:#fff}
.art-caption{font-size:10px;font-style:italic;margin-top:2px;clear:both}
.art-quote{padding-left:12px;margin:10px 0;font-style:italic;font-size:13px;line-height:1.5;clear:both}
.art-quote-name{font-weight:bold;font-style:normal;font-size:11px;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}

/* article template styles */
.art-box.tpl-breaking .breaking-banner{font-size:11px;font-weight:900;letter-spacing:3px;text-transform:uppercase;padding:4px 14px;display:inline-block;margin-bottom:8px}
.art-box.tpl-breaking .art-headline{font-size:26px}
.art-box.tpl-feature .art-headline{font-size:24px;margin-bottom:4px}
.art-box.tpl-feature .feature-lead{font-size:15px;font-weight:600;line-height:1.5;margin-bottom:8px;font-style:italic}
.art-box.tpl-editorial .drop-cap::first-letter{float:left;font-size:3.4em;line-height:.8;padding-right:8px;font-weight:700}
.art-box.tpl-editorial .ed-byline{font-style:italic;margin-bottom:8px;font-size:13px}
.art-box.tpl-interview .interview-line{margin-bottom:8px}
.art-box.tpl-interview .interview-speaker{font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:1px}
.art-box.tpl-interview .interview-text{font-size:13.5px;line-height:1.5}
.art-box.tpl-wanted{text-align:center;padding:16px}
.art-box.tpl-wanted .wanted-banner{font-size:28px;font-weight:900;letter-spacing:4px;text-transform:uppercase;margin-bottom:8px}
.art-box.tpl-wanted .wanted-reward{font-size:14px;font-weight:700;margin-top:10px;letter-spacing:1px}
.art-box.tpl-obituary{padding:14px}
.art-box.tpl-obituary .obit-dates{text-align:center;font-size:12px;font-style:italic;margin-bottom:8px}
.art-box.tpl-review .review-rating{font-size:18px;letter-spacing:2px;margin-bottom:6px}
.art-box.tpl-classified .art-headline{font-size:14px}
.art-box.tpl-classified .art-body{font-size:12px}
.art-box.tpl-letter .letter-opening{font-style:italic;margin-bottom:8px;font-size:14px}
.art-box.tpl-letter .letter-sig{text-align:right;font-style:italic;margin-top:10px;font-size:13px}
.art-box.tpl-prophecy{text-align:center;font-style:italic;padding:12px}
.art-box.tpl-prophecy .prophecy-source{font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-top:8px;font-style:normal}
.art-box.tpl-decree{padding:14px;text-align:center}
.art-box.tpl-decree .decree-banner{font-size:16px;font-weight:900;letter-spacing:4px;text-transform:uppercase;margin-bottom:8px}
.art-box.tpl-decree .decree-seal{font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-top:10px;font-style:italic}
.art-box.tpl-battle .battle-header{font-size:11px;font-weight:900;letter-spacing:3px;text-transform:uppercase;padding:3px 12px;display:inline-block;margin-bottom:8px}
.art-box.tpl-battle .art-headline{font-size:24px}
.art-box.tpl-tavern{padding:12px}
.art-box.tpl-tavern .tavern-notice{font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;text-align:center}
.art-box.tpl-poetry .art-body{text-align:center;font-style:italic;line-height:1.8}
.art-box.tpl-poetry .poetry-attr{font-size:12px;text-align:center;margin-top:8px;font-style:normal;letter-spacing:1px}
.art-box.tpl-exploration .log-header{font-size:11px;letter-spacing:1px;font-style:italic;margin-bottom:6px}

/* ads */
.ad-box{text-align:center;padding:14px}.ad-box.full{grid-column:1/-1}
.ad-faction{font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.ad-title{font-size:16px;font-weight:800;margin-bottom:4px;text-transform:uppercase}
.ad-body{font-size:12px;line-height:1.5;font-style:italic}
.ad-img{max-width:80%;max-height:150px;object-fit:contain;margin:8px auto;display:block}
.ad-box.tpl-banner{padding:20px}.ad-box.tpl-banner .ad-title{font-size:22px}
.ad-box.tpl-classified{padding:8px;font-size:11px}.ad-box.tpl-classified .ad-title{font-size:13px}
.ad-box.tpl-sponsor{font-size:11px}
.ad-box.tpl-event .event-date{font-size:14px;font-weight:700;margin-bottom:4px}
.ad-box.tpl-merchant .merchant-items{font-size:12px;text-align:left;margin-top:6px}
.ad-box.tpl-recruitment .recruit-banner{font-size:13px;font-weight:900;letter-spacing:3px;text-transform:uppercase;margin-bottom:6px}
.ad-box.tpl-potion{font-style:italic;padding:12px}
.ad-box.tpl-potion .potion-warning{font-size:10px;margin-top:6px;font-style:normal;text-transform:uppercase;letter-spacing:1px}

/* dividers */
.np-divider{grid-column:1/-1;text-align:center;padding:4px 0;font-size:14px;letter-spacing:4px;opacity:.5}
.np-divider.style-ornate1::before{content:"◆ ─── ❖ ─── ◆"}
.np-divider.style-ornate2::before{content:"═══════ ✦ ═══════"}
.np-divider.style-simple{border-top:1px solid;height:0;opacity:.3}
.np-divider.style-dots::before{content:"· · · · · · · · · · · · · · ·"}
.np-divider.style-stars::before{content:"✦ ✧ ✦ ✧ ✦ ✧ ✦ ✧ ✦"}
.np-divider.style-wave::before{content:"∿∿∿∿∿∿∿∿∿∿∿∿∿∿∿"}
.np-divider.style-flourish::before{content:"─── ⟡ ───"}
.np-divider.style-runes::before{content:"ᚠ ᚢ ᚦ ᚨ ᚱ ᚲ ᚷ ᚹ ᚺ"}
.np-divider.style-daggers::before{content:"† ── ‡ ── † ── ‡ ── †"}

/* section headers */
.np-section-header{grid-column:1/-1;text-align:center;padding:6px 0;margin:4px 0}
.np-section-header.style-banner span{display:inline-block;padding:4px 20px;font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase}
.np-section-header.style-simple span{font-size:12px;font-weight:700;letter-spacing:4px;text-transform:uppercase}
.np-section-header.style-ornate span{font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase}
.np-section-header.style-ornate::before,.np-section-header.style-ornate::after{content:"───── ";font-size:12px;opacity:.4}
.np-section-header.style-ornate::after{content:" ─────"}
.np-section-header.style-underline span{font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;border-bottom:2px solid;padding-bottom:2px}

.news-decor{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}

/* ═══ THEME-SPECIFIC STRUCTURAL STYLES ═══ */
.newspaper.t-broadsheet .news-inner{padding:28px 36px 36px}
.newspaper.t-broadsheet .art-box{border-top:2px solid var(--np-border)}

.newspaper.t-arcane .news-inner{padding:48px 52px 52px}
.newspaper.t-arcane .art-box{border:1px solid var(--np-border);border-radius:4px;padding:14px;background:rgba(255,255,255,.03);box-shadow:0 0 12px rgba(108,99,255,.08),inset 0 0 12px rgba(108,99,255,.04)}
.newspaper.t-arcane .ad-box{border-radius:4px;box-shadow:0 0 8px rgba(108,99,255,.1)}
.newspaper.t-arcane .mh-title{text-shadow:0 0 30px rgba(108,99,255,.3)}

.newspaper.t-scifi .news-inner{padding:46px 50px 50px}
.newspaper.t-scifi .art-box{border:1px solid var(--np-border);padding:14px;position:relative;background:rgba(0,212,255,.02);clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px))}
.newspaper.t-scifi .mh-title{letter-spacing:8px}
.newspaper.t-scifi .ad-box{clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}

.newspaper.t-steampunk .news-inner{padding:52px 56px 56px}
.newspaper.t-steampunk .art-box{border:2px solid var(--np-border);padding:12px;background:rgba(204,112,48,.03);position:relative}
.newspaper.t-steampunk .art-box::before,.newspaper.t-steampunk .art-box::after{content:'⚙';position:absolute;font-size:22px;opacity:.15;color:var(--np-accent)}
.newspaper.t-steampunk .art-box::before{top:-12px;left:6px}.newspaper.t-steampunk .art-box::after{bottom:-12px;right:6px}
.newspaper.t-steampunk .mh-title{text-shadow:2px 2px 0 rgba(0,0,0,.3)}

.newspaper.t-grimoire .news-inner{padding:48px 52px 52px}
.newspaper.t-grimoire .art-box{border-top:3px solid var(--np-accent);padding-top:12px;position:relative}
.newspaper.t-grimoire .art-box::before{content:'🜏';position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:24px;opacity:.2}
.newspaper.t-grimoire .mh-title{text-shadow:0 0 20px rgba(138,32,32,.4)}

.newspaper.t-elven .news-inner{padding:44px 50px 50px}
.newspaper.t-elven .art-grid{gap:20px}
.newspaper.t-elven .art-box{border-top:1px solid var(--np-border);padding-top:14px;position:relative}
.newspaper.t-elven .art-box::before{content:'❧';position:absolute;top:-12px;left:0;font-size:24px;opacity:.2;color:var(--np-accent)}
.newspaper.t-elven .ad-box{border-radius:12px;padding:18px}
.newspaper.t-elven .mh-title{font-style:italic}

.newspaper.t-feycourt .news-inner{padding:44px 48px 48px}
.newspaper.t-feycourt .art-box{border:1px solid var(--np-border);border-radius:16px 4px 16px 4px;padding:14px;background:rgba(224,128,192,.03)}
.newspaper.t-feycourt .ad-box{border-radius:4px 16px 4px 16px;border-style:dashed}
.newspaper.t-feycourt .mh-title{background:linear-gradient(135deg,var(--np-headline),var(--np-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.newspaper.t-dwarven .news-inner{padding:50px 54px 54px}
.newspaper.t-dwarven .art-box{border:2px solid var(--np-border);padding:12px;background:rgba(212,160,48,.03);position:relative}
.newspaper.t-dwarven .art-box::before{content:'';position:absolute;top:-2px;left:4px;right:4px;height:6px;background:repeating-linear-gradient(90deg,var(--np-accent),var(--np-accent) 3px,transparent 3px,transparent 8px)}
.newspaper.t-dwarven .mh-title{letter-spacing:6px}

.newspaper.t-celestial .news-inner{padding:44px 46px 46px}
.newspaper.t-celestial .art-headline{text-shadow:0 0 8px rgba(184,148,30,.2)}
.newspaper.t-celestial .ad-box{box-shadow:0 0 12px rgba(184,148,30,.08)}
.newspaper.t-celestial .mh-title{text-shadow:0 0 40px rgba(184,148,30,.3),0 0 80px rgba(184,148,30,.15)}

.newspaper.t-infernal .news-inner{padding:50px 54px 54px}
.newspaper.t-infernal .art-box{border-top:2px solid var(--np-accent);border-bottom:1px solid var(--np-border);padding:12px 0;position:relative}
.newspaper.t-infernal .art-box::after{content:'⛧';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);font-size:22px;opacity:.15;color:var(--np-accent)}
.newspaper.t-infernal .mh-title{text-shadow:0 0 20px rgba(232,80,32,.4),0 4px 8px rgba(0,0,0,.5)}

.newspaper.t-pirate .news-inner{padding:44px 48px 48px}
.newspaper.t-pirate .art-box{border-top:2px dashed var(--np-border);padding-top:10px}
.newspaper.t-pirate .ad-box{border-style:dashed}
.newspaper.t-pirate .mh-title{text-shadow:2px 2px 0 rgba(0,0,0,.2)}

.newspaper.t-underdark .news-inner{padding:48px 52px 52px}
.newspaper.t-underdark .art-box{border-left:2px solid var(--np-accent);padding:10px 0 10px 14px;box-shadow:-4px 0 12px rgba(64,224,208,.06)}
.newspaper.t-underdark .ad-box{box-shadow:0 0 10px rgba(64,224,208,.06)}
.newspaper.t-underdark .art-headline{text-shadow:0 0 10px rgba(64,224,208,.2)}
.newspaper.t-underdark .mh-title{text-shadow:0 0 30px rgba(64,224,208,.3),0 0 60px rgba(200,80,160,.15)}

/* Crest designer */
.crest-preview{width:200px;height:240px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:var(--ui-radius)}
.crest-symbols{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px}
.crest-sym{width:40px;height:40px;border:1px solid var(--ui-border);border-radius:var(--ui-radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--ui-bg);transition:all .2s;padding:4px}
.crest-sym:hover{border-color:var(--ui-accent)}
.crest-sym.selected{border-color:var(--ui-accent);background:rgba(167,139,250,.1)}
.crest-sym svg{width:28px;height:28px}

@media(max-width:900px){
  .newspaper{width:100%!important;min-width:0}
  .toolbar{padding:6px 10px}
  .tab-btn{padding:7px 12px;font-size:13px}
  .add-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
}
