/* ═══════════════════════════════════════════════════════════════
   Inkgility Design Studio — modernized design system
   Brand: Instrument Serif · DM Sans · Space Mono
   Palette: purple→blue gradient #8E21CA → #254AAD · cream #F8F5EE · dark #1A1218
   Direction: confident, refined, canvas-first. No visual noise.
   ═══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}

/* ── Tokens ────────────────────────────────────────────────────── */
:root{
  --purple:#8E21CA;
  --purple-deep:#7C3AED;
  --purple-soft:#C58BEB;
  --magenta:#D946EF;
  --blue:#254AAD;
  --blue-light:#3A6BD9;
  --cream:#F8F5EE;
  --cream-warm:#FBF7EB;
  --dark:#1A1218;
  --dark-deep:#0A0810;
  --dark-panel:#100D18;
  --dark-elev:#1A1218;

  /* Legacy aliases */
  --gold:var(--purple);
  --gold-deep:var(--purple-deep);
  --gold-soft:var(--purple-soft);

  --btn-gradient:linear-gradient(129deg,var(--purple) 0%,var(--blue) 100%);
  --accent-glow:0 0 0 3px rgba(142,33,202,0.18);

  --rail-w:68px;
  --panel-w:280px;
  --right-w:296px;
  --nav-h:56px;
  --bottom-h:60px;
  --radius-sm:6px;
  --radius:10px;
  --radius-lg:14px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

[data-theme="dark"]{
  --bg-app:var(--dark-deep);
  --bg-panel:#0F0C16;
  --bg-elev:#1A1521;
  --bg-hover:rgba(248,245,238,0.05);
  --bg-active:rgba(142,33,202,0.14);
  --bg-canvas:#0A0810;
  --bg-input:rgba(248,245,238,0.04);
  --bd:rgba(248,245,238,0.07);
  --bd-mid:rgba(248,245,238,0.12);
  --bd-strong:rgba(248,245,238,0.18);
  --tx:var(--cream);
  --tx-2:rgba(248,245,238,0.70);
  --tx-3:rgba(248,245,238,0.42);
  --tx-4:rgba(248,245,238,0.26);
  --ac:var(--purple-soft);            /* brighter accent in dark for legibility */
  --ac-pure:var(--purple);
  --ac-dim:rgba(142,33,202,0.16);
  --ac-glow:rgba(142,33,202,0.36);
  --shadow-sm:0 1px 2px rgba(0,0,0,.30), 0 1px 1px rgba(0,0,0,.20);
  --shadow:0 6px 24px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.28);
  --shadow-lg:0 24px 60px rgba(0,0,0,.55), 0 8px 20px rgba(0,0,0,.36);
  --shadow-paper:0 24px 80px rgba(0,0,0,.55), 0 4px 16px rgba(0,0,0,.30);
  --nav-glass:rgba(15,12,22,0.78);
  --canvas-bg:radial-gradient(ellipse 90% 70% at 50% 45%, rgba(142,33,202,0.06), transparent 70%), var(--dark-deep);
  --overlay:rgba(10,8,16,0.65);
  --grid-line:rgba(248,245,238,0.06);
}

[data-theme="light"]{
  --bg-app:var(--cream);
  --bg-panel:#FFFFFF;
  --bg-elev:var(--cream-warm);
  --bg-hover:rgba(26,18,24,0.045);
  --bg-active:rgba(142,33,202,0.08);
  --bg-canvas:#F5F1E6;
  --bg-input:#FFFFFF;
  --bd:rgba(26,18,24,0.08);
  --bd-mid:rgba(26,18,24,0.14);
  --bd-strong:rgba(26,18,24,0.22);
  --tx:var(--dark);
  --tx-2:rgba(26,18,24,0.70);
  --tx-3:rgba(26,18,24,0.46);
  --tx-4:rgba(26,18,24,0.28);
  --ac:var(--purple-deep);
  --ac-pure:var(--purple);
  --ac-dim:rgba(124,58,237,0.08);
  --ac-glow:rgba(124,58,237,0.20);
  --shadow-sm:0 1px 2px rgba(26,18,24,.06);
  --shadow:0 8px 24px rgba(26,18,24,.08), 0 2px 6px rgba(26,18,24,.04);
  --shadow-lg:0 24px 60px rgba(26,18,24,.14), 0 6px 18px rgba(26,18,24,.06);
  --shadow-paper:0 18px 60px rgba(26,18,24,.14), 0 4px 14px rgba(26,18,24,.06);
  --nav-glass:rgba(255,255,255,0.82);
  --canvas-bg:radial-gradient(ellipse 90% 70% at 50% 45%, rgba(142,33,202,0.04), transparent 70%), var(--cream);
  --overlay:rgba(26,18,24,0.42);
  --grid-line:rgba(26,18,24,0.06);
}

body{
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  background:var(--bg-app);color:var(--tx);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01','cv01';
  font-size:14px;line-height:1.45;
}
.serif{font-family:'Instrument Serif',Georgia,serif;font-weight:400;letter-spacing:-0.01em}
.mono{font-family:'Space Mono','SF Mono',monospace;letter-spacing:.01em;font-size:10px}
.gold{color:var(--ac)}
em.gold{font-style:italic}

/* Scrollbars — subtle */
*::-webkit-scrollbar{width:8px;height:8px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--bd-mid);border-radius:4px;border:2px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:var(--bd-strong);background-clip:padding-box;border:2px solid transparent}

/* ═══ TOP NAV ════════════════════════════════════════════════════ */
.nav{
  height:var(--nav-h);
  /* Inkgility brand gradient — purple → blue, on all themes. */
  background:linear-gradient(90deg, #8E21CA 0%, #5F2EBF 45%, #254AAD 100%);
  border-bottom:1px solid rgba(255,255,255,.12);
  box-shadow:0 1px 0 rgba(0,0,0,.05), 0 6px 24px rgba(64,18,128,.18);
  display:flex;align-items:center;padding:0 16px;gap:12px;
  position:relative;z-index:50;
  color:#fff;
}
/* All nav tools / labels read as white on the gradient. */
.nav-back, .nav-tool, .nav-zoom button, .nav-sel, .nav-theme, .nav-doc, .nav-brand{ color:rgba(255,255,255,.92); }
.nav-back:hover, .nav-tool:hover, .nav-zoom button:hover, .nav-theme:hover, .nav-brand:hover, .nav-doc:hover{ background:rgba(255,255,255,.12); color:#fff; }
.nav-tool[disabled]{ opacity:.45 }
.nav-sel{ background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18); color:#fff }
.nav-sel:hover{ background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.28) }
.nav-doc{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14) }
.nav-doc input{ color:#fff; background:transparent }
.nav-doc input::placeholder{ color:rgba(255,255,255,.55) }
.nav-zoom{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14) }
.nav-zoom .z-val{ color:#fff }
.nav-sep{ background:rgba(255,255,255,.18) !important }
.nav-brand-divider{ background:rgba(255,255,255,.22) !important }
.nav-brand-tag{ color:rgba(255,255,255,.88) }
/* CTA pill: white-on-brand for contrast against the gradient. */
.nav-cta{
  background:#fff;color:#5F2EBF;
  box-shadow:0 4px 16px rgba(0,0,0,.18), inset 0 -1px 0 rgba(0,0,0,.04);
}
.nav-cta:hover{ background:#FFFEF9;color:#3D1F8A;box-shadow:0 8px 28px rgba(0,0,0,.22) }
/* Avatar contrast on brand bar */
.nav-avatar{ border:2px solid rgba(255,255,255,.4); box-shadow:0 2px 8px rgba(0,0,0,.18) }

.nav-back{
  width:34px;height:34px;border-radius:8px;display:grid;place-items:center;
  color:rgba(255,255,255,.92);transition:.18s var(--ease);
}
.nav-back:hover{background:rgba(255,255,255,.16);color:#fff}
.nav-back svg{width:16px;height:16px}

.nav-brand{
  display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;
  padding:4px 8px;border-radius:8px;transition:background .15s;flex-shrink:0;
}
.nav-brand:hover{background:var(--bg-hover)}
/* Icon-only brand mark — full-color gradient SVG, works on both themes */
.nav-logo-img{
  height:30px;width:auto;display:block;flex-shrink:0;
  transition:opacity .25s,transform .25s;
  /* On the brand-gradient nav, force the SVG to render white. */
  filter:brightness(0) invert(1);
}
.nav-brand:hover .nav-logo-img{opacity:.85;transform:scale(1.04)}
.nav-brand-divider{width:1px;height:18px;background:var(--bd-mid);display:inline-block}
.nav-brand-tag{
  font-family:'Space Mono',monospace;font-size:10px;color:rgba(255,255,255,.85);
  letter-spacing:.02em;font-weight:700;white-space:nowrap;
}

.nav-sep{width:1px;height:24px;background:var(--bd)}

.nav-doc{
  display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px;
  border:1px solid transparent;transition:.18s var(--ease);
}
.nav-doc:hover{background:var(--bg-hover)}
.nav-doc:focus-within{border-color:var(--bd-mid);background:var(--bg-hover)}
.nav-doc input{
  background:transparent;border:none;outline:none;color:#fff;
  font-size:13px;font-weight:500;width:200px;letter-spacing:-0.005em;
}
.nav-doc input::placeholder{color:rgba(255,255,255,.6)}
/* The little document icon next to the input — also white on the brand bar. */
.nav-doc svg{color:rgba(255,255,255,.85) !important}

.nav-tools{display:flex;align-items:center;gap:3px;margin-left:auto}

.nav-tool{
  width:34px;height:34px;border-radius:8px;display:grid;place-items:center;
  color:rgba(255,255,255,.92);transition:.15s var(--ease);
}
.nav-tool:hover{background:rgba(255,255,255,.16);color:#fff}
.nav-tool[disabled]{opacity:.45;pointer-events:none}
.nav-tool svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

.nav-zoom{
  display:flex;align-items:center;gap:2px;font-size:12px;color:var(--tx-2);
  padding:3px;border:1px solid var(--bd);border-radius:8px;margin:0 4px;
  background:var(--bg-input);
}
.nav-zoom button{
  width:26px;height:26px;color:#1F1828;font-weight:600;
  border-radius:5px;transition:.12s;
}
.nav-zoom button:hover{background:rgba(95,46,191,.10);color:#5F2EBF}
.nav-zoom .z-val{min-width:46px;text-align:center;font-weight:600;color:#1F1828;font-variant-numeric:tabular-nums}

.nav-sel{
  background:var(--bg-input);border:1px solid var(--bd);border-radius:8px;
  padding:7px 12px;color:var(--tx);font-size:12px;font-weight:500;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:.15s;
}
.nav-sel:hover{border-color:var(--bd-mid);background:var(--bg-hover)}
.nav-sel:focus-visible{border-color:var(--ac);box-shadow:var(--accent-glow)}

.nav-cta{
  background:#fff;color:#5F2EBF;padding:9px 20px;border-radius:50px;
  letter-spacing:.005em;transition:.2s var(--ease);
  box-shadow:0 4px 16px rgba(0,0,0,.18), inset 0 -1px 0 rgba(0,0,0,.04);
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;font-size:14px;
  white-space:nowrap;flex-shrink:0;line-height:1.2;
  border:none;
}
.nav-cta:hover{transform:translateY(-1px);background:#FFFEF9;color:#3D1F8A;box-shadow:0 8px 28px rgba(0,0,0,.24)}
.nav-cta:active{transform:translateY(0)}

.nav-avatar{
  width:32px;height:32px;border-radius:50%;background:var(--btn-gradient);
  color:#fff;display:grid;place-items:center;font-weight:700;font-size:12px;
  box-shadow:0 2px 8px rgba(142,33,202,0.20), inset 0 1px 0 rgba(255,255,255,.18);
  cursor:pointer;transition:.15s var(--ease);
}
.nav-avatar:hover{transform:scale(1.06)}

.nav-theme{
  width:34px;height:34px;border-radius:8px;display:grid;place-items:center;
  color:rgba(255,255,255,.92);transition:.15s var(--ease);
  position:relative;
}
.nav-theme:hover{background:rgba(255,255,255,.16);color:#fff}
.nav-theme svg{width:16px;height:16px;transition:opacity .2s var(--ease), transform .25s var(--ease)}
.nav-theme .theme-ic{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(0deg);opacity:0;pointer-events:none}
[data-theme="light"] .nav-theme .theme-ic-moon{opacity:1;transform:translate(-50%,-50%) rotate(0deg)}
[data-theme="dark"]  .nav-theme .theme-ic-sun {opacity:1;transform:translate(-50%,-50%) rotate(0deg)}
[data-theme="light"] .nav-theme .theme-ic-sun {opacity:0;transform:translate(-50%,-50%) rotate(-60deg)}
[data-theme="dark"]  .nav-theme .theme-ic-moon{opacity:0;transform:translate(-50%,-50%) rotate(60deg)}

/* ═══ STUDIO LAYOUT ══════════════════════════════════════════════ */
.studio{display:flex;height:calc(100vh - var(--nav-h));position:relative}

/* ═══ LEFT RAIL ══════════════════════════════════════════════════ */
.rail{
  width:var(--rail-w);background:var(--bg-panel);border-right:1px solid var(--bd);
  display:flex;flex-direction:column;align-items:center;padding:14px 0;gap:4px;
  flex-shrink:0;
}
.rail-tab{
  position:relative;
  width:54px;padding:11px 0;border-radius:10px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  color:var(--tx-3);transition:.15s var(--ease);
}
.rail-tab:hover{background:var(--bg-hover);color:var(--tx)}
.rail-tab.active{background:var(--bg-active);color:var(--ac)}
.rail-tab.active::before{
  content:'';position:absolute;left:-1px;top:50%;transform:translateY(-50%);
  width:3px;height:22px;background:var(--ac);border-radius:0 4px 4px 0;
}
.rail-tab svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:filter .25s,transform .25s}
.rail-tab:hover svg{filter:drop-shadow(0 0 6px rgba(142,33,202,0.35));transform:translateY(-1px)}
.rail-tab.active svg{filter:drop-shadow(0 0 8px rgba(142,33,202,0.45))}
.rail-tab span{font-size:9px;font-weight:700;letter-spacing:.01em;line-height:1}
/* "More" tab — mobile-only, hidden on desktop where all 9 categories show */
.rail-tab-more{display:none}

/* ═══ AI Generate hero tab — gradient pill on desktop ═══════════════════
   Lives in the same rail-tab slot but visually treated as the headline
   creation moment: subtle gradient background, soft glow, sparkle icon. */
.rail-tab-ai{
  position:relative;
  background:linear-gradient(135deg,rgba(142,33,202,.10),rgba(37,74,173,.08));
  border:1px solid rgba(142,33,202,.16);
  box-shadow:0 0 0 0 rgba(142,33,202,0);
  animation:railAiBreath 3.6s ease-in-out infinite;
}
.rail-tab-ai:hover{
  background:linear-gradient(135deg,rgba(142,33,202,.18),rgba(37,74,173,.14));
  border-color:rgba(142,33,202,.32);
}
.rail-tab-ai.active{
  background:linear-gradient(135deg,rgba(142,33,202,.22),rgba(37,74,173,.18));
  border-color:rgba(142,33,202,.40);
  color:var(--ac);
}
.rail-tab-ai.active::before{display:none}
.rail-tab-ai svg{filter:drop-shadow(0 0 8px rgba(142,33,202,0.55))}
.rail-tab-ai:hover svg{filter:drop-shadow(0 0 12px rgba(142,33,202,0.70));transform:none}
@keyframes railAiBreath{
  0%,100%{box-shadow:0 0 0 0 rgba(142,33,202,0)}
  50%{box-shadow:0 0 14px 2px rgba(142,33,202,0.18)}
}
@media (prefers-reduced-motion: reduce){.rail-tab-ai{animation:none}}

/* ═══ AI Generate sheet — opens when the hero is tapped ═══════════════════ */
.ai-sheet{display:flex;flex-direction:column;gap:18px;padding:4px 2px 24px}
.ai-sheet-title{
  font-family:'Instrument Serif',serif;font-size:24px;font-weight:400;
  letter-spacing:-0.01em;line-height:1.1;color:var(--tx);
}
.ai-sheet-title em{color:var(--ac);font-style:italic}
.ai-sheet-sub{font-size:13px;color:var(--tx-2);line-height:1.5;max-width:42ch}

.ai-prompt{
  width:100%;min-height:96px;padding:14px 16px;border:1px solid var(--bd);
  border-radius:12px;background:var(--bg-app);color:var(--tx);
  font-family:inherit;font-size:14px;line-height:1.5;outline:none;resize:vertical;
  transition:border-color .15s,box-shadow .15s;
}
.ai-prompt:focus{border-color:var(--ac);box-shadow:var(--accent-glow,0 0 0 3px rgba(142,33,202,0.18))}
.ai-prompt::placeholder{color:var(--tx-3)}

.ai-chips-label{font-family:'Space Mono',monospace;font-size:11px;color:var(--tx-3);font-weight:700;margin-top:-4px}
.ai-chips{display:flex;flex-wrap:wrap;gap:6px}
.ai-chip{
  padding:7px 13px;border-radius:30px;
  background:var(--bg-elev);border:1px solid var(--bd);
  color:var(--tx);font-size:12px;font-weight:500;cursor:pointer;
  transition:.15s var(--ease);font-family:inherit;
}
.ai-chip:hover{border-color:var(--ac);color:var(--ac);background:var(--bg-hover)}
.ai-chip.active{background:var(--ac-dim);border-color:var(--ac);color:var(--ac)}

.ai-go{
  width:100%;padding:14px;border-radius:50px;
  background:var(--btn-gradient);color:#fff;border:none;cursor:pointer;
  font-family:'Instrument Serif',serif;font-style:italic;font-size:16px;font-weight:400;
  box-shadow:0 6px 24px rgba(142,33,202,0.28),inset 0 1px 0 rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;gap:10px;
  transition:.2s var(--ease);
}
.ai-go:hover{transform:translateY(-1px);box-shadow:0 10px 32px rgba(142,33,202,0.38),inset 0 1px 0 rgba(255,255,255,.22);filter:brightness(1.05)}
.ai-go:active{transform:translateY(0)}
.ai-go[disabled]{opacity:.5;cursor:not-allowed;transform:none}
.ai-go svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}

.ai-results-label{
  font-family:'Space Mono',monospace;font-size:11px;color:var(--tx-3);font-weight:700;
  display:flex;align-items:center;gap:10px;margin-top:8px;
}
.ai-results-label::after{content:'';flex:1;height:1px;background:var(--bd)}
.ai-results{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.ai-result{
  aspect-ratio:7/4;border-radius:8px;background:var(--bg-elev);border:1.5px solid var(--bd);
  cursor:pointer;overflow:hidden;position:relative;transition:.15s var(--ease);
}
.ai-result:hover{border-color:var(--ac);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.ai-result img{width:100%;height:100%;object-fit:cover}
.ai-result-label{
  position:absolute;bottom:0;left:0;right:0;padding:5px 8px;
  background:linear-gradient(transparent,rgba(0,0,0,.78));
  color:#fff;font-size:10px;font-weight:600;
}
.ai-loading{display:flex;align-items:center;justify-content:center;padding:32px;color:var(--tx-2);font-size:13px;gap:10px}
.ai-loading-dot{width:6px;height:6px;border-radius:50%;background:var(--ac);animation:aiLoad 1.2s infinite ease-in-out}
.ai-loading-dot:nth-child(2){animation-delay:.15s}
.ai-loading-dot:nth-child(3){animation-delay:.30s}
@keyframes aiLoad{0%,80%,100%{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}

/* ── More-sheet list (rendered inside #lp-body when "More" is tapped) ── */
.more-list{display:flex;flex-direction:column;gap:8px}
.more-item{
  display:flex;align-items:center;gap:14px;width:100%;text-align:left;cursor:pointer;
  padding:14px;border-radius:12px;
  background:var(--bg-elev);border:1px solid var(--bd);
  color:var(--tx);font-family:inherit;
  transition:.15s var(--ease);
}
.more-item:hover,.more-item:active{
  border-color:var(--ac);background:var(--bg-hover);
  transform:translateX(2px);
}
.more-item-ic{
  width:42px;height:42px;border-radius:10px;flex-shrink:0;
  background:var(--bg-app);
  display:flex;align-items:center;justify-content:center;color:var(--ac);
}
.more-item-ic svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.more-item-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.more-item-name{font-family:'Instrument Serif',serif;font-size:18px;font-weight:400;color:var(--tx);letter-spacing:-0.01em;line-height:1.2}
.more-item-desc{font-size:12px;color:var(--tx-3);line-height:1.45}
.more-item-arrow{color:var(--tx-3);font-size:18px;flex-shrink:0}

/* ═══ LEFT PANEL ═════════════════════════════════════════════════ */
.lpanel{
  width:var(--panel-w);background:var(--bg-panel);border-right:1px solid var(--bd);
  display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;
  transition:width .22s var(--ease), border-color .22s;
}
.lpanel.closed{width:0;border-right-color:transparent}

.lp-head{
  padding:18px 20px 14px;border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.lp-title{
  font-family:'Instrument Serif',serif;font-size:22px;font-weight:400;
  color:var(--tx);letter-spacing:-0.01em;
}
.lp-close{
  width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  color:var(--tx-3);transition:.15s;font-size:18px;line-height:1;
}
.lp-close:hover{background:var(--bg-hover);color:var(--tx)}

.lp-body{flex:1;overflow-y:auto;padding:14px 16px 24px}

.lp-search{
  width:100%;padding:10px 14px 10px 36px;border-radius:8px;border:1px solid var(--bd);
  background:var(--bg-input);color:var(--tx);font-size:13px;outline:none;
  margin-bottom:14px;transition:.15s var(--ease);
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='1.8' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.3-4.3'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:13px center;
}
.lp-search:focus{border-color:var(--ac);box-shadow:var(--accent-glow);background-color:var(--bg-input)}
.lp-search::placeholder{color:var(--tx-3)}

.lp-eyebrow{
  font-family:'Space Mono',monospace;font-size:10px;color:var(--tx-3);
  letter-spacing:.02em;margin:14px 0 10px;font-weight:700;
  display:flex;align-items:center;gap:10px;
}
.lp-eyebrow::after{content:'';flex:1;height:1px;background:var(--bd)}

/* Templates */
.tpl-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tpl-card{
  aspect-ratio:7/4;border-radius:8px;background:var(--bg-elev);
  border:1px solid var(--bd);cursor:pointer;overflow:hidden;
  position:relative;transition:.18s var(--ease);
}
.tpl-card:hover{border-color:var(--ac);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.tpl-card img{width:100%;height:100%;object-fit:cover}
.tpl-name{
  position:absolute;left:0;right:0;bottom:0;padding:6px 8px;
  background:linear-gradient(transparent,rgba(0,0,0,.82));
  color:#fff;font-size:10px;font-weight:600;letter-spacing:-0.005em;
}
.tpl-tier{
  position:absolute;top:6px;left:6px;padding:2px 7px;border-radius:50px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(8px);color:#fff;font-size:8px;font-weight:700;
  letter-spacing:.01em;
}

/* Elements / Photos */
.el-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.el-item{
  aspect-ratio:1;border-radius:8px;background:var(--bg-elev);
  border:1px solid var(--bd);display:grid;place-items:center;
  color:var(--tx-2);cursor:pointer;transition:.15s var(--ease);
}
.el-item:hover{border-color:var(--ac);color:var(--ac);background:var(--bg-active)}
.el-item svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.5}
.el-item.solid svg{fill:currentColor;stroke:none}
.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.photo-item{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;border:1px solid var(--bd);transition:.15s var(--ease)}
.photo-item:hover{border-color:var(--ac);transform:translateY(-1px)}
.photo-item img{width:100%;height:100%;object-fit:cover;display:block}

/* Text presets */
.text-list{display:flex;flex-direction:column;gap:8px}
.text-row{
  padding:16px 14px;border-radius:8px;border:1px solid var(--bd);
  background:var(--bg-elev);cursor:pointer;transition:.15s var(--ease);
}
.text-row:hover{border-color:var(--ac);transform:translateX(2px)}
.text-row.title{font-family:'Instrument Serif',serif;font-size:26px;color:var(--tx);letter-spacing:-0.01em}
.text-row.sub{font-family:'DM Sans',sans-serif;font-size:16px;font-weight:600}
.text-row.body{font-size:13px;color:var(--tx-2)}
.text-row.eyebrow{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.02em;color:var(--ac);font-weight:700}

/* Uploads */
.up-zone{
  border:1.5px dashed var(--bd-mid);border-radius:10px;padding:32px 16px;
  text-align:center;color:var(--tx-2);cursor:pointer;transition:.2s var(--ease);
  margin-bottom:14px;background:var(--bg-elev);
}
.up-zone:hover{border-color:var(--ac);color:var(--ac);background:var(--bg-active)}
.up-zone svg{width:28px;height:28px;margin-bottom:8px;stroke:currentColor;fill:none;stroke-width:1.5}
.up-zone p{font-size:13px;font-weight:600;margin-top:4px;color:var(--tx)}
.up-zone small{font-size:11px;color:var(--tx-3);display:block;margin-top:4px}
.up-zone:hover p{color:var(--ac)}

/* Brand kit */
.bk-section{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--bd)}
.bk-section:last-child{border-bottom:none}
.bk-colors{display:flex;flex-wrap:wrap;gap:8px}
.bk-color{
  width:40px;height:40px;border-radius:10px;border:2px solid var(--bd);
  cursor:pointer;transition:.18s var(--ease);position:relative;
}
.bk-color:hover{transform:scale(1.10);border-color:var(--ac);box-shadow:var(--shadow-sm)}
.bk-fonts{display:flex;flex-direction:column;gap:8px}
.bk-font{
  padding:12px 14px;border-radius:8px;border:1px solid var(--bd);
  cursor:pointer;background:var(--bg-elev);transition:.15s var(--ease);
}
.bk-font:hover{border-color:var(--ac);transform:translateY(-1px)}
.bk-font .lbl{font-family:'Space Mono',monospace;font-size:9px;color:var(--tx-3);letter-spacing:.02em;display:block;margin-bottom:4px;font-weight:700}
.bk-font .preview{font-size:20px;color:var(--tx);letter-spacing:-0.01em}

/* Saved designs */
.saved-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.saved-card{
  aspect-ratio:7/4;border-radius:8px;background:var(--bg-elev);border:1px solid var(--bd);
  cursor:pointer;position:relative;overflow:hidden;transition:.15s var(--ease);
}
.saved-card:hover{border-color:var(--ac);transform:translateY(-1px)}
.saved-card img{width:100%;height:100%;object-fit:cover}
.saved-card .nm{position:absolute;bottom:0;left:0;right:0;padding:6px 8px;background:linear-gradient(transparent,rgba(0,0,0,.8));color:#fff;font-size:10px;font-weight:600}

/* ═══ CANVAS AREA ═════════════════════════════════════════════════ */
.canvas-area{
  flex:1;background:var(--canvas-bg);position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.canvas-scroll{
  flex:1;overflow:auto;display:grid;place-items:center;
  padding:48px;position:relative;
}
.canvas-host{
  background:#fff;box-shadow:var(--shadow-paper);
  border-radius:2px;transition:transform .15s var(--ease);
  position:relative;
}
.canvas-host canvas{display:block}
.canvas-empty{
  position:absolute;inset:0;display:grid;place-items:center;
  pointer-events:none;color:var(--tx-3);font-family:'Instrument Serif',serif;
  font-size:24px;font-style:italic;letter-spacing:-0.005em;text-align:center;padding:32px;
}
.canvas-empty em{color:var(--ac);font-style:italic}

/* ═══ BOTTOM STRIP ════════════════════════════════════════════════ */
.bottom{
  height:var(--bottom-h);
  background:var(--nav-glass);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-top:1px solid var(--bd);
  display:flex;align-items:center;padding:0 20px;gap:14px;flex-shrink:0;
  position:relative;z-index:30;
}
.pages{display:flex;align-items:center;gap:8px;flex:1;overflow-x:auto;padding:6px 2px}
.pages::-webkit-scrollbar{height:0}
.page-thumb{
  width:60px;height:40px;border-radius:6px;background:#fff;
  border:1.5px solid var(--bd);cursor:pointer;display:grid;place-items:center;
  color:var(--tx-3);font-size:11px;font-weight:600;flex-shrink:0;transition:.18s var(--ease);
  font-variant-numeric:tabular-nums;
  box-shadow:0 1px 3px rgba(0,0,0,.08);
}
.page-thumb.active{border-color:var(--ac);box-shadow:0 0 0 2px var(--ac-dim), 0 1px 3px rgba(0,0,0,.08);color:var(--tx)}
.page-thumb:hover{border-color:var(--bd-strong);transform:translateY(-1px)}
.page-add{
  width:40px;height:40px;border-radius:6px;border:1.5px dashed var(--bd-strong);
  display:grid;place-items:center;color:var(--tx-2);flex-shrink:0;
  background:transparent;transition:.15s var(--ease);
}
.page-add:hover{border-color:var(--ac);color:var(--ac);background:var(--bg-active)}
.notes-btn{
  padding:8px 14px;border-radius:8px;border:1px solid var(--bd);
  color:var(--tx-2);font-size:12px;font-weight:600;display:flex;align-items:center;gap:7px;
  background:var(--bg-input);transition:.15s var(--ease);
}
.notes-btn:hover{border-color:var(--ac);color:var(--ac)}
.notes-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.7}

/* ═══ RIGHT PROPERTIES PANEL ══════════════════════════════════════ */
.rpanel{
  width:var(--right-w);background:var(--bg-panel);border-left:1px solid var(--bd);
  display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;
  transition:width .22s var(--ease);
}
.rpanel.closed{width:0;border-left-color:transparent}
.rp-head{
  padding:14px 20px;border-bottom:1px solid var(--bd);display:flex;
  align-items:center;justify-content:space-between;flex-shrink:0;
}
.rp-title{font-family:'Instrument Serif',serif;font-size:18px;font-weight:400;letter-spacing:-0.01em}
.rp-title em{color:var(--ac);font-style:italic}
.rp-body{flex:1;overflow-y:auto;padding:16px 18px}

.rp-empty{
  display:grid;place-items:center;height:100%;text-align:center;color:var(--tx-3);
  font-family:'Instrument Serif',serif;font-size:20px;font-style:italic;
  padding:32px;line-height:1.35;letter-spacing:-0.005em;
}
.rp-empty em{color:var(--ac)}

.rp-section{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--bd)}
.rp-section:last-child{border-bottom:none}

.rp-label{
  font-family:'Space Mono',monospace;font-size:10px;color:var(--tx-3);
  letter-spacing:.02em;margin-bottom:10px;font-weight:700;
  display:flex;align-items:center;gap:8px;
}

.rp-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.rp-row:last-child{margin-bottom:0}

.field{
  flex:1;background:var(--bg-input);border:1px solid var(--bd);border-radius:8px;
  padding:9px 12px;font-size:13px;color:var(--tx);outline:none;min-width:0;
  transition:.15s var(--ease);
  font-variant-numeric:tabular-nums;
}
.field:hover{border-color:var(--bd-mid)}
.field:focus{border-color:var(--ac);box-shadow:var(--accent-glow);background:var(--bg-input)}
select.field{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none' stroke='%23999' stroke-width='1.5'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}

input[type=color]{
  width:36px;height:36px;border:1px solid var(--bd);border-radius:8px;
  padding:0;cursor:pointer;background:transparent;overflow:hidden;
}
input[type=color]::-webkit-color-swatch-wrapper{padding:2px;border-radius:8px}
input[type=color]::-webkit-color-swatch{border:none;border-radius:6px}

input[type=range]{
  flex:1;accent-color:var(--ac);height:4px;background:var(--bd);border-radius:2px;
  appearance:none;cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;
  border:2px solid var(--ac);cursor:pointer;
  box-shadow:0 2px 6px rgba(0,0,0,.18);transition:transform .12s;
}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}

.rp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.rp-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}

.btn-sq{
  width:34px;height:34px;border-radius:8px;border:1px solid var(--bd);
  display:grid;place-items:center;color:var(--tx-2);background:var(--bg-input);
  transition:.15s var(--ease);
}
.btn-sq:hover{border-color:var(--bd-mid);color:var(--tx);background:var(--bg-hover)}
.btn-sq.active{background:var(--bg-active);color:var(--ac);border-color:var(--ac)}
.btn-sq svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.btn-sq.solid svg{fill:currentColor;stroke:none}

.btn-row{display:flex;gap:5px;flex-wrap:wrap}

.btn-text{
  padding:9px 12px;border-radius:8px;border:1px solid var(--bd);background:var(--bg-input);
  color:var(--tx);font-size:12px;font-weight:600;display:flex;align-items:center;gap:7px;
  transition:.15s var(--ease);
}
.btn-text:hover{border-color:var(--ac);color:var(--ac);background:var(--bg-hover)}
.btn-text svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.8}

.range-val{font-size:12px;color:var(--tx-2);min-width:40px;text-align:right;font-weight:600;font-variant-numeric:tabular-nums}

/* ═══ FORMAT PICKER — category-tabbed "What to make" chooser ═══════ */
.dd-menu.format-picker{
  min-width:520px;max-width:92vw;max-height:80vh;overflow:hidden;padding:0;
  flex-direction:column;
}
.dd-menu.format-picker.open{display:flex}
.fp-head{padding:18px 22px 12px;border-bottom:1px solid var(--bd);flex-shrink:0;display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.fp-title{font-family:'Instrument Serif',serif;font-size:22px;font-weight:400;letter-spacing:-0.01em;color:var(--tx);line-height:1.1}
.fp-sub{font-size:12px;color:var(--tx-3);margin-top:4px}
.fp-close{
  width:32px;height:32px;border-radius:50%;
  background:transparent;border:none;color:var(--tx-3);font-size:22px;line-height:1;
  cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:.15s var(--ease);
}
.fp-close:hover{background:var(--bg-hover);color:var(--tx)}
.fp-tabs{
  display:flex;gap:2px;padding:10px 14px;border-bottom:1px solid var(--bd);
  overflow-x:auto;flex-shrink:0;scrollbar-width:none;
}
.fp-tabs::-webkit-scrollbar{display:none}
.fp-tab{
  padding:8px 14px;border-radius:8px;
  font-size:12px;font-weight:600;color:var(--tx-2);
  background:transparent;border:none;cursor:pointer;white-space:nowrap;
  transition:.15s var(--ease);
}
.fp-tab:hover{background:var(--bg-hover);color:var(--tx)}
.fp-tab.active{background:var(--ac-dim);color:var(--ac)}
.fp-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
  padding:14px;overflow-y:auto;flex:1;
}
@media(min-width:680px){.fp-grid{grid-template-columns:repeat(3,1fr)}}
.fp-card{
  display:flex;align-items:center;gap:12px;
  padding:12px;border-radius:10px;
  background:var(--bg-elev);border:1px solid var(--bd);
  cursor:pointer;text-align:left;font-family:inherit;
  transition:.15s var(--ease);
}
.fp-card:hover{border-color:var(--ac);transform:translateY(-1px)}
.fp-card.active{border-color:var(--ac);background:var(--ac-dim)}
.fp-shape-wrap{
  width:42px;height:42px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-app);border-radius:6px;position:relative;
}
.fp-shape{
  background:linear-gradient(135deg,rgba(142,33,202,.5),rgba(37,74,173,.5));
  border-radius:2px;
}
.fp-card-text{min-width:0;flex:1}
.fp-card-name{font-size:13px;font-weight:600;color:var(--tx);line-height:1.2;letter-spacing:-0.005em}
.fp-card-unit{font-family:'Space Mono',monospace;font-size:10px;color:var(--tx-3);margin-top:3px;letter-spacing:.01em}
.fp-print-badge{
  position:absolute;top:-4px;right:-4px;
  font-family:'Space Mono',monospace;font-size:8px;font-weight:700;
  background:var(--btn-gradient);color:#fff;
  padding:1px 5px;border-radius:30px;letter-spacing:.04em;
}

@media(max-width:760px){
  .dd-menu.format-picker{
    position:fixed;top:auto;bottom:0;left:0;right:0;
    min-width:0;max-width:none;width:100%;max-height:85vh;
    border-radius:18px 18px 0 0;border-bottom:none;
  }
  .fp-grid{grid-template-columns:1fr}
}

/* ═══ BRAND KIT APPLY — one-click button at top of Brand panel ═══ */
.bk-apply-btn{
  width:100%;display:block;padding:14px;margin-bottom:16px;
  background:linear-gradient(135deg,rgba(142,33,202,.08),rgba(37,74,173,.06));
  border:1px solid rgba(142,33,202,.24);border-radius:12px;
  cursor:pointer;text-align:left;font-family:inherit;
  transition:.18s var(--ease);
}
.bk-apply-btn:hover{
  border-color:rgba(142,33,202,.50);transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(142,33,202,.18);
}
.bk-apply-row{display:flex;align-items:center;gap:12px}
.bk-apply-swatch{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  box-shadow:0 2px 8px rgba(142,33,202,.30),inset 0 1px 0 rgba(255,255,255,.18);
}
.bk-apply-text{flex:1;min-width:0}
.bk-apply-name{font-family:'Instrument Serif',serif;font-size:16px;font-weight:400;color:var(--tx);line-height:1.2;letter-spacing:-0.005em}
.bk-apply-sub{font-size:11px;color:var(--tx-3);margin-top:3px;line-height:1.4}
.bk-apply-cta{
  font-family:'Space Mono',monospace;font-size:10px;font-weight:700;color:var(--ac);
  letter-spacing:.04em;flex-shrink:0;
}

/* ═══ DESIGNER ASSIST — top nav button + handoff modal ═══════════ */
.designer-btn{color:rgba(255,255,255,.92) !important}
.designer-btn:hover{background:rgba(255,255,255,.16) !important;color:#fff !important}
.designer-btn svg{
  width:16px;height:16px;stroke:currentColor;fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 4px rgba(142,33,202,.35));
}

.designer-modal{width:520px;max-width:92vw;padding:36px 32px;position:relative}
.designer-close{
  position:absolute;top:14px;right:14px;width:32px;height:32px;
  border-radius:50%;background:transparent;color:var(--tx-3);font-size:20px;
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.designer-close:hover{background:var(--bg-hover);color:var(--tx)}
.designer-header{margin-bottom:18px}
.designer-eyebrow{
  font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.04em;
  font-weight:700;color:var(--ac);margin-bottom:10px;
}
.designer-modal h2{font-family:'Instrument Serif',serif;font-size:32px;font-weight:400;letter-spacing:-0.015em;line-height:1.05;margin-bottom:10px}
.designer-modal h2 em{font-style:italic;color:var(--ac)}
.designer-modal p{color:var(--tx-2);font-size:13.5px;line-height:1.55;margin-bottom:0}

.designer-thumb{
  margin:18px 0 22px;border:1px solid var(--bd);border-radius:10px;overflow:hidden;
  background:var(--bg-elev);max-height:220px;
}
.designer-thumb img{width:100%;height:auto;display:block;object-fit:cover;max-height:220px}

.designer-form{display:flex;flex-direction:column;gap:14px}
.designer-form label{
  display:flex;flex-direction:column;gap:6px;
  font-family:'Space Mono',monospace;font-size:10px;font-weight:700;
  letter-spacing:.04em;color:var(--tx-3);
}
.designer-form input,
.designer-form textarea{
  padding:11px 14px;border:1px solid var(--bd);border-radius:10px;
  background:var(--bg-app);color:var(--tx);font-family:inherit;font-size:14px;
  outline:none;transition:border-color .15s;
}
.designer-form input:focus,
.designer-form textarea:focus{border-color:var(--ac);box-shadow:var(--accent-glow,0 0 0 3px rgba(142,33,202,.18))}
.designer-form textarea{resize:vertical;min-height:80px;font-family:'DM Sans',sans-serif;font-weight:400}
.designer-row{display:flex;gap:10px}
.designer-row label{flex:1}
.designer-meta{
  font-size:12px;color:var(--tx-3);line-height:1.6;
  padding:12px 14px;background:var(--bg-elev);border-radius:8px;
}
.designer-meta strong{color:var(--tx);font-weight:600}
.designer-submit{
  width:100%;padding:15px;border:none;border-radius:50px;
  background:var(--btn-gradient);color:#fff;cursor:pointer;
  font-family:'Instrument Serif',serif;font-style:italic;font-size:16px;font-weight:400;
  box-shadow:0 6px 24px rgba(142,33,202,.28),inset 0 1px 0 rgba(255,255,255,.18);
  transition:.2s var(--ease);
}
.designer-submit:hover{transform:translateY(-1px);box-shadow:0 10px 32px rgba(142,33,202,.38),inset 0 1px 0 rgba(255,255,255,.22);filter:brightness(1.05)}
.designer-alt{
  display:block;text-align:center;margin-top:6px;
  font-family:'Space Mono',monospace;font-size:11px;
  letter-spacing:.04em;color:var(--tx-3);text-decoration:none;
}
.designer-alt:hover{color:var(--ac)}

.designer-success{
  padding:32px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;
}
.designer-success h3{font-family:'Instrument Serif',serif;font-size:24px;font-weight:400;color:var(--tx)}
.designer-success p{color:var(--tx-2);font-size:14px;line-height:1.55;max-width:42ch}

/* ═══ PREPRESS CHECK ═════════════════════════════════════════════ */
.prepress-modal{width:520px;max-width:92vw;padding:36px 32px;position:relative}
.prepress-header{margin-bottom:24px}
.prepress-eyebrow{
  font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.04em;
  font-weight:700;color:var(--ac);margin-bottom:10px;
}
.prepress-modal h2{font-family:'Instrument Serif',serif;font-size:32px;font-weight:400;letter-spacing:-0.015em;line-height:1.05;margin-bottom:10px}
.prepress-modal h2 em{font-style:italic;color:var(--ac)}
.prepress-modal p{color:var(--tx-2);font-size:13.5px;line-height:1.55}

.prepress-list{list-style:none;padding:0;margin:0 0 24px}
.prepress-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 16px;border-radius:10px;
  background:var(--bg-elev);margin-bottom:8px;
  border-left:3px solid transparent;
}
.prepress-item.pass{border-left-color:#10B981}
.prepress-item.warn{border-left-color:#D97706}
.prepress-item.fail{border-left-color:#DC2626;background:rgba(220,38,38,.06)}
.prepress-ic{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;margin-top:1px}
.prepress-text{flex:1;min-width:0}
.prepress-label{display:block;font-size:14px;font-weight:600;color:var(--tx);margin-bottom:3px;line-height:1.3}
.prepress-detail{display:block;font-size:12px;color:var(--tx-3);line-height:1.5}

.prepress-actions{display:flex;flex-direction:column;gap:8px}
.prepress-back{
  width:100%;padding:11px;border:1px solid var(--bd);border-radius:50px;
  background:transparent;color:var(--tx-2);cursor:pointer;
  font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.04em;
  transition:.15s var(--ease);
}
.prepress-back:hover{border-color:var(--ac);color:var(--ac)}

/* ═══ MAGIC RESIZE ════════════════════════════════════════════════ */
.magic-btn{color:rgba(255,255,255,.95) !important}
.magic-btn:hover{background:rgba(255,255,255,.16) !important;color:#fff !important}
.magic-btn svg{width:18px;height:18px;filter:drop-shadow(0 0 6px rgba(255,255,255,.4))}
.magic-modal{width:880px;max-width:94vw;max-height:88vh;padding:32px;overflow-y:auto;position:relative}
.magic-header{margin-bottom:24px}
.magic-modal h2{font-family:'Instrument Serif',serif;font-size:32px;font-weight:400;letter-spacing:-0.015em;line-height:1.05;margin-bottom:10px}
.magic-modal h2 em{font-style:italic;color:var(--ac)}
.magic-modal p{color:var(--tx-2);font-size:13.5px;line-height:1.55}
.magic-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:18px;margin-bottom:24px;
}
.magic-card{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:16px;border:1px solid var(--bd);border-radius:14px;
  background:var(--bg-elev);transition:.18s var(--ease);
}
.magic-card:hover{border-color:var(--ac);transform:translateY(-2px);box-shadow:0 8px 22px rgba(142,33,202,.12)}
.magic-frame{
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-app);border-radius:6px;overflow:hidden;
  box-shadow:inset 0 0 0 1px var(--bd);
}
.magic-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.magic-preview img{width:100%;height:100%;object-fit:contain;display:block}
.magic-loading{display:flex;gap:5px;padding:14px}
.magic-loading span{width:5px;height:5px;border-radius:50%;background:var(--ac);opacity:.3;animation:aiLoad 1.2s infinite ease-in-out}
.magic-loading span:nth-child(2){animation-delay:.15s}
.magic-loading span:nth-child(3){animation-delay:.30s}
.magic-meta{text-align:center}
.magic-name{font-family:'Instrument Serif',serif;font-size:16px;font-weight:400;color:var(--tx);letter-spacing:-0.005em;line-height:1.2}
.magic-unit{font-family:'Space Mono',monospace;font-size:10px;color:var(--tx-3);margin-top:3px}
.magic-actions{display:flex;gap:6px;width:100%}
.magic-action{
  flex:1;padding:9px;border-radius:30px;font-family:'Space Mono',monospace;
  font-size:10px;font-weight:700;letter-spacing:.04em;cursor:pointer;
  background:transparent;border:1px solid var(--bd);color:var(--tx);
  transition:.15s var(--ease);
}
.magic-action:hover{border-color:var(--ac);color:var(--ac)}
.magic-action.primary{background:var(--ac-dim);border-color:var(--ac);color:var(--ac)}
.magic-action.primary:hover{background:var(--ac);color:#fff}
.magic-footer{padding-top:18px;border-top:1px solid var(--bd)}

/* ═══ MOCKUPS ═════════════════════════════════════════════════════ */
.mockup-modal{width:1100px;max-width:96vw;max-height:90vh;padding:32px;overflow-y:auto;position:relative}
.mockup-header{margin-bottom:24px}
.mockup-modal h2{font-family:'Instrument Serif',serif;font-size:32px;font-weight:400;letter-spacing:-0.015em;line-height:1.05;margin-bottom:10px}
.mockup-modal h2 em{font-style:italic;color:var(--ac)}
.mockup-modal p{color:var(--tx-2);font-size:13.5px;line-height:1.55}
.mockup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.mockup-card{
  background:var(--bg-elev);border:1px solid var(--bd);border-radius:14px;
  overflow:hidden;transition:.18s var(--ease);display:flex;flex-direction:column;
}
.mockup-card:hover{border-color:var(--ac);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.20)}
.mockup-scene{
  position:relative;aspect-ratio:4/3;background-size:cover;background-position:center;
  overflow:hidden;background-color:var(--bg-canvas);
}
.mockup-overlay{
  position:absolute;
  border-radius:2px;overflow:hidden;
  transform-origin:center center;
}
.mockup-overlay img{width:100%;height:auto;display:block}
.mockup-meta{padding:12px 14px}
.mockup-name{font-family:'Instrument Serif',serif;font-size:18px;font-weight:400;color:var(--tx);letter-spacing:-0.005em;line-height:1.2}
.mockup-desc{font-size:12px;color:var(--tx-3);margin-top:3px;line-height:1.4}
.mockup-dl{
  margin:0 14px 14px;padding:9px;border:1px solid var(--bd);border-radius:30px;
  background:transparent;color:var(--tx);cursor:pointer;font-family:'Space Mono',monospace;
  font-size:10px;font-weight:700;letter-spacing:.04em;transition:.15s var(--ease);
}
.mockup-dl:hover{border-color:var(--ac);color:var(--ac);background:var(--bg-hover)}

/* ═══ SMART QR ════════════════════════════════════════════════════ */
.qr-modal{width:760px;max-width:94vw;padding:32px;position:relative}
.qr-grid-layout{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:flex-start}
@media(max-width:760px){.qr-grid-layout{grid-template-columns:1fr}}
.qr-form-side h2{font-family:'Instrument Serif',serif;font-size:28px;font-weight:400;letter-spacing:-0.015em;line-height:1.05;margin-bottom:8px}
.qr-form-side h2 em{font-style:italic;color:var(--ac)}
.qr-form-side > p{color:var(--tx-2);font-size:13px;line-height:1.55;margin-bottom:18px}

.qr-type-tabs{
  display:flex;gap:4px;margin-bottom:18px;padding:4px;
  background:var(--bg-app);border-radius:10px;
}
.qr-type-tab{
  flex:1;padding:8px;border-radius:7px;border:none;background:transparent;
  font-family:inherit;font-size:12px;font-weight:600;color:var(--tx-2);cursor:pointer;
  transition:.15s var(--ease);
}
.qr-type-tab:hover{color:var(--tx)}
.qr-type-tab.active{background:var(--bg-panel);color:var(--ac);box-shadow:0 1px 3px rgba(0,0,0,.08)}

.qr-fields{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}
.qr-fields label{
  display:flex;flex-direction:column;gap:6px;
  font-family:'Space Mono',monospace;font-size:10px;font-weight:700;
  letter-spacing:.04em;color:var(--tx-3);
}
.qr-fields input,
.qr-fields select{
  padding:11px 14px;border:1px solid var(--bd);border-radius:10px;
  background:var(--bg-app);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:14px;
  font-weight:400;outline:none;transition:border-color .15s;
}
.qr-fields input:focus,
.qr-fields select:focus{border-color:var(--ac);box-shadow:var(--accent-glow,0 0 0 3px rgba(142,33,202,.18))}

.qr-style{margin-bottom:18px}
.qr-style > label{display:block;font-family:'Space Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--tx-3);margin-bottom:10px}
.qr-style-opts{display:flex;gap:8px;flex-wrap:wrap}
.qr-style-opt{
  display:flex;align-items:center;gap:8px;padding:8px 14px;
  border:1px solid var(--bd);border-radius:30px;background:transparent;
  cursor:pointer;font-family:inherit;font-size:12px;color:var(--tx);
  transition:.15s var(--ease);
}
.qr-style-opt:hover{border-color:var(--ac)}
.qr-style-opt.active{border-color:var(--ac);background:var(--ac-dim);color:var(--ac)}
.qr-style-opt span{width:12px;height:12px;border-radius:3px}

.qr-preview-side{
  background:var(--bg-elev);border:1px solid var(--bd);border-radius:14px;
  padding:24px;display:flex;flex-direction:column;align-items:center;gap:14px;
}
.qr-preview-label{font-family:'Space Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--tx-3)}
.qr-preview{
  width:200px;height:200px;background:#fff;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(0,0,0,.12);
}
.qr-preview svg{width:100%;height:100%;display:block}
.qr-empty{font-size:11px;color:var(--tx-3);text-align:center;padding:20px;line-height:1.5}
.qr-scan-meta{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.04em;color:var(--tx-3);text-align:center;line-height:1.4}

.smart-qr-tile{position:relative}
.smart-qr-badge{
  position:absolute;top:-3px;right:-3px;
  font-family:'Space Mono',monospace;font-size:8px;font-weight:700;
  background:var(--btn-gradient);color:#fff;
  padding:2px 6px;border-radius:30px;letter-spacing:.04em;
}

/* ═══ DROPDOWNS ═══════════════════════════════════════════════════ */
.dd-wrap{position:relative}
.dd-menu{
  position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-panel);
  border:1px solid var(--bd);border-radius:10px;box-shadow:var(--shadow);
  padding:6px;min-width:220px;z-index:9999;display:none;
  backdrop-filter:blur(20px);
  animation:ddSlide .18s var(--ease);
}
/* Ensure the top nav itself sits above the canvas/panel stacking contexts */
.studio-nav,.top-nav,nav.studio-nav,header.studio-nav,nav.nav{position:relative;z-index:9000 !important}
@keyframes ddSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.dd-menu.open{display:block}
.dd-item{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 12px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--tx);
  transition:.12s;
}
.dd-item:hover{background:var(--bg-active);color:var(--ac)}
.dd-item small{color:var(--tx-3);font-size:11px;font-family:'Space Mono',monospace;letter-spacing:.05em}

/* ═══ TOAST ═══════════════════════════════════════════════════════ */
.toast{
  position:fixed;bottom:calc(var(--bottom-h) + 24px);left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--bg-panel);border:1px solid var(--bd);border-radius:50px;
  padding:12px 22px;font-size:13px;font-weight:600;color:var(--tx);
  box-shadow:var(--shadow);opacity:0;transition:.28s var(--ease);
  z-index:300;pointer-events:none;backdrop-filter:blur(20px);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.gold{border-color:var(--ac);color:var(--ac)}

/* ═══ NOTES OVERLAY ═══════════════════════════════════════════════ */
.notes-overlay{
  position:fixed;bottom:calc(var(--bottom-h) + 16px);right:24px;width:320px;
  background:var(--bg-panel);border:1px solid var(--bd);border-radius:14px;
  box-shadow:var(--shadow);padding:18px;z-index:60;display:none;
  backdrop-filter:blur(20px);
  animation:notesIn .22s var(--ease);
}
@keyframes notesIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.notes-overlay.open{display:block}
.notes-overlay h4{font-family:'Instrument Serif',serif;font-size:20px;margin-bottom:12px;font-weight:400;letter-spacing:-0.01em}
.notes-overlay h4 em{color:var(--ac);font-style:italic}
.notes-overlay textarea{
  width:100%;min-height:140px;background:var(--bg-input);border:1px solid var(--bd);
  border-radius:8px;padding:12px;color:var(--tx);font-size:13px;outline:none;resize:vertical;
  font-family:inherit;line-height:1.5;transition:.15s;
}
.notes-overlay textarea:focus{border-color:var(--ac);box-shadow:var(--accent-glow)}

/* ═══ ORDER MODAL ════════════════════════════════════════════════ */
.modal-backdrop{
  position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;z-index:500;
  animation:fade .2s var(--ease);
}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-backdrop.open{display:flex}
.modal{
  background:var(--bg-panel);border:1px solid var(--bd);border-radius:18px;
  box-shadow:var(--shadow-lg);width:460px;max-width:92vw;padding:32px;
  animation:modalIn .26s var(--ease);
}
@keyframes modalIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal h2{font-family:'Instrument Serif',serif;font-size:34px;font-weight:400;margin-bottom:8px;letter-spacing:-0.02em;line-height:1.1}
.modal h2 em{font-style:italic;color:var(--ac)}
.modal p{color:var(--tx-2);margin-bottom:22px;font-size:13.5px;line-height:1.55}
.modal .row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-top:1px solid var(--bd);font-size:13.5px}
.modal .row:first-of-type{border-top:none}
.modal .row span:first-child{color:var(--tx-3);font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.01em;font-weight:700}
.modal .row b{color:var(--ac);font-family:'Instrument Serif',serif;font-style:italic;font-size:20px;font-weight:400;letter-spacing:-0.01em}
.modal-actions{display:flex;gap:10px;margin-top:24px}
.modal-actions button{flex:1;padding:14px;border-radius:50px;font-weight:600;font-size:13px;transition:.18s var(--ease)}
.modal-actions .btn-cancel{
  background:var(--bg-input);color:var(--tx-2);border:1px solid var(--bd);
}
.modal-actions .btn-cancel:hover{border-color:var(--bd-mid);color:var(--tx)}
.modal-actions .btn-go{
  background:var(--btn-gradient);color:#fff;border:none;
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;font-size:15px;
  box-shadow:0 4px 18px rgba(142,33,202,0.22), inset 0 1px 0 rgba(255,255,255,.18);
}
.modal-actions .btn-go:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(142,33,202,0.36), inset 0 1px 0 rgba(255,255,255,.20);filter:brightness(1.05)}

/* fabric custom selection */
.canvas-host .canvas-container{margin:0!important}

/* ════════════════════════════════════════════════════════════════
   AMBIENT — Single refined radial gradient. Dropped the noise +
   multi-orb chaos for a calmer, more confident backdrop.
   ════════════════════════════════════════════════════════════════ */
.fx-noise{display:none}  /* dropped — was visual clutter */

.fx-orb{
  position:fixed;border-radius:50%;pointer-events:none;
  filter:blur(120px);z-index:0;will-change:transform;opacity:.5;
}
.fx-orb-purple{
  width:680px;height:680px;top:-20%;left:-10%;
  background:radial-gradient(circle,rgba(142,33,202,0.12),transparent 65%);
  animation:fxOrbFloat1 28s ease-in-out infinite;
}
.fx-orb-gold,
.fx-orb-blue{display:none}  /* dropped — single orb is enough */

[data-theme="dark"] .fx-orb-purple{
  background:radial-gradient(circle,rgba(142,33,202,0.22),transparent 65%);
}
[data-theme="light"] .fx-orb-purple{
  /* Softer on cream — purple stays just visible without muddying the bg */
  background:radial-gradient(circle,rgba(142,33,202,0.10),transparent 65%);
  filter:blur(140px);opacity:.55;
}

@keyframes fxOrbFloat1{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(60px,40px) scale(1.04)}
}

@media (prefers-reduced-motion: reduce){
  .fx-orb{animation:none}
  *,*::before,*::after{transition-duration:.001s !important;animation-duration:.001s !important}
}

/* Nav shimmer line — kept but softer */
.nav::after{
  content:'';position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(142,33,202,0.30) 30%,rgba(217,70,239,0.20) 50%,rgba(37,74,173,0.30) 70%,transparent 100%);
  background-size:200% 100%;
  animation:fxNavShimmer 10s linear infinite;
  pointer-events:none;opacity:.6;
}
[data-theme="dark"]  .nav::after{opacity:.85}
[data-theme="light"] .nav::after{
  opacity:.55;
  background:linear-gradient(90deg,transparent 0%,rgba(142,33,202,0.22) 30%,rgba(217,70,239,0.14) 50%,rgba(37,74,173,0.22) 70%,transparent 100%);
  background-size:200% 100%;
}
@keyframes fxNavShimmer{
  0%{background-position:0% 0%}
  100%{background-position:200% 0%}
}

/* Selection */
::selection{background:rgba(142,33,202,0.22);color:inherit}
[data-theme="dark"]  ::selection{background:rgba(142,33,202,0.36);color:var(--cream)}
[data-theme="light"] ::selection{background:rgba(142,33,202,0.18);color:var(--dark)}

/* Z-index discipline */
.nav, .rail, .lpanel, .canvas-area, .rpanel, .bottom, .modal-bg{
  position:relative;z-index:1;
}

/* ── Focus visible: accessibility ─────────────────────────────── */
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--ac);outline-offset:2px;
}
button:focus:not(:focus-visible){outline:none}

/* ── Helpful micro: collapsed-panel handle when lpanel/rpanel is closed ── */
.lpanel.closed + .canvas-area::before,
.rpanel.closed::before{display:none}

/* ── Responsive squeeze (small screens) ───────────────────────── */
@media (max-width: 1100px){
  :root{--panel-w:260px;--right-w:268px}
  .nav-doc input{width:160px}
}
@media (max-width: 900px){
  .nav-zoom{display:none}
  .nav-doc input{width:120px}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE — Tablet portrait & phones (≤ 760px)
   Layout pivots from horizontal three-column to canvas-first with
   bottom rail + slide-up bottom sheets for left/right panels.
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 760px){
  :root{
    --nav-h:52px;
    --bottom-h:46px;
    --rail-w:100%;
    --rail-h:60px;
    --panel-w:100vw;
    --right-w:100vw;
  }

  /* ── Top nav: compress, drop secondary tools ─────────────── */
  .nav{padding:0 10px;gap:6px}
  .nav-back{width:38px;height:38px}
  .nav-brand-tag,.nav-brand-divider{display:none}
  .nav-brand{padding:4px 6px;gap:0}
  .nav-brand-mark{font-size:18px}
  .nav-sep{display:none}

  /* Doc name fills available space */
  .nav-doc{flex:1;min-width:0;padding:6px 8px}
  .nav-doc input{width:100%;font-size:13px}

  /* Hide tools that don't belong on a phone screen */
  .nav-sel,                            /* size selector */
  #btn-snap, #btn-group, #btn-ungroup, /* alignment tools */
  #btn-present,                        /* present mode */
  .nav-zoom,                           /* zoom controls */
  #btn-share,                          /* share */
  .nav-tools .dd-wrap:first-of-type    /* download dropdown */
  {display:none}

  /* Order Print: compact */
  .nav-cta{padding:7px 14px;font-size:13px}
  .nav-tool{width:38px;height:38px}    /* bigger touch targets */
  .nav-avatar{width:34px;height:34px}

  /* ── Studio layout: column ─────────────────────────────── */
  .studio{
    flex-direction:column;
    height:calc(100vh - var(--nav-h));
    height:calc(100dvh - var(--nav-h));  /* dynamic viewport for mobile browsers */
    position:relative;overflow:hidden;
  }

  /* ── Canvas: hero element, fills available space ───────── */
  .canvas-area{order:1;flex:1;min-height:0}
  .canvas-scroll{padding:16px}
  .canvas-empty{font-size:18px;padding:24px;line-height:1.3}

  /* ── Bottom strip: pages thumbs only, compact ──────────── */
  .bottom{order:2;height:46px;padding:0 10px;gap:8px}
  .pages{gap:6px;padding:5px 2px}
  .page-thumb{width:48px;height:34px;font-size:10px}
  .page-add{width:36px;height:36px}
  /* Notes/Order buttons hidden — Order Print is in the top nav */
  #btn-notes,#btn-order{display:none}

  /* ── Rail: fixed bottom horizontal tab bar with 5 evenly-spread tabs ── */
  .rail{
    order:3;
    width:100%;height:var(--rail-h);
    flex-direction:row;align-items:center;justify-content:space-between;
    padding:0;gap:0;
    border-right:none;border-top:1px solid var(--bd);
    overflow:hidden;flex-shrink:0;
    background:var(--bg-panel);
    z-index:25;
  }
  .rail::-webkit-scrollbar{display:none}
  .rail-tab{
    flex:1 1 0;min-width:0;width:auto;
    padding:8px 4px;
    flex-direction:column;gap:3px;
    border-radius:8px;
  }
  .rail-tab.active::before{
    /* Active indicator moves to bottom edge */
    left:50%;top:auto;bottom:-1px;transform:translateX(-50%);
    width:24px;height:3px;border-radius:4px 4px 0 0;
  }
  .rail-tab svg{width:20px;height:20px}
  .rail-tab span{font-size:9px;letter-spacing:.04em}

  /* ── 5-tab bottom bar: Templates · Text · ✨AI · Uploads · More ──
     Hide categories that live behind "More" and the elements tab (also in More).
     Explicitly order the visible 5 (flex order ignores DOM order). */
  .rail-tab[data-panel="photos"],
  .rail-tab[data-panel="elements"],
  .rail-tab[data-panel="brand"],
  .rail-tab[data-panel="layers"],
  .rail-tab[data-panel="saved"],
  .rail-tab[data-panel="apps"]{display:none}
  .rail-tab-more{display:flex !important}
  .rail-tab[data-panel="templates"]{order:1}
  .rail-tab[data-panel="text"]    {order:2}
  .rail-tab[data-panel="ai"]      {order:3}
  .rail-tab[data-panel="uploads"] {order:4}
  .rail-tab[data-panel="more"]    {order:5;margin-top:0;margin-left:0}
  /* Override the desktop rule that pushed Apps to the end */
  .rail-tab[data-panel="apps"]{margin-top:0;margin-left:0}

  /* ── AI Generate — elevated center hero ─────────────────────────
     Sits ~14px above the rail baseline as a circular gradient button
     with a soft glow, the way Instagram/TikTok treat their + button. */
  .rail-tab-ai{
    position:relative;
    flex:0 0 auto !important;
    width:60px;height:60px;
    border-radius:50%;
    padding:0;margin:0 6px;
    transform:translateY(-14px);
    background:var(--btn-gradient);
    border:3px solid var(--bg-panel);
    color:#fff;
    box-shadow:0 8px 24px rgba(142,33,202,0.45),inset 0 1px 0 rgba(255,255,255,.18);
    animation:railAiBreathMobile 3.6s ease-in-out infinite;
  }
  .rail-tab-ai:hover,.rail-tab-ai.active{
    background:var(--btn-gradient);
    border-color:var(--bg-panel);
    transform:translateY(-16px) scale(1.03);
    box-shadow:0 12px 32px rgba(142,33,202,0.55),inset 0 1px 0 rgba(255,255,255,.22);
  }
  .rail-tab-ai svg{
    width:26px;height:26px;
    stroke:none;
    filter:drop-shadow(0 0 6px rgba(255,255,255,0.45));
  }
  .rail-tab-ai svg path{fill:#fff;stroke:none}
  .rail-tab-ai span{display:none}            /* label hidden — icon speaks */
  @keyframes railAiBreathMobile{
    0%,100%{box-shadow:0 8px 24px rgba(142,33,202,0.45),inset 0 1px 0 rgba(255,255,255,.18)}
    50%{box-shadow:0 8px 32px rgba(142,33,202,0.65),0 0 0 6px rgba(142,33,202,0.10),inset 0 1px 0 rgba(255,255,255,.22)}
  }

  /* ── Left panel: bottom sheet sliding up over canvas ───── */
  .lpanel{
    position:absolute;
    left:0;right:0;bottom:calc(var(--rail-h) + var(--bottom-h));
    width:100%;max-width:100%;
    max-height:55vh;height:auto;
    z-index:35;
    border-right:none;
    border-top:1px solid var(--bd);
    border-top-left-radius:18px;border-top-right-radius:18px;
    box-shadow:0 -16px 40px rgba(0,0,0,.18);
    transform:translateY(0);
    transition:transform .28s var(--ease);
  }
  .lpanel::before{
    /* Drag handle visual */
    content:'';display:block;width:40px;height:4px;
    background:var(--bd-strong);border-radius:2px;
    margin:10px auto 4px;flex-shrink:0;
  }
  .lpanel.closed{
    width:100%;border-top-color:transparent;
    transform:translateY(calc(100% + var(--rail-h) + var(--bottom-h) + 20px));
  }
  .lp-head{padding:10px 18px}
  .lp-title{font-size:18px}

  /* ── Right panel: same bottom-sheet treatment ──────────── */
  .rpanel{
    position:absolute;
    left:0;right:0;bottom:calc(var(--rail-h) + var(--bottom-h));
    width:100%;max-width:100%;
    max-height:60vh;height:auto;
    z-index:36;       /* sits above left panel if both somehow visible */
    border-left:none;
    border-top:1px solid var(--bd);
    border-top-left-radius:18px;border-top-right-radius:18px;
    box-shadow:0 -16px 40px rgba(0,0,0,.18);
    transform:translateY(0);
    transition:transform .28s var(--ease);
  }
  .rpanel::before{
    content:'';display:block;width:40px;height:4px;
    background:var(--bd-strong);border-radius:2px;
    margin:10px auto 4px;flex-shrink:0;
  }
  .rpanel.closed{
    width:100%;border-top-color:transparent;
    transform:translateY(calc(100% + var(--rail-h) + var(--bottom-h) + 20px));
  }

  /* ── Bigger touch targets in panels ─────────────────────── */
  .btn-sq{width:38px;height:38px}
  .field{padding:11px 12px;font-size:14px}
  .tpl-card,.saved-card{min-height:64px}
  .el-item{min-height:54px}

  /* ── Dropdowns: anchor right edge, narrower ─────────────── */
  .dd-menu{right:8px;left:auto;min-width:200px;max-width:calc(100vw - 24px)}

  /* ── Notes overlay: full-width on mobile ────────────────── */
  .notes-overlay{
    right:12px;left:12px;width:auto;
    bottom:calc(var(--rail-h) + var(--bottom-h) + 12px);
  }

  /* ── Toast: clear the bottom-rail stack ─────────────────── */
  .toast{bottom:calc(var(--rail-h) + var(--bottom-h) + 16px)}

  /* ── Order modal: comfortable on small screens ──────────── */
  .modal{padding:24px;border-radius:16px}
  .modal h2{font-size:28px}
  .modal-actions button{padding:13px;font-size:13px}
}

/* ═══════════════════════════════════════════════════════════════
   PHONE — Tight (≤ 480px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 480px){
  :root{--nav-h:48px}
  .nav{padding:0 8px;gap:4px}
  .nav-back{width:34px;height:34px}
  .nav-back svg{width:14px;height:14px}
  .nav-brand{padding:3px 4px}
  .nav-brand-mark{font-size:17px}

  /* Hide undo/redo on phones — too many tools competing */
  #btn-undo,#btn-redo{display:none}
  .nav-theme{width:34px;height:34px}
  .nav-cta{padding:6px 12px;font-size:12px}
  .nav-avatar{width:32px;height:32px;font-size:11px}

  /* Doc-name shrinks but keeps editable */
  .nav-doc{padding:4px 6px}
  .nav-doc input{font-size:12px}

  /* Rail labels off — icons only — and tighter */
  .rail-tab span{display:none}
  .rail-tab{min-width:50px;padding:10px 6px}
  .rail-tab svg{width:22px;height:22px}
  :root{--rail-h:54px}

  /* Pages thumbnails smaller */
  .page-thumb{width:44px;height:30px}
  .page-add{width:30px;height:30px}

  /* Panel max-heights bigger to compensate for smaller screen */
  .lpanel{max-height:60vh}
  .rpanel{max-height:65vh}

  /* Tighter panel inner padding */
  .lp-body{padding:12px 14px 20px}
  .rp-body{padding:14px 16px}
}

/* ── Landscape phone: keep canvas usable ────────────────────────
   Phones in landscape have very little vertical space. Collapse
   the bottom strip + rail height further so the canvas dominates. */
@media (max-width: 900px) and (max-height: 480px) and (orientation: landscape){
  :root{--nav-h:44px;--bottom-h:38px;--rail-h:48px}
  .nav-tool{width:32px;height:32px}
  .nav-tool svg{width:14px;height:14px}
  .lpanel,.rpanel{max-height:75vh}
  .canvas-scroll{padding:10px}
}
