/* ============================================================
   STASHD Pitch Deck Builder — standalone CSS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&display=swap');

:root {
  --espresso: #2b1d14; --espresso-2: #3a2a1d; --bean: #4a3528;
  --crema: #f6efe6; --paper: #fbf8f3; --ink: #241a12; --ink-soft: #5d4f42;
  --muted: #8c7c6b; --line: #e4d8c6; --amber: #c8862b; --amber-soft: #f3e2c4;
  --caramel: #b9712a; --teal: #2f7d72; --teal-soft: #d6ebe6; --berry: #9b3b54;
  --berry-soft: #f4dde2; --green: #3f7d4e; --green-soft: #dcebdd;
  --blue: #36618e; --blue-soft: #dde7f2; --gold: #d8a634;
  --shadow: 0 1px 2px rgba(43,29,20,.06), 0 8px 24px rgba(43,29,20,.07);
  --shadow-lg: 0 12px 40px rgba(43,29,20,.16);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; font-family: var(--font); color: var(--ink); background: var(--paper);
  line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: var(--caramel); }

/* ---------- Toolbar ---------- */
.deck-toolbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--espresso); padding: 12px 20px; position: sticky; top: 0; z-index: 200;
  border-bottom: 1px solid rgba(0,0,0,.3); }
.brand-mark { font-weight: 800; font-size: 14px; letter-spacing: 1.5px; color: #fff;
  display: flex; align-items: center; gap: 6px; margin-right: 6px; flex-shrink: 0; }
.brand-mark .bw-club { font-weight: 600; letter-spacing: .2px; color: var(--caramel); }
.brand-mark .bw-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--caramel); }
.tb-sep { width: 1px; height: 20px; background: rgba(255,255,255,.15); flex-shrink: 0; }
.tb-btn { border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.08); color: #fff;
  border-radius: 8px; padding: 7px 13px; font-size: 12.5px; font-weight: 600; cursor: pointer;
  font-family: var(--font); transition: all .15s; white-space: nowrap; }
.tb-btn:hover { background: rgba(255,255,255,.18); }
.tb-btn.primary { background: var(--caramel); border-color: var(--caramel); }
.tb-btn.primary:hover { background: var(--amber); }
.tb-hint { font-size: 11px; color: rgba(255,255,255,.5); margin-left: auto; text-align: right; line-height: 1.4; }
.story-picker { display: flex; gap: 6px; align-items: center; }
.story-label { font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: rgba(255,255,255,.45); white-space: nowrap; }
.story-btn { border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.06); color: rgba(255,255,255,.75);
  border-radius: 8px; padding: 6px 12px; font-size: 12px; font-weight: 600; cursor: pointer;
  font-family: var(--font); transition: all .15s; }
.story-btn:hover { background: rgba(255,255,255,.14); color: #fff; }
.story-btn.active { background: var(--caramel); border-color: var(--caramel); color: #fff; }

/* ---------- Deck container ---------- */
.deck { display: flex; flex-direction: column; gap: 28px; padding: 32px 40px 80px; max-width: 1100px; margin: 0 auto; }
.speaker-note { max-width: 1000px; margin: 8px 0 0 50px; background: var(--crema); border: 1px solid var(--line);
  border-left: 4px solid var(--caramel); border-radius: 0 10px 10px 0; padding: 11px 16px;
  font-size: 13px; color: var(--bean); line-height: 1.5; }
.speaker-note b { color: var(--caramel); text-transform: uppercase; font-size: 10.5px; letter-spacing: .8px; margin-right: 6px; }
.deck.notes-off .speaker-note { display: none; }

/* ---------- Slide base ---------- */
.slide { position: relative; width: 100%; max-width: 1000px; margin: 0 auto;
  aspect-ratio: 16/9; background: var(--paper); border: 1px solid var(--line);
  border-radius: 16px; box-shadow: var(--shadow); overflow: hidden; --acc: var(--caramel); --acc-soft: var(--amber-soft); }
.slide.acc-amber { --acc: var(--caramel); --acc-soft: var(--amber-soft); }
.slide.acc-teal  { --acc: var(--teal); --acc-soft: var(--teal-soft); }
.slide.acc-berry { --acc: var(--berry); --acc-soft: var(--berry-soft); }
.slide.acc-blue  { --acc: var(--blue); --acc-soft: var(--blue-soft); }
.slide.acc-green { --acc: var(--green); --acc-soft: var(--green-soft); }
.slide-accentbar { position: absolute; left: 0; top: 0; bottom: 0; width: 6px; background: var(--acc); z-index: 2; }
.slide-inner { position: absolute; inset: 0; display: flex; flex-direction: column; padding: 32px 40px 28px; }
.slide-top { display: flex; align-items: center; }
.slide-eyebrow { display: inline-flex; align-items: center; gap: 9px; font-size: 11px; font-weight: 800;
  letter-spacing: 1.2px; text-transform: uppercase; color: var(--acc); }
.ico-chip { width: 30px; height: 30px; border-radius: 8px; background: var(--acc-soft); color: var(--acc);
  display: grid; place-items: center; flex-shrink: 0; }
.ico-chip svg { width: 17px; height: 17px; }
.slide-title { font-size: clamp(22px, 3vw, 34px); line-height: 1.1; letter-spacing: -.4px;
  margin: 14px 0 5px; color: var(--espresso); }
.slide-lead { font-size: clamp(13px, 1.4vw, 15.5px); color: var(--ink-soft); margin: 0; max-width: 78%; line-height: 1.45; }
.slide-body { flex: 1; display: grid; grid-template-columns: 1.4fr 1fr; gap: 24px; align-items: center; margin-top: 14px; min-height: 0; }
.slide-points { display: flex; flex-direction: column; gap: 12px; }
.spt { display: flex; gap: 11px; align-items: flex-start; }
.spt .ico-chip { width: 32px; height: 32px; }
.spt .ico-chip svg { width: 18px; height: 18px; }
.spt-t { font-weight: 700; font-size: clamp(13px, 1.35vw, 15px); color: var(--espresso); }
.spt-s { font-size: clamp(11px, 1.05vw, 12.5px); color: var(--ink-soft); line-height: 1.4; margin-top: 1px; }
.slide-aside { align-self: stretch; display: flex; align-items: center; }
.stat-card { width: 100%; background: linear-gradient(160deg, var(--acc-soft), #fff); border: 1px solid var(--acc-soft);
  border-radius: 14px; padding: 20px; text-align: center; box-shadow: var(--shadow); }
.stat-card .sb { font-size: clamp(22px, 3vw, 36px); font-weight: 800; color: var(--acc); letter-spacing: -1px; line-height: 1; }
.stat-card .sl { font-size: 11.5px; color: var(--ink-soft); margin-top: 9px; line-height: 1.4; }
.stat-src { display: block; margin-top: 6px; font-size: 9.5px; }
.stat-src a { color: var(--muted); border-bottom: 1px solid rgba(140,124,107,.25); }
.stat-inline { display: flex; align-items: baseline; gap: 10px; margin-top: 8px; padding: 10px 14px;
  background: var(--acc-soft); border-radius: 10px; }
.stat-inline .si-b { font-size: clamp(17px,2vw,22px); font-weight: 800; color: var(--acc); white-space: nowrap; }
.stat-inline .si-l { font-size: 11px; color: var(--ink-soft); line-height: 1.35; }
/* cover */
.slide.cover .slide-inner { justify-content: center; }
.cover-logo { width: 50px; height: 50px; border-radius: 14px; background: linear-gradient(135deg,var(--amber),var(--caramel));
  display: grid; place-items: center; margin-bottom: 16px; color: #fff; }
.cover-logo svg { width: 26px; height: 26px; }
.cover-mark { font-size: 12px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--acc); }
.slide.cover .slide-title { font-size: clamp(26px,4vw,48px); margin: 12px 0 0; max-width: 92%; }
.cover-sub { font-size: clamp(13px,1.6vw,18px); color: var(--ink-soft); margin-top: 14px; max-width: 80%; line-height: 1.5; }
/* closing */
.slide.closing .slide-inner { justify-content: center; padding-top: 22px; padding-bottom: 14px; }
.slide.closing .slide-title { font-size: clamp(20px,2.7vw,30px); margin: 10px 0 4px; }
.hero { display: flex; gap: 12px; align-items: flex-start; background: linear-gradient(135deg,#3a7d54,#2a5a3a);
  color: #fff; border-radius: 12px; padding: 12px 16px; margin: 2px 0 9px; box-shadow: 0 4px 14px rgba(42,90,58,.28); }
.hero .ico-chip { background: rgba(255,255,255,.22); color: #fff; width: 34px; height: 34px; }
.hero .h-t { font-weight: 800; font-size: 15px; }
.hero .h-s { font-size: 12px; opacity: .96; margin-top: 3px; line-height: 1.4; }
.ctas { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-top: 4px; }
.cta-card { background: var(--acc-soft); border-radius: 12px; padding: 10px 11px; }
.cta-card .ico-chip { width: 29px; height: 29px; background: #fff; margin-bottom: 6px; }
.cta-t { font-weight: 800; font-size: 13.5px; color: var(--espresso); }
.cta-s { font-size: 11px; color: var(--ink-soft); margin-top: 3px; line-height: 1.32; }
.closing-line { font-size: clamp(12.5px,1.3vw,14px); color: var(--bean); margin-top: 6px; font-weight: 600; }
/* slide footer */
.slide-foot { display: flex; align-items: center; justify-content: space-between; font-size: 10.5px;
  color: var(--muted); border-top: 1px solid var(--line); padding-top: 9px; margin-top: auto; flex-shrink: 0; }
.slide-num { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--bean); }
.brand-wordmark { font-family: 'Inter', sans-serif; font-weight: 800; font-size: 12.5px; letter-spacing: 1.5px; color: var(--bean); }
.brand-wordmark .bw-club { font-weight: 600; color: var(--caramel); margin-left: 3px; letter-spacing: .3px; }
/* shot zone / image */
.shot-zone { width: 100%; aspect-ratio: 4/3; border: 2px dashed #d9cdb9; border-radius: 14px; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
  color: var(--muted); background: #fdfbf7; text-align: center; padding: 12px; position: relative;
  transition: border-color .15s, background .15s; }
.shot-zone:hover { border-color: var(--caramel); background: var(--amber-soft); }
.sz-label { font-size: 11px; font-weight: 600; }
.sz-upload-hint { position: absolute; inset: 0; background: rgba(185,113,42,.14); border-radius: inherit;
  display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .18s;
  font-size: 12px; font-weight: 700; color: var(--caramel); }
.shot-zone:hover .sz-upload-hint { opacity: 1; }
.shot-img { width: 100%; aspect-ratio: 4/3; border-radius: 14px; overflow: hidden; cursor: pointer;
  display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 10px rgba(0,0,0,.10); }
.shot-img img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* ---------- Click-to-edit ---------- */
.slide .editable { cursor: text; border-radius: 4px; outline: 2px dashed transparent; transition: outline-color .12s, background .12s; }
.slide .editable:hover { outline-color: rgba(185,113,42,.45); background: rgba(185,113,42,.06); }
#edit-popover { position: fixed; z-index: 8000; background: #fff; border: 1px solid var(--line);
  border-radius: 16px; box-shadow: var(--shadow-lg); padding: 16px; width: 400px; display: none; }
#edit-popover.open { display: block; }
.ep-head { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.ep-label { font-size: 11px; font-weight: 800; color: var(--caramel); text-transform: uppercase; letter-spacing: .8px; flex: 1; }
#ep-reset { background: var(--crema); border: 1px solid var(--line); border-radius: 7px; padding: 4px 10px;
  font-size: 11.5px; cursor: pointer; color: var(--bean); font-family: var(--font); }
#ep-close { background: none; border: 0; font-size: 18px; color: var(--muted); cursor: pointer; padding: 0 3px; line-height: 1; }
#ep-textarea { width: 100%; min-height: 78px; resize: vertical; border: 1px solid var(--line); border-radius: 10px;
  padding: 9px 11px; font-family: var(--font); font-size: 13.5px; line-height: 1.5; color: var(--ink); background: #fdfbf7; }
#ep-textarea:focus { outline: none; border-color: var(--caramel); box-shadow: 0 0 0 3px var(--amber-soft); }
.ep-foot { display: flex; gap: 8px; margin-top: 9px; align-items: center; }
#ep-save { flex: 1; background: var(--espresso); color: #fff; border: 0; border-radius: 9px; padding: 8px 14px;
  font-size: 13px; font-weight: 700; cursor: pointer; font-family: var(--font); }
#ep-suggest { background: linear-gradient(135deg,#6366f1,#8b5cf6); color: #fff; border: 0; border-radius: 9px;
  padding: 8px 13px; font-size: 12.5px; font-weight: 600; cursor: pointer; font-family: var(--font);
  display: flex; align-items: center; gap: 6px; white-space: nowrap; }
#ep-suggest:disabled { opacity: .55; cursor: not-allowed; }
#ep-suggest .spin { animation: spin .8s linear infinite; display: inline-block; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ai-suggestions { margin-top: 11px; display: flex; flex-direction: column; gap: 7px; }
.ai-suggestion { background: linear-gradient(135deg,#f5f3ff,#ede9fe); border: 1px solid #c4b5fd;
  border-radius: 10px; padding: 9px 12px; font-size: 12.5px; color: #4c1d95; cursor: pointer;
  line-height: 1.45; transition: background .12s; }
.ai-suggestion:hover { background: linear-gradient(135deg,#ede9fe,#ddd6fe); }
.ai-error { font-size: 12px; color: var(--berry); margin-top: 8px; }
.ep-ai-key-note { font-size: 11px; color: var(--muted); margin-top: 8px; text-align: center; }
.ep-ai-key-note a { color: var(--caramel); cursor: pointer; }

/* ---------- API Key modal ---------- */
#key-modal-bg { position: fixed; inset: 0; background: rgba(43,29,20,.5); backdrop-filter: blur(4px);
  z-index: 9000; display: none; align-items: center; justify-content: center; }
#key-modal-bg.open { display: flex; }
#key-modal { background: #fff; border-radius: 18px; box-shadow: var(--shadow-lg); width: 420px; max-width: 94vw; padding: 26px; }
.km-head { font-size: 16px; font-weight: 800; color: var(--espresso); display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
#km-close { background: var(--crema); border: 1px solid var(--line); border-radius: 8px; padding: 4px 10px; cursor: pointer; }
.km-info { font-size: 12.5px; color: var(--ink-soft); line-height: 1.5; margin-bottom: 14px; }
.km-info a { color: var(--caramel); }
#km-key-input { width: 100%; border: 1px solid var(--line); border-radius: 10px; padding: 10px 13px;
  font-family: var(--font); font-size: 13.5px; color: var(--ink); background: #fdfbf7; }
#km-key-input:focus { outline: none; border-color: var(--caramel); box-shadow: 0 0 0 3px var(--amber-soft); }
.km-foot { display: flex; gap: 8px; margin-top: 14px; }
#km-save { flex: 1; background: var(--espresso); color: #fff; border: 0; border-radius: 10px; padding: 10px;
  font-size: 13.5px; font-weight: 700; cursor: pointer; font-family: var(--font); }
#km-clear { background: none; border: 1px solid var(--line); border-radius: 10px; padding: 10px 14px;
  font-size: 12.5px; cursor: pointer; color: var(--berry); }

/* ---------- Image upload modal ---------- */
#img-modal-bg { position: fixed; inset: 0; background: rgba(43,29,20,.5); backdrop-filter: blur(4px);
  z-index: 8500; display: none; align-items: center; justify-content: center; }
#img-modal-bg.open { display: flex; }
#img-modal { background: #fff; border-radius: 18px; box-shadow: var(--shadow-lg); width: 460px; max-width: 95vw; overflow: hidden; }
.im-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px 12px;
  border-bottom: 1px solid var(--line); font-weight: 700; font-size: 15px; color: var(--espresso); }
#im-close { background: var(--crema); border: 1px solid var(--line); border-radius: 8px; padding: 4px 10px; cursor: pointer; font-size: 15px; color: var(--bean); }
.im-body { padding: 18px 20px; }
.im-drop-zone { border: 2px dashed var(--line); border-radius: 13px; padding: 26px; text-align: center;
  cursor: pointer; transition: border-color .15s, background .15s; background: #fdfbf7; }
.im-drop-zone:hover, .im-drop-zone.drag-over { border-color: var(--caramel); background: var(--amber-soft); }
.im-drop-zone .dz-icon { font-size: 28px; margin-bottom: 8px; }
.im-drop-zone .dz-label { font-size: 14px; color: var(--ink-soft); }
.im-drop-zone .dz-label b { color: var(--caramel); }
.im-or { text-align: center; font-size: 12px; color: var(--muted); margin: 13px 0; position: relative; }
.im-or::before,.im-or::after { content:''; position:absolute; top:50%; width:42%; height:1px; background:var(--line); }
.im-or::before { left:0; } .im-or::after { right:0; }
.im-url-row { display: flex; gap: 8px; }
#im-url-input { flex: 1; border: 1px solid var(--line); border-radius: 9px; padding: 9px 12px; font-family: var(--font); font-size: 13px; }
#im-url-input:focus { outline: none; border-color: var(--caramel); }
#im-url-go { background: var(--crema); border: 1px solid var(--line); border-radius: 9px; padding: 9px 14px;
  font-size: 13px; font-weight: 600; cursor: pointer; color: var(--bean); }
.im-preview { margin-top: 13px; display: none; border-radius: 11px; overflow: hidden; max-height: 160px;
  background: #fafafa; border: 1px solid var(--line); }
.im-preview img { width: 100%; object-fit: contain; display: block; max-height: 160px; }
.im-foot { display: flex; justify-content: space-between; gap: 8px; padding: 14px 20px 18px; border-top: 1px solid var(--line); }
#im-remove { background: none; border: 1px solid var(--line); border-radius: 9px; padding: 8px 14px; font-size: 13px; cursor: pointer; color: var(--berry); }
#im-save { background: var(--espresso); color: #fff; border: 0; border-radius: 9px; padding: 9px 20px; font-size: 13.5px; font-weight: 700; cursor: pointer; flex: 1; }

/* ---------- Present mode ---------- */
#present-overlay { position: fixed; inset: 0; background: #14100b; z-index: 9999; display: none; }
#present-overlay.open { display: block; }
#present-box { position: absolute; left: 50%; top: 50%; width: 1000px; transform: translate(-50%,-50%); transform-origin: center center; }
#present-box .deck { gap: 0; display: block; padding: 0; }
#present-box .slide { margin: 0; box-shadow: 0 24px 90px rgba(0,0,0,.55); }
#present-box .speaker-note { display: none; }
.present-bar { position: fixed; bottom: 16px; left: 50%; transform: translateX(-50%); display: flex; align-items: center;
  gap: 12px; background: rgba(0,0,0,.55); backdrop-filter: blur(8px); border-radius: 30px; padding: 7px 12px;
  z-index: 10000; opacity: .3; transition: opacity .2s; }
.present-bar:hover { opacity: 1; }
.present-bar button { background: rgba(255,255,255,.14); color: #fff; border: 0; border-radius: 50%; width: 34px;
  height: 34px; font-size: 17px; cursor: pointer; display: grid; place-items: center; }
.present-bar button:hover { background: rgba(255,255,255,.28); }
#present-exit { width: auto !important; border-radius: 18px !important; padding: 0 14px !important; font-size: 12px !important; font-weight: 600 !important; }
#present-counter { color: #fff; font-size: 13px; font-variant-numeric: tabular-nums; min-width: 54px; text-align: center; }
.present-nav-zone { position: fixed; top: 0; bottom: 0; width: 30%; z-index: 9998; cursor: pointer; }
.present-nav-zone.left { left: 0; } .present-nav-zone.right { right: 0; }

/* ---------- Image editor ---------- */
#img-editor-bg { position:fixed;inset:0;background:rgba(43,29,20,.6);backdrop-filter:blur(5px);z-index:9000;display:none;align-items:center;justify-content:center;padding:12px; }
#img-editor-bg.open { display:flex; }
#img-editor { background:#fff;border-radius:18px;box-shadow:0 24px 80px rgba(0,0,0,.4);width:560px;max-width:96vw;max-height:92vh;display:flex;flex-direction:column;overflow:hidden; }
.ied-head { display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--line);font-weight:700;font-size:15px;color:var(--espresso);flex-shrink:0; }
.ied-x { background:var(--crema);border:1px solid var(--line);border-radius:8px;padding:4px 10px;cursor:pointer;font-size:15px;color:var(--bean); }
.ied-tabs { display:flex;gap:4px;padding:10px 14px 0;flex-shrink:0; }
.ied-tab { border:0;background:transparent;border-bottom:2px solid transparent;padding:8px 14px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--font); }
.ied-tab:hover { color:var(--espresso); }
.ied-tab.active { color:var(--caramel);border-bottom-color:var(--caramel); }
.ied-tab:disabled { opacity:.35;cursor:not-allowed; }
.ied-body { flex:1;overflow:auto;min-height:0; }
.ied-panel { display:none;padding:14px; }
.ied-panel.active { display:block; }
.ied-hint { background:var(--amber-soft);border:1px solid #e8cfa3;border-radius:9px;padding:9px 13px;font-size:12.5px;color:#8a5a16;margin-bottom:10px; }
/* Crop canvas area */
.ied-canvas-wrap { position:relative;display:inline-block;max-width:100%;cursor:crosshair;user-select:none;-webkit-user-select:none;touch-action:none; }
.ied-canvas-wrap img { display:block;max-width:100%;max-height:280px;border-radius:8px; }
#ied-crop-sel { position:absolute;box-shadow:0 0 0 9999px rgba(0,0,0,.55);border:2px solid #fff;box-sizing:border-box;cursor:move;touch-action:none; }
.ied-h { position:absolute;width:14px;height:14px;background:#fff;border:1.5px solid var(--caramel);border-radius:3px;z-index:2;touch-action:none; }
.ied-h.nw { top:-7px;left:-7px;cursor:nw-resize; }
.ied-h.ne { top:-7px;right:-7px;cursor:ne-resize; }
.ied-h.sw { bottom:-7px;left:-7px;cursor:sw-resize; }
.ied-h.se { bottom:-7px;right:-7px;cursor:se-resize; }
.ied-move-area { position:absolute;inset:0;cursor:move;touch-action:none; }
/* Resize panel */
.ied-resize-row { display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px; }
.ied-resize-row label { display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--bean); }
.ied-resize-row input[type=number] { width:80px;border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-family:var(--font);font-size:13px; }
.ied-lock-label { gap:6px;font-size:12.5px;color:var(--muted); }
.ied-x-sep { color:var(--muted);font-size:13px; }
.ied-resize-img-wrap { text-align:center; }
.ied-resize-img-wrap img { max-width:100%;max-height:200px;border-radius:8px;border:1px solid var(--line); }
/* Slide preview strip */
.ied-preview-strip { display:flex;align-items:center;gap:12px;padding:10px 14px;border-top:1px solid var(--line);background:var(--crema);flex-shrink:0; }
.ied-preview-label { font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap; }
.ied-slide-preview { width:180px;aspect-ratio:4/3;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:#fafafa;flex-shrink:0; }
.ied-slide-preview img { width:100%;height:100%;object-fit:contain;display:block; }
/* Footer */
.ied-foot { display:flex;gap:8px;padding:12px 14px 16px;border-top:1px solid var(--line);flex-shrink:0; }
.ied-btn-pri { flex:1;background:var(--espresso);color:#fff;border:0;border-radius:10px;padding:10px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font); }
.ied-btn-sec { background:none;border:1px solid var(--line);border-radius:10px;padding:10px 16px;font-size:13px;cursor:pointer;color:var(--bean);font-family:var(--font); }
/* Trigger in img-modal */
#im-edit-btn { background:var(--crema);border:1px solid var(--line);border-radius:9px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;color:var(--bean); }

/* ---------- Mobile responsive ---------- */
@media (max-width: 640px) {
  /* Kiosk */
  #kiosk-pip { bottom:14px; }
  .kp-dot { width:5px;height:5px; }
  /* Admin toolbar */
  .deck-toolbar { padding:8px 12px;gap:6px; }
  .brand-mark { font-size:12px; }
  .tb-sep { display:none; }
  .story-picker { order:10;width:100%;margin-top:4px; }
  .story-label { display:none; }
  .tb-btn { padding:6px 10px;font-size:11.5px; }
  .tb-hint { display:none; }
  /* Deck */
  .deck { padding:14px 10px 60px; }
  /* Slide body: already 1-col below 820px but tighten further */
  .slide-inner { padding:20px 22px 18px; }
  .slide-title { font-size:clamp(18px,5vw,28px); }
  .slide-lead { font-size:clamp(11px,3vw,14px); max-width:100%; }
  .spt-t { font-size:clamp(11.5px,3.2vw,14px); }
  .spt-s { font-size:clamp(10px,2.8vw,12px); }
  /* Closing slide */
  .ctas { grid-template-columns:1fr 1fr; }
  /* Image editor on mobile */
  #img-editor { max-height:100vh;border-radius:12px; }
  .ied-slide-preview { width:120px; }
}
@media (max-width: 420px) {
  .ctas { grid-template-columns:1fr; }
  .ied-resize-row input[type=number] { width:64px; }
}

/* ---------- Print / PDF ---------- */
@media print {
  .deck-toolbar, .speaker-note, #present-overlay, #edit-popover, #img-modal-bg, #key-modal-bg { display: none !important; }
  .deck { gap: 0; padding: 0; }
  .slide { max-width: 100%; width: 100%; height: 100vh; aspect-ratio: auto; margin: 0;
    border: 0; border-radius: 0; box-shadow: none; page-break-after: always; break-after: page; }
  @page { size: A4 landscape; margin: 0; }
}
@media (max-width: 820px) { .slide-body { grid-template-columns: 1fr; } .ctas { grid-template-columns: 1fr; } }
