@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#f0f2f8;
  --panel:#ffffff;
  --panel2:#f7f8fc;
  --panel3:#eef0f8;
  --border:#e2e6f0;
  --border2:#cdd2e6;
  --text:#0d1225;
  --muted:#5c6380;
  --dim:#9ba3c2;
  --accent:#6366f1;
  --accent-s:#eef2ff;
  --accent-h:#4f46e5;
  --gold:#f59e0b;
  --gold-s:#fffbeb;
  --danger:#dc3545;
  --danger-s:#fff2f3;
  --success:#0d7a4e;
  --success-s:#eaf7f1;
  --warn:#c27c0a;
  --warn-s:#fff8ed;
  --r:10px;
  --r-sm:6px;
  --sh:0 1px 3px rgba(0,0,0,.07),0 4px 12px rgba(0,0,0,.05);
  --sh-lg:0 8px 24px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.06);
  --sh-xl:0 20px 48px rgba(0,0,0,.14),0 4px 12px rgba(0,0,0,.08);
  --doc:#6366f1;
  --topbar-h:56px;
  --stepbar-h:48px;
  --font-serif:'Playfair Display',Georgia,serif;
  --font-sans:'DM Sans',-apple-system,'Segoe UI',sans-serif;
}

html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}

/* ── DARK MODE ── */
body.dark{
  --bg:#0b0d17;--panel:#131620;--panel2:#181c28;--panel3:#1e2334;
  --border:#252a3c;--border2:#323850;--text:#e4e8f4;--muted:#8a92b4;--dim:#414a68;
  --accent:#818cf8;--accent-s:#1e1b4b;--accent-h:#a5b4fc;
  --gold:#fbbf24;--gold-s:#1c1505;
  --danger:#ff5c6a;--danger-s:#2a1118;
  --success:#34d399;--success-s:#0c2318;
  --warn:#f0a030;--warn-s:#261a06;
  --sh:0 2px 8px rgba(0,0,0,.4),0 1px 2px rgba(0,0,0,.3);
  --sh-lg:0 8px 24px rgba(0,0,0,.5);
  --sh-xl:0 16px 48px rgba(0,0,0,.6)
}
body.dark input,body.dark textarea,body.dark select{background:var(--panel2);border-color:var(--border2);color:var(--text)}
body.dark .irow{background:var(--panel2);border-color:var(--border)}
body.dark .irow:hover{background:var(--panel3);box-shadow:inset 3px 0 0 var(--accent)}
body.dark .irow-section{background:var(--panel3);border-color:var(--border)}
body.dark .items-hd{background:var(--accent)}
body.dark .tog-row{background:var(--panel2);border-color:var(--border)}
body.dark .tog-row:hover{background:var(--panel3)}
body.dark .modal{background:var(--panel);border:1px solid var(--border)}
body.dark .btn-outline{background:var(--panel2);border-color:var(--border2);color:var(--text)}
body.dark .btn-outline:hover{border-color:var(--accent);color:var(--accent)}
body.dark .btn-primary{background:var(--accent);border-color:var(--accent);box-shadow:0 2px 12px rgba(129,140,248,.25)}
body.dark .btn-primary:hover{background:var(--accent-h);border-color:var(--accent-h)}
body.dark .btn-ghost:hover{background:var(--panel2);color:var(--text)}
body.dark .btn-danger{background:var(--danger-s);color:var(--danger);border-color:rgba(255,92,106,.2)}
body.dark .btn-danger:hover{background:var(--danger);color:#fff}
body.dark .lib-item{background:var(--panel2);border-color:var(--border)}
body.dark .theme-card{background:var(--panel2);border-color:var(--border)}
body.dark .saved-row{background:var(--panel2);border-color:var(--border)}
body.dark .drawer{background:var(--panel2);border-color:var(--border)}
body.dark .toast{background:#1c2030;color:var(--text);border:1px solid var(--border)}
body.dark .toast.ok{background:#0c2318;color:var(--success);border-color:rgba(52,211,153,.2)}
body.dark .toast.err{background:#2a1118;color:var(--danger);border-color:rgba(255,92,106,.2)}
body.dark .overlay{background:rgba(0,0,0,.7)}
body.dark #overflow-menu{background:var(--panel);border-color:var(--border)}
body.dark .menu-item:hover{background:var(--accent-s);color:var(--accent)}
body.dark .add-btn{border-color:var(--border2);color:var(--muted)}
body.dark .add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-s)}
body.dark .ldrop{background:var(--panel2);border-color:var(--border2)}
body.dark .ldrop:hover{border-color:var(--accent);background:var(--accent-s)}
body.dark input:focus,body.dark textarea:focus,body.dark select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(129,140,248,.15)}
body.dark .stepbar{background:var(--panel);border-color:var(--border)}
body.dark .pane-head{background:var(--panel2)}
body.dark .pnav{background:var(--panel2);border-color:var(--border)}
body.dark .cpick:hover,body.dark .cpick.sel{border-color:var(--text)}
body.dark .quick-save-btn{background:var(--panel2);border-color:var(--border2);color:var(--muted)}
body.dark .quick-save-btn:hover{border-color:var(--accent);color:var(--accent)}
body.dark .vg{background:var(--panel2);border-color:var(--border)}
body.dark .pg-pill{background:var(--accent-s);color:var(--accent);border-color:rgba(129,140,248,.15)}

/* ── TOPBAR ── */
.topbar {
  height: var(--topbar-h);
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 18px; flex-shrink: 0; z-index: 100;
  position: sticky; top: 0;
}
body.dark .topbar { background: rgba(19, 22, 32, 0.85); }
.logo { font-family: var(--font-serif); font-size: 1.25rem; font-weight: 700; display: flex; align-items: center; gap: 10px; letter-spacing: -0.01em; cursor: pointer; transition: transform 0.2s; }
.logo:hover { transform: scale(1.02); }
.logo-mark { width: 30px; height: 30px; background: #0f172a; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 4px 12px rgba(15,23,42,0.3); transition: background .3s, box-shadow .3s; }
body.dark .logo-mark { background: #fbbf24; box-shadow: 0 4px 12px rgba(251,191,36,0.3); }
body.dark .logo-mark svg path:first-child { stroke: #0f172a; }
body.dark .logo-mark svg path:nth-child(3) { stroke: #0f172a; }
.logo-mark svg { width: 17px; height: 17px; }
.logo-name { display: flex; align-items: baseline; gap: 0; }
.logo-pro { color: var(--text); font-weight: 700; }
.logo-quote { color: #f59e0b; font-weight: 700; }
.top-r{display:flex;gap:5px;align-items:center}
.autosave-pill{display:none;align-items:center;gap:5px;font-size:.68rem;color:var(--success);background:var(--success-s);padding:3px 9px;border-radius:20px;font-weight:600}
.autosave-dot{width:6px;height:6px;border-radius:50%;background:var(--success)}

/* ── DOCUMENT TYPE TABS ── */
.doctype-tabs{display:flex;background:var(--panel3);border-radius:8px;padding:3px;gap:2px}
.doctype-tab{padding:5px 12px;border-radius:6px;font-size:.74rem;font-weight:600;border:none;cursor:pointer;background:none;color:var(--muted);transition:all .18s;font-family:var(--font-sans)}
.doctype-tab.active{background:var(--panel);color:var(--accent);box-shadow:var(--sh);font-weight:700}

/* ── STEPBAR ── */
.stepbar{
  height:var(--stepbar-h);background:var(--panel);border-bottom:1px solid var(--border);
  display:flex;align-items:stretch;padding:0 16px;gap:0;flex-shrink:0;
  overflow-x:auto;scrollbar-width:none
}
.stepbar::-webkit-scrollbar{display:none}
.stab{
  display:flex;align-items:center;gap:6px;padding:0 14px;
  background:none;border:none;border-bottom:2px solid transparent;
  font-family:var(--font-sans);font-size:.78rem;font-weight:500;color:var(--muted);
  cursor:pointer;white-space:nowrap;transition:all .18s;letter-spacing:.01em
}
.stab:hover{color:var(--text)}
.stab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.stab.done{color:var(--success)}
.sbadge{
  width:19px;height:19px;border-radius:50%;background:var(--border);
  font-size:.62rem;font-weight:700;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .18s
}
.stab.active .sbadge{background:var(--accent);color:#fff}
.stab.done .sbadge{background:var(--success);color:#fff}
.ssep{width:1px;background:var(--border);margin:14px 2px;flex-shrink:0}

/* ── MAIN GRID ── */
.main{display:grid;grid-template-columns:430px 1fr;flex:1;overflow:hidden;min-height:0}

/* ── FORM PANEL ── */
.fp{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.pane{display:none;flex:1;flex-direction:column;min-height:0}
.pane.active{display:flex;animation:paneIn .22s cubic-bezier(.2,.8,.3,1)}
@keyframes paneIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.pane-head{padding:16px 22px 13px;border-bottom:1px solid var(--border);background:var(--panel2);flex-shrink:0}
.pane-title{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--text);letter-spacing:-.01em}
.pane-sub{font-size:.74rem;color:var(--muted);margin-top:3px;font-weight:400}
.pane-body{flex:1;overflow-y:auto;padding:18px 22px;scrollbar-width:thin;scrollbar-color:var(--border2) transparent;scroll-behavior:smooth}
.pane-body::-webkit-scrollbar{width:4px}
.pane-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.pnav{display:flex;gap:8px;padding:12px 22px;border-top:1px solid var(--border);background:var(--panel2);flex-shrink:0}

/* ── FORM CONTROLS ── */
.fg{margin-bottom:14px}.fg:last-child{margin-bottom:0}
.fl{display:block;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
input[type=text],input[type=number],input[type=date],input[type=email],input[type=tel],textarea,select{
  width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-family:var(--font-sans);font-size:.88rem;color:var(--text);
  background:var(--panel);outline:none;transition:border-color .15s,box-shadow .15s;appearance:none
}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(99,102,241,.1)}
input::placeholder,textarea::placeholder{color:var(--dim);font-weight:400}
textarea{resize:vertical;min-height:60px;line-height:1.6}
select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a7f9a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;padding-right:30px;cursor:pointer
}
input[type=range]{width:100%;padding:0;border:none;background:none;box-shadow:none;accent-color:var(--accent);height:20px;cursor:pointer}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none}
input[type=number]{-moz-appearance:textfield;appearance:textfield}
input[type=color]{width:32px;height:32px;padding:2px;border-radius:6px;cursor:pointer;border:1.5px solid var(--border)}
.r2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hr{border:none;border-top:1px solid var(--border);margin:16px 0}
.sec-lbl{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:10px}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 16px;border-radius:var(--r-sm);font-family:var(--font-sans);
  font-size:.8rem;font-weight:600;border:1.5px solid transparent;cursor:pointer;
  transition:background .16s,border-color .16s,box-shadow .16s,transform .08s,color .16s;
  white-space:nowrap;letter-spacing:.01em
}
.btn:active{transform:scale(.96);transition-duration:.05s}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px rgba(99,102,241,.28)}
.btn-primary:hover{background:var(--accent-h);border-color:var(--accent-h);box-shadow:0 4px 14px rgba(99,102,241,.38)}
.btn-outline{background:var(--panel);color:var(--text);border-color:var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-s)}
.btn-ghost{background:transparent;color:var(--muted);border:none}
.btn-ghost:hover{color:var(--text);background:var(--panel2)}
.btn-danger{background:var(--danger-s);color:var(--danger);border-color:rgba(220,53,69,.2)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn-success{background:var(--success);color:#fff;border:none}
.btn-success:hover{filter:brightness(1.08)}
.btn-gold{background:var(--gold);color:#fff;border:none;box-shadow:0 2px 8px rgba(184,150,12,.3)}
.btn-gold:hover{filter:brightness(1.1)}
.btn-whatsapp{background:#25D366;color:#fff;border:none}
.btn-whatsapp:hover{background:#1ebe5d}
.btn-sm{padding:5px 11px;font-size:.73rem}
.btn-full{width:100%}

/* ── SECTION HEADER INSIDE FORM ── */
.form-section-hd{
  display:flex;align-items:center;gap:8px;margin-bottom:12px;
  font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)
}
.form-section-hd::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── TOGGLE ── */
.tog-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);
  margin-bottom:6px;cursor:pointer;user-select:none;background:var(--panel2);transition:all .16s
}
.tog-row:hover{border-color:var(--border2);background:var(--panel)}
.tog-name{font-size:.82rem;font-weight:500}
.tog-hint{font-size:.7rem;color:var(--muted);margin-top:2px}
.sw{width:34px;height:19px;border-radius:10px;background:var(--border2);position:relative;transition:background .18s;flex-shrink:0;margin-left:10px}
.sw::after{content:'';position:absolute;width:13px;height:13px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .18s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.sw.on{background:var(--accent)}.sw.on::after{left:18px}

/* ── ITEMS EDITOR ── */
.items-wrap{border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:8px}
.items-hd{
  display:grid;grid-template-columns:18px 1fr 52px 80px 58px 50px;
  column-gap:8px;padding:9px 12px;
  background:var(--accent);font-size:.68rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:#fff;
  position:sticky;top:0;z-index:10
}
.irow{
  display:grid;grid-template-columns:18px 1fr 52px 80px 58px 50px;
  column-gap:8px;padding:7px 12px;
  border-top:1px solid var(--border);align-items:center;
  background:var(--panel);transition:background .12s
}
.irow:first-of-type{border-top:none}
.irow:hover{background:var(--accent-s);box-shadow:inset 3px 0 0 var(--accent)}
.irow input{padding:6px 8px;font-size:.83rem;border-radius:5px;width:100%;border-color:transparent;background:var(--panel2);font-family:var(--font-sans)}
.irow input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 2px rgba(99,102,241,.1)}
.irow input[type=number]{text-align:right}
.idesc-wrap{display:flex;flex-direction:column;gap:2px;min-width:0}
.irow.has-disc .idr{display:flex}
.idel{background:none;border:none;width:22px;height:22px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--dim);font-size:.78rem;transition:all .12s}
.idel:hover{background:var(--danger-s);color:var(--danger)}
.irow-section{display:grid;grid-template-columns:18px 1fr 26px;column-gap:8px;padding:7px 12px;border-top:1px solid var(--border);align-items:center;background:var(--panel2)}
.irow-section:first-of-type{border-top:none}
.irow-section input[type=text]{font-weight:700;font-size:.82rem;background:transparent;border-color:transparent;padding:3px 6px}
.irow-section input[type=text]:focus{background:var(--panel);border-color:var(--accent)}
.add-btn{
  width:100%;padding:9px;background:none;border:1.5px dashed var(--border2);
  border-radius:var(--r-sm);color:var(--muted);font-family:var(--font-sans);
  font-size:.78rem;font-weight:600;cursor:pointer;display:flex;align-items:center;
  justify-content:center;gap:5px;transition:all .15s
}
.add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-s)}

/* ── LOGO UPLOAD ── */
.ldrop{
  border:2px dashed var(--border2);border-radius:var(--r-sm);padding:14px;
  text-align:center;position:relative;cursor:pointer;transition:all .15s;background:var(--panel2)
}
.ldrop:hover{border-color:var(--accent);background:var(--accent-s)}
.ldrop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.ldrop-lbl{font-size:.74rem;color:var(--muted);font-weight:500}
.ldrop-sub{font-size:.66rem;color:var(--dim);margin-top:2px}

/* ── COLOR PRESETS ── */
.cpicks{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
.cpick{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:all .14s;flex-shrink:0}
.cpick:hover,.cpick.sel{border-color:var(--text);transform:scale(1.2)}

/* ── THEME GRID ── */
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.theme-card{border:2px solid var(--border);border-radius:var(--r-sm);padding:10px 10px 8px;cursor:pointer;transition:all .16s;background:var(--panel2)}
.theme-card:hover{border-color:var(--accent)}.theme-card.sel{border-color:var(--accent);background:var(--accent-s)}
.theme-preview{height:40px;border-radius:4px;margin-bottom:6px;overflow:hidden}
.theme-name{font-size:.73rem;font-weight:700;text-align:center}
.theme-desc{font-size:.62rem;color:var(--muted);text-align:center;margin-top:2px}

/* ── PREVIEW PANEL ── */
.pp{background:var(--bg);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;align-items:center;padding:16px 16px 32px;gap:12px;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.pp::-webkit-scrollbar{width:6px}.pp::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.pvbar{width:100%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;flex-shrink:0}
.pvbar-l{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
.pg-pill{background:var(--accent-s);color:var(--accent);border:1px solid rgba(99,102,241,.15);border-radius:20px;padding:2px 10px;font-size:.68rem;font-weight:700}
.pvbar-r{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.vg{display:flex;gap:2px;background:var(--panel);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:3px;align-items:center}
.vc{display:flex;align-items:center;gap:3px;padding:3px 8px;border-radius:4px;font-size:.68rem;font-weight:600;border:none;background:none;cursor:pointer;color:var(--muted);transition:all .12s;font-family:var(--font-sans)}
.vc.on{background:var(--accent);color:#fff}
.doc-scaler{width:100%;flex-shrink:0}
.doc-scaler-inner{transform-origin:top left;width:794px;flex-shrink:0}
#qdoc{width:794px;background:#fff;box-shadow:var(--sh-xl);border-radius:3px;font-family:var(--font-sans)}
.dpage{width:794px;min-height:1122px;padding:40px 52px 52px;position:relative;background:#fff;display:flex;flex-direction:column;border-bottom:3px dashed #dde0ee}
.dpage:last-child{border-bottom:none}

/* ── DOCUMENT STATUS CHIPS ── */
.schip{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.s-draft{background:#fff3cd;color:#856404;border:1px solid #ffc107}
.s-sent{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}
.s-approved{background:#dcfce7;color:#15803d;border:1px solid #86efac}
.s-rejected{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}
.s-unpaid{background:#fff3cd;color:#856404;border:1px solid #ffc107}
.s-paid{background:#dcfce7;color:#15803d;border:1px solid #86efac}
.s-overdue{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}

/* ── SUMMARY CARD ── */
.sum-card{background:var(--panel2);border:1.5px solid var(--border);border-radius:var(--r);padding:13px 15px;font-size:.8rem;line-height:2}

/* ── MODALS & OVERLAYS ── */
.overlay{display:none;position:fixed;inset:0;background:rgba(5,8,20,.58);backdrop-filter:blur(5px);z-index:500;align-items:center;justify-content:center}
.overlay.open{display:flex;animation:ovIn .18s ease}
@keyframes ovIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--panel);border-radius:14px;padding:28px 24px;max-width:400px;width:90%;box-shadow:var(--sh-xl);animation:mIn .22s cubic-bezier(.2,.8,.3,1)}
@keyframes mIn{from{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.micon{text-align:center;font-size:1.8rem;margin-bottom:8px}
.mtitle{font-family:var(--font-serif);font-size:.95rem;font-weight:600;text-align:center;margin-bottom:6px}
.mmsg{font-size:.8rem;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:18px}
.mbtns{display:flex;gap:8px;justify-content:center}

/* ── TOAST ── */
.tray{position:fixed;bottom:18px;right:18px;z-index:600;display:flex;flex-direction:column;gap:6px;pointer-events:none}
.toast{
  background:#0d1225;color:#fff;padding:9px 14px;border-radius:8px;
  font-size:.76rem;font-weight:500;box-shadow:var(--sh-xl);
  display:flex;align-items:center;gap:6px;animation:tIn .2s ease;
  pointer-events:auto;max-width:260px;font-family:var(--font-sans)
}
.toast.ok{background:var(--success)}.toast.err{background:var(--danger)}
@keyframes tIn{from{opacity:0;transform:translateX(12px) scale(.96)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes tOut{to{opacity:0;transform:translateX(12px) scale(.94)}}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes slideUp{from{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── SAVED ROW (companies, clients, library) ── */
.saved-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1.5px solid var(--border);border-radius:var(--r-sm);margin-bottom:6px;cursor:pointer;background:var(--panel2);transition:all .15s}
.saved-row:hover{border-color:var(--accent);background:var(--accent-s)}
.saved-dot{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.72rem;font-weight:700;flex-shrink:0}
.saved-row-info{flex:1;min-width:0}
.saved-row-name{font-size:.84rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.saved-row-meta{font-size:.7rem;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.saved-row-del{background:none;border:none;color:var(--dim);cursor:pointer;padding:3px 6px;border-radius:4px;font-size:.8rem;transition:all .12s;flex-shrink:0}
.saved-row-del:hover{background:var(--danger-s);color:var(--danger)}
.saved-empty{text-align:center;padding:16px 8px;color:var(--muted);font-size:.78rem;line-height:1.6}
.saved-empty-icon{font-size:1.5rem;margin-bottom:6px}

/* ── QUICK SAVE BTN ── */
.quick-save-btn{
  width:100%;padding:8px 12px;border-radius:var(--r-sm);border:1.5px solid var(--border2);
  background:var(--panel);color:var(--muted);font-family:var(--font-sans);
  font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;display:flex;
  align-items:center;justify-content:center;gap:6px
}
.quick-save-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-s)}

/* ── DRAWER (collapsible section) ── */
.drawer{background:var(--panel2);border:1.5px solid var(--border);border-radius:var(--r-sm);margin-bottom:12px;overflow:hidden}
.drawer-hd{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;cursor:pointer;user-select:none;transition:background .12s}
.drawer-hd:hover{background:var(--panel)}
.drawer-hd-l{display:flex;align-items:center;gap:7px;font-size:.76rem;font-weight:600}
.drawer-body{display:none;padding:0 12px 10px}
.drawer.open .drawer-body{display:block}
.drawer-chevron{font-size:.68rem;color:var(--dim);transition:transform .18s}
.drawer.open .drawer-chevron{transform:rotate(180deg)}

/* ── PRODUCT LIBRARY ── */
.lib-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--r-sm);margin-bottom:5px;background:var(--panel2);transition:all .12s;cursor:pointer}
.lib-item:hover{border-color:var(--accent);background:var(--accent-s)}
.lib-item-name{font-size:.82rem;font-weight:600}
.lib-item-meta{font-size:.69rem;color:var(--muted);margin-top:1px}

/* ── LOGO BG TOGGLE ── */
.logo-bg-toggle{display:flex;align-items:center;gap:7px;font-size:.74rem;color:var(--muted);cursor:pointer;user-select:none;margin-top:5px}
.logo-bg-toggle input{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}

/* ── OVERFLOW MENU ── */
.overflow-menu-wrap{position:relative}
#overflow-menu{
  display:none;position:absolute;right:0;top:calc(100% + 6px);
  background:var(--panel);border:1.5px solid var(--border);border-radius:var(--r);
  box-shadow:var(--sh-xl);min-width:200px;z-index:300;padding:6px;
  animation:mIn .16s ease
}
.menu-group{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);padding:6px 10px 4px}
.menu-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;font-size:.78rem;font-weight:500;cursor:pointer;transition:background .12s;border:none;background:none;width:100%;text-align:left;color:var(--text);font-family:var(--font-sans)}
.menu-item:hover{background:var(--accent-s);color:var(--accent)}
.menu-sep{height:1px;background:var(--border);margin:4px 6px}

/* ── INSTALL BANNER ── */
@keyframes bannerIn{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes bannerOut{from{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}

/* ── SPLASH ── */
#splash{position:fixed;inset:0;background:linear-gradient(145deg,#312e81 0%,#6366f1 55%,#1e1b4b 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease}
#splash.hidden{opacity:0;pointer-events:none}
.splash-logo{display:flex;flex-direction:column;align-items:center;animation:splashIn .65s cubic-bezier(.34,1.56,.64,1) both}
.splash-icon{width:84px;height:84px;margin-bottom:20px}
.splash-name{font-family:var(--font-serif);font-size:2.4rem;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1}
.splash-name span{color:#f59e0b}
.splash-tagline{font-size:.78rem;color:rgba(255,255,255,.55);margin-top:8px;letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.splash-bar{width:110px;height:3px;background:rgba(255,255,255,.15);border-radius:3px;margin-top:28px;overflow:hidden}
.splash-bar-inner{height:100%;width:0%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:3px;animation:splashLoad 1.8s ease forwards}
@keyframes splashIn{from{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes splashLoad{0%{width:0%}60%{width:70%}100%{width:100%}}

/* ── WATERMARK STYLE BTN ── */
.wm-style-btn{flex:1;padding:7px;border-radius:6px;font-weight:700;font-size:.76rem;cursor:pointer;transition:all .15s}

/* ── TABLET ── */
@media(max-width:1100px){.main{grid-template-columns:380px 1fr}}
@media(max-width:960px){.main{grid-template-columns:340px 1fr}}

/* ── MOBILE — full portrait layout ── */
@media(max-width:768px){
  html{font-size:14px}
  body{overflow-y:auto;overflow-x:hidden;height:auto;min-height:100vh}

  /* Stack form above preview */
  .main{display:flex;flex-direction:column;overflow:visible;min-height:0}
  .fp{border-right:none;border-bottom:1px solid var(--border);display:flex;flex-direction:column;overflow:visible;flex-shrink:0}
  .pane{display:none;flex-direction:column;min-height:0}
  .pane.active{display:flex;animation:none}
  .pane-body{overflow-y:visible;max-height:none;padding:14px 16px}
  .pp{min-height:50vh;padding:10px 8px 24px;overflow-x:hidden;overflow-y:visible}
  .doc-scaler{width:100%;overflow:hidden}

  /* 1-col inputs */
  .r2{grid-template-columns:1fr}

  /* Topbar — move doctype tabs below on very small, keep in topbar otherwise */
  .topbar{padding:0 10px;height:auto;min-height:50px;flex-wrap:wrap;gap:6px;padding:6px 10px}
  .doctype-tabs{order:3;width:100%;margin:0 0 4px}
  .doctype-tab{flex:1;text-align:center;padding:6px 4px;font-size:.71rem}
  .top-r{gap:4px}

  /* Stepbar */
  .stepbar{height:42px;padding:0 6px}
  .stab{padding:0 8px;font-size:.7rem;gap:4px}
  .ssep{margin:10px 2px}

  /* Buttons — bigger touch targets */
  .btn{min-height:44px;padding:10px 14px;font-size:.84rem}
  .btn-sm{min-height:38px;padding:7px 12px;font-size:.76rem}
  .btn-full{min-height:46px;font-size:.9rem}

  /* Form nav */
  .pnav{padding:10px 14px;gap:8px}
  .pane-head{padding:13px 16px 10px}

  /* Items table — compact but readable */
  .items-hd{grid-template-columns:18px 1fr 42px 70px 50px 48px;column-gap:5px;padding:7px 10px;font-size:.67rem}
  .irow{grid-template-columns:18px 1fr 42px 70px 50px 48px;column-gap:5px;padding:6px 10px}
  .irow input{padding:5px 6px;font-size:.82rem}

  /* Toggle rows */
  .tog-row{padding:11px 12px;min-height:46px}

  /* Product library */
  .items-wrap{border-radius:8px}

  /* Preview bar */
  .pvbar{flex-wrap:wrap;gap:6px;padding:0 4px}
  .pvbar-r .vg{display:none}

  /* Modal */
  .modal{padding:22px 18px;border-radius:12px;width:96%}

  /* Toast */
  .tray{bottom:80px;right:12px}
  .toast{max-width:calc(100vw - 40px)}

  /* Saved row */
  .saved-row{padding:10px}
}

/* ── MOBILE LANDSCAPE ── */
@media(max-width:768px) and (orientation:landscape){
  body{overflow:hidden;height:100vh}
  .main{display:grid;grid-template-columns:300px 1fr;flex-direction:unset;height:calc(100vh - 92px)}
  .fp{overflow:hidden;border-right:1px solid var(--border);border-bottom:none;display:flex}
  .pane-body{overflow-y:auto;max-height:none}
  .pp{height:100%;overflow-y:auto}
  /* Topbar in landscape — keep inline */
  .topbar{flex-wrap:nowrap;height:50px;padding:0 10px}
  .doctype-tabs{order:unset;width:auto;margin:0}
  .doctype-tab{padding:5px 8px;font-size:.67rem}
}

/* ── SMALL PHONES (<400px) ── */
@media(max-width:400px){
  html{font-size:13.5px}
  .stab span:not(.sbadge){display:none}
  .stab{padding:0 6px}
  .pane-body{padding:11px}
  .btn{font-size:.82rem}
  /* Topbar — just show type as short labels */
  .doctype-tab{font-size:.67rem;padding:5px 4px}
}

/* ── DOCUMENT PAGE CSS (for live preview) ── */
.dco-name{font-family:var(--font-serif)}

.parties{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;padding:11px 14px;background:#f7f8fd;border-radius:6px;border:1px solid #eaecf8}
.pty-lbl{font-size:.57rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#9ba3c2;margin-bottom:3px}
.pty-name{font-size:.86rem;font-weight:700;color:#0d1225}
.pty-detail{font-size:.71rem;color:#636882;margin-top:2px;line-height:1.7}

/* ── TOPBAR RIGHT-ALIGN IMPROVEMENTS ── */
.topbar{justify-content:space-between}
.top-r{margin-left:auto;display:flex;align-items:center;gap:5px;flex-shrink:0}
.topbar-icon-btn{width:36px;height:36px;padding:0 !important;display:flex;align-items:center;justify-content:center}

/* ── ANIMATED THEME TOGGLE (app) ── */
.theme-switch{--ts:1;position:relative;display:inline-block;width:calc(var(--ts)*60px);height:calc(var(--ts)*34px);flex-shrink:0;vertical-align:middle}
.theme-switch input{opacity:0;width:0;height:0;position:absolute}
.ts-slider{position:absolute;cursor:pointer;inset:0;background:var(--accent);transition:.4s;overflow:hidden}
.ts-slider.round{border-radius:calc(var(--ts)*34px)}
.ts-knob{position:absolute;height:calc(var(--ts)*26px);width:calc(var(--ts)*26px);left:calc(var(--ts)*4px);bottom:calc(var(--ts)*4px);background-color:#fbbf24;transition:.4s}
.ts-slider.round .ts-knob{border-radius:50%}
.theme-switch input:checked+.ts-slider{background:#0b1220}
.theme-switch input:checked+.ts-slider .ts-knob{transform:translateX(calc(var(--ts)*26px));background:#e0e0e0}
.ts-dot{opacity:0;transition:.4s;fill:#999;position:absolute;z-index:4}
.theme-switch input:checked+.ts-slider .ts-dot{opacity:1}
#atmd1{left:calc(var(--ts)*10px);top:calc(var(--ts)*3px);width:calc(var(--ts)*6px);height:calc(var(--ts)*6px)}
#atmd2{left:calc(var(--ts)*2px);top:calc(var(--ts)*10px);width:calc(var(--ts)*10px);height:calc(var(--ts)*10px)}
#atmd3{left:calc(var(--ts)*16px);top:calc(var(--ts)*18px);width:calc(var(--ts)*3px);height:calc(var(--ts)*3px)}
.ts-ray{position:absolute;z-index:-1;fill:white;opacity:.1}
#atr1{left:calc(var(--ts)*-8px);top:calc(var(--ts)*-8px);width:calc(var(--ts)*43px);height:calc(var(--ts)*43px)}
#atr2{left:-50%;top:-50%;width:calc(var(--ts)*55px);height:calc(var(--ts)*55px)}
#atr3{left:calc(var(--ts)*-18px);top:calc(var(--ts)*-18px);width:calc(var(--ts)*60px);height:calc(var(--ts)*60px)}
.ts-cld{position:absolute;animation:ts-cloud 6s infinite}
.ts-cl{fill:#eee}
.ts-cd{fill:#ccc;animation-delay:1s}
#atc1{left:calc(var(--ts)*30px);top:calc(var(--ts)*15px);width:calc(var(--ts)*40px)}
#atc2{left:calc(var(--ts)*44px);top:calc(var(--ts)*10px);width:calc(var(--ts)*20px)}
#atc3{left:calc(var(--ts)*18px);top:calc(var(--ts)*24px);width:calc(var(--ts)*30px)}
#atc4{left:calc(var(--ts)*36px);top:calc(var(--ts)*18px);width:calc(var(--ts)*40px)}
#atc5{left:calc(var(--ts)*48px);top:calc(var(--ts)*14px);width:calc(var(--ts)*20px)}
#atc6{left:calc(var(--ts)*22px);top:calc(var(--ts)*26px);width:calc(var(--ts)*30px)}
@keyframes ts-cloud{0%{transform:translateX(0)}40%{transform:translateX(4px)}80%{transform:translateX(-4px)}100%{transform:translateX(0)}}
.ts-stars{transform:translateY(calc(var(--ts)*-32px));opacity:0;transition:.4s}
.theme-switch input:checked+.ts-slider .ts-stars{transform:translateY(0);opacity:1}
.ts-star{fill:white;position:absolute;animation:ts-twinkle 2s infinite}
#ats1{width:calc(var(--ts)*20px);top:calc(var(--ts)*2px);left:calc(var(--ts)*3px);animation-delay:.3s}
#ats2{width:calc(var(--ts)*6px);top:calc(var(--ts)*16px);left:calc(var(--ts)*3px)}
#ats3{width:calc(var(--ts)*12px);top:calc(var(--ts)*20px);left:calc(var(--ts)*10px);animation-delay:.6s}
#ats4{width:calc(var(--ts)*18px);top:calc(var(--ts)*0);left:calc(var(--ts)*18px);animation-delay:1.3s}
@keyframes ts-twinkle{0%{transform:scale(1)}40%{transform:scale(1.2)}80%{transform:scale(.8)}100%{transform:scale(1)}}

/* ── CURRENCY PICKER ── */
.curr-picker{position:relative}
.curr-selected{
  width:100%;display:flex;align-items:center;gap:8px;
  padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);
  background:var(--panel);color:var(--text);font-family:var(--font-sans);font-size:.88rem;
  cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left
}
.curr-selected:hover{border-color:var(--accent)}
.curr-selected:focus,.curr-picker.open .curr-selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(99,102,241,.1)}
.curr-flag{font-size:1.1rem;line-height:1;flex-shrink:0}
.curr-text{flex:1;font-weight:500}
.curr-chevron{flex-shrink:0;color:var(--muted);transition:transform .2s}
.curr-picker.open .curr-chevron{transform:rotate(180deg)}
.curr-dropdown{
  display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:300;
  background:var(--panel);border:1.5px solid var(--border);border-radius:var(--r);
  box-shadow:0 12px 40px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.06);
  overflow:hidden;animation:currSlide .15s ease
}
body.dark .curr-dropdown{box-shadow:0 12px 40px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.25)}
.curr-picker.open .curr-dropdown{display:block}
@keyframes currSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.curr-search-wrap{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  border-bottom:1px solid var(--border);color:var(--muted)
}
.curr-search{
  border:none!important;padding:0!important;font-size:.84rem!important;
  background:transparent!important;box-shadow:none!important;flex:1;
  font-weight:500;color:var(--text)
}
.curr-search:focus{box-shadow:none!important}
.curr-list{max-height:190px;overflow-y:auto;padding:4px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.curr-list::-webkit-scrollbar{width:5px}
.curr-list::-webkit-scrollbar-track{background:transparent}
.curr-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}
.curr-list::-webkit-scrollbar-thumb:hover{background:var(--dim)}
.curr-item{
  display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);
  cursor:pointer;transition:background .1s;font-size:.84rem;color:var(--text)
}
.curr-item:hover{background:var(--accent-s)}
.curr-item.active{background:var(--accent-s);font-weight:700}
.curr-item .ci-flag{font-size:1.1rem;line-height:1;flex-shrink:0}
.curr-item .ci-code{font-weight:700;min-width:34px;color:var(--text)}
.curr-item .ci-name{flex:1;color:var(--muted);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.curr-item .ci-sym{font-weight:700;color:var(--accent);font-size:.9rem;min-width:20px;text-align:right}
.curr-empty{padding:16px;text-align:center;font-size:.82rem;color:var(--dim)}

/* Hide text labels on narrow screens, keep icons */
@media(max-width:680px){
  .topbar-label{display:none}
  .top-r .btn-outline span.topbar-label{display:none}
}
@media(max-width:480px){
  .top-r{gap:3px}
  .top-r .btn-primary{padding:7px 10px}
}

/* ═══ DARK MODE — DOCUMENT AREA ═══ */
/* Keep document itself white for print, but darken surrounding area */
body.dark .pp{background:var(--bg)}
body.dark #qdoc{box-shadow:0 4px 20px rgba(0,0,0,.5)}
body.dark .dpage{border-color:var(--border)}
/* Item sheet in dark */
body.dark #item-sheet>div{background:var(--panel);border-color:var(--border)}
/* Selection highlights */
body.dark .theme-card.sel{border-color:var(--accent);background:var(--accent-s)}
body.dark .saved-row:hover{border-color:var(--accent);background:var(--accent-s)}
body.dark .lib-item:hover{border-color:var(--accent);background:var(--accent-s)}
/* Doctype tabs in dark */
body.dark .doctype-tabs{background:var(--panel3)}
body.dark .doctype-tab{color:var(--muted)}
body.dark .doctype-tab.active{background:var(--panel);color:var(--accent);box-shadow:none;border:1px solid var(--border)}
/* Scrollbar in dark */
body.dark .pane-body::-webkit-scrollbar-thumb{background:var(--border2)}
body.dark .pp::-webkit-scrollbar-thumb{background:var(--border2)}
/* Mobile type selector */
body.dark #mobile-type-sel{background:var(--panel2);border-color:var(--border);color:var(--text)}

/* ═══ GUIDE MODAL ═══ */
#guide-overlay .modal{max-width:540px;max-height:85vh;overflow-y:auto}
.guide-section{margin-bottom:6px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.guide-section-title{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;font-size:.84rem;font-weight:600;background:var(--panel2);user-select:none;transition:background .15s}
.guide-section-title:hover{background:var(--accent-s)}
.section-toggle{font-size:.65rem;color:var(--muted);flex-shrink:0}
.guide-section-content{padding:10px 14px;font-size:.8rem;line-height:1.7;color:var(--text);display:none}
.guide-section-content ul{margin:4px 0;padding-left:18px}
.guide-section-content li{margin-bottom:4px}
.guide-section-content kbd{display:inline-block;padding:1px 6px;font-size:.72rem;font-family:inherit;background:var(--panel2);border:1px solid var(--border);border-radius:4px;box-shadow:0 1px 0 var(--border)}

/* ═══ DELETE MODAL ═══ */
#delete-modal .modal{max-width:380px;text-align:center}
#delete-mood-feedback{font-size:.78rem;color:var(--accent);margin-top:4px;display:none}

/* ═══ WHATSAPP BATCH MODAL ═══ */
#whatsapp-modal .modal{max-width:500px;max-height:85vh;overflow-y:auto}
#whatsapp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:12px 0}

/* ═══ PRINT PREVIEW MODAL ═══ */
#print-preview-modal .modal{max-width:700px;max-height:90vh;display:flex;flex-direction:column}
#print-preview-inner{background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.1);border-radius:4px;max-width:100%}
#print-preview-inner *{pointer-events:none}
