*{box-sizing:border-box;margin:0;padding:0}
:root{--ac:#087f5b;--ac-d:#066548;--ac-l:#eaf8f1;--ac-t:#07543a;--info:#2563eb;--warn:#b7791f;--bg:#fff;--bg2:#f8faf7;--bg3:#eef1ed;--tx:#101828;--tx2:#475467;--tx3:#98a2b3;--bd:#dfe5dc;--bd2:#c9d3c8;--rd:8px;--rd2:10px;--sh:0 1px 2px rgba(16,24,40,.06);--sh2:0 10px 28px rgba(16,24,40,.10)}
body{font-family:'PingFang SC','Microsoft YaHei','Helvetica Neue',Arial,sans-serif;font-size:14px;color:var(--tx);background:var(--bg3);min-height:100vh}
.auth-pending{overflow:hidden}
.auth-pending .shell{display:none}
.auth-screen{position:fixed;inset:0;z-index:10000;display:grid;grid-template-columns:minmax(0,1fr) 430px;background:#f5f7fb;color:#111827;overflow:hidden;transition:opacity .28s ease,visibility .28s ease}
.auth-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.switch-landing.auth-pending .auth-screen{opacity:0;visibility:hidden;pointer-events:none}
.auth-stage{position:relative;overflow:hidden;background:#111827;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;padding:48px}
.auth-stage:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(20,184,166,.18),transparent 32%),linear-gradient(210deg,rgba(245,158,11,.18),transparent 40%),repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 72px),repeating-linear-gradient(0deg,rgba(255,255,255,.028) 0 1px,transparent 1px 72px)}
.auth-stage:after{content:"";position:absolute;left:-18%;right:-18%;bottom:13%;height:150px;background:linear-gradient(90deg,transparent,rgba(14,165,233,.26),rgba(250,204,21,.2),transparent);transform:rotate(-8deg);animation:authSweep 7s ease-in-out infinite}
.auth-brand-lock{position:relative;z-index:1;width:48px;height:48px;border:1px solid rgba(255,255,255,.18);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.08);box-shadow:0 14px 50px rgba(0,0,0,.25)}
.auth-title-wrap{position:relative;z-index:1;color:#fff;margin-bottom:20px}
.auth-title-wrap p{font-size:13px;color:#a7f3d0;margin-bottom:8px;font-weight:600;letter-spacing:0}
.auth-title-wrap h1{font-size:44px;line-height:1;font-weight:800;letter-spacing:0}
.auth-motion{position:absolute;inset:0;z-index:0}
.motion-grid{position:absolute;inset:15% 12%;border:1px solid rgba(255,255,255,.08);background:linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:42px 42px;transform:perspective(780px) rotateX(58deg) rotateZ(-10deg);animation:gridDrift 10s linear infinite}
.motion-line{position:absolute;height:3px;border-radius:2px;background:linear-gradient(90deg,transparent,#2dd4bf,#f59e0b,transparent);opacity:.8;animation:lineRun 5s ease-in-out infinite}
.line-a{top:24%;left:6%;width:62%;animation-delay:.1s}
.line-b{top:50%;right:10%;width:54%;animation-delay:1.2s}
.line-c{bottom:24%;left:18%;width:48%;animation-delay:2.1s}
.motion-sheet{position:absolute;width:220px;min-height:286px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:rgba(255,255,255,.9);box-shadow:0 28px 70px rgba(0,0,0,.28);padding:24px;display:flex;flex-direction:column;gap:15px;transform-origin:center;animation:sheetFloat 6s ease-in-out infinite}
.motion-sheet span{height:11px;border-radius:2px;background:#cbd5e1}
.motion-sheet span:first-child{width:58%;height:18px;background:#0f766e}
.motion-sheet span:nth-child(2){width:82%;background:#94a3b8}
.motion-sheet span:nth-child(3){width:70%;background:#f59e0b}
.sheet-a{right:18%;top:17%;transform:rotate(-7deg)}
.sheet-b{right:36%;bottom:14%;width:184px;min-height:230px;animation-delay:1.4s;transform:rotate(8deg)}
.motion-strip{position:absolute;width:280px;height:54px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);backdrop-filter:blur(14px);transform:skewX(-12deg);animation:stripPulse 4.5s ease-in-out infinite}
.strip-a{left:17%;top:34%}
.strip-b{left:27%;bottom:25%;animation-delay:1.6s}
.auth-panel{background:#fff;min-height:100vh;padding:46px 38px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid #e5e7eb;box-shadow:-18px 0 50px rgba(15,23,42,.12);position:relative;z-index:2}
.auth-mark{display:flex;align-items:center;gap:12px;margin-bottom:30px}
.auth-mark strong{display:block;font-size:16px;color:#0f172a;margin-bottom:3px}
.auth-mark span{display:block;font-size:12px;color:#64748b}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:5px;margin-bottom:16px}
.auth-tabs button{border:0;background:transparent;border-radius:6px;padding:9px 8px;font-family:inherit;font-size:13px;font-weight:700;color:#64748b;cursor:pointer;transition:all .18s}
.auth-tabs button.on{background:#111827;color:#fff;box-shadow:0 6px 16px rgba(17,24,39,.18)}
.auth-msg{min-height:0;border-radius:8px;font-size:12px;line-height:1.6;color:#475569;background:#f8fafc;border:1px solid transparent;padding:0;max-height:0;opacity:0;overflow:hidden;transition:all .2s;margin-bottom:0}
.auth-msg.show{max-height:76px;opacity:1;padding:9px 11px;margin-bottom:12px;border-color:#e2e8f0}
.auth-msg.ok{color:#166534;background:#f0fdf4;border-color:#bbf7d0}
.auth-msg.err{color:#991b1b;background:#fef2f2;border-color:#fecaca}
.auth-form{display:none;flex-direction:column;gap:8px}
.auth-form.on{display:flex;animation:formIn .25s ease}
.auth-form label{font-size:12px;color:#334155;font-weight:700;margin-top:6px}
.auth-form input{width:100%;height:42px;border:1px solid #cbd5e1;border-radius:8px;padding:0 12px;font-size:14px;font-family:inherit;color:#0f172a;background:#fff;outline:none;transition:border .16s,box-shadow .16s}
.auth-form input:focus{border-color:#0f766e;box-shadow:0 0 0 3px rgba(15,118,110,.12)}
.auth-inline{display:grid;grid-template-columns:1fr 92px;gap:8px}
.auth-inline button{height:42px;border:1px solid #0f766e;border-radius:8px;background:#0f766e;color:#fff;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer}
.auth-inline button:disabled,.auth-submit:disabled{opacity:.68;cursor:wait}
.auth-submit{height:44px;margin-top:16px;border:0;border-radius:8px;background:#111827;color:#fff;font-size:14px;font-weight:800;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;box-shadow:0 12px 26px rgba(17,24,39,.22);transition:transform .16s,box-shadow .16s,background .16s}
.auth-submit:hover{background:#0f766e;box-shadow:0 14px 30px rgba(15,118,110,.24)}
.auth-submit:active{transform:translateY(1px)}
.auth-submit.loading i,.auth-inline button.loading{animation:authBlink .9s ease-in-out infinite}
.auth-links{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:18px;font-size:12px;color:#94a3b8}
.auth-links a{color:#0f766e;text-decoration:none;font-weight:800}
.auth-links a:hover{text-decoration:underline}
.user-badge{display:flex;align-items:center;gap:7px;border:1px solid var(--bd);border-radius:8px;background:#fff;padding:5px 6px 5px 9px;color:var(--tx2);font-size:12px;max-width:300px}
.sync-dot{width:8px;height:8px;border-radius:50%;background:#94a3b8;box-shadow:0 0 0 3px rgba(148,163,184,.12);flex-shrink:0;transition:all .2s}
.sync-dot.ok{background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.16)}
.user-email{max-width:145px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-logout,.user-delete{width:27px;height:27px;border:0;border-left:1px solid var(--bd);background:transparent;color:var(--tx2);cursor:pointer;display:flex;align-items:center;justify-content:center}
.user-logout:hover{color:#dc2626}
.user-delete:hover{color:#dc2626}
.mobile-account-strip{display:none}
.legal-page{background:#f7f9f7;color:#101828}
.legal-shell{min-height:100vh;background:#f7f9f7}
.legal-hero{background:#111827;color:#fff;padding:42px 22px 34px}
.legal-hero-inner{max-width:1040px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.legal-kicker{font-size:12px;color:#a7f3d0;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.legal-hero h1{font-size:36px;line-height:1.12;font-weight:900;letter-spacing:0;margin-bottom:10px}
.legal-hero p{font-size:15px;color:#cbd5e1;line-height:1.7;max-width:680px}
.legal-nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.legal-nav a{height:38px;display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:0 14px;color:#fff;text-decoration:none;font-size:13px;font-weight:800;background:rgba(255,255,255,.08)}
.legal-nav a:hover{background:rgba(255,255,255,.14)}
.legal-main{max-width:1040px;margin:0 auto;padding:24px 22px 48px;display:grid;gap:14px}
.legal-panel{background:#fff;border:1px solid #dfe5dc;border-radius:8px;padding:20px 22px;box-shadow:0 8px 24px rgba(16,24,40,.05)}
.legal-panel h2{font-size:18px;line-height:1.35;margin-bottom:10px;color:#0f172a}
.legal-panel h3{font-size:14px;margin:14px 0 7px;color:#0f172a}
.legal-panel p,.legal-panel li{font-size:14px;line-height:1.8;color:#475467}
.legal-panel ul,.legal-panel ol{padding-left:19px;display:grid;gap:6px}
.legal-note{border-left:4px solid #0f766e;background:#eefbf5}
.legal-muted{font-size:12px;color:#667085;line-height:1.7}
.legal-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.legal-button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid #0f766e;background:#0f766e;color:#fff;text-decoration:none;font-size:13px;font-weight:850;padding:0 14px}
.legal-button.secondary{background:#fff;color:#0f766e}
.legal-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:10px}
.legal-table th,.legal-table td{border:1px solid #e2e8f0;padding:10px 12px;text-align:left;vertical-align:top;line-height:1.65}
.legal-table th{width:190px;background:#f8fafc;color:#334155;font-weight:850}
@keyframes authSweep{0%,100%{transform:translateX(-8%) rotate(-8deg);opacity:.5}50%{transform:translateX(8%) rotate(-8deg);opacity:.9}}
@keyframes gridDrift{from{background-position:0 0,0 0}to{background-position:84px 42px,84px 42px}}
@keyframes lineRun{0%,100%{transform:translateX(-20%);opacity:.25}45%{opacity:1}60%{transform:translateX(20%);opacity:.7}}
@keyframes sheetFloat{0%,100%{translate:0 0}50%{translate:0 -18px}}
@keyframes stripPulse{0%,100%{opacity:.35;translate:0 0}50%{opacity:.85;translate:18px -8px}}
@keyframes formIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes authBlink{0%,100%{opacity:1}50%{opacity:.55}}
.shell{display:grid;grid-template-rows:56px 1fr;min-height:100vh}
.topbar{background:var(--bg);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:var(--sh)}
.brand{display:flex;align-items:center;gap:10px}
.brand-icon{width:34px;height:34px;background:var(--ac);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;flex-shrink:0}
.brand-name{font-size:17px;font-weight:600;color:var(--tx)}
.brand-tag{font-size:10px;background:var(--ac-l);color:var(--ac-t);padding:2px 8px;border-radius:20px;font-weight:600;margin-left:4px}
.top-actions{display:flex;align-items:center;gap:12px;min-width:0}
.top-btns{display:flex;gap:8px;align-items:center;min-width:0}
.module-entry{display:flex;align-items:center;gap:8px;border-left:1px solid var(--bd);padding-left:12px}
.module-entry span{font-size:10px;font-weight:700;color:var(--tx3);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.module-entry-btn{background:#0f766e!important;color:#fff!important;border-color:#0f766e!important;box-shadow:0 8px 18px rgba(15,118,110,.16)}
.module-entry-btn:hover{background:#0d5f59!important;border-color:#0d5f59!important;color:#fff!important}
.module-transition{position:fixed;inset:0;z-index:12000;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,.72);backdrop-filter:blur(12px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,visibility .18s ease}
.module-transition.show{opacity:1;visibility:visible}
.module-transition:before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 0 38%,rgba(45,212,191,.34) 46%,rgba(245,158,11,.24) 53%,transparent 62%);transform:translateX(-115%);animation:moduleWipe .68s cubic-bezier(.16,1,.3,1) forwards}
.module-transition-inner{position:relative;z-index:1;display:flex;align-items:center;gap:14px;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:12px;padding:18px 22px;box-shadow:0 24px 70px rgba(0,0,0,.28);transform:translateY(10px) scale(.98);opacity:0;animation:moduleCardIn .42s cubic-bezier(.16,1,.3,1) .06s forwards}
.module-transition-icon{width:46px;height:46px;border-radius:10px;background:#0f766e;display:flex;align-items:center;justify-content:center;font-size:19px;box-shadow:0 12px 32px rgba(15,118,110,.35)}
.module-transition-title{font-size:17px;font-weight:800;letter-spacing:0}
.module-transition-sub{font-size:12px;color:#cbd5e1;margin-top:2px}
.module-transition-line{position:absolute;left:12%;right:12%;bottom:24%;height:2px;border-radius:999px;background:linear-gradient(90deg,transparent,#2dd4bf,#f59e0b,transparent);opacity:0;animation:moduleLine .54s ease .08s forwards}
@keyframes moduleWipe{to{transform:translateX(115%)}}
@keyframes moduleCardIn{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes moduleLine{0%{opacity:0;transform:scaleX(.2)}40%,100%{opacity:1;transform:scaleX(1)}}
.layout{display:grid;grid-template-columns:210px 1fr;height:calc(100vh - 56px);overflow:hidden}
.sidebar{background:var(--bg);border-right:1px solid var(--bd);padding:14px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.sb-sec{font-size:10px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em;padding:10px 10px 5px}
.nav{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--rd);cursor:pointer;font-size:13px;color:var(--tx2);border:none;background:transparent;width:100%;text-align:left;font-family:inherit;transition:all .15s}
.nav i{width:16px;text-align:center;font-size:13px;opacity:.75}
.nav:hover{background:var(--bg2);color:var(--tx)}
.nav.on{background:var(--ac-l);color:var(--ac-t);font-weight:500}
.nav.on i{opacity:1}
.sb-sep{height:1px;background:var(--bd);margin:5px 0}
.sb-foot{margin-top:auto;padding:14px 10px 8px;border-top:1px solid var(--bd);text-align:center;line-height:1.6}
.sb-foot .sb-foot-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--tx3);display:block;margin-bottom:2px}
.sb-foot a{font-size:11px;color:var(--tx3);text-decoration:none;font-weight:500;transition:color .15s}
.sb-foot a:hover{color:var(--ac)}
.main{overflow-y:auto;padding:24px;background:var(--bg3)}
.panel{display:none;max-width:960px}
.panel.on{display:block}
.ph{margin-bottom:18px}
.ph h2{font-size:19px;font-weight:600;color:var(--tx);margin-bottom:3px}
.ph p{font-size:13px;color:var(--tx2)}
.card{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rd2);padding:18px 20px;margin-bottom:14px;box-shadow:var(--sh)}
.ct{font-size:13px;font-weight:600;color:var(--tx);margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:7px}
.ct i{color:var(--ac);font-size:13px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:11px}.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:11px}
.full{grid-column:1/-1}
.mb{margin-bottom:12px}
.f{display:flex;flex-direction:column;gap:4px}
.f label{font-size:11px;font-weight:600;color:var(--tx2)}
.f input,.f select,.f textarea{font-size:13px;padding:7px 9px;border:1px solid var(--bd);border-radius:var(--rd);background:var(--bg);color:var(--tx);outline:none;font-family:inherit;transition:border .15s,box-shadow .15s;width:100%}
.f input:focus,.f select:focus,.f textarea:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.f textarea{resize:vertical;min-height:68px;line-height:1.6}
.inline-field{display:flex;gap:6px;align-items:center}
.inline-field input{flex:1;min-width:0}
.field-error{border-color:#dc2626!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important;background:#fff7f7!important}
.validation-note{font-size:11px;color:#dc2626;margin-top:4px}
/* 自动换行 + 自动撑高的多行文本框（用于表格/条款内的描述类字段） */
textarea.txa{resize:none;overflow:hidden;white-space:pre-wrap;word-break:break-word;line-height:1.4;min-height:30px;height:30px}
.bank-info-textarea{min-height:96px!important;line-height:1.55!important}
.bank-tools{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}
.f input::placeholder{color:var(--tx3);font-size:12px}
.logo-box{border:2px dashed var(--bd2);border-radius:var(--rd2);padding:18px;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg2);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:90px}
.logo-box:hover{border-color:var(--ac);background:var(--ac-l)}
.logo-box img{max-height:52px;max-width:170px;object-fit:contain}
.logo-icon{font-size:26px;color:var(--tx3);margin-bottom:7px}
.logo-lbl{font-size:13px;color:var(--tx2);font-weight:500}
.logo-sub{font-size:11px;color:var(--tx3);margin-top:3px}
.tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.tpl-card{border:2px solid var(--bd);border-radius:var(--rd2);padding:11px;cursor:pointer;transition:all .15s;text-align:center}
.tpl-card:hover{border-color:var(--ac);transform:translateY(-1px);box-shadow:var(--sh2)}
.tpl-card.sel{border-color:var(--ac);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.tpl-thumb{height:40px;border-radius:var(--rd);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;letter-spacing:.07em;margin-bottom:7px}
.tpl-nm{font-size:11px;color:var(--tx2);font-weight:500}
.tpl-card.sel .tpl-nm{color:var(--ac-t);font-weight:600}
/* ─── Tables ─── */
.tbl-wrap{overflow-x:auto;border-radius:var(--rd);border:1px solid var(--bd);margin-bottom:10px;-webkit-overflow-scrolling:touch}
table.it{width:100%;border-collapse:collapse;font-size:13px;min-width:900px}
table.it th{text-align:left;padding:8px 9px;font-size:10px;font-weight:700;color:var(--tx2);background:var(--bg2);border-bottom:1px solid var(--bd);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
table.it td{padding:4px 3px;border-bottom:1px solid var(--bd);vertical-align:top}
table.it tr:last-child td{border-bottom:none}
table.it td input,table.it td select,table.it td textarea{width:100%;border:1px solid transparent;border-radius:5px;padding:5px 6px;font-size:12px;background:transparent;color:var(--tx);font-family:inherit;transition:border .12s,background .12s}
table.it td input:focus,table.it td select:focus,table.it td textarea:focus{border-color:var(--ac);background:var(--bg);outline:none}
table.it .r{text-align:right}
table.it .amc{text-align:right;font-weight:600;color:var(--tx);padding-right:9px;font-size:12px;min-width:60px}
table.it .td-img{padding:4px 3px;text-align:center;min-width:110px}
table.it .td-img img{width:100px;height:100px;object-fit:cover;border-radius:6px;border:1px solid var(--bd);display:block;margin:0 auto;cursor:pointer}
table.it .td-img .no-img{width:100px;height:100px;border-radius:6px;border:1px dashed var(--bd2);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--tx3);margin:0 auto;cursor:pointer;transition:all .15s}
table.it .td-img .no-img:hover{border-color:var(--ac);color:var(--ac);background:var(--ac-l)}
.del-btn{background:none;border:none;color:var(--tx3);cursor:pointer;padding:4px 7px;border-radius:5px;font-size:12px;transition:all .12s}
.del-btn:hover{background:rgba(239,68,68,.1);color:#dc2626}
/* ─── Totals ─── */
.tot-box{padding:12px 0 0;border-top:1px solid var(--bd);margin-bottom:12px}
.tr{display:flex;justify-content:space-between;font-size:13px;color:var(--tx2);padding:3px 0}
.tr.grand{font-size:16px;font-weight:700;color:var(--tx);padding-top:9px;margin-top:5px;border-top:2px solid var(--bd)}
/* ─── Terms ─── */
.term-row{display:flex;gap:7px;align-items:flex-start;margin-bottom:7px}
.term-row input,.term-row textarea{flex:1;font-size:12px;padding:6px 9px;border:1px solid var(--bd);border-radius:var(--rd);background:var(--bg);color:var(--tx);font-family:inherit}
.term-row input:focus,.term-row textarea:focus{border-color:var(--ac);outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
/* ─── Buttons ─── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--rd);font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--bd);background:var(--bg);color:var(--tx);font-family:inherit;transition:all .15s}
.btn:hover{background:var(--bg2);border-color:var(--bd2)}
.btn:active{transform:scale(.98)}
.btn-p{background:var(--ac);color:#fff;border-color:var(--ac)}
.btn-p:hover{background:var(--ac-d);border-color:var(--ac-d);color:#fff}
.btn-pdf{background:#dc2626;color:#fff;border-color:#dc2626}
.btn-pdf:hover{background:#b91c1c;border-color:#b91c1c;color:#fff}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-del{background:none;color:#dc2626;border-color:#fca5a5}
.btn-del:hover{background:rgba(239,68,68,.06)}
.btn-add{border-style:dashed;border-color:var(--bd2);color:var(--tx2);width:100%;justify-content:center;padding:8px}
.btn-add:hover{border-color:var(--ac);color:var(--ac);background:var(--ac-l)}
.btn-success{background:#16a34a;color:#fff;border-color:#16a34a}
.btn-success:hover{background:#15803d;border-color:#15803d;color:#fff}
/* ─── Stats ─── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:14px}
.sc{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rd2);padding:11px 13px;box-shadow:var(--sh)}
.sl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--tx3);margin-bottom:3px}
.sv{font-size:17px;font-weight:700;color:var(--tx)}
.ss{font-size:11px;color:var(--tx3);margin-top:1px}
/* ─── History ─── */
.hc{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rd2);padding:11px 13px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:all .15s;margin-bottom:7px}
.hc:hover{border-color:var(--ac);box-shadow:var(--sh2)}
.hi{width:36px;height:36px;background:var(--ac-l);border-radius:var(--rd);display:flex;align-items:center;justify-content:center;color:var(--ac);font-size:15px;flex-shrink:0}
.hinfo{flex:1;min-width:0}
.hno{font-size:13px;font-weight:600;color:var(--tx)}
.hmeta{font-size:11px;color:var(--tx2);margin-top:2px}
/* ─── FX ─── */
.fx-row{display:flex;align-items:center;gap:9px;flex-wrap:wrap;padding:9px 12px;background:var(--bg2);border-radius:var(--rd);border:1px solid var(--bd);margin-bottom:11px}
.fx-row label{font-size:12px;color:var(--tx2);font-weight:500;white-space:nowrap}
.fx-row select,.fx-row input{font-size:12px;padding:5px 7px;border:1px solid var(--bd);border-radius:5px;background:var(--bg);color:var(--tx);font-family:inherit}
.fx-row input[type=number]{width:85px}
.fx-badge{font-size:11px;color:var(--tx3);background:var(--bg3);border-radius:4px;padding:3px 7px;border:1px solid var(--bd)}
.toast{position:fixed;bottom:22px;right:22px;background:#0f172a;color:#fff;padding:11px 16px;border-radius:var(--rd2);font-size:13px;display:flex;align-items:center;gap:8px;box-shadow:var(--sh2);transform:translateY(70px);opacity:0;transition:all .3s;z-index:9999;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast i{color:#4ade80;font-size:14px}
.generate-motion{position:fixed;inset:0;z-index:9800;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,.42);backdrop-filter:blur(8px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility .2s ease}
.generate-motion.show{opacity:1;visibility:visible;pointer-events:auto}
.generate-motion-panel{width:min(410px,calc(100vw - 36px));border:1px solid rgba(255,255,255,.38);border-radius:10px;background:#fff;box-shadow:0 24px 70px rgba(15,23,42,.24);padding:22px 20px 20px;text-align:center;transform:translateY(12px) scale(.98);transition:transform .24s ease}
.generate-motion.show .generate-motion-panel{transform:translateY(0) scale(1)}
.generate-motion-stage{height:118px;position:relative;margin-bottom:10px}
.motion-doc{position:absolute;left:50%;top:18px;width:86px;height:98px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;box-shadow:0 14px 32px rgba(16,24,40,.12);padding:14px 12px;display:grid;gap:9px;transform-origin:center}
.motion-doc span{display:block;height:8px;border-radius:3px;background:#d0d5dd}
.motion-doc span:first-child{height:13px;width:58%;background:#087f5b}
.motion-doc span:nth-child(2){width:82%}
.motion-doc span:nth-child(3){width:68%;background:#f59e0b}
.motion-doc-a{margin-left:-92px;animation:generateDocA 1.05s ease-in-out infinite}
.motion-doc-b{margin-left:6px;animation:generateDocB 1.05s ease-in-out infinite}
.motion-check{position:absolute;left:50%;top:40px;width:48px;height:48px;margin-left:-24px;border-radius:50%;background:#087f5b;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(8,127,91,.25);animation:generateCheck 1.05s ease-in-out infinite}
.generate-motion h3{font-size:18px;font-weight:900;color:#101828;line-height:1.25;margin:0 0 6px}
.generate-motion p{font-size:13px;font-weight:700;color:#667085;line-height:1.5;min-height:20px;margin:0 0 14px}
.generate-motion-steps{display:grid;grid-template-columns:1fr 1fr 1fr;border:1px solid #dce5da;border-radius:8px;overflow:hidden;background:#f8faf7}
.generate-motion-steps span{min-height:42px;display:flex;align-items:center;justify-content:center;padding:0 8px;font-size:12px;font-weight:850;color:#667085;border-right:1px solid #dce5da;line-height:1.25}
.generate-motion-steps span:last-child{border-right:0}
.generate-motion-steps span.active{background:#eff6ff;color:#1d4ed8}
.generate-motion-steps span.done{background:#ecfdf3;color:#067647}
@keyframes generateDocA{0%,100%{transform:translateX(0) rotate(-5deg)}50%{transform:translateX(18px) rotate(-1deg)}}
@keyframes generateDocB{0%,100%{transform:translateX(0) rotate(5deg)}50%{transform:translateX(-18px) rotate(1deg)}}
@keyframes generateCheck{0%,100%{transform:scale(.92);opacity:.72}50%{transform:scale(1);opacity:1}}
.hint-box{background:#fefce8;border:1px solid #fde047;border-radius:var(--rd);padding:11px 13px;font-size:12px;color:#713f12;display:flex;gap:9px;align-items:flex-start;margin-top:11px;line-height:1.6}
.hint-box i{color:#ca8a04;margin-top:1px;flex-shrink:0}
.exp-row{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--bd)}
/* ─── AI workbench ─── */
#p-ai{max-width:1060px}
.ai-workbench{position:relative;overflow:hidden}
.ai-input{width:100%;min-height:260px;border:1px solid var(--bd);border-radius:var(--rd2);padding:13px 14px;background:var(--bg2);color:var(--tx);font-family:inherit;font-size:13px;line-height:1.7;resize:vertical;outline:none;transition:border .15s,box-shadow .15s,background .15s}
.ai-input:focus{background:var(--bg);border-color:var(--ac);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.ai-toolbar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:12px}
.ai-status{font-size:12px;color:var(--tx3);min-height:18px;display:inline-flex;align-items:center}
.ai-status.ok{color:#15803d;font-weight:600}
.ai-status.err{color:#dc2626;font-weight:600}
.ai-status.warn{color:#b65c00;font-weight:600}
.ai-status.loading{color:var(--ac);font-weight:600}
.ai-pill{font-size:11px;font-weight:700;color:var(--tx2);background:var(--bg2);border:1px solid var(--bd);border-radius:999px;padding:4px 9px}
.ai-empty{min-height:160px;border:1px dashed var(--bd2);border-radius:var(--rd2);background:var(--bg2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--tx3);font-size:13px}
.ai-empty i{font-size:24px;color:var(--tx3)}
.ai-result{display:flex;flex-direction:column;gap:12px}
.ai-summary{border-left:3px solid var(--ac);background:var(--ac-l);border-radius:0 var(--rd) var(--rd) 0;padding:11px 13px;font-size:13px;line-height:1.7;color:var(--tx)}
.ai-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.ai-info{border:1px solid var(--bd);border-radius:var(--rd);background:var(--bg2);padding:9px 10px;min-width:0}
.ai-info span{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--tx3);margin-bottom:3px}
.ai-info b{display:block;font-size:12px;color:var(--tx);font-weight:600;line-height:1.45;word-break:break-word}
.ai-required{display:none;margin-top:12px;border-radius:8px;border:1px solid var(--bd);padding:11px 12px;background:#fff}
.ai-required.ok,.ai-required.warn{display:block}
.ai-required strong{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:900;margin-bottom:8px}
.ai-required.ok{border-color:#abefc6;background:#ecfdf3;color:#067647}
.ai-required.warn{border-color:#f1be78;background:#fffaf2;color:#b65c00}
.ai-required p{font-size:12px;line-height:1.5;color:inherit;margin:0}
.ai-required div{display:grid;gap:7px}
.ai-required button{width:100%;min-height:42px;border:1px solid rgba(182,92,0,.24);border-radius:8px;background:#fff;color:#344054;font-family:inherit;text-align:left;padding:8px 10px;display:grid;grid-template-columns:128px minmax(0,1fr);gap:8px;align-items:center;cursor:pointer}
.ai-required button b{font-size:12px;color:#b65c00}
.ai-required button span{font-size:12px;color:#475467;line-height:1.4}
.ai-money-row{display:flex;gap:8px;flex-wrap:wrap}
.ai-money-row span{font-size:12px;color:var(--tx2);background:#f8fafc;border:1px solid var(--bd);border-radius:999px;padding:5px 9px}
.ai-money-row b{color:var(--tx)}
.ai-table-wrap{margin:0}
.ai-table{width:100%;border-collapse:collapse;font-size:12px;min-width:720px}
.ai-table th{background:var(--bg2);border-bottom:1px solid var(--bd);color:var(--tx2);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:8px 9px;white-space:nowrap}
.ai-table td{border-bottom:1px solid var(--bd);padding:8px 9px;vertical-align:top;color:var(--tx)}
.ai-table tbody tr:last-child td{border-bottom:none}
.ai-table .r{text-align:right}
.ai-muted{font-size:11px;color:var(--tx3);line-height:1.5;margin-top:2px}
.ai-questions{display:flex;gap:7px;flex-wrap:wrap}
.ai-questions span{font-size:11px;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:999px;padding:5px 8px}
.ai-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:13px;padding-top:13px;border-top:1px solid var(--bd)}
.btn:disabled{opacity:.58;cursor:not-allowed;transform:none!important}
/* ─── Product library toolbar ─── */
.prod-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.prod-toolbar .search-box{flex:1;min-width:160px;position:relative}
.prod-toolbar .search-box input{width:100%;padding:6px 10px 6px 28px;border:1px solid var(--bd);border-radius:var(--rd);font-size:13px;background:var(--bg);color:var(--tx);font-family:inherit}
.prod-toolbar .search-box i{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--tx3);font-size:12px}
/* ─── Product library full width ─── */
#p-products{max-width:none;width:100%}
#p-products .tbl-wrap{overflow-x:auto}
#p-products table.it{min-width:1080px;width:100%}
@media(min-width:1400px){#p-products table.it{min-width:1320px}}
/* ─── Category management ─── */
.cat-mgr{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.cat-mgr.show{opacity:1;pointer-events:auto}
.cat-mgr-inner{background:var(--bg);border-radius:var(--rd2);padding:22px;width:380px;max-width:90vw;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.cat-mgr h3{font-size:15px;margin-bottom:12px;color:var(--tx)}
.cat-row{display:flex;align-items:center;gap:6px;padding:6px 0;border-bottom:1px solid var(--bd)}
.cat-row span{flex:1;font-size:13px;color:var(--tx)}
.cat-add{display:flex;gap:6px;margin-top:12px}
.cat-add input{flex:1;font-size:13px;padding:6px 9px;border:1px solid var(--bd);border-radius:var(--rd);font-family:inherit}
.cat-add input:focus{border-color:var(--ac);outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.cat-badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:10px;background:var(--ac-l);color:var(--ac-t);font-weight:500;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}
.party-row{display:flex;align-items:center;gap:10px;padding:10px 11px;border:1px solid var(--bd);border-radius:var(--rd);margin-bottom:7px;cursor:pointer;transition:all .15s}
.party-row:hover{border-color:var(--ac);background:var(--ac-l)}
.party-ico{width:34px;height:34px;border-radius:8px;background:var(--ac-l);color:var(--ac-t);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.party-info{flex:1;min-width:0}
.party-nm{font-size:13px;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.party-meta{font-size:11px;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.party-del{background:none;border:none;color:var(--tx3);cursor:pointer;padding:5px 8px;border-radius:5px;font-size:12px;flex-shrink:0;transition:all .12s}
.party-del:hover{background:rgba(239,68,68,.1);color:#dc2626}
.party-empty{color:var(--tx3);font-size:13px;text-align:center;padding:24px 0}
/* ══════════════════════════════ PACKING LIST / CONTRACT PANELS ══════════════════════════════ */
.pl-config-card{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rd2);padding:16px 18px;margin-bottom:12px}
.pl-config-card .ct{font-size:13px;font-weight:600;color:var(--tx);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.pl-config-card .ct i{color:var(--ac)}
.pl-mode-btn{flex:1;min-width:240px;text-align:left;background:var(--bg);border:2px solid var(--bd);border-radius:var(--rd2);padding:12px 14px;cursor:pointer;font-family:inherit;color:var(--tx);transition:all .15s}
.pl-mode-btn:hover{border-color:var(--bd2);background:var(--bg2)}
.pl-mode-btn.on{border-color:var(--ac);background:var(--ac-l);box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.pl-mode-btn.on>div:first-child{color:var(--ac-t)}
table.pld{width:100%;border-collapse:collapse;font-size:12px;min-width:920px}
table.pld th{background:var(--bg2);color:var(--tx2);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:7px 5px;border-bottom:1px solid var(--bd);text-align:left;white-space:nowrap}
table.pld td{padding:3px 4px;border-bottom:1px solid var(--bd);vertical-align:top}
table.pld td input,table.pld td textarea{width:100%;border:1px solid transparent;border-radius:5px;padding:5px 6px;font-size:12px;background:transparent;color:var(--tx);font-family:inherit}
table.pld td input:focus,table.pld td textarea:focus{border-color:var(--ac);background:var(--bg);outline:none}
table.pld td input.r{text-align:right}
table.pld td.vol-cell input{color:var(--ac);font-weight:600}
table.pld tfoot td{background:var(--bg2);font-weight:700;color:var(--ac);border-top:2px solid var(--ac);padding:7px 5px}
.pkg-row{display:flex;gap:7px;align-items:center;margin-bottom:6px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rd);padding:7px 9px}
.pkg-row label{font-size:11px;color:var(--tx2);font-weight:600;white-space:nowrap;min-width:70px}
.pkg-row input,.pkg-row select{font-size:12px;padding:5px 8px;border:1px solid var(--bd);border-radius:5px;background:var(--bg);color:var(--tx);font-family:inherit;flex:1}
.pkg-row input:focus,.pkg-row select:focus{border-color:var(--ac);outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.clause-row{display:flex;gap:6px;align-items:flex-start;margin-bottom:6px}
.clause-row textarea{flex:1;font-size:12px;padding:6px 9px;border:1px solid var(--bd);border-radius:var(--rd);background:var(--bg);color:var(--tx);font-family:inherit;resize:vertical;min-height:46px;line-height:1.5}
.clause-row textarea:focus{border-color:var(--ac);outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.doc-tab-bar{display:flex;gap:4px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--rd);padding:4px;margin-bottom:14px;overflow-x:auto}
.doc-tab{padding:8px 14px;font-size:13px;font-weight:600;color:var(--tx2);cursor:pointer;border:none;background:transparent;font-family:inherit;border-radius:6px;display:flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap}
.doc-tab:hover{color:var(--tx);background:var(--bg2)}
.doc-tab.on{background:var(--ac);color:#fff;box-shadow:0 6px 16px rgba(37,99,235,.18)}
.doc-tab i{font-size:12px}
/* ══════════════════════════════ QUOTATION DOCUMENT ══════════════════════════════ */
#preview-wrap{background:#d1d5db;padding:22px;border-radius:var(--rd2);min-height:400px;overflow:auto}
.doc-page{background:#fff;width:100%;max-width:740px;margin:0 auto;padding:34px 38px;box-shadow:0 4px 24px rgba(0,0,0,.14);font-family:'Segoe UI',Arial,Helvetica,sans-serif;font-size:12px;line-height:1.6;color:#1e293b}
.dh{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:14px;border-bottom:3px solid var(--ac)}
.dh-l .dlogo{max-height:50px;max-width:155px;object-fit:contain;display:block;margin-bottom:6px}
.dh-l .dco{font-size:15px;font-weight:700;color:var(--ac)}
.dh-l .dsub{font-size:9.5px;color:#64748b;line-height:1.7;margin-top:2px}
.dh-r{text-align:right}
.dh-r .dtitle{font-size:24px;font-weight:800;color:var(--ac);text-transform:uppercase;letter-spacing:.04em}
.dh-r .dref{font-size:10px;color:#64748b;line-height:1.9;margin-top:4px}
.daddr{margin-bottom:13px}
.dal{font-size:9px;font-weight:700;color:var(--ac);text-transform:uppercase;letter-spacing:.09em;margin-bottom:5px}
.dab{font-size:10.5px;color:#334155;line-height:1.75}
.dmeta{display:flex;gap:16px;flex-wrap:wrap;padding:7px 11px;background:#f8fafc;border-radius:5px;margin-bottom:13px;font-size:10px;color:#64748b}
.dmeta b{color:#1e293b}
table.dtbl{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:13px}
table.dtbl thead th{background:var(--ac);color:#fff;padding:7px 9px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:none}
table.dtbl thead th.r{text-align:right}
table.dtbl tbody td{padding:6px 9px;border-bottom:1px solid #e2e8f0;color:#1e293b;vertical-align:top}
table.dtbl tbody td.r{text-align:right}
table.dtbl tbody tr:nth-child(even) td{background:#f8fafc}
table.dtbl tfoot td{padding:5px 9px;font-size:11px;color:#475569;border:none}
table.dtbl tfoot td.r{text-align:right}
table.dtbl tfoot tr.grd td{font-size:14px;font-weight:700;color:var(--ac);padding-top:9px;border-top:2px solid var(--ac)}
.drem{font-size:10px;color:#475569;padding:8px 11px;border-left:3px solid var(--ac);background:#f8fafc;border-radius:0 4px 4px 0;margin-bottom:11px;line-height:1.7}
.dterms{margin-bottom:11px}
.dterms h4{font-size:9.5px;font-weight:700;color:var(--ac);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.dterms ol{padding-left:15px}
.dterms li{font-size:9.5px;color:#64748b;margin-bottom:3px;line-height:1.6}
.dsign{margin-top:22px}
.dsb .sline{border-top:1px solid #94a3b8;margin-top:26px;margin-bottom:4px}
.dsb .slbl{font-size:9.5px;color:#64748b}

/* ══════════════════════════════ DOCUMENT STUDIO APP SHELL ══════════════════════════════ */
body{background:var(--bg3)}
.shell{grid-template-rows:72px 1fr;background:var(--bg3)}
.studio-topbar{height:72px;padding:0 22px;border-bottom:1px solid rgba(16,24,40,.08);box-shadow:0 1px 0 rgba(16,24,40,.03);background:rgba(255,255,255,.94);backdrop-filter:blur(12px)}
.studio-topbar .brand{min-width:172px}
.brand-copy{display:flex;flex-direction:column;line-height:1.15}
.studio-topbar .brand-icon{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,#087f5b,#0c9463);box-shadow:0 10px 22px rgba(8,127,91,.18)}
.brand-sub{font-size:11px;color:var(--tx3);margin-top:2px}
.module-tabs{display:flex;align-items:center;gap:8px;min-width:0;flex:1;margin:0 22px;overflow-x:auto;scrollbar-width:none}
.module-tabs::-webkit-scrollbar{display:none}
.module-tab{height:40px;border:1px solid transparent;background:transparent;border-radius:8px;color:#344054;font-family:inherit;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;padding:0 13px;white-space:nowrap;cursor:pointer;transition:background .16s,border .16s,color .16s,box-shadow .16s}
.module-tab i{font-size:13px;color:#475467}
.module-tab:hover{background:#f3f6f1;border-color:#e3eadf;color:#111827}
.module-tab.on{background:var(--ac-l);border-color:#bde7d0;color:var(--ac-t);box-shadow:inset 0 -2px 0 var(--ac)}
.module-tab.on i{color:var(--ac)}
.studio-topbar .top-actions{gap:10px}
.studio-topbar .btn{height:36px;border-radius:8px;font-weight:700}
.module-entry{border-left:1px solid var(--bd);padding-left:12px;margin-left:2px}
.module-entry-btn{height:42px!important;padding:0 17px!important;background:linear-gradient(135deg,#087f5b,#0a8f60)!important;border-color:#087f5b!important;box-shadow:0 12px 26px rgba(8,127,91,.22)!important}
.layout{grid-template-columns:238px minmax(0,1fr) 334px;height:calc(100vh - 72px);background:var(--bg3)}
.studio-flow{background:#fbfcfa;border-right:1px solid var(--bd);padding:16px 12px;gap:5px}
.flow-head{display:flex;align-items:center;justify-content:space-between;padding:10px 6px 13px;border-bottom:1px solid var(--bd);margin-bottom:8px}
.flow-head strong{display:block;font-size:15px;color:#111827;font-weight:800}
.flow-head span{display:block;font-size:11px;color:var(--tx3);margin-top:3px}
.icon-btn{width:32px;height:32px;border:1px solid var(--bd);border-radius:8px;background:#fff;color:#475467;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .16s;font-family:inherit}
.icon-btn:hover{border-color:#bde7d0;color:var(--ac);background:var(--ac-l)}
.flow-step{position:relative;align-items:flex-start;gap:11px;padding:8px;border-radius:8px;color:#667085}
.flow-step:before{content:"";position:absolute;left:20px;top:37px;bottom:-10px;width:1px;background:#d7ddd3}
.flow-step:last-of-type:before{display:none}
.flow-step .step-index{width:25px;height:25px;border-radius:50%;border:1px solid #cfd8cd;background:#fff;color:#667085;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex:0 0 auto;position:relative;z-index:1}
.flow-step b{display:block;font-size:13px;color:#344054;line-height:1.2}
.flow-step small{display:block;font-size:11px;color:#98a2b3;margin-top:3px}
.flow-step:hover{background:#f4f7f2}
.flow-step.on{background:transparent;color:var(--ac-t);font-weight:700}
.flow-step.on .step-index{background:var(--info);border-color:var(--info);color:#fff;box-shadow:0 0 0 4px rgba(37,99,235,.10)}
.flow-step.on b{color:var(--info)}
.flow-step.is-done .step-index{background:var(--ac);border-color:var(--ac);color:#fff}
.flow-summary{margin-top:auto;border-top:1px solid var(--bd);padding:14px 8px 8px}
.flow-summary-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.flow-summary-title span{font-size:13px;font-weight:800;color:#111827}
.flow-summary-title button{border:0;background:transparent;color:var(--info);font-family:inherit;font-size:12px;font-weight:700;cursor:pointer}
.flow-summary dl{display:grid;grid-template-columns:68px 1fr;gap:7px 8px;font-size:12px;line-height:1.45;margin-bottom:12px}
.flow-summary dt{color:#667085}
.flow-summary dd{color:#111827;min-width:0;word-break:break-word}
.soft-pill{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:800;border:1px solid var(--bd);background:#fff;color:#667085}
.soft-pill.ok{background:#dcfae6;border-color:#abefc6;color:#067647}
.flow-raw-btn{width:100%;justify-content:center}
.flow-mini-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 8px 8px}
.flow-mini-actions .btn{justify-content:center}
.studio-main{padding:16px;overflow-y:auto;background:#eef1ed}
.studio-main>.panel{max-width:1100px;margin:0 auto}
.studio-main>#p-preview.panel.on{display:flex;flex-direction:column;max-width:none;width:100%;min-height:100%;margin:0}
.studio-main #p-preview>.ph{background:#fff;border:1px solid var(--bd);border-bottom:0;border-radius:8px 8px 0 0;margin:0;padding:12px 14px;align-items:center;justify-content:space-between}
.studio-main #p-preview>.ph h2{font-size:15px;margin:0}
.studio-main #p-preview>.ph p{font-size:12px}
.ph-r{display:flex;align-items:center;gap:8px}
.doc-tab-bar{margin:0;border-radius:0;border-left:1px solid var(--bd);border-right:1px solid var(--bd);border-top:0;border-bottom:1px solid var(--bd);padding:0 10px;background:#fff;gap:0;min-height:45px;align-items:flex-end}
.doc-tab{height:45px;border-radius:8px 8px 0 0;border:1px solid transparent;border-bottom:0;margin-bottom:-1px;padding:0 18px;color:#344054}
.doc-tab.on{background:#fff;color:#111827;border-color:#9bc7ff;box-shadow:inset 0 2px 0 var(--info)}
.doc-tab.on i{color:var(--info)}
#preview-wrap{flex:1;min-height:620px;background:#f2f4f7;border:1px solid var(--bd);border-top:0;border-radius:0 0 8px 8px;padding:34px 22px;box-shadow:inset 0 1px 0 rgba(255,255,255,.6)}
#preview-wrap .doc-page{max-width:840px;border:1px solid #d0d5dd;box-shadow:0 18px 42px rgba(16,24,40,.14);border-radius:2px}
.studio-main #p-preview>.exp-row,.studio-main #p-preview>.hint-box{display:none}
.studio-main .card,.studio-main .pl-config-card{border-radius:8px;box-shadow:0 8px 22px rgba(16,24,40,.05)}
.studio-main .stats .sc{border-radius:8px}
.studio-inspector{background:#fbfcfa;border-left:1px solid var(--bd);padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.inspector-section{background:#fff;border:1px solid var(--bd);border-radius:8px;padding:13px;box-shadow:var(--sh)}
.inspector-head{display:flex;align-items:center;justify-content:space-between}
.inspector-head strong{font-size:15px;color:#111827}
.inspector-head>div{display:flex;align-items:center;gap:8px}
.studio-ai-input{width:100%;min-height:104px;border:1px solid var(--bd);border-radius:8px;background:#f8faf7;color:#111827;font-family:inherit;font-size:12px;line-height:1.6;padding:10px;resize:vertical;outline:none;transition:border .16s,box-shadow .16s,background .16s}
.studio-ai-input:focus{background:#fff;border-color:var(--ac);box-shadow:0 0 0 3px rgba(8,127,91,.10)}
.studio-inspector-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.studio-inspector-actions .btn{justify-content:center}
.inspector-tabs{display:grid;grid-template-columns:1fr 1fr 1fr;border-bottom:1px solid var(--bd);margin:-13px -13px 13px}
.inspector-tabs button{height:43px;border:0;border-right:1px solid var(--bd);background:#fbfcfa;color:#667085;font-family:inherit;font-size:12px;font-weight:800;cursor:pointer}
.inspector-tabs button:last-child{border-right:0}
.inspector-tabs button.on{background:#fff;color:var(--ac-t);box-shadow:inset 0 -2px 0 var(--ac)}
.inspector-form{display:grid;gap:8px}
.inspector-form label{font-size:11px;font-weight:800;color:#667085}
.inspector-form input,.inspector-form select{height:36px;border:1px solid var(--bd);border-radius:6px;background:#fff;color:#111827;font-family:inherit;font-size:12px;padding:0 10px;outline:none;transition:border .16s,box-shadow .16s}
.inspector-form input:focus,.inspector-form select:focus{border-color:#84caff;box-shadow:0 0 0 3px rgba(37,99,235,.10)}
.export-section{margin-top:auto}
.export-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.export-meta span{font-size:12px;color:#667085;font-weight:700}
.export-meta b{font-size:14px;color:#111827}
.export-main{width:100%;height:46px;justify-content:center;border-radius:8px;background:linear-gradient(135deg,#087f5b,#0a8f60);border-color:#087f5b;box-shadow:0 12px 24px rgba(8,127,91,.20);font-size:14px;font-weight:900}
.export-main:hover{background:linear-gradient(135deg,#066548,#087f5b)}
.export-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.export-grid button{height:58px;border:1px solid var(--bd);border-radius:8px;background:#fff;color:#344054;font-family:inherit;font-size:11px;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all .16s}
.export-grid button i{font-size:15px;color:#475467}
.export-grid button:hover{border-color:#bde7d0;background:var(--ac-l);color:var(--ac-t)}
.export-grid button:hover i{color:var(--ac)}
.user-badge{border-radius:8px;background:#f8faf7}
.btn-p{background:var(--ac);border-color:var(--ac)}
.btn-p:hover{background:var(--ac-d);border-color:var(--ac-d)}
.btn-pdf{background:#087f5b;border-color:#087f5b}
.btn-pdf:hover{background:#066548;border-color:#066548}
.f input:focus,.f select:focus,.f textarea:focus,.term-row input:focus,.term-row textarea:focus,.cat-add input:focus,.pkg-row input:focus,.pkg-row select:focus,.clause-row textarea:focus{box-shadow:0 0 0 3px rgba(8,127,91,.10)}

.mobile-app-shell,.mobile-editor-bar,.mobile-items-editor,.mobile-products-editor{display:none}

@media(max-width:1240px){
  .layout{grid-template-columns:214px minmax(0,1fr)}
  .studio-inspector{display:none}
  .module-tabs{margin:0 12px}
}
@media(max-width:920px){
  .shell{grid-template-rows:auto 1fr}
  .studio-topbar{position:sticky;height:auto;min-height:72px;align-items:flex-start;gap:10px;padding:12px;flex-wrap:wrap}
  .studio-topbar .brand{width:100%}
  .module-tabs{order:3;width:100%;margin:0}
  .top-actions{margin-left:auto}
  .layout{height:calc(100vh - 126px);grid-template-columns:1fr}
  .studio-flow{display:none}
  .studio-main{padding:10px}
  #preview-wrap{min-height:520px;padding:18px 10px}
  .doc-tab{padding:0 12px}
}
@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}@page{size:A4 portrait;margin:12mm 15mm}html,body{background:#fff!important;margin:0!important;padding:0!important}.auth-screen,.shell,.topbar,.layout,.sidebar,.main{display:none!important}#print-area{display:block!important;position:static!important;width:100%!important;background:#fff!important}#print-doc{width:100%!important}}
#print-area{display:none}
@media(max-width:900px){.auth-screen{grid-template-columns:1fr}.auth-stage{display:none}.auth-panel{min-height:100vh;border-left:0;padding:32px 22px}.auth-mark{margin-bottom:22px}}
@media(max-width:768px){.layout{grid-template-columns:1fr}.sidebar{display:none}.g2,.g3,.g4,.ai-grid{grid-template-columns:1fr}.tpl-grid{grid-template-columns:1fr 1fr}.stats{grid-template-columns:1fr 1fr}.topbar{padding:0 12px}.top-actions{gap:8px;overflow-x:auto}.top-btns{gap:5px}.module-entry{padding-left:8px}.module-entry span{display:none}.user-badge{max-width:226px}.user-email{max-width:95px}.ai-input{min-height:220px}.ai-actions .btn{flex:1;justify-content:center}.legal-hero-inner{display:grid;gap:18px}.legal-nav{justify-content:flex-start}.legal-hero h1{font-size:28px}.legal-main{padding:16px 14px 34px}.legal-panel{padding:16px}.legal-table th,.legal-table td{display:block;width:100%}.legal-table th{border-bottom:0}.legal-table td{border-top:0}}

@media(max-width:768px){
  html{scroll-padding-top:calc(76px + env(safe-area-inset-top));-webkit-tap-highlight-color:transparent}
  body{background:#f4f7f5;overscroll-behavior-y:none}
  .shell{display:block;min-height:100vh;background:#f4f7f5}
  .studio-topbar,.layout{display:none!important}
  .mobile-app-shell{display:block;width:100%;min-height:100vh;padding:0 12px calc(184px + env(safe-area-inset-bottom));background:#f4f7f5;color:#101828;overflow-x:hidden}
  #mobile-app-shell button,#mobile-app-shell input,#mobile-app-shell select,#mobile-app-shell textarea,.mobile-editor-bar button{touch-action:manipulation;pointer-events:auto}
  .mobile-appbar{position:sticky;top:0;z-index:120;margin:0 -12px;padding:calc(12px + env(safe-area-inset-top)) 12px 10px;background:rgba(255,255,255,.98);backdrop-filter:blur(18px);border-bottom:1px solid #e3e9e2;box-shadow:0 8px 26px rgba(16,24,40,.08);display:grid;grid-template-columns:42px minmax(0,1fr) 42px;gap:8px;align-items:center}
  .mobile-back,.mobile-avatar{width:42px;height:42px;border:0;background:transparent;color:#111827;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;position:relative;z-index:2}
  .mobile-avatar{border:1px solid #dbe4d9;background:#fff;color:#087f5b}
  .mobile-title{display:flex;flex-direction:column;gap:3px;min-width:0}
  .mobile-title strong{font-size:22px;line-height:1.1;font-weight:850;letter-spacing:0;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-title span{font-size:12px;color:#087f5b;display:flex;align-items:center;gap:6px}
  .mobile-title b{font-weight:800}
  .mobile-modebar{position:relative;z-index:3;display:grid;grid-template-columns:1fr;gap:0;margin:16px 0 12px;border:1px solid #d9e2d8;border-radius:22px;background:#fff;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,40,.04)}
  .mobile-account-strip{position:relative;z-index:4;display:flex;align-items:center;gap:8px;margin:12px 0 2px;padding:8px 9px;border:1px solid #d9e2d8;border-radius:10px;background:#fff;box-shadow:0 1px 2px rgba(16,24,40,.04)}
  .mobile-account-email{min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#475467;font-size:12px;font-weight:800}
  .mobile-account-strip button{height:32px;border:1px solid #dce5da;border-radius:8px;background:#fff;color:#087f5b;font-family:inherit;font-size:12px;font-weight:850;padding:0 10px;display:flex;align-items:center;gap:5px}
  .mobile-account-strip button.danger{color:#dc2626;border-color:#fecaca;background:#fff7f7}
  .mobile-modebar button{height:52px;border:0;background:#fff;color:#344054;font-family:inherit;font-size:17px;font-weight:800;letter-spacing:0}
  .mobile-modebar button.on{background:linear-gradient(135deg,#087f5b,#0a8f60);color:#fff;box-shadow:0 10px 24px rgba(8,127,91,.18)}
  .mobile-customs-entry{position:relative;z-index:3;width:100%;min-height:54px;margin-bottom:14px;border:1.5px solid #087f5b;background:#fff;border-radius:10px;color:#087f5b;font-family:inherit;font-size:15px;font-weight:850;display:flex;align-items:center;justify-content:space-between;padding:0 16px;box-shadow:0 8px 22px rgba(8,127,91,.08)}
  .mobile-customs-entry span{display:flex;align-items:center;gap:8px}
  .mobile-wizard{position:relative;z-index:1;display:flex;flex-direction:column;gap:17px;padding-bottom:8px}
  .mobile-wizard:before{content:"";position:absolute;left:31px;top:56px;bottom:160px;width:2px;background:repeating-linear-gradient(to bottom,#cad5c9 0 8px,transparent 8px 15px);z-index:0;pointer-events:none}
  .mobile-step{position:relative;z-index:2;background:#fff;border:1px solid #dce5da;border-radius:12px;padding:13px 11px 14px;box-shadow:0 10px 28px rgba(16,24,40,.06);overflow:visible}
  .mobile-step-head{display:grid;grid-template-columns:46px minmax(0,1fr) auto;gap:8px;align-items:center;margin-bottom:11px}
  .mobile-step-num{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#087f5b,#0a8f60);color:#fff;font-size:22px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(8,127,91,.2)}
  .mobile-step h3{font-size:20px;font-weight:900;color:#101828;letter-spacing:0;line-height:1.1;margin:0}
  .mobile-step p{font-size:12px;color:#667085;margin-top:4px;line-height:1.4}
  .mobile-chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:9px;font-size:12px;font-weight:800;white-space:nowrap;border:1px solid #f4c78a;color:#b65c00;background:#fff8ed}
  .mobile-chip.warn{color:#b65c00;background:#fff8ed;border-color:#f4c78a}
  .mobile-chip.ok{color:#067647;background:#ecfdf3;border-color:#abefc6}
  .mobile-doc-state{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:9px;font-size:12px;font-weight:800;white-space:nowrap;border:1px solid #bfdbfe;color:#1d4ed8;background:#eff6ff}
  .mobile-ai-text{width:100%;min-height:142px;border:1px solid #dbe4d9;border-radius:8px;background:#fbfcfb;color:#111827;font-size:16px;line-height:1.55;font-family:inherit;padding:13px 14px;resize:vertical;outline:none}
  .mobile-ai-text:focus{background:#fff;border-color:#84caff;box-shadow:0 0 0 3px rgba(37,99,235,.10)}
  .mobile-step-actions{position:relative;z-index:5;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;margin-top:11px}
  .mobile-ai-action{width:100%;min-height:52px;border:1.5px solid #2563eb;border-radius:10px;background:#2563eb;color:#fff;font-family:inherit;font-size:16px;font-weight:900;padding:0 16px;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 12px 26px rgba(37,99,235,.22);position:relative;z-index:6}
  .mobile-ai-action:active{transform:translateY(1px);box-shadow:0 7px 18px rgba(37,99,235,.18)}
  .mobile-ai-action:disabled{opacity:.72}
  .mobile-link-action,.mobile-edit-link{border:0;background:transparent;color:#087f5b;font-family:inherit;font-size:14px;font-weight:850;display:flex;align-items:center;gap:6px;white-space:nowrap;position:relative;z-index:6}
  .mobile-ai-status{display:none;margin-top:9px;border-radius:9px;padding:9px 10px;font-size:13px;font-weight:800;line-height:1.35;background:#f2f4f7;color:#475467}
  .mobile-ai-status.show{display:block}
  .mobile-ai-status.loading{background:#eff6ff;color:#1d4ed8}
  .mobile-ai-status.ok{background:#ecfdf3;color:#067647}
  .mobile-ai-status.warn{background:#fffaf2;color:#b65c00}
  .mobile-ai-status.err{background:#fff1f2;color:#be123c}
  .mobile-meta-line{margin-top:11px;color:#667085;font-size:13px;display:flex;align-items:center;gap:6px}
  .mobile-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px;border:1px solid #dce5da;border-radius:8px;padding:12px;background:#fbfcfb}
  .mobile-form-grid label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:800;color:#667085;min-width:0}
  .mobile-form-grid input,.mobile-form-grid select{width:100%;height:38px;border:0;border-bottom:1px solid transparent;background:transparent;color:#111827;font-family:inherit;font-size:15px;font-weight:650;padding:0;outline:none;min-width:0}
  .mobile-form-grid input:focus,.mobile-form-grid select:focus{border-bottom-color:#087f5b}
  .mobile-span-2{grid-column:1/-1}
  .mobile-party-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
  .mobile-party-actions button{min-height:40px;border:1px solid #dce5da;border-radius:8px;background:#fff;color:#087f5b;font-family:inherit;font-size:14px;font-weight:850;display:flex;align-items:center;justify-content:center;gap:7px}
  .mobile-required{margin:11px 0 0 auto;min-height:36px;border:1px solid #f1be78;background:#fffaf2;color:#b65c00;border-radius:8px;font-family:inherit;font-size:13px;font-weight:800;padding:0 11px;display:flex;align-items:center;gap:7px}
  .mobile-required.ok{border-color:#abefc6;background:#ecfdf3;color:#067647}
  .mobile-items-list{border:1px solid #dce5da;border-radius:8px;overflow:hidden;background:#fff}
  .mobile-item-row{display:grid;grid-template-columns:32px minmax(0,1fr) 96px;align-items:center;gap:9px;min-height:72px;padding:9px 8px;border-bottom:1px solid #e5ebe4;font-size:13px}
  .mobile-item-row:last-child{border-bottom:0}
  .mobile-item-row b{display:block;font-size:14px;color:#101828;line-height:1.25;word-break:normal;overflow-wrap:normal}
  .mobile-item-row small{display:block;color:#667085;font-size:12px;margin-top:3px;line-height:1.25}
  .mobile-item-row .r{text-align:right;font-weight:750;color:#101828}
  .mobile-item-head{min-height:38px;background:#fbfcfb;color:#475467;font-size:12px;font-weight:850}
  .mobile-item-more{width:28px;height:28px;border:0;background:transparent;color:#98a2b3}
  .mobile-view-all{width:100%;height:42px;border:0;border-top:1px solid #e5ebe4;background:#fff;color:#087f5b;font-family:inherit;font-size:14px;font-weight:850}
  .mobile-inline-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
  .mobile-inline-actions button{height:42px;border:1px solid #dce5da;background:#fff;border-radius:8px;color:#087f5b;font-family:inherit;font-size:14px;font-weight:850;display:flex;align-items:center;justify-content:center;gap:7px}
  .mobile-doc-tabs{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid #dce5da;border-radius:8px;background:#fff;overflow:hidden;margin-bottom:10px}
  .mobile-doc-tabs button{height:46px;border:0;border-right:1px solid #dce5da;border-bottom:1px solid #dce5da;background:#fff;color:#344054;font-family:inherit;font-size:14px;font-weight:750}
  .mobile-doc-tabs button:nth-child(2n){border-right:0}
  .mobile-doc-tabs button:nth-last-child(-n+2){border-bottom:0}
  .mobile-doc-tabs button.on{background:#087f5b;color:#fff}
  .mobile-doc-config-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:-1px 0 10px}
  .mobile-doc-config-actions button{min-height:40px;border:1px solid #dce5da;border-radius:8px;background:#fff;color:#344054;font-family:inherit;font-size:14px;font-weight:850;display:flex;align-items:center;justify-content:center;gap:7px}
  .mobile-generate-card{display:grid;grid-template-columns:minmax(0,1fr) 128px;gap:12px;align-items:center;border:1px solid #dce5da;border-radius:10px;background:#fbfcfb;padding:12px}
  .mobile-generate-card strong{display:block;font-size:17px;line-height:1.2;color:#101828;font-weight:900}
  .mobile-generate-card span{display:block;margin-top:5px;font-size:12px;line-height:1.35;color:#667085;font-weight:750}
  .mobile-generate-btn{height:50px;border:1.5px solid #087f5b;border-radius:10px;background:#087f5b;color:#fff;font-family:inherit;font-size:15px;font-weight:900;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 10px 24px rgba(8,127,91,.18)}
  .mobile-generate-btn:active{transform:translateY(1px);box-shadow:0 6px 16px rgba(8,127,91,.16)}
  .mobile-preview-frame{height:255px;border:1px solid #dce5da;border-radius:8px;background:#f4f6f4;overflow:auto;padding:12px}
  .mobile-preview-doc{transform-origin:top left;width:760px;transform:scale(.42);background:#fff;min-height:560px;box-shadow:0 10px 28px rgba(16,24,40,.10)}
  .mobile-preview-doc>p{width:390px;padding:40px 20px;color:#98a2b3;text-align:center;font-size:14px}
  .mobile-bottom-sheet{position:fixed;left:12px;right:12px;bottom:max(10px,env(safe-area-inset-bottom));z-index:100;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);border:1px solid #cfd8cd;border-radius:14px;box-shadow:0 18px 46px rgba(16,24,40,.18);padding:15px 14px calc(15px + env(safe-area-inset-bottom));display:grid;grid-template-columns:minmax(0,1fr) 92px 98px;gap:10px;align-items:center;pointer-events:none}
  .mobile-bottom-sheet span{display:block;font-size:13px;color:#344054;margin-bottom:4px}
  .mobile-bottom-sheet strong{display:block;font-size:27px;line-height:1;color:#087f5b;font-weight:900;letter-spacing:0}
  .mobile-bottom-sheet small{display:block;font-size:12px;color:#667085;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-save-btn,.mobile-export-btn{height:54px;border-radius:8px;font-family:inherit;font-size:15px;font-weight:900;display:flex;align-items:center;justify-content:center;gap:7px}
  .mobile-save-btn,.mobile-export-btn{pointer-events:auto}
  .mobile-save-btn{border:1.5px solid #087f5b;background:#fff;color:#087f5b}
  .mobile-export-btn{border:1.5px solid #087f5b;background:#087f5b;color:#fff;box-shadow:0 10px 24px rgba(8,127,91,.18)}
  .toast{left:18px;right:18px;bottom:176px;justify-content:center}
  .cat-mgr-inner{width:min(360px,92vw)}
  .auth-screen{grid-template-columns:1fr}
  .auth-stage{display:none}
  .auth-panel{min-height:100vh;border-left:0;padding:32px 22px}
  body.mobile-editor-active{overflow:hidden}
  body.mobile-editor-active .mobile-app-shell{display:none}
  body.mobile-editor-active .layout{display:block!important;position:fixed;inset:0;z-index:9000;height:100vh;background:#eef1ed;overflow:hidden}
  body.mobile-editor-active .studio-flow,body.mobile-editor-active .studio-inspector{display:none!important}
  body.mobile-editor-active .studio-main{height:100vh;overflow-y:auto;padding:calc(70px + env(safe-area-inset-top)) 10px calc(112px + env(safe-area-inset-bottom));background:#eef1ed;-webkit-overflow-scrolling:touch}
  body.mobile-editor-active .studio-main>.panel{max-width:none;margin:0 auto;display:none}
  body.mobile-editor-active .studio-main>.panel.on{display:block}
  body.mobile-editor-active .studio-main>#p-preview.panel.on{display:flex;min-height:calc(100vh - 174px)}
  body.mobile-preview-active .studio-main{height:100dvh;overflow:hidden;padding:calc(58px + env(safe-area-inset-top)) 0 0;background:#111827}
  body.mobile-preview-active .studio-main>#p-preview.panel.on{height:calc(100dvh - 58px - env(safe-area-inset-top));min-height:0;margin:0;display:flex;overflow:hidden;background:#111827}
  body.mobile-preview-active #p-preview>.ph,
  body.mobile-preview-active #p-preview>.exp-row,
  body.mobile-preview-active #p-preview>.hint-box{display:none!important}
  body.mobile-preview-active #p-preview>.doc-tab-bar{flex:0 0 auto;margin:0;padding:6px 8px;border:0;border-radius:0;background:#fff;box-shadow:0 8px 22px rgba(0,0,0,.16);overflow-x:auto;scrollbar-width:none}
  body.mobile-preview-active #p-preview>.doc-tab-bar::-webkit-scrollbar{display:none}
  body.mobile-preview-active .doc-tab{height:38px;min-width:138px;padding:0 10px;font-size:13px;border-radius:8px}
  body.mobile-preview-active #preview-wrap{position:relative;flex:1;height:auto;min-height:0;margin:0;padding:0;border:0;border-radius:0;background:#111827;overflow:hidden;touch-action:none;overscroll-behavior:none;box-shadow:none}
  body.mobile-preview-active #preview-wrap .doc-page{position:absolute;left:0;top:0;width:760px!important;min-width:760px;max-width:none;margin:0;border:1px solid #d0d5dd;border-radius:2px;box-shadow:0 18px 42px rgba(0,0,0,.34);transform-origin:0 0;will-change:transform}
  body.mobile-preview-active .mobile-editor-bar{background:rgba(255,255,255,.98);box-shadow:0 8px 22px rgba(0,0,0,.16)}
  .mobile-editor-bar{position:fixed;top:0;left:0;right:0;z-index:9100;height:calc(58px + env(safe-area-inset-top));padding:calc(8px + env(safe-area-inset-top)) 12px 8px;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);border-bottom:1px solid #dce5da;align-items:center;grid-template-columns:42px minmax(0,1fr) auto;gap:9px;box-shadow:0 8px 24px rgba(16,24,40,.08)}
  body.mobile-editor-active .mobile-editor-bar{display:grid}
  .mobile-editor-bar strong{font-size:18px;color:#101828;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-editor-back{width:42px;height:42px;border:0;background:transparent;color:#101828;border-radius:12px;font-size:18px}
  .mobile-editor-save{height:38px;border:1px solid #087f5b;background:#fff;color:#087f5b;border-radius:8px;font-family:inherit;font-size:13px;font-weight:850;padding:0 11px;display:flex;align-items:center;gap:6px}
  body.mobile-editor-active .ph{margin:4px 0 12px}
  body.mobile-editor-active .ph h2{font-size:18px}
  body.mobile-editor-active .card,body.mobile-editor-active .pl-config-card{padding:13px;border-radius:9px;margin-bottom:12px}
  body.mobile-editor-active .ct{font-size:14px;margin-bottom:10px}
  body.mobile-editor-active .f input,body.mobile-editor-active .f select,body.mobile-editor-active .f textarea,
  body.mobile-editor-active .term-row input,body.mobile-editor-active .term-row textarea{font-size:16px;min-height:42px}
  body.mobile-editor-active .btn{min-height:42px;justify-content:center}
  body.mobile-editor-active .inline-field{align-items:stretch}
  body.mobile-editor-active .stats{grid-template-columns:1fr 1fr;gap:8px}
  body.mobile-editor-active .sc{padding:10px}
  body.mobile-editor-active .tbl-wrap{border-radius:8px}
  body.mobile-editor-active .doc-tab-bar{overflow-x:auto;align-items:flex-end}
  body.mobile-editor-active .doc-tab{min-width:130px;padding:0 12px}
  body.mobile-editor-active #preview-wrap{min-height:520px;padding:14px 8px}
  body.mobile-editor-active #preview-wrap .doc-page{min-width:760px}
  body.mobile-editor-active #p-preview>.ph{display:flex;gap:8px}
  body.mobile-editor-active #p-preview>.ph .ph-r{flex-shrink:0}
  body.mobile-editor-active.mobile-preview-active .doc-tab-bar{height:50px;align-items:center}
  body.mobile-editor-active.mobile-preview-active .doc-tab{height:38px;min-width:138px;padding:0 10px}
  body.mobile-editor-active.mobile-preview-active #preview-wrap{height:auto;min-height:0;padding:0!important}
  body.mobile-editor-active.mobile-preview-active #preview-wrap .doc-page{width:760px!important;min-width:760px;max-width:none}
  body.mobile-editor-active .prod-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  body.mobile-editor-active .prod-toolbar .btn{width:100%}
  body.mobile-editor-active .prod-toolbar .search-box{grid-column:1/-1;width:100%}
  body.mobile-editor-active .prod-toolbar #prod-cat-filter{max-width:none;width:100%;min-height:42px}
  body.mobile-editor-active .desktop-items-table,body.mobile-editor-active .desktop-products-table{display:none!important}
  body.mobile-editor-active .mobile-items-editor,body.mobile-editor-active .mobile-products-editor{display:block}
  .mobile-empty-card,.mobile-edit-card,.mobile-product-card{background:#fff;border:1px solid #dce5da;border-radius:10px;padding:12px;margin-bottom:12px;box-shadow:0 8px 22px rgba(16,24,40,.05)}
  .mobile-empty-card{display:grid;gap:8px;color:#667085}
  .mobile-empty-card strong{font-size:16px;color:#101828}
  .mobile-edit-card-head,.mobile-product-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
  .mobile-edit-card-head span,.mobile-product-head span{font-size:13px;color:#667085;font-weight:800}
  .mobile-edit-card-head b,.mobile-product-head b{font-size:17px;color:#087f5b}
  .mobile-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .mobile-edit-grid label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:850;color:#667085;min-width:0}
  .mobile-edit-grid label.wide{grid-column:1/-1}
  .mobile-edit-grid input,.mobile-edit-grid select{width:100%;height:42px;border:1px solid #dce5da;border-radius:8px;background:#fff;color:#101828;font-family:inherit;font-size:16px;padding:0 10px;outline:none}
  .mobile-edit-grid input:focus,.mobile-edit-grid select:focus{border-color:#087f5b;box-shadow:0 0 0 3px rgba(8,127,91,.10)}
  .mobile-edit-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:11px}
  .mobile-edit-actions button,.mobile-add-row-btn{min-height:42px;border:1px solid #087f5b;border-radius:8px;background:#fff;color:#087f5b;font-family:inherit;font-size:14px;font-weight:850;display:flex;align-items:center;justify-content:center;gap:7px}
  .mobile-edit-actions button.danger{border-color:#fca5a5;color:#dc2626;background:#fff7f7}
  .mobile-add-row-btn{width:100%;background:#087f5b;color:#fff}
  .mobile-product-main{display:grid;grid-template-columns:72px minmax(0,1fr);gap:10px;align-items:start;margin-bottom:10px}
  .mobile-product-photo img,.mobile-product-photo-empty{width:72px;height:72px;border-radius:9px;border:1px solid #dce5da;background:#f8faf7;object-fit:cover;display:flex;align-items:center;justify-content:center;color:#98a2b3;font-size:20px}
  .mobile-check{display:flex!important;flex-direction:row!important;align-items:center!important;gap:7px!important;color:#087f5b!important;font-size:13px!important}
  .mobile-check input{width:18px!important;height:18px!important;accent-color:#087f5b}
  .mobile-product-card.selected{border-color:#087f5b;box-shadow:0 0 0 3px rgba(8,127,91,.10)}
}

@media(max-width:420px){
  .mobile-app-shell{padding-left:10px;padding-right:10px}
  .mobile-appbar{margin-left:-10px;margin-right:-10px}
  .mobile-title strong{font-size:21px}
  .mobile-bottom-sheet{left:10px;right:10px;grid-template-columns:minmax(0,1fr) 88px 94px;padding-left:12px;padding-right:12px}
  .mobile-save-btn,.mobile-export-btn{font-size:14px}
  .mobile-step-actions{grid-template-columns:1fr}
  .mobile-link-action{min-height:38px;justify-content:center}
  .mobile-step-head{grid-template-columns:42px minmax(0,1fr);align-items:start}
  .mobile-chip,.mobile-edit-link,.mobile-doc-state{grid-column:2;justify-self:start}
  .mobile-generate-card{grid-template-columns:1fr}
  .mobile-generate-btn{width:100%}
  .mobile-form-grid{gap:11px 12px}
  .mobile-preview-doc{transform:scale(.40)}
}
