/* ── Publisher module shared styles ──────────────────────── */
.pub-tbtn{border:1px solid #e5e7eb;background:#fff;border-radius:8px;padding:7px 14px;font:inherit;font-size:13px;font-weight:700;cursor:pointer;color:#374151;transition:all .14s;white-space:nowrap}
.pub-tbtn:hover{background:#f8fafc;border-color:#d0d5dd}
.pub-tbtn-primary{background:#111827!important;color:#fff!important;border-color:#111827!important}
.pub-tbtn-primary:hover{background:#1f2937!important}
.pub-tbtn-danger{background:#b42318!important;color:#fff!important;border-color:#b42318!important}
.pub-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;margin-bottom:5px}
.pub-input{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:8px 10px;font:inherit;font-size:13px;color:#111827;background:#fff;outline:none;transition:border-color .14s}
.pub-input:focus{border-color:#d62828}
.pub-palette-block{display:flex;align-items:center;gap:8px;padding:9px 10px;border:1px solid #e5e7eb;border-radius:9px;cursor:pointer;font-size:12.5px;font-weight:600;color:#374151;background:#fff;transition:all .14s;margin-bottom:6px;user-select:none}
.pub-palette-block:hover{background:#f8fafc;border-color:#d0d5dd;color:#111827;transform:translateX(2px)}
.pub-palette-icon{width:28px;height:28px;border-radius:6px;background:#f3f4f6;display:grid;place-items:center;font-size:13px;flex-shrink:0}

/* Canvas blocks */
.pub-canvas-block{position:relative;border:2px solid transparent;border-radius:6px;transition:border-color .14s;cursor:pointer}
.pub-canvas-block:hover{border-color:#e5e7eb}
.pub-canvas-block.selected{border-color:#d62828!important;box-shadow:0 0 0 3px rgba(214,40,40,.08)}
.pub-block-toolbar{position:absolute;top:-36px;right:0;display:none;gap:4px;z-index:10}
.pub-canvas-block.selected .pub-block-toolbar{display:flex}
.pub-block-toolbar-btn{border:1px solid #e5e7eb;background:#fff;border-radius:6px;padding:4px 8px;font-size:11px;font-weight:700;cursor:pointer;color:#374151;white-space:nowrap}
.pub-block-toolbar-btn:hover{background:#fef2f2;color:#b42318;border-color:#fecaca}
.pub-drop-indicator{height:3px;background:#d62828;border-radius:999px;margin:2px 0;display:none}
.pub-dragging .pub-drop-indicator{display:block}

/* Dashboard */
.pub-dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.pub-dash-search{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.pub-dash-search input{flex:1;min-width:200px;border:1px solid #e5e7eb;border-radius:10px;padding:9px 12px;font:inherit;font-size:13px}
.pub-dash-search select{border:1px solid #e5e7eb;border-radius:10px;padding:9px 12px;font:inherit;font-size:13px;background:#fff}
.pub-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.pub-page-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;transition:box-shadow .15s,border-color .15s}
.pub-page-card:hover{box-shadow:0 8px 24px rgba(16,24,40,.09);border-color:#d0d5dd}
.pub-page-card-thumb{height:120px;background:linear-gradient(135deg,#f8fafc,#e9ecf0);display:flex;align-items:center;justify-content:center;font-size:32px;border-bottom:1px solid #f3f4f6;position:relative}
.pub-page-card-body{padding:14px}
.pub-page-card-title{font-size:14px;font-weight:800;color:#111827;margin-bottom:4px;line-height:1.3}
.pub-page-card-meta{font-size:11.5px;color:#6b7280;margin-bottom:10px}
.pub-page-card-actions{display:flex;gap:6px;flex-wrap:wrap}
.pub-status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:10.5px;font-weight:800;position:absolute;top:10px;right:10px}
.pub-status-draft{background:#fef3c7;color:#92400e}
.pub-status-published{background:#d1fae5;color:#065f46}
.pub-status-archived{background:#f3f4f6;color:#6b7280}
.pub-status-featured{background:#ede9fe;color:#4c1d95}

/* Published page blocks */
.pub-view-hero{background:linear-gradient(135deg,#111827 0%,#1f2937 100%);color:#fff;padding:64px 48px;text-align:center}
.pub-view-hero h1{font-size:36px;font-weight:850;letter-spacing:-.03em;margin:0 0 12px;line-height:1.1}
.pub-view-hero p{font-size:16px;color:rgba(255,255,255,.75);margin:0 0 24px;max-width:600px;margin-left:auto;margin-right:auto}
.pub-view-text{padding:40px 48px;max-width:720px;margin:0 auto}
.pub-view-text h2{font-size:24px;font-weight:800;color:#111827;margin:0 0 12px;letter-spacing:-.02em}
.pub-view-text p{font-size:15px;color:#374151;line-height:1.7;margin:0 0 16px}
.pub-view-image{text-align:center;padding:32px 48px}
.pub-view-image img{max-width:100%;border-radius:12px;box-shadow:0 4px 20px rgba(16,24,40,.12)}
.pub-view-image .pub-caption{font-size:12px;color:#9ca3af;margin-top:8px}
.pub-view-two-col{display:grid;grid-template-columns:1fr 1fr;gap:32px;padding:40px 48px}
.pub-view-three-card{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:40px 48px}
.pub-view-card{border:1px solid #e5e7eb;border-radius:12px;padding:20px;background:#fff}
.pub-view-card h3{font-size:16px;font-weight:800;color:#111827;margin:0 0 8px}
.pub-view-card p{font-size:13px;color:#6b7280;margin:0}
.pub-view-announcement{background:#fef3c7;border-left:4px solid #f59e0b;padding:18px 24px;margin:0}
.pub-view-announcement h3{font-size:15px;font-weight:800;color:#92400e;margin:0 0 6px}
.pub-view-announcement p{font-size:13px;color:#78350f;margin:0}
.pub-view-callout{padding:16px 24px;margin:0;border-left:4px solid #d62828;background:#fff5f5}
.pub-view-callout.info{border-color:#0f62fe;background:#eff6ff}
.pub-view-callout.success{border-color:#16a34a;background:#f0fdf4}
.pub-view-callout h3{font-size:14px;font-weight:800;color:#111827;margin:0 0 4px}
.pub-view-callout p{font-size:13px;color:#374151;margin:0}
.pub-view-faq{padding:32px 48px}
.pub-view-faq-item{border-bottom:1px solid #f3f4f6;padding:14px 0}
.pub-view-faq-item h4{font-size:14px;font-weight:700;color:#111827;margin:0 0 6px}
.pub-view-faq-item p{font-size:13px;color:#6b7280;margin:0}
.pub-view-contact{display:flex;align-items:center;gap:16px;padding:24px 48px;border-bottom:1px solid #f3f4f6}
.pub-view-contact-avatar{width:56px;height:56px;border-radius:50%;background:#111827;color:#fff;display:grid;place-items:center;font-size:18px;font-weight:800;flex-shrink:0}
.pub-view-contact h4{font-size:14px;font-weight:800;color:#111827;margin:0 0 2px}
.pub-view-contact p{font-size:13px;color:#6b7280;margin:0}
.pub-view-btn-row{padding:24px 48px;display:flex;gap:10px;flex-wrap:wrap}
.pub-view-btn{display:inline-flex;align-items:center;gap:6px;background:#111827;color:#fff;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:700;text-decoration:none;border:0;cursor:pointer}
.pub-view-btn.secondary{background:#fff;color:#111827;border:1px solid #e5e7eb}
.pub-view-divider{height:1px;background:#f3f4f6;margin:0 48px}
.pub-view-video{padding:32px 48px}
.pub-view-video iframe{width:100%;border-radius:12px;border:0;aspect-ratio:16/9}
.pub-view-file{display:flex;align-items:center;gap:12px;padding:16px 48px;border-bottom:1px solid #f3f4f6}
.pub-view-file-icon{width:40px;height:40px;border-radius:8px;background:#f3f4f6;display:grid;place-items:center;font-size:18px}
.pub-view-file h4{font-size:13px;font-weight:700;color:#111827;margin:0}
.pub-view-file a{font-size:12px;color:#d62828;font-weight:600}
.pub-view-policy{padding:32px 48px;background:#fafafa}
.pub-view-policy h2{font-size:18px;font-weight:800;color:#111827;margin:0 0 12px}
.pub-view-policy .pub-view-policy-body{font-size:14px;color:#374151;line-height:1.8;white-space:pre-wrap}
.pub-view-dept{background:linear-gradient(90deg,#111827,#1f2937);color:#fff;padding:18px 48px;display:flex;align-items:center;gap:16px}
.pub-view-dept h3{font-size:16px;font-weight:800;margin:0}
.pub-view-dept p{font-size:13px;color:rgba(255,255,255,.65);margin:0}
.pub-view-spacer{height:32px}

/* Settings form items */
.pub-settings-group{margin-bottom:14px}
.pub-settings-group label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;margin-bottom:5px}
.pub-settings-group input,.pub-settings-group textarea,.pub-settings-group select{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:7px 9px;font:inherit;font-size:13px;color:#111827;background:#fff;outline:none}
.pub-settings-group textarea{min-height:72px;resize:vertical}
.pub-settings-group input:focus,.pub-settings-group textarea:focus,.pub-settings-group select:focus{border-color:#d62828}
.pub-color-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.pub-color-swatch{width:24px;height:24px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .12s}
.pub-color-swatch.active{border-color:#111827;transform:scale(1.15)}
.pub-color-swatch:hover{transform:scale(1.1)}

@media(max-width:900px){
  .pub-view-two-col,.pub-view-three-card{grid-template-columns:1fr}
  .pub-view-hero{padding:40px 24px}
  .pub-view-text,.pub-view-image,.pub-view-faq,.pub-view-contact,.pub-view-btn-row,.pub-view-video,.pub-view-file,.pub-view-policy,.pub-view-dept,.pub-view-divider{padding-left:20px;padding-right:20px}
  .pub-view-two-col,.pub-view-three-card{padding:20px}
  #pubBlockPalette{width:180px}
  #pubSettingsPanel{width:240px}
}
