:root{
  --bg:#eef6fb; --panel:#fff; --ink:#101828; --muted:#667085; --line:#dbe6f0;
  --navy:#07111f; --blue:#0ea5e9; --deep:#0369a1; --mint:#31d0aa; --shadow:0 24px 70px rgba(16,24,40,.12);
  --max:1320px; --r:28px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,"Noto Sans KR",system-ui,sans-serif;background:radial-gradient(circle at 0 0,rgba(14,165,233,.10),transparent 28%),radial-gradient(circle at 100% 0,rgba(49,208,170,.09),transparent 22%),var(--bg);color:var(--ink)}
button,input,select,textarea{font:inherit} button{cursor:pointer} .hidden{display:none!important}
.app-shell{max-width:var(--max);min-height:100vh;margin:0 auto;padding:28px 22px 46px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px}.brand{display:flex;align-items:center;gap:12px;background:transparent;border:0;color:var(--ink);text-align:left}.brand-mark{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue),var(--mint));color:white;font-weight:900}.brand b{display:block;font-size:21px}.brand small{display:block;color:var(--muted);font-size:13px}.top-actions{display:flex;gap:10px;flex-wrap:wrap}.page{display:none}.page.active{display:block}
.btn{border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--ink);font-weight:800;padding:12px 18px;box-shadow:0 10px 26px rgba(16,24,40,.08)}.btn.primary{border:0;background:linear-gradient(135deg,var(--blue),var(--deep));color:white}.btn.white{border:0;background:#fff;color:var(--ink)}.btn.ghost{background:rgba(255,255,255,.65)}.btn.secondary{background:#f8fbff}.btn.big{padding:15px 24px}.btn.small{padding:9px 14px;font-size:14px}.quick-actions{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
.hero{background:linear-gradient(135deg,#07111f,#111c2c);color:white;border-radius:36px;padding:44px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:center;min-height:420px}.hero h1{font-size:clamp(38px,4vw,58px);line-height:1.08;letter-spacing:-.04em;margin:18px 0}.hero p{font-size:18px;line-height:1.8;color:#d6e4f2;max-width:740px}.eyebrow{display:inline-flex;align-items:center;gap:8px;border-radius:999px;background:rgba(255,255,255,.08);padding:8px 14px;font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:#bfefff}.eyebrow:before{content:"";width:8px;height:8px;border-radius:99px;background:var(--mint)}.status-panel{border:1px solid rgba(255,255,255,.16);border-radius:26px;background:rgba(255,255,255,.08);padding:24px}.status-panel h3{margin:0 0 12px}.status-panel ol{margin:0;padding-left:22px;color:#d6e4f2;line-height:2}
.card-grid,.grid{display:grid;gap:20px;margin-top:24px}.three{grid-template-columns:repeat(3,1fr)}.two{grid-template-columns:1fr 1fr}.card{background:white;border:1px solid var(--line);border-radius:28px;padding:26px;box-shadow:0 18px 50px rgba(16,24,40,.08)}.card h3{margin:0 0 10px;font-size:23px}.card p{color:var(--muted);line-height:1.7}.muted{color:var(--muted)}.page-title-row{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:8px 0 18px}.page-title-row h2{font-size:36px;margin:0;letter-spacing:-.03em}.page-title-row p{margin:8px 0 0;color:var(--muted)}
.label{display:block;font-weight:800;color:#475467;margin:14px 0 7px}.input{width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;min-height:52px;padding:0 14px}.input.file{padding:13px}.link-area{min-height:100px;padding:14px;resize:vertical}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wide{grid-column:1/-1}.template-box{border:1px solid #cfe2ff;background:#f0f7ff;border-radius:18px;padding:16px;margin:18px 0}.template-box b,.template-box span{display:block}.template-box span{color:var(--muted);margin-top:4px}.mapping-list{display:flex;gap:10px;flex-wrap:wrap}.mapping-list span{border:1px solid #cfe2ff;background:#f6fbff;border-radius:999px;padding:10px 14px;font-weight:800;color:#1d4ed8}.hint{border:1px solid #cfe2ff;background:#f0f7ff;color:#1d4ed8;border-radius:16px;padding:12px 14px;line-height:1.6}.card-head.compact{display:flex;justify-content:space-between;align-items:center;gap:12px}.card-head.compact h3{margin:0}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}.items-table{width:100%;border-collapse:collapse;min-width:720px}.items-table th,.items-table td{border-bottom:1px solid var(--line);padding:10px}.items-table th{background:#f8fbff;text-align:left;color:#475467}.items-table input{width:100%;height:42px;border:1px solid var(--line);border-radius:12px;padding:0 10px}.bottom-bar{position:sticky;bottom:0;background:rgba(238,246,251,.86);backdrop-filter:blur(8px);border-top:1px solid var(--line);padding:16px 0;margin-top:24px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.preview-card{padding:12px} iframe{width:100%;height:74vh;border:0;border-radius:20px;background:#e9eef5}.sign-pad{width:100%;height:220px;border:2px dashed #cbd5e1;border-radius:18px;background:#fff;touch-action:none}.sign-actions{display:flex;gap:10px;margin:12px 0 20px;flex-wrap:wrap}hr{border:0;border-top:1px solid var(--line);margin:22px 0}.status-list{display:grid;gap:12px;margin-bottom:18px}.status-list div{display:flex;justify-content:space-between;border:1px solid var(--line);border-radius:16px;padding:14px;background:#f9fbfd}.ok{color:#15803d;font-weight:900}.warn{color:#b45309;font-weight:900}
@media(max-width:900px){.app-shell{padding:18px 14px}.topbar{align-items:flex-start}.top-actions{justify-content:flex-end}.hero{grid-template-columns:1fr;padding:28px;min-height:auto}.status-panel{display:none}.three,.two,.form-grid{grid-template-columns:1fr}.page-title-row{align-items:flex-start;flex-direction:column}.page-title-row h2{font-size:28px}.card{padding:20px;border-radius:22px}.hero h1{font-size:34px}.hero p{font-size:16px}iframe{height:58vh}.bottom-bar{justify-content:stretch}.bottom-bar .btn,.quick-actions .btn{width:100%}}
@media(max-width:520px){.brand b{font-size:18px}.brand small{font-size:12px}.brand-mark{width:38px;height:38px}.topbar{flex-direction:column}.top-actions{width:100%}.top-actions .btn{flex:1}.hero h1{font-size:30px}.sign-pad{height:180px}.items-table{min-width:640px}}
.row-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.hint.slim{margin:10px 0 0;padding:9px 12px}.summary-box{border:1px solid #cfe2ff;background:#f6fbff;border-radius:20px;padding:16px;margin:14px 0 18px}.summary-box b{display:block;font-size:20px;margin-bottom:12px;color:#0f172a}.summary-box dl{display:grid;grid-template-columns:90px 1fr;gap:8px 12px;margin:0}.summary-box dt{font-weight:900;color:#475467}.summary-box dd{margin:0;color:#101828;font-weight:700}.link-area{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;line-height:1.55}.input[readonly]{background:#f8fbff}.status-list b:not(.ok):not(.warn){color:#111827}.mapper-card{margin-top:20px}@media(max-width:900px){.row-actions{width:100%;justify-content:stretch}.row-actions .btn{flex:1}.summary-box dl{grid-template-columns:1fr}.summary-box dt{margin-top:8px}}

/* 0935 dashboard/process refinements */
.dashboard-hero{background:linear-gradient(135deg,#07111f,#0f2740);color:white;border-radius:36px;padding:34px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}.dashboard-hero h1{font-size:clamp(34px,3.6vw,52px);line-height:1.08;letter-spacing:-.04em;margin:12px 0}.dashboard-hero p{font-size:17px;line-height:1.75;color:#d6e4f2;max-width:760px}.eyebrow.dark{background:rgba(255,255,255,.1)}.dashboard-actions{justify-content:flex-end;margin-top:0}.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:20px 0}.dash-stat{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 14px 38px rgba(16,24,40,.06)}.dash-stat span{display:block;color:var(--muted);font-weight:800;font-size:13px}.dash-stat b{display:block;font-size:30px;margin-top:6px;letter-spacing:-.03em}.share-panel{margin-top:20px;border-color:#b6dbff;background:linear-gradient(180deg,#fff,#f6fbff)}.dashboard-title{margin-top:28px}.dashboard-list{display:grid;gap:14px}.contract-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:0 14px 38px rgba(16,24,40,.06);display:grid;grid-template-columns:1.2fr .8fr;gap:16px;align-items:center}.contract-card.highlight{border-color:#38bdf8;box-shadow:0 18px 44px rgba(14,165,233,.18)}.contract-card h3{margin:0 0 8px;font-size:22px}.contract-meta{display:flex;gap:8px;flex-wrap:wrap;color:#475467}.contract-meta span{border:1px solid var(--line);background:#f8fbff;border-radius:999px;padding:7px 10px;font-weight:800;font-size:13px}.status-badge{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:8px 12px;font-weight:900;font-size:13px}.status-badge:before{content:"";width:9px;height:9px;border-radius:99px;background:currentColor}.status-wait{color:#b45309;background:#fff7ed}.status-view{color:#0369a1;background:#e0f2fe}.status-signed{color:#15803d;background:#dcfce7}.status-final{color:#4c1d95;background:#ede9fe}.contract-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.empty-dashboard{border:1px dashed #bcd3e8;background:rgba(255,255,255,.72);border-radius:24px;padding:30px;text-align:center;color:#475467}.empty-dashboard h3{margin:0 0 8px;color:#101828}.toast{position:fixed;right:22px;bottom:22px;z-index:99;max-width:420px;background:#07111f;color:white;border-radius:18px;padding:16px 18px;box-shadow:0 18px 54px rgba(16,24,40,.32);font-weight:800;line-height:1.55}.client-shell-note{border:1px solid #cfe2ff;background:#f6fbff;border-radius:18px;padding:14px;margin:0 0 16px;color:#1d4ed8;font-weight:800;line-height:1.6}
@media(max-width:900px){.dashboard-hero,.contract-card{grid-template-columns:1fr}.dashboard-actions,.contract-actions{justify-content:stretch}.dashboard-actions .btn,.contract-actions .btn{flex:1}.dash-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.dash-stats{grid-template-columns:1fr}.dashboard-hero{padding:24px;border-radius:26px}.contract-card{padding:16px}.contract-actions .btn{width:100%}.toast{left:14px;right:14px;bottom:14px}}

/* 0936 mobile PDF / final delivery refinements */
.pdf-tools{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 14px}.pdf-tools a{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.client-text-preview{border:1px solid #dbeafe;background:#fff;border-radius:18px;padding:16px;margin:12px 0 14px}.client-text-preview h4{margin:0 0 12px;font-size:18px}.client-text-preview dl{display:grid;grid-template-columns:128px 1fr;gap:8px 12px;margin:0 0 12px}.client-text-preview dt{font-weight:900;color:#475467}.client-text-preview dd{margin:0;font-weight:700;color:#111827;word-break:break-word}.items-table.mini{min-width:620px;font-size:14px}.table-wrap.mini{margin-top:8px}.mobile-pdf-hint{border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:14px;padding:10px 12px;margin:12px 0 0;font-weight:800;line-height:1.55}.wait-card{max-width:920px;margin:0 auto}.wait-card h3{font-size:28px;margin:16px 0 8px}.wait-message{border:1px solid #cfe2ff;background:#f6fbff;color:#1d4ed8;border-radius:18px;padding:16px;font-weight:900;line-height:1.7}.final-ready{border:1px solid #bbf7d0;background:#f0fdf4;border-radius:22px;padding:18px;margin-top:18px}.final-ready h3{margin-top:0}.final-ready iframe{margin-top:12px;height:70vh}.final-note{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;border-radius:16px;padding:14px 16px;font-weight:900;line-height:1.6;margin:0 0 16px}.contract-card .final-note{margin-top:12px;margin-bottom:0}
@media(max-width:900px){.pdf-tools .btn{flex:1}.client-text-preview dl{grid-template-columns:1fr}.client-text-preview dt{margin-top:6px}.final-ready iframe{height:58vh}}
@media(max-width:520px){.pdf-tools .btn{width:100%}.client-text-preview{padding:14px}.wait-card h3{font-size:23px}}

/* 0937 mobile PDF canvas / Drive delivery refinements */
.delivery-settings-panel{margin-top:20px;border-color:#b7e4cf;background:linear-gradient(180deg,#fff,#f4fff8)}.setting-actions{display:flex;gap:10px;flex-wrap:wrap}.saved-folder-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.saved-folder-list span{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;border-radius:999px;padding:8px 12px;font-weight:900;font-size:13px}.pdf-canvas-viewer{border:1px solid var(--line);border-radius:20px;background:#f8fafc;padding:12px;margin:12px 0;min-height:180px;display:grid;gap:14px;place-items:center}.pdf-canvas-viewer canvas{width:100%;height:auto;max-width:100%;border-radius:14px;background:#fff;box-shadow:0 10px 26px rgba(16,24,40,.12)}.pdf-canvas-viewer p{margin:0;color:#475467;font-weight:800;line-height:1.6;text-align:center}.pdf-render-fallback{border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:14px;padding:12px 14px;font-weight:900;line-height:1.6}.native-pdf-frame{margin-top:10px}.final-message-box{border:1px solid #bbf7d0;background:#f0fdf4;border-radius:20px;padding:18px;margin:0 0 18px}.final-message-box h3{margin-top:0}.final-message-box .btn{margin:8px 0 12px}.drive-path-pill{display:inline-flex;align-items:center;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:7px 10px;font-weight:900;font-size:13px;margin:4px 4px 0 0}
@media(max-width:900px){.setting-actions .btn{flex:1}.native-pdf-frame#clientPreviewFrame,.native-pdf-frame#clientWaitFinalFrame{display:none}.pdf-canvas-viewer{min-height:260px;padding:10px}.delivery-settings-panel .form-grid{grid-template-columns:1fr}}
@media(max-width:520px){.setting-actions .btn{width:100%}.pdf-canvas-viewer{border-radius:16px;padding:8px}.final-message-box{padding:14px}}
.hidden-native-pdf{display:none!important}.delivery-settings-panel.embedded{margin:18px 0;border-color:#b7e4cf;background:linear-gradient(180deg,#fff,#f4fff8);border-radius:20px;padding:18px}.delivery-settings-panel.embedded.hidden{display:none!important}

/* 0939 productization / tenant-ready refinements */
:root{--tenant-blue:var(--blue);--tenant-deep:var(--deep);--tenant-mint:var(--mint)}
body{background:radial-gradient(circle at 0 0,color-mix(in srgb,var(--blue) 14%,transparent),transparent 28%),radial-gradient(circle at 100% 0,color-mix(in srgb,var(--mint) 12%,transparent),transparent 22%),var(--bg)}
.topbar{position:sticky;top:12px;z-index:30;background:rgba(238,246,251,.72);backdrop-filter:blur(18px);border:1px solid rgba(219,230,240,.75);border-radius:28px;padding:12px 14px;box-shadow:0 18px 50px rgba(16,24,40,.08)}
.brand-mark{overflow:hidden;background:linear-gradient(135deg,var(--blue),var(--mint));font-size:14px}.brand-mark img{width:100%;height:100%;object-fit:cover;border-radius:16px}.top-actions .btn{box-shadow:none}.top-actions .btn.primary{box-shadow:0 12px 28px color-mix(in srgb,var(--blue) 22%,transparent)}
.product-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#07111f 0%,color-mix(in srgb,var(--deep) 42%,#07111f) 54%,#102033 100%)}
.product-hero:after{content:"";position:absolute;inset:-40% -20% auto auto;width:520px;height:520px;border-radius:999px;background:radial-gradient(circle,color-mix(in srgb,var(--blue) 42%,transparent),transparent 65%);opacity:.75;pointer-events:none}.product-hero>*{position:relative;z-index:1}.hero-proof-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.hero-proof-row span{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#e7f8ff;border-radius:999px;padding:9px 12px;font-weight:900;font-size:13px}
.eyebrow.light{background:#eef8ff;color:#0369a1;margin-bottom:14px}.eyebrow.light:before{background:var(--blue)}.settings-grid{align-items:start}.color-input{height:52px;padding:8px}.tenant-preview-card{background:linear-gradient(180deg,#fff,#f7fbff)}.tenant-phone-preview{border:1px solid #dbeafe;border-radius:30px;background:linear-gradient(180deg,#fff,#eef7ff);padding:22px;box-shadow:inset 0 0 0 8px rgba(255,255,255,.5),0 24px 70px rgba(16,24,40,.14);max-width:420px;margin:10px auto 22px}.tenant-phone-top{display:flex;align-items:center;gap:10px;margin-bottom:22px}.tenant-phone-top span{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue),var(--mint));color:white;font-weight:900;overflow:hidden}.tenant-phone-top span img{width:100%;height:100%;object-fit:cover}.tenant-phone-preview h4{font-size:28px;letter-spacing:-.04em;line-height:1.1;margin:0 0 10px}.tenant-phone-preview p{margin:0 0 18px}.tenant-preview-cardline{border:1px solid #dbeafe;background:#fff;border-radius:18px;padding:14px;margin:14px 0}.tenant-preview-cardline span{display:block;color:#667085;font-weight:800;font-size:13px}.tenant-preview-cardline b{display:block;margin-top:4px}.product-actions{margin-top:16px}.ops-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}.ops-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:0 18px 48px rgba(16,24,40,.07)}.ops-card b{display:grid;place-items:center;width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,var(--blue),var(--deep));color:white;margin-bottom:16px}.ops-card h3{font-size:22px;margin:0 0 8px}.ops-card p{color:var(--muted);line-height:1.7;margin:0}.product-roadmap{margin-top:20px}.roadmap-list{display:flex;flex-wrap:wrap;gap:10px}.roadmap-list span{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;border-radius:999px;padding:10px 14px;font-weight:900}.client-brand-strip{border:1px solid #dbeafe;background:linear-gradient(135deg,#fff,#f3fbff);border-radius:22px;padding:16px;margin:0 0 16px;display:flex;gap:12px;align-items:center}.client-brand-strip .brand-mark{flex:0 0 auto}.pwa-install-note{border:1px solid #c7d2fe;background:#eef2ff;color:#3730a3;border-radius:18px;padding:13px 15px;font-weight:900;line-height:1.55;margin-top:14px}
@media(max-width:1100px){.ops-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.topbar{top:8px;border-radius:22px}.top-actions{width:100%;display:grid;grid-template-columns:repeat(3,1fr)}.top-actions .btn{padding:11px 10px;font-size:14px}.product-hero{border-radius:28px}.ops-grid{grid-template-columns:1fr}.tenant-phone-preview{max-width:none}.hero-proof-row span{font-size:12px}.settings-grid{grid-template-columns:1fr}}
@media(max-width:520px){.top-actions{grid-template-columns:repeat(2,1fr)}.tenant-phone-preview{padding:18px;border-radius:24px}.tenant-phone-preview h4{font-size:24px}.ops-card{padding:20px;border-radius:22px}.hero-proof-row span{width:100%;text-align:center}.product-actions .btn{width:100%}}

/* AXWorks portal-modern-1: visual refresh only. Existing IDs, routes, storage and signing logic are untouched. */
:root{--bg:#f7fafc;--panel:#fff;--ink:#0a1830;--muted:#637188;--line:#e3eaf3;--navy:#061a35;--blue:#1f64d6;--deep:#062d64;--mint:#2fb892;--shadow:0 24px 70px rgba(10,24,48,.12);--r:30px;--max:1440px}
body{background:radial-gradient(circle at 0 0,rgba(31,100,214,.08),transparent 28%),radial-gradient(circle at 100% 0,rgba(47,184,146,.08),transparent 24%),#f7fafc;color:var(--ink);letter-spacing:-.025em}
.app-shell{max-width:var(--max);padding:24px clamp(16px,4vw,64px) 56px}.topbar{position:sticky;top:12px;z-index:30;margin:0 0 26px;padding:14px 16px;border:1px solid rgba(227,234,243,.92);border-radius:24px;background:rgba(255,255,255,.9);backdrop-filter:blur(16px);box-shadow:0 18px 48px rgba(10,24,48,.08)}
.brand-mark{background:linear-gradient(135deg,#062d64,#1f64d6);box-shadow:0 12px 28px rgba(31,100,214,.25)}.brand b{font-size:22px;letter-spacing:-.04em}.brand small{color:#53657b}.top-actions{align-items:center}.top-actions .btn{min-height:42px;padding:0 15px;box-shadow:none}.portal-link{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.btn{min-height:48px;padding:0 18px;border-radius:999px;font-weight:900;box-shadow:0 12px 28px rgba(10,24,48,.08);transition:.18s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 18px 38px rgba(10,24,48,.12)}.btn.primary{background:linear-gradient(135deg,#062d64,#1f64d6)}.btn.secondary{background:#eef5ff;color:#0f3e86}.btn.ghost{background:rgba(255,255,255,.82)}.btn.big{min-height:58px;padding:0 24px;font-size:17px}.btn.white{color:#0a1830}.page-title-row h2{font-size:clamp(30px,4vw,48px);line-height:1.1;letter-spacing:-.06em}.page-title-row p{font-size:16px;line-height:1.65}
.dashboard-hero{position:relative;overflow:hidden;min-height:420px;border-radius:36px;padding:clamp(30px,5vw,56px);background:linear-gradient(90deg,rgba(6,26,53,.94) 0%,rgba(6,26,53,.78) 46%,rgba(6,26,53,.42) 100%),url('/assets/service-contract-hero-photo.png') center/cover no-repeat;box-shadow:var(--shadow);align-items:end}.dashboard-hero h1{font-size:clamp(38px,6vw,72px);line-height:1.04;letter-spacing:-.075em;max-width:820px}.dashboard-hero p{font-size:clamp(16px,1.5vw,21px);line-height:1.8;max-width:760px;color:#e4edf8}.dashboard-actions{align-self:end;justify-content:flex-start}.hero-proof-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}.hero-proof-row span{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:999px;padding:9px 12px;color:#fff;font-weight:850;font-size:13px}.eyebrow.dark{background:rgba(255,255,255,.14);color:#dbeafe;letter-spacing:.08em}
.dash-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.dash-stat,.card,.contract-card{border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.94);box-shadow:0 16px 46px rgba(10,24,48,.075)}.dash-stat{padding:22px}.dash-stat b{font-size:34px;color:#0a1830}.card{padding:clamp(20px,3vw,30px)}.card h3{font-size:clamp(21px,2vw,27px);letter-spacing:-.045em}.card p,.muted{color:#627287}.input{min-height:56px;border-radius:18px;border-color:#dfe7f1;background:#fff}.label{color:#3d5069}.hint{border-color:#d4e5ff;background:#f2f7ff;color:#1f4f96}.template-box{background:#f4f8ff;border-color:#d4e5ff}.mapping-list span{background:#eef5ff;border-color:#d4e5ff;color:#1f64d6}.form-grid{gap:14px}.table-wrap{border-radius:22px}.items-table th{background:#f7faff}.items-table td,.items-table th{padding:12px}.bottom-bar{margin-top:28px;border:1px solid var(--line);border-radius:24px;padding:14px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);box-shadow:0 18px 54px rgba(10,24,48,.10)}iframe{border-radius:24px}.sign-pad{border-radius:22px;border-color:#c8d8ea;background:#fff}.status-list div{border-radius:18px;background:#fbfdff}.delivery-settings-panel,.final-message-box,.share-panel{border-radius:28px}.client-text-preview,.summary-box,.share-doc-info{border-radius:22px}.pdf-canvas-viewer{border-radius:24px;background:#f8fbff}.toast{border-radius:20px;background:#061a35}.pwa-install-note{max-width:var(--max);margin:16px 0 0;border:1px solid #d4e5ff;border-radius:18px;background:#f2f7ff;color:#1f4f96;padding:13px 16px;font-weight:850;line-height:1.6}
@media(max-width:1050px){.dashboard-hero{grid-template-columns:1fr}.dash-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-actions{justify-content:flex-start}.topbar{top:8px}}
@media(max-width:760px){.app-shell{padding:12px 12px 44px}.topbar{border-radius:20px;align-items:flex-start;gap:12px}.top-actions{width:100%;display:flex;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}.top-actions .btn{flex:0 0 auto;min-height:40px}.brand b{font-size:19px}.brand small{font-size:12px}.brand-mark{width:38px;height:38px;border-radius:14px}.dashboard-hero{min-height:auto;display:block;padding:28px 22px;border-radius:28px;background:linear-gradient(180deg,rgba(6,26,53,.94) 0%,rgba(6,26,53,.78) 56%,rgba(6,26,53,.58) 100%),url('/assets/service-contract-hero-photo.png') center top/cover no-repeat}.dashboard-hero h1{font-size:36px;line-height:1.08}.dashboard-hero p{font-size:15.5px}.dashboard-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:24px}.dashboard-actions .btn,.bottom-bar .btn,.sign-actions .btn,.pdf-tools .btn{width:100%}.dash-stats{grid-template-columns:1fr}.page-title-row{gap:10px}.card,.contract-card{border-radius:22px;padding:18px}.form-grid,.grid.two{grid-template-columns:1fr}.bottom-bar{position:static;display:grid;grid-template-columns:1fr}.client-mode .app-shell{padding:12px}.client-mode .page-title-row h2{font-size:32px}.client-mode .card{padding:18px}.share-doc-info{grid-template-columns:1fr}.client-text-preview dl,.summary-box dl{grid-template-columns:1fr}.pdf-canvas-viewer{min-height:230px}.native-pdf-frame{display:none!important}}
@media(max-width:430px){.dashboard-hero h1{font-size:32px}.hero-proof-row span{font-size:12px}.page-title-row h2{font-size:28px}.card h3{font-size:21px}.btn.big{font-size:16px}}


/* v2 brand + viewer fixes */
html{scrollbar-gutter:stable both-edges;}
body{overflow-x:clip;}
.brand-logo-image{display:block;height:54px;width:auto;max-width:min(280px,46vw);object-fit:contain;flex:0 0 auto}
.native-pdf-frame{display:block;width:100%;min-height:76vh;height:76vh;border:1px solid var(--line);background:#fff;border-radius:24px;box-shadow:0 14px 34px rgba(16,24,40,.08)}
.pdf-canvas-viewer{align-items:start;justify-items:center}
.pdf-canvas-viewer canvas{width:100%!important;height:auto!important}
.hidden-native-pdf{display:none!important}
.top-actions .btn{justify-content:center}
.dashboard-actions,.bottom-bar,.sign-actions,.pdf-tools{align-items:center}
@media(max-width:900px){.native-pdf-frame{min-height:68vh;height:68vh}}
@media(max-width:760px){
  .brand-logo-image{height:46px;max-width:210px}
  .topbar{position:sticky;top:10px;z-index:20}
  .top-actions{scrollbar-width:none;-ms-overflow-style:none;overscroll-behavior-x:contain}
  .top-actions::-webkit-scrollbar{display:none}
  .dashboard-actions,.bottom-bar,.sign-actions,.pdf-tools{justify-content:center}
  .dashboard-actions .btn,.bottom-bar .btn,.sign-actions .btn,.pdf-tools .btn{margin-inline:auto}
  .native-pdf-frame#clientPreviewFrame,.native-pdf-frame#clientWaitFinalFrame{display:block!important;min-height:62vh;height:62vh}
}
@media(max-width:430px){.brand-logo-image{height:40px;max-width:182px}.native-pdf-frame#clientPreviewFrame,.native-pdf-frame#clientWaitFinalFrame{min-height:56vh;height:56vh}}


/* commercial v4 polish: app dashboard/forms without changing functions */
:root{
  --bg:#f3f7fb;
  --panel:#fff;
  --ink:#07162d;
  --muted:#64748b;
  --line:#dbe6f2;
  --blue:#155dd8;
  --deep:#0b3475;
  --mint:#22b58d;
  --shadow:0 28px 84px rgba(7,22,45,.12);
}
html{scrollbar-gutter:stable both-edges;scroll-behavior:auto}
body{line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:
  radial-gradient(circle at 0 0,rgba(21,93,216,.10),transparent 28%),
  radial-gradient(circle at 100% 0,rgba(34,181,141,.08),transparent 23%),
  var(--bg);overflow-x:clip}
.app-shell{max-width:1380px;padding:24px 22px 52px}
.topbar{
  position:sticky;top:14px;z-index:30;
  display:flex;align-items:center;justify-content:space-between;
  min-height:74px;margin-bottom:28px;padding:12px 14px 12px 18px;
  border:1px solid rgba(219,230,242,.9);border-radius:28px;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(16px);
  box-shadow:0 18px 54px rgba(7,22,45,.08)
}
.brand{min-width:0}
.brand-logo-image{display:block;height:54px;width:auto;max-width:min(280px,42vw);object-fit:contain;flex:0 0 auto}
.brand b{font-size:21px;letter-spacing:-.045em}
.brand small{font-weight:750;color:#50647d}
.top-actions{gap:8px;align-items:center}
.btn{
  min-height:44px;padding:0 17px;border-radius:999px;
  font-weight:900;letter-spacing:-.035em;border-color:#d9e5f1;
  box-shadow:0 10px 26px rgba(7,22,45,.075);
  display:inline-flex;align-items:center;justify-content:center;text-align:center
}
.btn.primary{background:linear-gradient(135deg,var(--deep),var(--blue))}
.btn.secondary{background:#eef6ff;color:#0b3475}
.btn.ghost{background:rgba(255,255,255,.78)}
.btn.white{background:#fff;color:#07162d}
.btn.big{min-height:56px;padding:0 24px;font-size:16px}
.dashboard-hero{
  min-height:455px;border-radius:40px;padding:clamp(32px,5vw,58px);
  box-shadow:0 34px 94px rgba(7,22,45,.16);
  border:1px solid rgba(255,255,255,.16);
  background-position:center!important;
}
.dashboard-hero:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,0));pointer-events:none}
.dashboard-hero h1{font-size:clamp(40px,5.4vw,68px);line-height:1.04;letter-spacing:-.075em;margin:16px 0 18px;max-width:830px}
.dashboard-hero p{font-size:clamp(16px,1.42vw,20px);line-height:1.82;color:#edf5ff;font-weight:650;max-width:820px}
.eyebrow.dark{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.12);color:#dcebff;letter-spacing:.11em}
.hero-proof-row{gap:9px;margin-top:24px}
.hero-proof-row span{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);box-shadow:0 10px 26px rgba(0,0,0,.08)}
.dashboard-actions{gap:11px;align-self:end;justify-content:flex-start}
.dash-stats{gap:18px;margin:24px 0}
.dash-stat,.card,.contract-card{
  border-color:#dce8f5;background:rgba(255,255,255,.94);
  box-shadow:0 18px 50px rgba(7,22,45,.075)
}
.dash-stat{border-radius:26px;padding:22px}
.dash-stat span{font-weight:900;color:#64748b}
.dash-stat b{font-size:34px;color:#07162d;letter-spacing:-.04em}
.page-title-row{margin:30px 0 18px}
.page-title-row h2{font-size:clamp(30px,3.4vw,42px);letter-spacing:-.065em}
.page-title-row p{font-weight:650;color:#66758a}
.card{border-radius:30px;padding:clamp(22px,3vw,32px)}
.card h3{font-size:clamp(22px,2vw,28px);letter-spacing:-.05em}
.card p,.muted{font-weight:600;color:#66758a}
.input{
  min-height:56px;border-radius:18px;border-color:#dbe6f2;
  color:#07162d;background:#fff;box-shadow:inset 0 1px 0 rgba(7,22,45,.02)
}
.input:focus{outline:3px solid rgba(21,93,216,.14);border-color:#9abcf6}
.label{font-weight:900;color:#354861}
.hint{border-color:#cfe0ff;background:#f3f8ff;color:#184e9f;font-weight:800}
.table-wrap{border-radius:24px;border-color:#dbe6f2}
.items-table th{background:#f6f9fd;color:#4e6078;font-weight:900}
.items-table td,.items-table th{padding:12px 11px}
.bottom-bar{
  border:1px solid rgba(219,230,242,.92);border-radius:26px;padding:14px;margin-top:28px;
  background:rgba(255,255,255,.90);backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 18px 54px rgba(7,22,45,.08);justify-content:flex-end
}
.contract-card{border-radius:28px}
.contract-card h3{letter-spacing:-.045em}
.status-badge{font-weight:950}
.client-text-preview,.summary-box,.final-message-box,.share-doc-info{border-radius:24px}
.pdf-canvas-viewer{border-radius:28px;background:#f8fbff;align-items:start;justify-items:center;overflow:hidden}
.pdf-canvas-viewer canvas{width:100%!important;height:auto!important}
.native-pdf-frame{display:block;width:100%;min-height:76vh;height:76vh;border:1px solid var(--line);background:#fff;border-radius:24px;box-shadow:0 14px 34px rgba(7,22,45,.08)}
.hidden-native-pdf{display:none!important}
.toast{border-radius:22px;background:#061a35}
@media(max-width:1050px){
  .dashboard-hero{grid-template-columns:1fr}
  .dashboard-actions{justify-content:flex-start}
}
@media(max-width:900px){
  .topbar{top:10px;align-items:flex-start}
  .top-actions{width:100%;display:flex;flex-wrap:nowrap;overflow-x:auto;padding:2px 0 4px;scrollbar-width:none;overscroll-behavior-x:contain}
  .top-actions::-webkit-scrollbar{display:none}
  .native-pdf-frame{min-height:68vh;height:68vh}
  .native-pdf-frame#clientPreviewFrame,.native-pdf-frame#clientWaitFinalFrame{display:block!important}
}
@media(max-width:760px){
  .app-shell{padding:12px 12px 44px}
  .topbar{border-radius:22px;margin-bottom:18px;padding:12px}
  .brand-logo-image{height:44px;max-width:198px}
  .brand b{font-size:18px}
  .brand small{font-size:11.5px}
  .top-actions .btn{min-height:41px;padding:0 13px;font-size:13.5px}
  .dashboard-hero{min-height:auto;display:block;border-radius:30px;padding:30px 22px}
  .dashboard-hero h1{font-size:34px;line-height:1.08;letter-spacing:-.065em}
  .dashboard-hero p{font-size:15.5px;line-height:1.72}
  .hero-proof-row span{font-size:12px;padding:8px 10px}
  .dashboard-actions,.bottom-bar,.sign-actions,.pdf-tools{display:grid;grid-template-columns:1fr;justify-content:center;gap:10px}
  .dashboard-actions .btn,.bottom-bar .btn,.sign-actions .btn,.pdf-tools .btn{width:100%;max-width:520px;margin-inline:auto}
  .dash-stats{grid-template-columns:1fr;gap:12px}
  .dash-stat{padding:18px;border-radius:22px}
  .page-title-row{display:grid;gap:12px;margin:24px 0 16px}
  .page-title-row h2{font-size:31px}
  .card,.contract-card{border-radius:24px;padding:18px}
  .form-grid,.grid.two{grid-template-columns:1fr}
  .pdf-canvas-viewer{min-height:220px;border-radius:20px}
  .native-pdf-frame#clientPreviewFrame,.native-pdf-frame#clientWaitFinalFrame{display:block!important;min-height:62vh;height:62vh}
}
@media(max-width:430px){
  .brand-logo-image{height:38px;max-width:168px}
  .top-actions .btn{font-size:13px}
  .dashboard-hero h1{font-size:30px}
  .dashboard-hero p{font-size:14.8px}
  .page-title-row h2{font-size:28px}
  .native-pdf-frame#clientPreviewFrame,.native-pdf-frame#clientWaitFinalFrame{min-height:56vh;height:56vh}
}
