/* ═══════════════════════════════════════════════════════
   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{padding:10px}
.art-box.tpl-interview .interview-line{margin-bottom:12px;padding-left:12px;border-left:2px solid;border-left-color:inherit}
.art-box.tpl-interview .interview-speaker{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:3px}
.art-box.tpl-interview .interview-text{font-size:13.5px;line-height:1.6;font-style:italic;padding-left:1px}
.art-box.tpl-wanted{text-align:center;padding:20px 16px}
.art-box.tpl-wanted .wanted-banner{font-size:36px;font-weight:900;letter-spacing:8px;text-transform:uppercase;margin-bottom:4px;text-shadow:1px 1px 0 currentColor,-1px -1px 0 currentColor,1px -1px 0 currentColor,-1px 1px 0 currentColor;-webkit-text-stroke:0.5px currentColor}
.art-box.tpl-wanted .wanted-subtitle{font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;margin-bottom:12px;font-style:italic}
.art-box.tpl-wanted .wanted-divider{width:80%;height:2px;margin:10px auto;position:relative}
.art-box.tpl-wanted .wanted-divider::before{content:'✦';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:10px;padding:0 8px}
.art-box.tpl-wanted .art-headline{font-size:24px;font-weight:900;letter-spacing:3px;text-transform:uppercase;margin:8px 0;border-top:1px solid;border-bottom:1px solid;padding:8px 0}
.art-box.tpl-wanted .art-body{font-size:13px;line-height:1.7;margin:12px auto;max-width:90%;text-align:left}
.art-box.tpl-wanted .art-body p{margin-bottom:8px;text-indent:0}
.art-box.tpl-wanted .wanted-reward{font-size:16px;font-weight:900;margin-top:14px;letter-spacing:2px;text-transform:uppercase;padding:10px 16px;border:2px solid;display:inline-block}
.art-box.tpl-wanted .art-img-top{width:auto;max-width:55%;max-height:150px;margin:10px auto;display:block;object-fit:cover;border-width:3px;box-shadow:2px 2px 0 rgba(0,0,0,.15)}
.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-birth{padding:14px}
.art-box.tpl-birth .birth-parents{text-align:center;font-size:12px;margin-bottom:2px}
.art-box.tpl-birth .birth-date{text-align:center;font-size:12px;font-style:italic;margin-bottom:8px}
.art-box.tpl-birth .art-headline{text-align:center}
.art-box.tpl-birth .art-body{text-align:center}
.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 */
.notice-box{text-align:center;padding:14px}.notice-box.full{grid-column:1/-1}
.notice-faction{font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.notice-title{font-size:16px;font-weight:800;margin-bottom:4px;text-transform:uppercase}
.notice-body{font-size:12px;line-height:1.5;font-style:italic}
.notice-img{max-width:80%;max-height:150px;object-fit:contain;margin:8px auto;display:block}
.notice-img-full{max-width:100%;object-fit:contain;margin:0 auto;display:block}
.notice-box.tpl-image{padding:10px}
.notice-box.tpl-image .notice-title{font-size:11px;font-weight:600;margin-top:6px;margin-bottom:0;text-transform:none;font-style:italic}
.notice-box.tpl-banner{padding:20px}.notice-box.tpl-banner .notice-title{font-size:22px}
.notice-box.tpl-classified{padding:8px;font-size:11px}.notice-box.tpl-classified .notice-title{font-size:13px}
.notice-box.tpl-sponsor{font-size:11px}
.notice-box.tpl-event .event-date{font-size:14px;font-weight:700;margin-bottom:4px}
.notice-box.tpl-merchant .merchant-items{font-size:12px;text-align:left;margin-top:6px}
.notice-box.tpl-recruitment .recruit-header{font-size:13px;font-weight:900;letter-spacing:3px;text-transform:uppercase;margin-bottom:6px}
.notice-box.tpl-potion{font-style:italic;padding:12px}
.notice-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 .notice-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 .notice-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 .notice-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 .notice-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 .notice-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 .notice-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 .notice-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}

/* ═══════════════════════════════════════════════════════
   PRO / ACCOUNT STYLES
   ═══════════════════════════════════════════════════════ */

/* Auth modal tabs */
.auth-tabs { display:flex; border-radius:var(--ui-radius); overflow:hidden; border:1px solid var(--ui-border); margin-bottom:20px; }
.auth-tab { flex:1; padding:10px; border:none; background:transparent; color:var(--ui-dim); cursor:pointer; font-family:var(--font-ui); font-size:14px; font-weight:600; transition:all .2s; }
.auth-tab.active { color:#fff; background:var(--ui-accent2); }
.auth-form { display:flex; flex-direction:column; }
.auth-submit { width:100%; justify-content:center; margin-top:16px; padding:12px; font-size:15px; }
.auth-link-btn { width:100%; justify-content:center; margin-top:8px; font-size:13px; color:var(--ui-dim); }
.auth-msg { font-size:13px; padding:10px 14px; border-radius:var(--ui-radius-sm); margin-top:10px; }
.auth-msg-error { color:#fca5a5; background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.2); }
.auth-msg-success { color:#86efac; background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.2); }

/* Account info block */
.account-info-block { text-align:center; padding:20px 0 4px; }
.account-avatar-circle { font-size:40px; margin-bottom:10px; }
.account-email-text { font-size:15px; font-weight:600; color:var(--ui-text); margin-bottom:8px; word-break:break-all; }

/* Plan badges */
.plan-badge { display:inline-flex; align-items:center; gap:6px; padding:4px 14px; border-radius:20px; font-size:12px; font-weight:800; letter-spacing:1px; text-transform:uppercase; }
.plan-badge-free { background:var(--ui-bg3); color:var(--ui-dim); border:1px solid var(--ui-border); }
.plan-badge-pro { background:linear-gradient(135deg,#7c3aed,#a78bfa); color:#fff; box-shadow:0 2px 12px rgba(167,139,250,.3); }
.plan-badge-lifetime { background:linear-gradient(135deg,#b45309,#f59e0b); color:#fff; box-shadow:0 2px 12px rgba(245,158,11,.3); }

/* Account button states */
#account-btn.is-pro { border-color:var(--ui-accent); color:var(--ui-accent); }
.pro-badge-inline { font-size:10px; font-weight:800; background:var(--ui-accent2); color:#fff; padding:1px 6px; border-radius:10px; letter-spacing:.5px; text-transform:uppercase; margin-left:4px; }

/* Upgrade modal */
.upgrade-features { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:24px; }
.upgrade-feature { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ui-text); padding:8px 12px; background:var(--ui-bg3); border-radius:var(--ui-radius-sm); border:1px solid var(--ui-border); }
.upgrade-pricing { display:flex; gap:12px; }
.upgrade-plan { flex:1; padding:20px 16px; border-radius:var(--ui-radius); border:2px solid var(--ui-border); cursor:pointer; text-align:center; transition:all .25s; position:relative; background:var(--ui-bg2); }
.upgrade-plan:hover { border-color:var(--ui-accent); transform:translateY(-2px); box-shadow:0 8px 24px rgba(167,139,250,.15); }
.upgrade-plan-featured { border-color:var(--ui-accent); background:linear-gradient(160deg,rgba(124,58,237,.12),rgba(167,139,250,.06)); }
.upgrade-plan-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--ui-accent2); color:#fff; font-size:10px; font-weight:800; padding:3px 12px; border-radius:10px; letter-spacing:1px; white-space:nowrap; }
.upgrade-plan-name { font-size:14px; font-weight:700; color:var(--ui-dim); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.upgrade-plan-price { font-size:28px; font-weight:800; color:var(--ui-accent); line-height:1; margin-bottom:6px; }
.upgrade-plan-price span { font-size:14px; font-weight:400; color:var(--ui-dim); }
.upgrade-plan-desc { font-size:12px; color:var(--ui-dim); }

/* Locked theme cards */
.theme-card.pro-locked { opacity:.6; cursor:pointer; }
.theme-card.pro-locked:hover { border-color:var(--ui-accent); opacity:.85; transform:translateY(-1px); }
.pro-lock-badge { position:absolute; top:8px; right:8px; background:rgba(124,58,237,.85); color:#fff; font-size:10px; font-weight:800; padding:2px 8px; border-radius:10px; letter-spacing:.5px; backdrop-filter:blur(4px); }

/* Locked background options */
.bg-option.pro-locked { opacity:.55; cursor:pointer; position:relative; }
.bg-option.pro-locked:hover { opacity:.8; border-color:var(--ui-accent); }
.bg-lock-icon { position:absolute; top:4px; right:4px; font-size:12px; }

/* Locked add buttons */
.add-btn.add-btn-locked { opacity:.5; border-style:dashed; }
.add-btn.add-btn-locked:hover { border-color:var(--ui-accent); color:var(--ui-accent); opacity:.8; }

/* Pro gate overlay (for Colours/Fonts sections) */
.pro-gate-wrap { position:relative; min-height:80px; }
.pro-gate-overlay { position:absolute; inset:0; background:rgba(17,16,22,.88); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; border-radius:var(--ui-radius-sm); cursor:pointer; z-index:10; backdrop-filter:blur(3px); padding:20px; text-align:center; }
.pro-gate-overlay:hover { background:rgba(17,16,22,.75); }
.pro-gate-icon { font-size:28px; }
.pro-gate-title { font-size:15px; font-weight:700; color:var(--ui-accent); }
.pro-gate-desc { font-size:12px; color:var(--ui-dim); max-width:200px; line-height:1.4; }
.pro-gate-btn { padding:8px 20px; border-radius:var(--ui-radius-sm); border:1px solid var(--ui-accent); background:var(--ui-accent2); color:#fff; cursor:pointer; font-family:var(--font-ui); font-size:13px; font-weight:700; margin-top:4px; }

/* Pro section tag (in section titles) */
.pro-section-tag { font-size:10px; font-weight:800; background:var(--ui-accent2); color:#fff; padding:2px 8px; border-radius:10px; letter-spacing:.5px; text-transform:uppercase; margin-left:8px; vertical-align:middle; }

/* Article limit warning */
.article-limit-warning { background:rgba(245,158,11,.08); border:1px solid rgba(245,158,11,.2); border-radius:var(--ui-radius-sm); padding:12px 16px; margin-bottom:12px; font-size:13px; color:var(--ui-warning); display:flex; align-items:center; gap:10px; }
.article-limit-warning button { margin-left:auto; padding:4px 12px; border-radius:var(--ui-radius-sm); border:1px solid var(--ui-warning); background:transparent; color:var(--ui-warning); cursor:pointer; font-size:12px; font-weight:700; font-family:var(--font-ui); white-space:nowrap; }

/* Custom bg lock placeholder */
.pro-custom-bg-lock { margin-top:12px; padding:12px; background:var(--ui-bg3); border-radius:var(--ui-radius-sm); border:1px dashed var(--ui-border); cursor:pointer; text-align:center; font-size:13px; color:var(--ui-dim); transition:all .2s; }
.pro-custom-bg-lock:hover { border-color:var(--ui-accent); color:var(--ui-accent); }

/* PDF/Split button states */
#pdf-btn.pdf-unlocked { border-color:var(--ui-success); color:var(--ui-success); }
#split-btn.split-locked { opacity:.7; }

/* ═══════════════════════════════════════════════════════
   PRO FEATURES: FONT PICKER
   ═══════════════════════════════════════════════════════ */
.font-picker-wrap { margin-bottom:16px; }
.font-picker { border:1px solid var(--ui-border); border-radius:var(--ui-radius); overflow:hidden; }
.font-search-input { border:none; border-bottom:1px solid var(--ui-border); border-radius:0; }
.font-category-tabs { display:flex; gap:0; border-bottom:1px solid var(--ui-border); overflow-x:auto; }
.font-category-tabs button { padding:6px 12px; border:none; background:transparent; color:var(--ui-dim); cursor:pointer; font-size:12px; font-weight:600; white-space:nowrap; transition:all .2s; font-family:var(--font-ui); }
.font-category-tabs button.active, .font-category-tabs button:hover { color:var(--ui-accent); background:rgba(167,139,250,.06); }
.font-list { max-height:200px; overflow-y:auto; }
.font-list-item { padding:10px 14px; cursor:pointer; font-size:16px; transition:background .15s; color:var(--ui-text); }
.font-list-item:hover { background:var(--ui-bg3); }
.font-list-item.selected { background:rgba(167,139,250,.1); color:var(--ui-accent); }
.font-preview-large { font-size:20px; padding:10px 0 4px; color:var(--ui-text); }

/* ═══════════════════════════════════════════════════════
   PRO FEATURES: WEATHERING PANEL
   ═══════════════════════════════════════════════════════ */
.weather-row { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.weather-row label { font-size:13px; color:var(--ui-dim); min-width:130px; font-weight:600; }
.weather-row input[type=range] { flex:1; accent-color:var(--ui-accent); }
.weather-val { font-size:12px; color:var(--ui-dim); min-width:36px; text-align:right; font-family:'Share Tech Mono',monospace; }

/* ═══════════════════════════════════════════════════════
   PRO FEATURES: STAMP OVERLAYS
   ═══════════════════════════════════════════════════════ */
.stamp-palette { display:flex; align-items:center; gap:6px; padding:8px 16px; border-bottom:1px solid var(--ui-border); flex-wrap:wrap; background:var(--ui-bg2); }
.stamp-pick-btn { padding:4px 10px; border-radius:4px; border:2px solid; cursor:pointer; font-family:'Share Tech Mono',monospace; font-size:11px; font-weight:800; letter-spacing:1px; background:transparent; transition:all .2s; }
.stamp-pick-btn:hover { opacity:.8; transform:rotate(-3deg); }
.stamp-pick-btn.stamp-red { color:#cc0000; border-color:#cc0000; }
.stamp-pick-btn.stamp-black { color:#333; border-color:#333; }
.stamp-pick-btn.stamp-green { color:#006600; border-color:#006600; }
.stamp-pick-btn.stamp-blue { color:#003399; border-color:#003399; }
.stamp-pick-btn.stamp-gold { color:#996600; border-color:#996600; }
.stamp-pick-btn.stamp-purple { color:#660066; border-color:#660066; }
.stamp-pick-btn.wax-btn { font-size:16px; border:none; padding:4px 8px; }

/* Stamp overlay styles */
.stamp-overlay-item { padding:6px 14px; border-radius:4px; border:3px solid; font-family:'Share Tech Mono',monospace; font-size:18px; font-weight:900; letter-spacing:3px; text-transform:uppercase; opacity:0.75; pointer-events:auto; }
.stamp-overlay-item:hover { opacity:1; }
.stamp-red    { color:#cc0000; border-color:#cc0000; }
.stamp-black  { color:#111; border-color:#111; }
.stamp-green  { color:#006600; border-color:#006600; }
.stamp-blue   { color:#003399; border-color:#003399; }
.stamp-gold   { color:#996600; border-color:#996600; }
.stamp-purple { color:#660066; border-color:#660066; }
.wax-seal-red  { font-size:40px; border:none; padding:0; opacity:.85; }
.wax-seal-blue { font-size:40px; border:none; padding:0; opacity:.85; }
.wax-seal-gold { font-size:40px; border:none; padding:0; opacity:.85; }

/* ═══════════════════════════════════════════════════════
   PRO FEATURES: MASTHEAD PRESETS
   ═══════════════════════════════════════════════════════ */
.masthead-presets { background:var(--ui-bg2); border:1px solid var(--ui-border); border-radius:var(--ui-radius); padding:16px 20px; margin-bottom:16px; }
.masthead-presets-title { font-size:13px; font-weight:700; color:var(--ui-dim); text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; display:flex; align-items:center; }
.masthead-preset-item { display:flex; align-items:center; gap:8px; padding:8px 0; border-bottom:1px solid var(--ui-border); }
.masthead-preset-item:last-child { border-bottom:none; }
.preset-name { flex:1; font-size:14px; color:var(--ui-text); }

/* ═══════════════════════════════════════════════════════
   PRO FEATURES: QR CODE
   ═══════════════════════════════════════════════════════ */
.qr-box { text-align:center; padding:14px; border:1px solid var(--np-border); }
.qr-box.full { grid-column:1/-1; }
.qr-box.third { /* handled by has-thirds grid */ }
.qr-code-img { margin:0 auto 8px; }
.qr-code-img canvas, .qr-code-img img { display:block; margin:0 auto; }
.qr-label { font-size:12px; font-style:italic; margin-top:8px; }

/* ═══════════════════════════════════════════════════════
   PRO FEATURES: THIRD WIDTH GRID
   ═══════════════════════════════════════════════════════ */
.art-grid.has-thirds { grid-template-columns: repeat(3, 1fr); }
.art-box.third, .notice-box.third { /* spans 1 column naturally */ }
.art-box.full, .notice-box.full, .qr-box.full { grid-column: 1 / -1; }

/* Export clip button */
.btn-clip:hover { border-color:#60a5fa; color:#60a5fa; }

@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))}
  .stamp-palette { padding:6px 10px; }
  .stamp-pick-btn { font-size:9px; padding:3px 6px; }
}
