/* ════════════════════════════════════════════
   NOVARESUME — APP CSS
════════════════════════════════════════════ */
:root{
  --bg:#080a12;--s0:#0d0f1a;--s1:#11141f;--s2:#161925;--s3:#1c2030;--s4:#222638;
  --bd:rgba(255,255,255,.05);--bd2:rgba(255,255,255,.1);
  --tx:#dde1f0;--tx2:#8890aa;--tx3:#4a5070;
  --ac:#7060f2;--ac2:#9580ff;--acg:rgba(112,96,242,.2);--acs:rgba(112,96,242,.08);
  --cyan:#00c8e0;--ok:#2dd4a0;--err:#f06b6b;--warn:#f5a623;
  --ease:cubic-bezier(.22,.68,0,1.2);--ease2:cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;overflow:hidden}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s4);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--tx3)}

/* ════ SECURITY — no text select, no right-click, no screenshot assist ════ */
body{-webkit-user-drag:none}
@media print{body{display:none!important}}

/* ════ HEADER ════ */
#hdr{
  position:fixed;top:0;left:0;right:0;z-index:200;height:52px;
  background:rgba(8,10,18,.94);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;padding:0 .75rem;gap:.35rem;
  overflow:hidden;
}
.logo{font-family:'DM Serif Display',serif;font-size:1rem;letter-spacing:-.02em;color:var(--tx);
  flex-shrink:0;display:flex;align-items:center;gap:1px;white-space:nowrap}
.logo-dot{width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--ac),var(--cyan));
  margin-left:2px;margin-bottom:2px;flex-shrink:0}
.hdr-mid{flex:1;display:flex;justify-content:center;min-width:0;overflow:hidden}
.hdr-right{display:flex;gap:.28rem;flex-shrink:0;align-items:center}

/* Tab bar */
.tabbar{display:flex;background:var(--s2);border:1px solid var(--bd2);border-radius:9px;padding:3px;gap:2px}
.tabbar button{padding:.28rem .65rem;border:none;background:none;
  font-family:'DM Sans',sans-serif;font-size:.7rem;font-weight:500;
  color:var(--tx3);border-radius:7px;cursor:pointer;
  transition:all .18s var(--ease2);white-space:nowrap}
.tabbar button.on{background:var(--ac);color:#fff;box-shadow:0 2px 10px var(--acg)}

/* Language selector — strict 32×32, NEVER grows */
.lang-btn{
  position:relative;width:32px;height:32px;
  min-width:32px;max-width:32px;flex-shrink:0;flex-grow:0;
  border:1px solid var(--bd2);border-radius:8px;background:var(--s2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:border-color .15s;overflow:hidden;
}
.lang-btn:hover{border-color:var(--ac)}
.lang-flag{font-size:.95rem;line-height:1;pointer-events:none;user-select:none;position:relative;z-index:0}
.lang-btn select{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;font-size:16px;z-index:1}

/* Generic buttons */
.btn{display:inline-flex;align-items:center;gap:.3rem;
  padding:.36rem .7rem;border-radius:8px;
  font-family:'DM Sans',sans-serif;font-size:.7rem;font-weight:500;
  cursor:pointer;border:none;transition:all .16s var(--ease2);white-space:nowrap;line-height:1;flex-shrink:0}
.btn-p{background:linear-gradient(135deg,var(--ac),var(--ac2));color:#fff;box-shadow:0 2px 14px var(--acg)}
.btn-p:hover{transform:translateY(-1px);box-shadow:0 5px 22px var(--acg)}
.btn-p:active{transform:translateY(0)}
.btn-g{background:var(--s2);color:var(--tx2);border:1px solid var(--bd2)}
.btn-g:hover{background:var(--s3);color:var(--tx)}
.btn-icon{padding:.36rem .42rem}
@media(max-width:580px){.btn .bl{display:none}.btn{padding:.36rem .42rem}}

/* ════ APP BODY ════ */
#app{position:fixed;top:52px;left:0;right:0;bottom:0;display:grid;grid-template-columns:390px 1fr;overflow:hidden}
@media(max-width:1100px){#app{grid-template-columns:340px 1fr}}
@media(max-width:800px){
  #app{grid-template-columns:1fr;bottom:50px}
  #prevPane{display:none}
  #prevPane.mob-show{display:flex}
  #editPane.mob-hide{display:none}
}
@media(min-width:801px){#mobNav{display:none!important}#prevPane{display:flex!important}#editPane{display:flex!important}}

/* ════ EDITOR PANE ════ */
#editPane{background:var(--s1);border-right:1px solid var(--bd);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;padding:.85rem;gap:.7rem}
.card{border:1px solid var(--bd);border-radius:12px;overflow:hidden;background:var(--s2);transition:border-color .2s}
.card:focus-within{border-color:rgba(112,96,242,.25)}
.card-hd{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;background:var(--s3);border-bottom:1px solid var(--bd);cursor:pointer;user-select:none;gap:.5rem}
.card-hd h3{font-size:.63rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--tx2);display:flex;align-items:center;gap:.4rem}
.card-dot{width:5px;height:5px;border-radius:50%;background:linear-gradient(135deg,var(--ac),var(--cyan));flex-shrink:0}
.card-chev{width:14px;height:14px;color:var(--tx3);transition:transform .2s var(--ease2);flex-shrink:0}
.card-body{padding:.8rem;display:flex;flex-direction:column;gap:.6rem}
.card-body.collapsed{display:none}

/* Template grid — now 3 wide for 6 templates + wraps to 2nd row */
.tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;padding:.75rem}
.tpl{border:2px solid var(--bd2);border-radius:8px;padding:.4rem;cursor:pointer;transition:all .15s var(--ease2);text-align:center;background:var(--s1)}
.tpl.on{border-color:var(--ac);background:var(--acs);box-shadow:0 0 0 1px var(--ac)}
.tpl:hover:not(.on){border-color:var(--tx3)}
.tpl-thumb{width:100%;aspect-ratio:3/4;border-radius:3px;margin-bottom:.25rem;display:flex;flex-direction:column;padding:4px;gap:2px;overflow:hidden}
.tl{height:3px;border-radius:2px;background:var(--s4)}
.tl.ac{background:linear-gradient(90deg,var(--ac),var(--cyan))}
.tl.thick{height:5px}
.tpl-name{font-size:.6rem;color:var(--tx3);font-weight:500;line-height:1.2}

/* ── Color palette picker ── */
.palette-wrap{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap;padding:.6rem .85rem .7rem}
.pal-swatch{
  width:28px;height:28px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;
  transition:transform .15s,box-shadow .15s;flex-shrink:0;
}
.pal-swatch.on,.pal-swatch:hover{transform:scale(1.18);box-shadow:0 0 0 2px #fff4}
.pal-custom-wrap{display:flex;align-items:center;gap:.3rem;margin-left:auto}
.pal-custom-label{font-size:.6rem;color:var(--tx3);letter-spacing:.05em;text-transform:uppercase}
.pal-custom-input{width:28px;height:28px;border-radius:50%;border:2.5px solid var(--bd2);cursor:pointer;padding:0;background:none;-webkit-appearance:none;appearance:none}
.pal-custom-input::-webkit-color-swatch-wrapper{padding:0;border-radius:50%}
.pal-custom-input::-webkit-color-swatch{border:none;border-radius:50%}

/* ── Custom section builder ── */
.custom-sec-item{border:1px solid var(--bd);border-radius:8px;padding:.65rem;background:var(--s1);position:relative;animation:fadeUp .18s var(--ease2);margin-bottom:.5rem}
.custom-sec-title-row{display:flex;gap:.4rem;align-items:center;margin-bottom:.4rem}
.custom-sec-name{flex:1;padding:.38rem .55rem;border:1px solid var(--bd2);border-radius:6px;background:var(--s2);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:.78rem;outline:none}
.custom-sec-name:focus{border-color:var(--ac)}
.custom-sec-content{width:100%;padding:.38rem .55rem;border:1px solid var(--bd2);border-radius:6px;background:var(--s2);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:.78rem;outline:none;resize:vertical;min-height:60px;line-height:1.5}
.custom-sec-content:focus{border-color:var(--ac)}

label{display:block;font-size:.61rem;font-weight:600;color:var(--tx3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.2rem}
input,textarea,select{width:100%;padding:.44rem .62rem;border:1px solid var(--bd2);border-radius:7px;background:var(--s1);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:.8rem;outline:none;-webkit-appearance:none;transition:border-color .18s,box-shadow .18s}
input:focus,textarea:focus,select:focus{border-color:var(--ac);box-shadow:0 0 0 3px var(--acs)}
input::placeholder,textarea::placeholder{color:var(--tx3)}
textarea{resize:vertical;min-height:72px;line-height:1.5}
select{cursor:pointer}
select option{background:var(--s2)}
.r2{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
@media(max-width:340px){.r2{grid-template-columns:1fr}}
.ig{display:flex;flex-direction:column}
.ilist{display:flex;flex-direction:column;gap:.6rem}
.iblk{border:1px solid var(--bd);border-radius:9px;padding:.75rem;background:var(--s1);position:relative;animation:fadeUp .18s var(--ease2)}
@keyframes fadeUp{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.irem{position:absolute;top:.45rem;right:.45rem;width:22px;height:22px;border:none;background:none;color:var(--tx3);cursor:pointer;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.95rem;line-height:1;transition:background .14s,color .14s}
.irem:hover{background:rgba(240,107,107,.14);color:var(--err)}
.add-btn{display:flex;align-items:center;gap:.3rem;padding:.4rem .7rem;border:1px dashed rgba(112,96,242,.3);border-radius:7px;background:none;color:var(--ac);font-family:'DM Sans',sans-serif;font-size:.74rem;font-weight:500;cursor:pointer;width:100%;justify-content:center;transition:all .16s var(--ease2)}
.add-btn:hover{background:var(--acs);border-color:var(--ac)}
.char-hint{font-size:.58rem;color:var(--tx3);text-align:right;margin-top:.15rem}
.char-hint.warn{color:var(--warn)}
.mt{margin-top:.42rem}
.sec-count{margin-left:auto;font-size:.58rem;padding:.1rem .4rem;background:var(--s4);color:var(--tx3);border-radius:20px;font-weight:600}

/* ════ PREVIEW PANE ════ */
#prevPane{background:#14161f;display:flex;flex-direction:column;overflow:hidden}
.prev-bar{display:flex;align-items:center;justify-content:space-between;padding:.52rem .9rem;border-bottom:1px solid var(--bd);flex-shrink:0;background:var(--s1);gap:.5rem}
.prev-lbl{font-size:.61rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--tx3);display:flex;align-items:center;gap:.4rem}
.prev-lbl::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 6px var(--ok);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.prev-actions{display:flex;gap:.3rem;align-items:center}
.zoom-pill{display:flex;align-items:center;gap:2px;background:var(--s2);border:1px solid var(--bd2);border-radius:7px;padding:2px}
.zpx{width:24px;height:24px;border:none;background:none;color:var(--tx2);cursor:pointer;border-radius:5px;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:all .13s}
.zpx:hover{background:var(--s3);color:var(--tx)}
.zoom-val{font-size:.61rem;color:var(--tx2);padding:0 4px;min-width:30px;text-align:center}
#prevScroll{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;align-items:center;padding:1.4rem 1rem}
#prevScaler{flex-shrink:0;transform-origin:top center}

/* Document */
.doc-page{width:794px;background:#fff;box-shadow:0 24px 70px rgba(0,0,0,.8),0 4px 16px rgba(0,0,0,.4);border-radius:2px;padding:56px 60px 64px;position:relative;font-size:10.5pt;line-height:1.58;color:#18191f;font-family:'DM Sans',system-ui,sans-serif}
/* prevDoc wrapper — pointer-events off to block IDM/copy but allow style injection */
#prevDoc{pointer-events:none;user-select:none;-webkit-user-select:none}

/* ════ EXPORT MODAL ════ */
#pdfModal{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.85);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .22s var(--ease2)}
#pdfModal.on{opacity:1;pointer-events:all}
.modal{background:var(--s2);border:1px solid var(--bd2);border-radius:18px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 40px 100px rgba(0,0,0,.8);transform:scale(.95) translateY(16px);transition:transform .26s var(--ease)}
#pdfModal.on .modal{transform:scale(1) translateY(0)}
.m-hdr{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.1rem;border-bottom:1px solid var(--bd);flex-shrink:0}
.m-title{font-size:.82rem;font-weight:600;color:var(--tx);display:flex;align-items:center;gap:.4rem}
.m-badge{font-size:.58rem;padding:.1rem .45rem;background:rgba(45,212,160,.12);color:#2dd4a0;border-radius:20px;font-weight:600;letter-spacing:.04em}
.m-x{width:28px;height:28px;border:none;background:var(--s3);border-radius:6px;color:var(--tx2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .13s}
.m-x:hover{background:var(--s4);color:var(--tx)}
.m-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.2rem;display:flex;justify-content:center;background:#181a24}
.m-doc-wrap{flex-shrink:0;transform-origin:top left}
.m-foot{display:flex;flex-direction:column;gap:.65rem;padding:.85rem 1.1rem;border-top:1px solid var(--bd);flex-shrink:0}
.m-info{display:flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--tx3)}
.m-info svg{flex-shrink:0;color:var(--ok)}
.m-acts{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}
.fmt-wrap{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}
.fmt-label{font-size:.6rem;font-weight:700;color:var(--tx3);letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.fmt-sel-wrap{position:relative;display:flex;align-items:center;flex:1;min-width:0}
.fmt-indicator{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--ac);pointer-events:none;transition:background .2s}
#fmtSelect{-webkit-appearance:none;appearance:none;width:100%;padding:.38rem 1.8rem .38rem 1.5rem;border-radius:8px;border:1px solid var(--bd2);background:var(--s3);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;outline:none;transition:border-color .15s,box-shadow .15s}
#fmtSelect:focus{border-color:var(--ac);box-shadow:0 0 0 3px var(--acs)}
#fmtSelect option{background:var(--s2);color:var(--tx)}
.fmt-chevron{position:absolute;right:7px;top:50%;transform:translateY(-50%);width:11px;height:11px;color:var(--tx3);pointer-events:none}
.m-acts .btn{flex-shrink:0;white-space:nowrap}
@media(max-width:520px){.m-acts{flex-wrap:wrap;gap:.45rem}.fmt-wrap{width:100%;flex:none;order:0}.m-acts .btn-g{order:1;flex:1;justify-content:center}.m-acts .btn-p{order:2;flex:1;justify-content:center}}

/* ════ PAYMENT MODAL ════ */
#payModal{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .24s var(--ease2)}
#payModal.on{opacity:1;pointer-events:all}
.pay-card{position:relative;background:var(--s2);border:1px solid var(--bd2);border-radius:22px;box-shadow:0 40px 100px rgba(0,0,0,.85);width:100%;max-width:420px;padding:2rem 1.75rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.85rem;text-align:center;transform:scale(.93) translateY(18px);transition:transform .26s var(--ease);overflow:hidden}
#payModal.on .pay-card{transform:scale(1) translateY(0)}
.pay-card::before{content:'';position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:var(--acg);pointer-events:none}
.pay-close{position:absolute;top:.9rem;right:.9rem;width:28px;height:28px;border:none;background:var(--s3);border-radius:7px;color:var(--tx2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.05rem;transition:all .13s;z-index:1}
.pay-close:hover{background:var(--s4);color:var(--tx)}
.pay-icon{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--ac),var(--cyan));display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px var(--acg)}
.pay-icon svg{width:28px;height:28px;color:#fff}
.pay-title{font-size:1.15rem;font-weight:700;color:var(--tx);line-height:1.2}
.pay-sub{font-size:.8rem;color:var(--tx2);line-height:1.6;max-width:300px}
.pay-price{display:flex;align-items:baseline;gap:.2rem;font-family:'DM Serif Display',serif}
.pay-currency{font-size:1rem;color:var(--tx2);padding-top:.25rem;align-self:flex-start}
.pay-amount{font-size:2.6rem;color:var(--tx);line-height:1}
.pay-period{font-size:.75rem;color:var(--tx3)}
.pay-features{list-style:none;width:100%;display:flex;flex-direction:column;gap:.38rem;text-align:left}
.pay-features li{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--tx2)}
.pay-features li::before{content:'✓';width:17px;height:17px;border-radius:50%;background:rgba(45,212,160,.15);color:var(--ok);font-size:.63rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* Payment methods tabs */
.pay-methods{width:100%;display:flex;flex-direction:column;gap:.6rem}
.pay-tabs{display:flex;background:var(--s3);border-radius:10px;padding:3px;gap:2px}
.pay-tab{flex:1;padding:.38rem .4rem;border:none;background:none;color:var(--tx3);font-family:'DM Sans',sans-serif;font-size:.68rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .16s var(--ease2);white-space:nowrap}
.pay-tab.on{background:var(--s2);color:var(--tx);box-shadow:0 2px 8px rgba(0,0,0,.3)}
.pay-panel{display:none}.pay-panel.on{display:flex;flex-direction:column;gap:.5rem}

/* Stripe panel */
.pay-btn{width:100%;padding:.82rem;border-radius:12px;border:none;background:linear-gradient(135deg,var(--ac),var(--ac2));color:#fff;font-family:'DM Sans',sans-serif;font-size:.93rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 24px var(--acg);transition:all .18s var(--ease2)}
.pay-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--acg)}
.pay-btn:active{transform:translateY(0)}

/* Crypto panel */
.crypto-select{display:flex;gap:.4rem;margin-bottom:.3rem}
.crypto-option{flex:1;padding:.45rem .3rem;border:1.5px solid var(--bd2);border-radius:8px;background:var(--s3);color:var(--tx2);font-size:.68rem;font-weight:600;cursor:pointer;text-align:center;transition:all .15s var(--ease2)}
.crypto-option.on{border-color:var(--ac);background:var(--acs);color:var(--tx)}
.crypto-addr-box{background:var(--s3);border:1px solid var(--bd2);border-radius:10px;padding:.75rem;display:flex;flex-direction:column;gap:.4rem}
.crypto-coin-badge{font-size:.65rem;font-weight:700;letter-spacing:.07em;color:var(--ac);text-transform:uppercase}
.crypto-addr{font-family:'DM Mono',monospace;font-size:.62rem;color:var(--tx2);word-break:break-all;line-height:1.5}
.crypto-copy-btn{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.38rem;border:1px solid var(--bd2);border-radius:7px;background:var(--s2);color:var(--tx2);font-size:.7rem;cursor:pointer;transition:all .14s;width:100%}
.crypto-copy-btn:hover{background:var(--s4);color:var(--tx)}
.crypto-note{font-size:.67rem;color:var(--tx3);text-align:center;line-height:1.5}
.crypto-confirm-btn{width:100%;padding:.72rem;border-radius:10px;border:1.5px solid var(--ac);background:var(--acs);color:var(--ac);font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .16s var(--ease2)}
.crypto-confirm-btn:hover{background:var(--ac);color:#fff}

.pay-secure{font-size:.64rem;color:var(--tx3);display:flex;align-items:center;gap:.3rem}
.pay-secure svg{flex-shrink:0}

/* ════ FOOTER (payment icons + copyright) ════ */
#appFooter{
  position:fixed;bottom:0;left:0;right:0;height:28px;z-index:99;
  background:rgba(8,10,18,.95);border-top:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 .9rem;font-size:.6rem;color:var(--tx3);
}
.footer-copy{white-space:nowrap}
.footer-pay-icons{display:flex;align-items:center;gap:.5rem}
.footer-pay-icons svg{opacity:.5;transition:opacity .15s;cursor:default}
.footer-pay-icons svg:hover{opacity:.85}
/* Adjust app to account for footer */
#app{bottom:28px}
@media(max-width:800px){#app{bottom:78px}#appFooter{bottom:50px}}

/* ════ LOADING OVERLAY ════ */
#loadOv{position:fixed;inset:0;z-index:700;background:rgba(8,10,18,.96);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.8rem;backdrop-filter:blur(12px);opacity:0;pointer-events:none;transition:opacity .2s}
#loadOv.on{opacity:1;pointer-events:all}
.spinner{width:38px;height:38px;border:3px solid var(--s4);border-top-color:var(--ac);border-radius:50%;animation:spin .65s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.spin-msg{font-size:.85rem;color:var(--tx2)}.spin-sub{font-size:.7rem;color:var(--tx3)}

/* ════ TOAST ════ */
#toast{position:fixed;bottom:calc(32px + .8rem + env(safe-area-inset-bottom));right:1rem;z-index:800;background:var(--s4);color:var(--tx);padding:.6rem 1rem;border-radius:10px;font-size:.76rem;border:1px solid var(--bd2);box-shadow:0 8px 28px rgba(0,0,0,.55);display:flex;align-items:center;gap:.4rem;transform:translateY(60px);opacity:0;transition:all .26s var(--ease2);max-width:calc(100vw - 2rem);pointer-events:none}
#toast.on{transform:translateY(0);opacity:1}
@media(max-width:800px){#toast{bottom:calc(78px + .8rem + env(safe-area-inset-bottom))}}

/* ════ MOBILE NAV ════ */
#mobNav{position:fixed;bottom:28px;left:0;right:0;z-index:150;height:50px;background:rgba(8,10,18,.97);backdrop-filter:blur(14px);border-top:1px solid var(--bd);display:none;align-items:stretch}
.mn-btn{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2px;border:none;background:none;color:var(--tx3);font-family:'DM Sans',sans-serif;font-size:.61rem;font-weight:500;cursor:pointer;padding:.5rem;transition:color .16s}
.mn-btn svg{width:17px;height:17px}
.mn-btn.on{color:var(--ac)}
#progBar{position:fixed;top:52px;left:0;z-index:250;height:2px;width:0%;background:linear-gradient(90deg,var(--ac),var(--cyan));transition:width .3s var(--ease2);pointer-events:none}
