/* ============================================================
   GAME MAKER — the no-code step-card maker (src/maker.jsx),
   styled to the claude.ai/design "Torchlit Maker" Build kit.
   Everything is scoped under .mk-overlay so the maker tokens
   (--mk-*) and rules never touch the rest of the app.
   ============================================================ */
.mk-overlay{
  position:fixed; inset:0; z-index:9600; overflow-y:auto; -webkit-overflow-scrolling:touch;
  display:flex; flex-direction:column; align-items:center; padding:18px 16px 40px;
  background:radial-gradient(ellipse 90% 60% at 50% 0%, hsl(196 45% 13%), hsl(var(--background)) 70%);
  color:hsl(var(--foreground)); font-family:var(--font-body);
  --mk-gold-fill: linear-gradient(180deg, hsl(44 92% 64%), hsl(38 82% 48%));
  --mk-gold-bevel: inset 0 1px 0 hsl(48 95% 82% / .7), inset 0 0 0 1px hsl(40 80% 55% / .8), 0 6px 20px hsl(var(--primary) / .3);
  --mk-steel-fill: linear-gradient(180deg, hsl(var(--steel-top)), hsl(var(--steel-bot)));
  --mk-steel-bevel: inset 0 1px 0 hsl(var(--bevel-hi) / .25), inset 0 0 0 1px hsl(200 28% 34% / .55);
  --mk-glass-fill: linear-gradient(180deg, hsl(var(--steel-top) / .92), hsl(var(--steel-bot) / .96));
  --mk-glass-shadow: inset 0 1px 0 hsl(var(--bevel-hi) / .22), inset 0 0 0 1px hsl(200 30% 40% / .18), 0 12px 36px rgba(0,0,0,.55);
  --mk-notch-lg: polygon(0 14px, 14px 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
  --mk-notch-sm: polygon(0 9px, 9px 0, 100% 0, 100% calc(100% - 9px), calc(100% - 9px) 100%, 0 100%);
  --mk-gold: hsl(44 80% 66%);
  --mk-mono: 'Space Mono', ui-monospace, Menlo, monospace;
  --mk-faint: hsl(var(--muted-foreground) / .7);
}
.mk-overlay *{ -webkit-tap-highlight-color:transparent; box-sizing:border-box; }

/* top bar + brand */
.mk-topbar{ width:100%; max-width:1000px; display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.mk-brand-flame{ font-size:1.5rem; }
.mk-brand{ font-family:var(--font-display); font-weight:800; font-size:1.35rem; letter-spacing:.04em; color:var(--mk-gold); text-shadow:0 0 22px hsl(var(--primary)/.35); }
.mk-brand-tag{ font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--mk-faint); }
.mk-title-readout{ font-family:var(--mk-mono); color:hsl(var(--muted-foreground)); font-size:.84rem; max-width:40vw; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mk-x{ width:36px; height:36px; flex:none; border:none; cursor:pointer; border-radius:9px; color:hsl(var(--foreground));
  background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); font-size:1rem; }

/* step rail + progress (endowed progress) */
.mk-railwrap{ width:100%; max-width:1000px; margin-bottom:18px; }
.mk-rail{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.mk-rail-btn{ display:flex; align-items:center; gap:7px; padding:8px 14px; cursor:pointer; border:none; border-radius:999px;
  font-family:var(--font-display); font-weight:700; font-size:.85rem; color:hsl(var(--muted-foreground));
  background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }
.mk-rail-btn.done{ color:var(--mk-gold); }
.mk-rail-btn.on{ color:hsl(var(--primary-foreground)); background:var(--mk-gold-fill); box-shadow:var(--mk-gold-bevel); }
.mk-progress{ height:10px; border-radius:999px; background:hsl(var(--steel-bot)); box-shadow:inset 0 1px 2px rgba(0,0,0,.45), inset 0 0 0 1px hsl(200 26% 30%/.6); overflow:hidden; }
.mk-progress-fill{ height:100%; border-radius:999px; background:var(--mk-gold-fill); box-shadow:0 0 16px hsl(var(--primary)/.4); transition:width .4s cubic-bezier(.2,.8,.2,1); }
.mk-progress-lbl{ margin-top:6px; font-size:.74rem; font-weight:700; letter-spacing:.06em; color:var(--mk-faint); }

/* the screen panel (liquid-glass) */
.mk-screen{ width:100%; max-width:1000px; min-height:360px; padding:22px 24px; position:relative; overflow:hidden;
  border-radius:14px; background:var(--mk-glass-fill); -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px); box-shadow:var(--mk-glass-shadow);
  animation:fade-rise .25s ease both; }
.mk-screen-h{ display:flex; align-items:center; gap:10px; margin:0 0 18px; font-family:var(--font-display); font-weight:700; font-size:1.4rem; color:hsl(var(--foreground)); }

/* footer nav */
.mk-foot{ width:100%; max-width:1000px; display:flex; justify-content:space-between; gap:10px; margin-top:18px; }
.mk-btn{ display:inline-flex; align-items:center; justify-content:center; gap:7px; cursor:pointer; border:none; white-space:nowrap;
  font-family:var(--font-display); font-weight:700; font-size:.95rem; letter-spacing:.03em; padding:.7rem 1.3rem; border-radius:10px;
  color:hsl(var(--foreground)); background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }
.mk-btn:active{ transform:translateY(1px); }
.mk-btn[disabled]{ opacity:.4; pointer-events:none; }
.mk-btn.gold{ color:hsl(var(--primary-foreground)); background:var(--mk-gold-fill); box-shadow:var(--mk-gold-bevel); clip-path:var(--mk-notch-sm); }
.mk-btn.ghost{ background:transparent; box-shadow:inset 0 0 0 1px hsl(var(--border)); color:hsl(var(--muted-foreground)); }

/* fields + inputs */
.mk-field-wrap{ display:flex; flex-direction:column; gap:22px; }
.mk-field{ display:flex; flex-direction:column; gap:10px; }
.mk-label{ font-family:var(--font-display); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:hsl(var(--primary)); font-size:.82rem; }
.mk-hint{ font-size:.8rem; color:hsl(var(--muted-foreground)); }
.mk-input{ width:100%; max-width:420px; height:48px; padding:0 14px; border:none; border-radius:8px; color:hsl(var(--foreground));
  background:hsl(var(--steel-bot)/.85); box-shadow:inset 0 1px 2px rgba(0,0,0,.45), inset 0 0 0 1px hsl(200 26% 30%/.6); font:inherit; font-size:1rem; outline:none; }
.mk-input:focus{ box-shadow:inset 0 1px 2px rgba(0,0,0,.45), inset 0 0 0 1px hsl(var(--accent)/.8), 0 0 0 3px hsl(var(--accent)/.18); }
.mk-row-wrap{ display:flex; gap:36px; flex-wrap:wrap; align-items:flex-start; }

/* picture cards */
.mk-pics{ display:flex; gap:14px; flex-wrap:wrap; }
.mk-pic{ position:relative; min-width:150px; padding:20px 16px; display:flex; flex-direction:column; align-items:center; gap:8px; cursor:pointer;
  border:none; clip-path:var(--mk-notch-sm); background:var(--mk-glass-fill); -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px);
  box-shadow:var(--mk-steel-bevel); --pt:40 86% 58%; }
.mk-pic.tone-teal{ --pt:190 80% 52%; } .mk-pic.tone-evil{ --pt:270 55% 62%; } .mk-pic.tone-heal{ --pt:150 54% 47%; }
.mk-pic:hover{ filter:brightness(1.1); box-shadow:inset 0 1px 0 hsl(var(--bevel-hi)/.3), inset 0 0 0 1px hsl(var(--pt)/.5); }
.mk-pic.sel{ box-shadow:inset 0 1px 0 hsl(var(--bevel-hi)/.3), inset 0 0 0 1.5px hsl(var(--pt)/.9), 0 0 22px hsl(var(--pt)/.35); }
.mk-pic-check{ position:absolute; top:8px; right:8px; width:24px; height:24px; border-radius:50%; background:hsl(var(--pt)); color:hsl(var(--primary-foreground)); display:grid; place-items:center; font-size:.8rem; font-weight:800; }
.mk-pic-emoji{ font-size:3rem; line-height:1; }
.mk-pic-label{ font-family:var(--font-display); font-weight:700; font-size:1.1rem; color:hsl(var(--foreground)); text-align:center; }
.mk-pic.sel .mk-pic-label{ color:hsl(var(--pt)); }
.mk-pic-sub{ font-size:.78rem; color:hsl(var(--muted-foreground)); text-align:center; }

/* stepper */
.mk-stepper{ display:inline-flex; align-items:center; gap:18px; }
.mk-round{ width:60px; height:60px; flex:none; border-radius:50%; border:none; cursor:pointer; font-family:var(--font-display); font-weight:700; font-size:1.8rem; line-height:1;
  color:hsl(var(--primary-foreground)); background:var(--mk-gold-fill); box-shadow:var(--mk-gold-bevel); }
.mk-round:active{ transform:translateY(1px); }
.mk-round[disabled]{ color:var(--mk-faint); background:hsl(var(--steel-bot)); box-shadow:inset 0 1px 2px rgba(0,0,0,.45); cursor:not-allowed; }
.mk-stepper-n{ min-width:64px; text-align:center; font-family:var(--mk-mono); font-weight:700; font-size:2.4rem; color:var(--mk-gold); text-shadow:0 0 18px hsl(var(--primary)/.4); }

/* toggle */
.mk-toggle-wrap{ display:inline-flex; align-items:center; gap:12px; cursor:pointer; }
.mk-toggle{ position:relative; width:68px; height:38px; flex:none; border-radius:999px; background:hsl(var(--steel-bot)); box-shadow:inset 0 1px 2px rgba(0,0,0,.45), inset 0 0 0 1px hsl(200 26% 30%/.6); transition:background .24s ease; }
.mk-toggle.on{ background:hsl(var(--accent)); box-shadow:inset 0 1px 2px rgba(0,0,0,.45), 0 0 16px hsl(var(--accent)/.5); }
.mk-toggle-knob{ position:absolute; top:5px; left:5px; width:28px; height:28px; border-radius:50%; background:linear-gradient(180deg,#f4f8fa,#c4d2d8); box-shadow:0 2px 5px rgba(0,0,0,.5), inset 0 1px 0 #fff; transition:left .24s cubic-bezier(.34,1.4,.5,1); }
.mk-toggle.on .mk-toggle-knob{ left:35px; }
.mk-toggle-label{ font-weight:700; font-size:1rem; color:hsl(var(--foreground)); }

/* list chips */
.mk-list{ display:flex; flex-wrap:wrap; gap:8px; }
.mk-list-chip{ display:inline-flex; align-items:center; gap:6px; padding:7px 12px; border-radius:999px; font-weight:700; font-size:.85rem; color:hsl(var(--foreground)); background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }

/* ---------- step 3: the stack editor ---------- */
.mk-steps-grid{ display:grid; grid-template-columns:1fr 300px; gap:20px; align-items:start; }
.mk-stack{ display:flex; flex-direction:column; gap:12px; margin-top:8px; }
.mk-addstep{ height:50px; border:none; border-radius:14px; cursor:pointer; font-family:var(--font-display); font-weight:700; font-size:.95rem;
  color:hsl(var(--foreground)); background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }

/* the step-card */
.mk-step{ position:relative; padding:14px 16px; cursor:pointer; clip-path:var(--mk-notch-lg); overflow:hidden;
  background:var(--mk-glass-fill); -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px); box-shadow:var(--mk-glass-shadow); }
.mk-step.sel{ box-shadow:inset 0 1px 0 hsl(var(--bevel-hi)/.3), inset 0 0 0 1.5px hsl(var(--primary)/.85), 0 0 24px hsl(var(--primary)/.3); }
.mk-step-head{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.mk-step-n{ width:32px; height:32px; flex:none; border-radius:8px; display:grid; place-items:center; font-family:var(--mk-mono); font-weight:700; font-size:1rem;
  color:hsl(var(--primary-foreground)); background:var(--mk-gold-fill); box-shadow:var(--mk-gold-bevel); }
.mk-step-emoji{ font-size:1.5rem; line-height:1; }
.mk-step-title{ flex:1; font-family:var(--font-display); font-weight:700; font-size:1.1rem; color:var(--mk-gold); }
.mk-step-grip{ color:var(--mk-faint); font-size:1.3rem; cursor:grab; }
.mk-step-zones{ display:flex; gap:14px; }
.mk-step-div{ width:1px; background:hsl(var(--border)/.6); align-self:stretch; }
.mk-zone{ flex:1; min-width:0; }
.mk-zone-h{ font-weight:800; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:7px; }
.mk-zone-h.pub{ color:hsl(var(--accent)); } .mk-zone-h.sec{ color:hsl(var(--primary)); }
.mk-zone-items{ display:flex; flex-direction:column; gap:6px; }
.mk-zone-empty{ font-size:.85rem; color:var(--mk-faint); font-style:italic; }
.mk-item{ display:inline-flex; align-items:center; gap:7px; padding:5px 10px; border-radius:8px; font-weight:700; font-size:.82rem; color:hsl(var(--foreground)); }
.mk-item.pub{ background:hsl(var(--accent)/.1); box-shadow:inset 0 0 0 1px hsl(var(--accent)/.28); }
.mk-item.sec{ background:hsl(var(--primary)/.1); box-shadow:inset 0 0 0 1px hsl(var(--primary)/.28); }
.mk-step-foot{ display:flex; align-items:center; gap:8px; margin-top:14px; padding-top:12px; border-top:1px dashed hsl(var(--border)/.6); }
.mk-step-foot-lbl{ font-size:.7rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--mk-faint); }
.mk-step-adv{ display:inline-flex; align-items:center; gap:7px; padding:6px 12px; border-radius:999px; font-weight:800; font-size:.82rem; color:var(--mk-gold); background:hsl(var(--primary)/.12); box-shadow:inset 0 0 0 1px hsl(var(--primary)/.35); }

/* the editor panel (content menu + advance) */
.mk-panel{ position:sticky; top:8px; padding:16px; clip-path:var(--mk-notch-sm); background:var(--mk-glass-fill); -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px); box-shadow:var(--mk-glass-shadow); display:flex; flex-direction:column; gap:10px; }
.mk-panel .mk-input{ height:42px; max-width:none; }
.mk-panel-row{ display:flex; gap:6px; }
.mk-mini{ flex:1; padding:7px 0; border:none; border-radius:8px; cursor:pointer; font-weight:700; font-size:.8rem; color:hsl(var(--foreground)); background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }
.mk-mini.danger{ color:hsl(var(--damage)); }
.mk-mini[disabled]{ opacity:.4; pointer-events:none; }
.mk-menu{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.mk-menu-item{ display:flex; flex-direction:column; gap:5px; padding:8px; border-radius:8px; background:hsl(var(--steel-bot)/.7); box-shadow:inset 0 0 0 1px hsl(200 28% 34%/.55); }
.mk-menu-name{ display:flex; align-items:center; gap:6px; font-weight:700; font-size:.8rem; color:hsl(var(--foreground)); }
.mk-menu-adds{ display:flex; gap:4px; }
.mk-add{ flex:1; padding:6px 0; border:none; border-radius:6px; cursor:pointer; font-size:1rem; }
.mk-add.pub{ background:hsl(var(--accent)/.14); box-shadow:inset 0 0 0 1px hsl(var(--accent)/.4); }
.mk-add.sec{ background:hsl(var(--primary)/.14); box-shadow:inset 0 0 0 1px hsl(var(--primary)/.4); }
.mk-advance{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.mk-adv{ display:flex; align-items:center; justify-content:center; gap:7px; padding:11px 0; border:none; border-radius:10px; cursor:pointer; font-family:var(--font-display); font-weight:700; font-size:.85rem;
  color:hsl(var(--foreground)); background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }
.mk-adv.on{ color:hsl(var(--primary-foreground)); background:var(--mk-gold-fill); box-shadow:var(--mk-gold-bevel); }

/* ---------- step 4: win sentence ---------- */
.mk-sentence-box{ display:flex; flex-wrap:wrap; align-items:center; gap:12px; padding:20px 22px; border-radius:14px;
  background:var(--mk-glass-fill); box-shadow:var(--mk-glass-shadow); font-size:1.1rem; font-weight:700; line-height:2.1; }
.mk-sentence{ height:44px; min-width:170px; padding:0 32px 0 12px; cursor:pointer; border:none; border-radius:8px; font:inherit; font-weight:700; color:var(--mk-gold);
  background:hsl(var(--steel-bot)/.85); box-shadow:inset 0 1px 2px rgba(0,0,0,.45), inset 0 0 0 1px hsl(200 26% 30%/.6); -webkit-appearance:none; appearance:none; }

/* ---------- step 5: try ---------- */
.mk-try{ text-align:center; padding:10px 0; }
.mk-try-emoji{ font-size:3.4rem; }
.mk-try-h{ font-family:var(--font-display); font-size:1.6rem; color:var(--mk-gold); text-shadow:0 0 26px hsl(var(--primary)/.4); margin:.3rem 0; }
.mk-try-sub{ color:hsl(var(--muted-foreground)); max-width:48ch; margin:0 auto 1.4rem; line-height:1.5; }
.mk-try-facts{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; font-weight:700; color:hsl(var(--foreground)); }
.mk-try-facts span{ padding:8px 14px; border-radius:999px; background:var(--mk-steel-fill); box-shadow:var(--mk-steel-bevel); }

@media (max-width:760px){
  .mk-steps-grid{ grid-template-columns:1fr; }
  .mk-panel{ position:static; }
  .mk-sentence-box{ font-size:1rem; line-height:1.9; }
}
@media (prefers-reduced-motion: reduce){ .mk-screen{ animation:none; } .mk-progress-fill, .mk-toggle-knob{ transition:none; } }
