:root{--rail:#3D2A33;--rail-2:#33232C;--rail-line:rgba(247,243,236,.12);
    --ivory:#F7F3EC;--champagne:#D4A574;--gold:#C9A240;--brass:#B89867;
    --canvas:#EAE4D9;--card:#FDFBF7;--ink-soft:rgba(247,243,236,.62)}
  *{box-sizing:border-box}
  html,body{margin:0;height:100%}
  body{font-family:'Inter',system-ui,sans-serif;background:var(--canvas);color:#2a2a2a;display:grid;grid-template-columns:340px 1fr;height:100vh;overflow:hidden}
  .rail{background:linear-gradient(180deg,var(--rail),var(--rail-2));color:var(--ivory);overflow-y:auto;border-right:1px solid #00000022}
  .rail::-webkit-scrollbar{width:10px}.rail::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:8px}
  .brand{padding:22px 22px 18px;border-bottom:1px solid var(--rail-line);position:sticky;top:0;background:var(--rail);z-index:5}
  .brand .wmt{font-family:'Fraunces',serif;font-weight:500;font-size:26px;letter-spacing:.06em}
  .brand .sub{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--champagne);margin-top:3px}
  .buildstamp{padding:15px 22px 24px;font-size:10px;letter-spacing:.05em;color:var(--ink-soft);border-top:1px solid var(--rail-line);margin-top:6px}
  .group{padding:18px 22px;border-bottom:1px solid var(--rail-line)}
  .group h3{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 12px;font-weight:600}
  .seg{display:flex;background:#ffffff12;border-radius:10px;padding:3px;gap:2px;flex-wrap:wrap}
  .seg button{flex:1 1 40%;border:0;background:transparent;color:var(--ink-soft);font:inherit;font-size:12px;font-weight:500;padding:8px 4px;border-radius:8px;cursor:pointer;transition:.15s;white-space:nowrap}
  .seg button.on{background:var(--ivory);color:var(--rail);font-weight:600}
  .seg.small button{font-size:11.5px;flex:1}
  .pal{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
  .sw{aspect-ratio:1/1.18;border-radius:9px;cursor:pointer;position:relative;border:2px solid transparent;overflow:hidden;display:flex;align-items:flex-end;box-shadow:0 1px 0 #00000022 inset;transition:.12s}
  .sw:hover{transform:translateY(-1px)}
  .sw.on{border-color:var(--gold);box-shadow:0 0 0 2px #C9A24055}
  .sw .dot{width:13px;height:13px;border-radius:50%;margin:0 0 6px 6px;border:1.5px solid #ffffff55}
  .sw .nm{position:absolute;top:5px;left:7px;font-size:9px;font-weight:600;letter-spacing:.02em}
  label.fld{display:block;margin:0 0 12px}
  label.fld span{display:block;font-size:11px;color:var(--ink-soft);margin:0 0 5px}
  .ipt{width:100%;background:#ffffff14;border:1px solid #ffffff1f;border-radius:9px;color:var(--ivory);font:inherit;font-size:13px;padding:9px 11px;outline:none;transition:.15s}
  .ipt:focus{border-color:var(--gold);background:#ffffff1c}
  textarea.ipt{resize:vertical;min-height:52px;line-height:1.45}
  select.ipt{appearance:none}
  .hint{font-size:10.5px;color:var(--ink-soft);margin:-7px 0 12px;line-height:1.45}
  .two{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .rowlist{display:flex;flex-direction:column;gap:9px;margin-bottom:10px}
  .row{background:#ffffff10;border:1px solid #ffffff18;border-radius:10px;padding:9px;position:relative}
  .row .x{position:absolute;top:7px;right:7px;width:20px;height:20px;border-radius:6px;border:0;background:#ffffff14;color:var(--ink-soft);cursor:pointer;font-size:13px;line-height:1}
  .row .x:hover{background:#C8102E;color:#fff}
  .row .ipt{margin-bottom:7px}.row .ipt:last-child{margin-bottom:0}
  .addbtn{width:100%;border:1px dashed #ffffff33;background:transparent;color:var(--champagne);font:inherit;font-size:12px;font-weight:600;padding:9px;border-radius:9px;cursor:pointer;transition:.15s}
  .addbtn:hover{background:#ffffff10;border-color:var(--gold)}
  .filewrap{margin-top:2px}.filewrap input{display:none}
  .filebtn{display:flex;align-items:center;gap:8px;width:100%;background:#ffffff10;border:1px solid #ffffff1f;border-radius:9px;color:var(--ivory);font:inherit;font-size:12px;padding:8px 10px;cursor:pointer}
  .filebtn:hover{border-color:var(--gold)}
  .filebtn .tag{margin-left:auto;font-size:10px;color:var(--ink-soft);max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .pchip{width:34px;height:42px;border-radius:6px;background-size:cover;background-position:center;flex:none;border:1px solid #ffffff26}
  .rowhead{display:flex;gap:9px;align-items:center;margin-bottom:8px}
  .rowhead .filebtn{padding:7px 9px}
  .miniopts{display:flex;gap:6px;margin-top:2px}
  .miniopts select{flex:1}
  .chkline{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--ivory);cursor:pointer;white-space:nowrap}
  .chkline input{width:15px;height:15px;accent-color:var(--gold)}

  .stage{display:flex;flex-direction:column;height:100vh;overflow:hidden}
  .bar{display:flex;align-items:center;gap:14px;padding:14px 22px;background:var(--card);border-bottom:1px solid #0000000f}
  .bar .title{font-family:'Fraunces',serif;font-size:17px;font-weight:500;color:#3a2b33}
  .bar .count{font-size:12px;color:#9a8f86}.bar .spacer{flex:1}
  .btn{border:0;border-radius:9px;font:inherit;font-size:13px;font-weight:600;padding:10px 16px;cursor:pointer;transition:.15s}
  .btn.ghost{background:#efe7db;color:#6a4f5b}.btn.ghost:hover{background:#e6dccd}
  .btn.gold{background:var(--gold);color:#3a2b1a}.btn.gold:hover{background:#d4ad48}
  .btn:disabled{opacity:.5;cursor:default}
  .sheet{flex:1;overflow-y:auto;padding:30px;display:flex;flex-wrap:wrap;gap:26px;align-content:flex-start}
  .sheet::-webkit-scrollbar{width:12px}.sheet::-webkit-scrollbar-thumb{background:#c9bdae;border-radius:8px}
  .thumb{position:relative;width:260px}
  .thumb .scaler{width:260px;height:325px;border-radius:14px;overflow:hidden;box-shadow:0 10px 30px -12px #00000040,0 1px 0 #ffffff inset;background:#2E1D26}
  .thumb .scaler>.slide{transform:scale(.24074);transform-origin:top left}
  .thumb .lbl{display:flex;justify-content:space-between;align-items:center;margin-top:9px;padding:0 3px;font-size:11px;color:#8a7f77}
  .thumb .lbl b{color:#5a4f47;font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:.1em}
  .thumb .dl{border:0;background:#efe7db;color:#6a4f5b;border-radius:7px;font:inherit;font-size:10.5px;font-weight:600;padding:4px 9px;cursor:pointer}
  .thumb .dl:hover{background:var(--gold);color:#3a2b1a}
  #fullstage{position:fixed;left:-99999px;top:0;width:1080px;height:1350px}

  /* ---------- shared slide ---------- */
  .slide{width:1080px;height:1350px;position:relative;overflow:hidden;display:flex;flex-direction:column;--g:#5F4352;--ink:#F7F3EC;--acc:#C9A240;background:var(--g);color:var(--ink)}
  .slide *{box-sizing:border-box}
  .wm{display:inline-block;line-height:0}.wm svg{display:block;width:100%;height:auto}

  /* ---------- text formats (Fraunces) ---------- */
  .slide.txt::after{content:'';position:absolute;inset:0;pointer-events:none;opacity:.06;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
  .slide.txt .pad{padding:92px 90px;flex:1;display:flex;flex-direction:column;height:100%;position:relative;z-index:1}
  .topbar{display:flex;justify-content:flex-start;align-items:flex-start}
  .brandmark{font-family:'Inter',sans-serif;font-size:32px;font-weight:600;letter-spacing:.03em;opacity:.8}
  .eyebrow{font-family:'Inter',sans-serif;font-size:23px;font-weight:600;letter-spacing:.42em;text-transform:uppercase;color:var(--acc)}
  .rule{width:78px;height:3px;background:var(--acc);margin:26px 0 0;border-radius:2px}
  h1.big{font-family:'Fraunces',serif;font-weight:500;font-size:100px;line-height:1.02;margin:0;letter-spacing:-.01em}
  h2.mid{font-family:'Fraunces',serif;font-weight:500;font-size:72px;line-height:1.06;margin:0}
  .body{font-family:'Inter',sans-serif;font-size:33px;line-height:1.5;opacity:.92}
  .handle{font-family:'Inter',sans-serif;font-size:38px;font-weight:500;letter-spacing:.05em;opacity:.75}
  .footer{display:flex;justify-content:space-between;align-items:center}
  .footerwrap{margin-top:auto}
  .hair{height:2px;background:var(--ink);opacity:.18;border-radius:2px;margin-bottom:28px}
  .siteurl{font-family:'Inter',sans-serif;font-size:30px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;opacity:.72}
  .footer .wm{width:188px}
  .content{flex:1;display:flex;flex-direction:column;justify-content:center}
  .mark{position:relative;display:inline-block;white-space:nowrap}
  .mark svg{position:absolute;left:-7%;top:-16%;width:114%;height:132%;overflow:visible}
  .swipe{width:150px;height:30px;margin-top:44px}
  .feat-top{display:flex;align-items:baseline;gap:22px}
  .feat-num{font-family:'Fraunces',serif;font-weight:500;font-style:italic;font-size:56px;color:var(--acc);line-height:1}
  .feat-label{font-family:'Inter',sans-serif;font-size:22px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--acc)}
  .checklist{display:flex;flex-direction:column;gap:30px}
  .check{display:flex;gap:26px;align-items:flex-start}
  .check .box{flex:none;width:50px;height:50px;border:3px solid var(--acc);border-radius:11px;margin-top:2px;display:flex;align-items:center;justify-content:center;color:var(--acc);font-size:32px;font-family:'Fraunces',serif}
  .check .ct{font-family:'Inter',sans-serif;font-size:34px;line-height:1.34}
  .tip-num-big{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:220px;line-height:.78;color:var(--acc);opacity:.9}
  .cmp-title{font-family:'Fraunces',serif;font-weight:500;font-size:52px;text-align:center}
  .cmp-title b{font-weight:700}
  .cmp-grid{display:grid;grid-template-columns:1fr 1px 1fr;margin-top:70px}
  .cmp-col{padding:0 40px;text-align:center}
  .cmp-h{font-family:'Inter',sans-serif;font-size:22px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--acc);padding-bottom:26px;border-bottom:2px solid;border-color:color-mix(in srgb,var(--ink) 22%,transparent);margin-bottom:34px}
  .cmp-b{font-family:'Inter',sans-serif;font-size:33px;line-height:1.4}
  .cmp-div{background:color-mix(in srgb,var(--ink) 30%,transparent)}
  .pills{display:flex;align-items:center;justify-content:center;gap:22px;margin-top:auto}
  .pill{font-family:'Inter',sans-serif;font-size:24px;font-weight:600;letter-spacing:.04em;padding:16px 34px;border-radius:60px}
  .pill.fill{background:var(--acc);color:var(--g)}
  .pill.out{border:2.5px solid var(--ink);color:var(--ink)}
  .spark{color:var(--acc);font-size:34px;line-height:1}
  .slide.scrap .eyebrow,.slide.scrap .feat-label,.slide.scrap .cmp-h{font-family:'Caveat',cursive;font-weight:700;letter-spacing:.04em;text-transform:none;font-size:40px}
  .slide.scrap .kicker{font-family:'Caveat',cursive;font-weight:600;font-size:46px;color:var(--acc)}

  /* ---------- photographic venue (Jost) ---------- */
  .slide.photo{background:#2E1D26}
  .slide.photo .ph{position:absolute;inset:0;overflow:hidden;z-index:0}
  .slide.photo .ph img{width:100%;height:100%;object-fit:cover}
  .slide.photo .ph .noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Inter';font-size:26px;letter-spacing:.2em;text-transform:uppercase;color:#ffffff44;background:repeating-linear-gradient(45deg,#3a2733,#3a2733 24px,#33222c 24px,#33222c 48px)}
  .pscrim{position:absolute;inset:0;pointer-events:none;z-index:1}
  .s-bot{background:linear-gradient(to top,rgba(46,29,38,.92)0%,rgba(46,29,38,.55)15%,rgba(46,29,38,.12)33%,rgba(46,29,38,0)48%)}
  .s-top{background:linear-gradient(to bottom,rgba(46,29,38,.66)0%,rgba(46,29,38,.22)18%,rgba(46,29,38,0)38%)}
  .s-radial{background:radial-gradient(ellipse 84% 48% at 50% 50%,rgba(40,25,34,.64)0%,rgba(40,25,34,.34)52%,rgba(40,25,34,0)84%)}
  .pcap{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;padding:130px 84px;color:var(--ivory)}
  .pcap.top{justify-content:flex-start;padding-top:150px}
  .pcap.center{justify-content:center}
  .pcap.lower{justify-content:flex-end;padding-bottom:288px}
  .phero{font-family:'Jost',sans-serif;font-weight:500;font-size:80px;line-height:1.16;letter-spacing:.3px;max-width:900px;text-shadow:0 2px 10px rgba(14,8,11,.7),0 1px 2px rgba(14,8,11,.92)}
  .phero em{font-style:normal;color:var(--gold);font-weight:700}
  .pkick{font-family:'Inter',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.36em;font-size:30px;color:var(--gold);text-shadow:0 1px 3px rgba(14,8,11,.85);margin-bottom:20px}
  /* Frosted-glass caption plate. Real backdrop-filter — the /api/render headless browser
     rasterises it faithfully, so the export matches this preview exactly. */
  .plate{padding:44px 62px;border-radius:30px;background:rgba(38,24,32,.6);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);box-shadow:0 0 48px 24px rgba(38,24,32,.34)}
  .dia-row{display:flex;align-items:center;justify-content:center;gap:22px;margin-top:26px}
  .dia{width:14px;height:14px;background:var(--gold);transform:rotate(45deg);display:inline-block}
  .plisted{font-family:'Inter',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.34em;font-size:34px;color:var(--ivory);text-shadow:0 1px 3px rgba(14,8,11,.8)}
  .ptop{position:absolute;top:84px;left:0;right:0;z-index:3;display:flex;flex-direction:column;align-items:center;gap:16px}
  .ptop .wm{width:360px;filter:drop-shadow(0 3px 18px rgba(20,12,16,.5))}
  .purl{font-family:'Inter',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.32em;font-size:27px;color:var(--ivory);text-shadow:0 1px 3px rgba(14,8,11,.85)}
  .pfoot{position:absolute;left:50%;bottom:112px;transform:translateX(-50%);z-index:3;width:196px;filter:drop-shadow(0 3px 18px rgba(20,12,16,.5))}
  .endcard{display:flex;flex-direction:column;align-items:center;max-width:860px;padding:56px 62px 62px}
  .endcard .wm{width:300px;margin-bottom:12px;filter:drop-shadow(0 3px 18px rgba(20,12,16,.5))}
  .end-lead{font-family:'Jost',sans-serif;font-weight:500;font-size:56px;margin-top:10px}
  .end-url{font-family:'Inter',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.26em;font-size:44px;color:var(--gold);margin-top:16px}
  .end-tag{font-family:'Jost',sans-serif;font-weight:400;font-size:40px;opacity:.95;margin-top:26px}

  .projname{background:transparent;border:1px solid transparent;border-radius:8px;font:inherit;font-size:15px;font-weight:600;color:#3a2b33;padding:6px 10px;max-width:300px}
  .projname:hover{border-color:#e0d6c8}
  .projname:focus{outline:none;border-color:var(--gold);background:#fff}
  .status{font-size:12px;color:#a99;letter-spacing:.02em;min-width:70px;text-align:right}
  .gx{border:0;background:transparent;font-size:26px;line-height:1;color:#8a7f77;cursor:pointer;padding:0 6px}
  .gx:hover{color:#3a2b33}
  .gwrap{position:fixed;inset:0;background:rgba(40,27,35,.55);backdrop-filter:blur(3px);display:none;z-index:50;align-items:flex-start;justify-content:center;padding:56px 40px;overflow:auto}
  .gwrap.show{display:flex}
  .gpanel{background:var(--card);border-radius:18px;width:100%;max-width:1040px;box-shadow:0 30px 80px -20px #00000060;padding:26px 28px 34px}
  .ghead{display:flex;align-items:center;gap:14px;margin-bottom:22px}
  .ghead h2{font-family:'Fraunces',serif;font-weight:500;font-size:26px;color:#3a2b33;margin:0}
  .ghead .spacer{flex:1}
  .ggrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}
  .gcard{cursor:pointer;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 4px 14px -6px #00000030;border:1px solid #eadfd0;transition:.14s}
  .gcard:hover{transform:translateY(-2px);box-shadow:0 12px 26px -10px #00000045}
  .gthumb{aspect-ratio:4/5;background-size:cover;background-position:center;background-color:#2E1D26}
  .gmeta{padding:10px 12px 4px}
  .gname{font-size:13.5px;font-weight:600;color:#3a2b33;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .gdate{font-size:11px;color:#a99;margin-top:2px}
  .gactions{display:flex;gap:4px;padding:8px 10px 12px}
  .gactions button{flex:1;border:0;background:#efe7db;color:#6a4f5b;border-radius:6px;font:inherit;font-size:10.5px;font-weight:600;padding:5px 4px;cursor:pointer}
  .gactions button:hover{background:var(--gold);color:#3a2b1a}
  .gactions button[data-act=del]:hover{background:#C8102E;color:#fff}
  .mk{flex:none;width:60px;height:60px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:600;font-size:38px;line-height:1}
  .mk.check{background:var(--acc);color:var(--g)}
  .mk.ask{border:3px solid var(--acc);color:var(--acc)}
  .mk-lg{width:100px;height:100px;border-radius:22px;font-size:60px;margin-bottom:6px}
  .edit-head{display:flex;align-items:center;gap:28px;margin-bottom:40px}
  .edit-num{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:70px;color:var(--acc);line-height:1}
  .edit-title{font-family:'Fraunces',serif;font-weight:500;font-size:66px;line-height:1.07;margin:0}
  .edit-body{font-family:'Inter',sans-serif;font-size:32px;line-height:1.46;margin-top:24px;opacity:.92}
  .sec-eyebrow{font-family:'Inter',sans-serif;font-weight:600;letter-spacing:.28em;text-transform:uppercase;font-size:22px;color:var(--acc);margin-top:30px;text-align:center}
  .sec-label{font-family:'Fraunces',serif;font-weight:500;font-size:80px;line-height:1.04;margin-top:16px;text-align:center;max-width:900px}
  .edit-tag{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:42px;color:var(--acc);margin-top:32px}
  .slide.scrap .sec-eyebrow{font-family:'Caveat',cursive;font-size:34px;letter-spacing:.04em;text-transform:none}

  /* font vars: slide type is driven by the chosen pairing */
  .slide{--disp:'Fraunces',serif;--body:'Inter',sans-serif}
  .slide h1.big,.slide h2.mid,.slide .feat-num,.slide .tip-num-big,.slide .cmp-title,.slide .edit-num,.slide .edit-title,.slide .sec-label,.slide .edit-tag,.slide .phero,.slide .end-lead,.slide .end-tag,.slide .check .box,.slide .mk{font-family:var(--disp)!important}
  .slide .body,.slide .handle,.slide .eyebrow,.slide .feat-label,.slide .cmp-h,.slide .cmp-b,.slide .check .ct,.slide .brandmark,.slide .pkick,.slide .purl,.slide .plisted,.slide .end-url,.slide .edit-body,.slide .sec-eyebrow,.slide .siteurl{font-family:var(--body)!important}
  /* bigger carousel type (ref: Vivaha reel v2 / reviews carousel) */
  .slide h1.big{font-size:132px;line-height:1.0}
  .slide h2.mid{font-size:94px}
  .slide .body{font-size:39px}
  .slide .cmp-title{font-size:58px}
  .slide .cmp-b{font-size:37px}.slide .cmp-h{font-size:24px}
  .slide .tip-num-big{font-size:300px}
  .slide .edit-title{font-size:82px}.slide .edit-num{font-size:90px}.slide .edit-body{font-size:36px}
  .slide .sec-label{font-size:104px}.slide .sec-eyebrow{font-size:24px}
  .slide .feat-num{font-size:66px}.slide .feat-label{font-size:24px}
  .slide .check .ct{font-size:38px}.slide .check .box{width:58px;height:58px;font-size:36px}
  .slide .edit-tag{font-size:46px}.slide .eyebrow{font-size:24px}
  .slide .end-lead{font-size:62px}.slide .end-url{font-size:52px}.slide .end-tag{font-size:44px}
  /* logo in rail */
  .brand .logo{display:block;color:var(--ivory);width:132px;height:42px;margin-bottom:16px}
  .brand .logo svg{width:100%;height:100%;display:block;filter:drop-shadow(0 2px 10px rgba(0,0,0,.3))}
  /* colour-theme chips */
  .themes{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
  .thmchip{display:flex;height:46px;border-radius:9px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:.12s}
  .thmchip:hover{transform:translateY(-1px)}
  .thmchip.on{border-color:var(--gold);box-shadow:0 0 0 2px #C9A24055}
  .thmchip span{flex:1;display:flex;align-items:flex-end;justify-content:flex-end}
  .thmchip span i{width:10px;height:10px;border-radius:50%;margin:0 4px 4px 0;box-shadow:0 0 0 1.5px #ffffff40}
  /* font options */
  .fonts{display:flex;flex-direction:column;gap:6px}
  .fontopt{display:flex;align-items:center;gap:12px;padding:9px 11px;border-radius:9px;background:#ffffff10;border:1px solid #ffffff1f;cursor:pointer;transition:.12s}
  .fontopt:hover{background:#ffffff18}
  .fontopt.on{border-color:var(--gold);background:#ffffff1f}
  .fo-a{font-size:26px;line-height:1;color:var(--ivory);width:36px;text-align:center;flex:none}
  .fo-n{font-size:12.5px;color:var(--ivory);opacity:.9}
  /* modal (custom prompt/confirm) */
  .mwrap{position:fixed;inset:0;background:rgba(40,27,35,.55);backdrop-filter:blur(3px);display:none;z-index:80;align-items:center;justify-content:center;padding:24px}
  .mwrap.show{display:flex}
  .mbox{background:var(--card);border-radius:16px;padding:22px;width:100%;max-width:400px;box-shadow:0 30px 80px -20px #00000070}
  .mtitle{font-family:'Fraunces',serif;font-size:19px;color:#3a2b33;margin-bottom:14px;line-height:1.3}
  .mInput{margin-bottom:16px;color:#3a2b33!important;background:#fff!important;border:1px solid #e0d6c8!important}
  .mInput:focus{border-color:var(--gold)!important}
  .mbtns{display:flex;gap:10px;justify-content:flex-end}
  /* mobile toolbar + bottom-sheet rail */
  .mobar{display:none;position:fixed;left:0;right:0;bottom:0;height:62px;background:var(--rail);border-top:1px solid var(--rail-line);z-index:58;align-items:center;justify-content:space-around;padding:0 8px}
  .mob-btn{flex:1;background:transparent;border:0;color:var(--ivory);font:inherit;font-size:12px;font-weight:600;padding:12px 6px;border-radius:10px}
  .mob-btn:active{background:#ffffff1f}
  .railback{display:none;position:fixed;inset:0;background:rgba(20,12,16,.5);z-index:55}
  .railback.show{display:block}
  @media (max-width:820px){
    body{grid-template-columns:1fr}
    .rail{position:fixed;left:0;right:0;bottom:0;top:auto;width:100%;height:84vh;transform:translateY(103%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:60;border-radius:22px 22px 0 0;box-shadow:0 -20px 50px rgba(0,0,0,.45)}
    .rail.open{transform:none}
    .brand{border-radius:22px 22px 0 0;position:static}
    .stage{height:100vh}
    .bar{padding:12px 14px;gap:10px}
    .bar #projBtn,.bar .btn{display:none}
    .bar .spacer,.bar .status{display:none}
    .projname{max-width:60vw;font-size:15px}
    .sheet{justify-content:center;padding:18px 14px 84px}
    .mobar{display:flex}
  }
  .fontprev{margin-top:2px;padding:12px 14px;border-radius:10px;background:#ffffff10;border:1px solid #ffffff1f}
  .fp-h{color:var(--ivory);font-size:32px;line-height:1.05}
  .fp-b{color:var(--ink-soft);font-size:14px;margin-top:5px;line-height:1.3}
  .filebtn input[type=file]{display:none}
  .rowhead{min-width:0}
  .rowhead .filebtn{flex:1;width:auto;min-width:0;padding:7px 9px}
  .posseg{display:flex;gap:4px;background:#ffffff12;border-radius:9px;padding:3px;flex:1}
  .posseg button{flex:1;border:0;background:transparent;color:var(--ink-soft);cursor:pointer;border-radius:7px;padding:5px 3px;display:flex;align-items:center;justify-content:center;transition:.12s}
  .posseg button svg{width:17px;height:21px;display:block}
  .posseg button.on{background:var(--ivory);color:var(--rail)}
  .posseg button:hover:not(.on){color:var(--ivory)}
  .twfams{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;margin-bottom:8px}
  .twfam{aspect-ratio:1;border:2px solid transparent;border-radius:7px;cursor:pointer;padding:0;transition:.1s}
  .twfam:hover{transform:translateY(-1px)}
  .twfam.on{border-color:var(--ivory);box-shadow:0 0 0 2px var(--gold)}
  .twshades{display:grid;grid-template-columns:repeat(11,1fr);gap:3px;margin-bottom:10px}
  .twsh{aspect-ratio:1;border:2px solid transparent;border-radius:5px;cursor:pointer;padding:0}
  .twsh.on{border-color:var(--gold);box-shadow:0 0 0 1.5px var(--ivory)}
  .schemeprev{display:flex;gap:6px;margin-top:2px}
  .spcell{flex:1;min-height:54px;border-radius:9px;font-size:10px;font-weight:700;letter-spacing:.02em;padding:7px;position:relative;line-height:1.2}
  .spcell i{position:absolute;right:7px;bottom:7px;width:11px;height:11px;border-radius:50%;box-shadow:0 0 0 1.5px #ffffff55}
  .pvwrap{position:fixed;inset:0;background:rgba(18,10,14,.94);backdrop-filter:blur(6px);display:none;z-index:70;align-items:center;justify-content:center}
  .pvwrap.show{display:flex}
  .pvframe{height:84vh;aspect-ratio:4/5;overflow:hidden;border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.6);position:relative;background:#2E1D26}
  .pvframe .slide{transform-origin:top left;position:absolute;top:0;left:0}
  .pvnav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:0;background:#ffffff1f;color:#fff;font-size:30px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;backdrop-filter:blur(4px)}
  .pvnav:hover{background:#ffffff33}
  .pvnav:active{transform:translateY(-50%) scale(.92)}
  .pvprev{left:max(24px,calc(50% - 42vh - 78px))}
  .pvnext{right:max(24px,calc(50% - 42vh - 78px))}
  .pvx{position:absolute;top:22px;right:26px;width:44px;height:44px;border-radius:50%;border:0;background:#ffffff1a;color:#fff;font-size:26px;line-height:1;cursor:pointer}
  .pvx:hover{background:#ffffff33}
  .pvcount{position:absolute;top:30px;left:0;right:0;text-align:center;color:#ffffffcc;font-family:'Inter',sans-serif;font-size:14px;letter-spacing:.08em;font-weight:500}
  .pvdots{position:absolute;bottom:24px;left:0;right:0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap;padding:0 40px}
  .pvdots span{width:8px;height:8px;border-radius:50%;background:#ffffff40;cursor:pointer;transition:.12s}
  .pvdots span.on{background:#fff;transform:scale(1.25)}
  @media (max-width:820px){
    .pvframe{height:auto;width:92vw;max-height:80vh}
    .pvnav{width:46px;height:46px;font-size:26px}
    .pvprev{left:8px}.pvnext{right:8px}
  }
  .loginwrap{position:fixed;inset:0;background:linear-gradient(160deg,#3D2A33,#241820);display:none;z-index:90;align-items:center;justify-content:center;padding:24px}
  .loginwrap.show{display:flex}
  .loginbox{width:100%;max-width:360px;text-align:center;color:var(--ivory)}
  .loginlogo{width:180px;height:56px;margin:0 auto 26px;color:var(--ivory)}
  .loginlogo svg{width:100%;height:100%;display:block}
  .logintitle{font-family:'Fraunces',serif;font-size:20px;margin-bottom:20px;color:var(--ivory)}
  .loginpw{text-align:center;background:#ffffff14!important;color:var(--ivory)!important;border:1px solid #ffffff2a!important;font-size:16px;padding:12px!important;margin-bottom:12px}
  .loginpw:focus{border-color:var(--gold)!important}
  .loginerr{color:#E9AE8B;font-size:13px;min-height:18px;margin-bottom:10px}
  .loginbox .btn{width:100%;padding:12px}
  .railbtn{display:flex;align-items:center;gap:9px;width:100%;padding:11px 14px;border-radius:10px;border:1px solid #ffffff26;background:#ffffff12;color:var(--ivory);font:inherit;font-size:13px;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:.14s}
  .railbtn span{font-size:15px;opacity:.85}
  .railbtn:hover{background:#ffffff1f;border-color:var(--gold)}
  .railbtn:active{transform:scale(.99)}
  .projname{font-size:16px}
  .railtabs{display:flex;gap:4px;margin:4px 22px 14px;background:#ffffff12;border-radius:10px;padding:3px}
  .railtabs button{flex:1;border:0;background:transparent;color:var(--ink-soft);font:inherit;font-size:12.5px;font-weight:600;padding:9px;border-radius:8px;cursor:pointer;transition:.12s}
  .railtabs button.on{background:var(--ivory);color:var(--rail)}
  .rowtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
  .rown{font-size:10.5px;font-weight:700;color:var(--ink-soft);letter-spacing:.06em}
  .rowctl{display:flex;gap:4px}
  .mvb,.rowctl .x{position:static;width:22px;height:22px;border-radius:6px;border:0;background:#ffffff14;color:var(--ink-soft);cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0}
  .mvb:hover{background:var(--gold);color:#3a2b1a}
  .rowctl .x:hover{background:#C8102E;color:#fff}
  .brandgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:4px}
  .brandsw{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:10px;border:1.5px solid #ffffff22;background:#ffffff10;cursor:pointer;color:var(--ivory);font:inherit;text-align:left;transition:.12s}
  .brandsw:hover{background:#ffffff18}
  .brandsw.on{border-color:var(--gold);background:#ffffff1f}
  .bsw-pair{display:flex;width:46px;height:34px;border-radius:8px;overflow:hidden;flex:none}
  .bsw-pair>span{flex:1;display:flex;align-items:flex-end;justify-content:flex-end}
  .bsw-pair>span i{width:9px;height:9px;border-radius:50%;margin:0 3px 3px 0;box-shadow:0 0 0 1.5px #ffffff66}
  .bsw-nm{font-size:11.5px;font-weight:600;line-height:1.15}
  .slide h1.big,.slide h2.mid,.slide .cmp-title,.slide .edit-title,.slide .sec-label,.slide .edit-tag{color:var(--head,var(--ink))}
  .palsw-c{width:44px;height:34px;border-radius:8px;flex:none;display:flex;align-items:flex-end;justify-content:flex-end}
  .palsw-c i{width:10px;height:10px;border-radius:50%;margin:0 3px 3px 0;box-shadow:0 0 0 1.5px #ffffff66}
  #srcSeg button{font-size:11px;padding:8px 4px;white-space:nowrap}
  .fmthint{font-size:11px;color:var(--ink-soft);margin-top:9px;line-height:1.45}
  .ficon{width:13px;height:13px;vertical-align:-2px;margin-right:5px;opacity:.85}
  .notetext{font-size:12px;color:var(--ink-soft);line-height:1.5;margin:0}
