/* QuickPassMaker Design Studio — Fabric.js editor.
   Dark, vibrant theme to match quickpassmaker.com: near-black surfaces,
   magenta (#FF3AF2) chrome accents, yellow (#FFE600) primary CTA, cyan/purple
   highlights, thick borders + hard offset shadows. Responsive: on phones the
   4-column layout collapses to a full-screen canvas with a bottom tool-rail and
   slide-up bottom sheets for the tool panel + the object inspector. */
:root{
  --bg:#0d0d1a;
  --surface:#15152b;
  --surface-2:#1e1e3c;
  --line:#33335c;
  --magenta:#ff3af2;
  --purple:#7b2fff;
  --cyan:#22d3ee;
  --accent:#ffe600;
  --accent-ink:#0d0d1a;
  --ink:#ffffff;
  --muted:#9aa0be;
  --shadow:3px 3px 0 rgba(0,0,0,.55);
}
*{box-sizing:border-box;}
[hidden]{display:none !important;}        /* beat author display rules (e.g. .ds-custom-size) */
html,body{margin:0;height:100%;}
body{
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--ink); background:var(--bg); overflow:hidden; -webkit-font-smoothing:antialiased;
}
button{font-family:inherit;}
#ds-app{display:flex;flex-direction:column;height:100vh;height:100dvh;}

/* ---------- top bar ---------- */
#ds-topbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:8px 14px;background:var(--surface);border-bottom:3px solid var(--magenta);flex:0 0 auto;
}
.ds-tb-left,.ds-tb-center,.ds-tb-right{display:flex;align-items:center;gap:8px;min-width:0;}
.ds-brand{display:flex;align-items:center;gap:7px;font-weight:800;font-size:16px;text-decoration:none;color:var(--ink);letter-spacing:-.01em;white-space:nowrap;}
.ds-brand-mark{color:var(--accent);font-size:18px;}
.ds-divider{width:2px;height:24px;background:var(--line);border-radius:2px;}
.ds-tb-field{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);min-width:0;}
.ds-tb-field select{font:inherit;font-size:13px;text-transform:none;letter-spacing:0;font-weight:600;padding:6px 8px;border:2px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink);max-width:220px;}
.ds-custom-size{display:flex;align-items:center;gap:5px;font-weight:700;color:var(--ink);}
.ds-custom-size input{width:68px;padding:5px 6px;border:2px solid var(--line);border-radius:7px;font:inherit;background:var(--surface-2);color:var(--ink);}
.ds-zoom-label{min-width:46px;text-align:center;font-weight:700;font-size:13px;color:var(--ink);}

.ds-icon-btn{
  width:34px;height:34px;border:2px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink);
  font-size:17px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
}
.ds-icon-btn:hover:not(:disabled){background:var(--line);border-color:var(--cyan);}
.ds-icon-btn:disabled{opacity:.32;cursor:default;}
.ds-btn{
  font-weight:800;font-size:14px;padding:8px 14px;border:2px solid var(--line);border-radius:9px;
  background:var(--surface-2);color:var(--ink);cursor:pointer;white-space:nowrap;
}
.ds-btn:hover{background:var(--line);border-color:var(--cyan);}
.ds-btn-sm{padding:5px 9px;font-size:12px;}
.ds-btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent-ink);box-shadow:var(--shadow);}
.ds-btn-primary:hover{background:#fff04d;border-color:var(--accent-ink);}
.ds-btn.ds-block{display:block;width:100%;margin-top:10px;}
.ds-menu{position:relative;}
.ds-menu-list{
  position:absolute;right:0;top:calc(100% + 6px);background:var(--surface-2);border:2px solid var(--magenta);
  border-radius:10px;box-shadow:var(--shadow);min-width:190px;z-index:90;overflow:hidden;
}
.ds-menu-list button{display:block;width:100%;text-align:left;padding:10px 14px;border:0;background:transparent;color:var(--ink);font:inherit;font-size:14px;font-weight:600;cursor:pointer;}
.ds-menu-list button:hover{background:var(--magenta);color:#fff;}

/* ---------- body grid ---------- */
#ds-body{flex:1 1 auto;display:flex;min-height:0;position:relative;}
#ds-rail{
  flex:0 0 88px;background:var(--surface);border-right:3px solid var(--line);
  display:flex;flex-direction:column;padding:8px 0;gap:4px;overflow:auto;
}
.ds-rail-btn{
  display:flex;flex-direction:column;align-items:center;gap:3px;border:0;background:transparent;
  padding:9px 4px;font-size:20px;cursor:pointer;color:var(--muted);border-left:3px solid transparent;overflow:hidden;
}
.ds-rail-btn span{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:0;max-width:100%;}
.ds-rail-btn:hover{background:var(--surface-2);color:var(--ink);}
.ds-rail-btn.is-active{background:var(--surface-2);color:var(--ink);border-left-color:var(--magenta);}

#ds-panel{flex:0 0 248px;background:var(--surface);border-right:3px solid var(--line);overflow:auto;padding:14px;}
.ds-pane h3{margin:2px 0 10px;font-size:16px;font-weight:800;color:var(--ink);}
.ds-hint{font-size:12px;color:var(--muted);line-height:1.4;margin:10px 0 0;}
.ds-field{display:block;margin-bottom:11px;}
.ds-field>span{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:5px;}
.ds-field input,.ds-field select{width:100%;font:inherit;padding:7px 9px;border:2px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink);}
.ds-field input::placeholder{color:var(--muted);}
.ds-field input[type=color]{height:38px;padding:3px;cursor:pointer;}

.ds-add-text{display:block;width:100%;text-align:left;border:2px solid var(--line);border-radius:9px;background:var(--surface-2);color:var(--ink);cursor:pointer;margin-bottom:9px;padding:11px 13px;}
.ds-add-text[data-style=heading]{font-size:21px;font-weight:800;}
.ds-add-text[data-style=subheading]{font-size:16px;font-weight:700;}
.ds-add-text[data-style=body]{font-size:13px;font-weight:500;}
.ds-add-text:hover{background:var(--magenta);color:#fff;border-color:var(--magenta);}

.ds-shape-grid,.ds-template-grid,.ds-upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.ds-shape{aspect-ratio:1;border:2px solid var(--line);border-radius:10px;background:var(--surface-2);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.ds-shape:hover{background:var(--line);border-color:var(--cyan);}
.ds-shape span{display:inline-block;}
.sh-rect{width:34px;height:24px;background:var(--ink);}
.sh-round{width:34px;height:24px;background:var(--ink);border-radius:7px;}
.sh-circle{width:30px;height:30px;background:var(--ink);border-radius:50%;}
.sh-tri{width:0;height:0;border-left:18px solid transparent;border-right:18px solid transparent;border-bottom:30px solid var(--ink);}
.sh-line{width:34px;height:4px;background:var(--ink);}
.sh-star{font-size:30px;line-height:1;color:var(--ink);}

.ds-template-grid{grid-template-columns:1fr;}
.ds-tpl-cat{grid-column:1/-1;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--cyan);margin:15px 0 1px;}
.ds-tpl-cat:first-child{margin-top:2px;}
.ds-check{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--ink);margin:4px 0 13px;cursor:pointer;}
.ds-check input{width:auto;margin:0;accent-color:var(--magenta);}
.ds-template-card{border:2px solid var(--line);border-radius:10px;overflow:hidden;cursor:pointer;background:var(--surface-2);box-shadow:var(--shadow);transition:transform .12s ease,border-color .12s ease;}
.ds-template-card:hover{transform:translate(-1px,-1px);border-color:var(--magenta);}
.ds-template-card .ds-tc-prev{height:96px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;}
.ds-template-card .ds-tc-name{padding:7px 10px;font-size:12px;font-weight:700;border-top:2px solid var(--line);color:var(--ink);}

.ds-upload-drop{display:flex;align-items:center;justify-content:center;text-align:center;border:2px dashed var(--line);border-radius:11px;padding:22px 12px;cursor:pointer;font-weight:600;font-size:13px;color:var(--muted);background:var(--surface-2);}
.ds-upload-drop:hover{background:var(--line);border-color:var(--cyan);color:var(--ink);}
.ds-upload-drop small{color:var(--muted);font-weight:500;}
.ds-bg-upload{margin-top:12px;}
.ds-upload-grid{margin-top:12px;}
.ds-upload-grid img{width:100%;aspect-ratio:1;object-fit:cover;border:2px solid var(--line);border-radius:8px;cursor:pointer;}

.ds-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin:8px 0 4px;}
.ds-swatches button{aspect-ratio:1;border:2px solid var(--line);border-radius:7px;cursor:pointer;padding:0;}

/* ---------- stage ---------- */
#ds-stage{flex:1 1 auto;min-width:0;overflow:auto;background:
  repeating-linear-gradient(45deg,#121226 0 12px,#0d0d1a 12px 24px);
  display:flex;align-items:center;justify-content:center;padding:32px;}
#ds-canvas-wrap{box-shadow:0 12px 40px rgba(0,0,0,.5);background:#fff;}
.canvas-container{display:block;}

/* ---------- inspector ---------- */
#ds-inspector{flex:0 0 264px;background:var(--surface);border-left:3px solid var(--line);overflow:auto;display:flex;flex-direction:column;}
.ds-insp-empty{padding:18px;font-size:13px;color:var(--muted);line-height:1.5;}
#ds-inspector-props{padding:14px;border-bottom:3px solid var(--line);}
.ds-insp-group{margin-bottom:14px;}
.ds-insp-group>label.ds-field{margin-bottom:9px;}
.ds-row{display:flex;gap:8px;}
.ds-row>*{flex:1;}
.ds-btn-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(62px,1fr));gap:6px;margin-top:6px;}
.ds-mini{min-width:0;border:2px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink);padding:8px 5px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ds-mini:hover{background:var(--line);border-color:var(--cyan);}
.ds-mini.ds-danger:hover{background:#7f1d1d;border-color:#ef4444;color:#fff;}
.ds-toggle-row{display:flex;gap:6px;margin-bottom:11px;}
.ds-toggle{flex:1;border:2px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink);padding:7px;font-weight:800;cursor:pointer;}
.ds-toggle.is-on{background:var(--magenta);color:#fff;border-color:var(--magenta);}

.ds-layers{padding:14px;flex:1;}
.ds-layers h4{margin:0 0 9px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);}
#ds-layer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px;}
.ds-layer{display:flex;align-items:center;gap:8px;border:2px solid var(--line);border-radius:8px;padding:6px 8px;background:var(--surface-2);color:var(--ink);cursor:pointer;font-size:13px;}
.ds-layer.is-active{background:var(--magenta);color:#fff;border-color:var(--magenta);}
.ds-layer .ds-layer-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;}
.ds-layer .ds-layer-vis{border:0;background:transparent;cursor:pointer;font-size:15px;line-height:1;}
.ds-layer-icon{width:18px;text-align:center;}

/* ---------- right-click context menu ---------- */
.ds-ctx{
  position:fixed;z-index:200;min-width:196px;padding:6px;
  background:var(--surface-2);border:2px solid var(--magenta);border-radius:12px;
  box-shadow:0 16px 44px rgba(0,0,0,.6);user-select:none;
}
.ds-ctx-item{
  display:flex;align-items:center;justify-content:space-between;gap:20px;width:100%;
  border:0;background:transparent;color:var(--ink);font:inherit;font-size:13px;font-weight:600;
  text-align:left;padding:8px 10px;border-radius:8px;cursor:pointer;white-space:nowrap;
}
.ds-ctx-item:hover{background:var(--magenta);color:#fff;}
.ds-ctx-accel{font-size:11px;font-weight:600;color:var(--muted);}
.ds-ctx-item:hover .ds-ctx-accel{color:#ffe;}
.ds-ctx-danger:hover{background:#7f1d1d;}
.ds-ctx-sep{height:2px;background:var(--line);margin:5px 6px;border-radius:2px;}

/* sheet header — only rendered/visible in the mobile bottom-sheet layout */
.ds-sheet-head{display:none;}

/* ---------- tablet: tighten the side columns ---------- */
@media (max-width:1100px){
  #ds-panel{flex-basis:216px;}
  #ds-inspector{flex-basis:228px;}
}
@media (max-width:900px){
  #ds-rail{flex-basis:64px;}
  .ds-rail-btn span{font-size:8px;}
  .ds-tb-field>span{display:none;}
  #ds-panel{flex-basis:198px;}
  #ds-inspector{flex-basis:210px;}
}

/* ---------- phones: full-screen canvas + bottom rail + slide-up sheets ---------- */
@media (max-width:768px){
  /* compact top bar (canvas auto-fits, so drop the zoom stepper) */
  #ds-topbar{gap:7px;padding:7px 10px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;}
  #ds-topbar::-webkit-scrollbar{display:none;}
  .ds-brand{gap:0;font-size:0;}                        /* hide the "Design Studio" text node */
  .ds-brand-mark{font-size:24px;}                      /* keep only the ◆ mark */
  .ds-tb-left .ds-divider{display:none;}
  .ds-tb-field select{max-width:118px;}
  .ds-zoom-label,#ds-zoom-in,#ds-zoom-out,#ds-zoom-fit,.ds-tb-center .ds-divider{display:none;}
  .ds-btn{padding:8px 11px;font-size:13px;}

  /* canvas fills everything above the bottom rail */
  #ds-body{display:block;}
  #ds-stage{height:100%;padding:14px;padding-bottom:74px;}

  /* tool rail → fixed bottom toolbar */
  #ds-rail{
    position:fixed;left:0;right:0;bottom:0;height:58px;flex:none;
    flex-direction:row;justify-content:space-around;align-items:stretch;gap:0;padding:0;overflow:visible;
    border-right:0;border-top:3px solid var(--magenta);z-index:60;
  }
  .ds-rail-btn{flex:1;border-left:0;border-top:3px solid transparent;justify-content:center;padding:5px 2px;font-size:18px;gap:2px;}
  .ds-rail-btn span{display:block;font-size:8.5px;}
  .ds-rail-btn.is-active{border-left-color:transparent;border-top-color:var(--magenta);}

  /* tool panel + inspector → slide-up bottom sheets */
  #ds-panel,#ds-inspector{
    position:fixed;left:0;right:0;bottom:58px;width:auto;flex:none;max-height:64vh;
    border:0;border-top:3px solid var(--magenta);border-radius:18px 18px 0 0;
    transform:translateY(115%);transition:transform .28s cubic-bezier(.22,1,.36,1);
    z-index:55;box-shadow:0 -12px 34px rgba(0,0,0,.55);-webkit-overflow-scrolling:touch;
    padding-bottom:20px;
  }
  #ds-panel.ds-open,#ds-inspector.ds-open{transform:translateY(0);}
  #ds-inspector{padding:0 0 20px;}

  .ds-sheet-head{
    display:flex;align-items:center;justify-content:space-between;gap:10px;
    position:sticky;top:0;background:var(--surface);padding:12px 14px 10px;
    border-bottom:2px solid var(--line);z-index:2;
  }
  .ds-sheet-head .ds-sheet-title{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--ink);}
  .ds-sheet-close{
    width:34px;height:34px;flex:0 0 auto;border:2px solid var(--line);border-radius:9px;
    background:var(--surface-2);color:var(--ink);font-size:18px;line-height:1;cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;
  }
  /* a small grab handle above the title */
  .ds-sheet-head::before{
    content:"";position:absolute;top:5px;left:50%;transform:translateX(-50%);
    width:42px;height:4px;border-radius:3px;background:var(--line);
  }
}
