:root{--bg:#f5f3ef;--card:#fff;--ink:#171717;--muted:#666;--line:#dedbd4;--accent:#111}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif}a{color:inherit}.top{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}.brand{font-weight:800;text-decoration:none}.top nav{display:flex;gap:16px}.foot{padding:24px;text-align:center;color:var(--muted)}main{padding:24px}.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:0 10px 25px rgba(0,0,0,.04)}.narrow{max-width:520px;margin:32px auto}.legal{max-width:900px;margin:auto;line-height:1.6}.between{display:flex;gap:12px;align-items:center;justify-content:space-between}button,.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 18px;border-radius:12px;border:1px solid var(--accent);background:var(--accent);color:#fff;text-decoration:none;font-weight:700;cursor:pointer}.secondary{background:#fff;color:#111;border-color:#ccc}button:disabled{opacity:.6}input{width:100%;min-height:44px;border:1px solid #ccc;border-radius:12px;padding:8px 12px;background:#fff}label{display:block;font-weight:650;margin:12px 0 6px}.cols,.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}table{width:100%;border-collapse:collapse;margin-top:16px}td,th{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}.badge{display:inline-block;background:#eee;border-radius:20px;padding:4px 10px}.signwrap{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:24px;align-items:start}.preview{position:sticky;top:88px}.paper{background:#fff;min-height:760px;border-radius:20px;border:1px solid var(--line);padding:42px;box-shadow:0 12px 30px rgba(0,0,0,.05);line-height:1.55}.muted,.small{color:var(--muted);font-size:.92rem}.formpanel{background:#fff;border:1px solid var(--line);border-radius:20px;padding:20px;box-shadow:0 10px 25px rgba(0,0,0,.04)}.confirm{border:1px solid var(--line);border-radius:14px;padding:10px;margin:14px 0}.confirm label{display:flex;gap:10px;font-weight:500}.confirm input{width:auto;min-height:auto;margin-top:4px}.annex{display:flex;gap:10px;flex-wrap:wrap}.sigpad{width:100%;height:220px;border:2px dashed #aaa;border-radius:14px;background:#fff;touch-action:none}.sig-preview{display:block;max-width:260px;min-height:80px;border-bottom:1px solid #222}.full{width:100%;margin-top:14px}.pdfbox{margin-top:14px}.cookie{position:fixed;left:16px;right:16px;bottom:16px;background:#111;color:#fff;padding:14px;border-radius:16px;display:flex;gap:14px;align-items:center;z-index:20;box-shadow:0 10px 30px rgba(0,0,0,.25)}.cookie p{margin:0;flex:1}.cookie a{color:#fff}code{word-break:break-all}@media(max-width:900px){main{padding:12px}.top{padding:0 14px}.top nav{font-size:.9rem}.signwrap{grid-template-columns:1fr}.preview{position:static;order:2}.formpanel{order:1}.paper{padding:22px;min-height:auto}.cols,.grid2{grid-template-columns:1fr}.cookie{display:block}.cookie button{margin:10px 10px 0 0;width:auto}.between{align-items:stretch;flex-direction:column}table{font-size:.86rem;display:block;overflow-x:auto}.sigpad{height:240px}}
.contract-frame{width:100%;height:520px;border:1px solid #e5e7eb;border-radius:12px;margin-top:12px;background:#fff}.pdfbox{margin-top:16px}@media(max-width:900px){.contract-frame{height:420px}}
.privacy-note{background:#f8fafc;border:1px solid #dbe3ea;border-radius:14px;padding:12px 14px;margin:14px 0;line-height:1.45;font-size:.92rem}.success{max-width:1100px;margin:24px auto}.success-actions{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}.final-pdf-frame{width:100%;height:720px;border:1px solid var(--line);border-radius:16px;background:#fff;margin:12px 0 20px}.email-copy-box{background:#fafafa;border:1px solid var(--line);border-radius:16px;padding:18px;margin:18px 0}.email-copy-box h2{margin-top:0}@media(max-width:900px){.final-pdf-frame{height:520px}.success-actions .btn{width:100%}}
.admin-create-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0 24px}.mini-create{border:1px solid var(--line);border-radius:16px;padding:16px;background:#fafafa}.mini-create h2{margin-top:0}.mini-create button{margin-top:10px}@media(max-width:900px){.admin-create-grid{grid-template-columns:1fr}}

.badge.status-completed{background:#dcfce7;color:#166534;border:1px solid #86efac}.badge.status-processing{background:#fef9c3;color:#854d0e;border:1px solid #fde68a}.badge.status-pdf_error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.badge.status-open{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}
.success-top{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px;align-items:start;margin:18px 0}.success-top .email-copy-box{margin:0}@media(max-width:900px){.success-top{grid-template-columns:1fr}}

/* V11 admin status/roles */
.status-row-completed{background:#f0fdf4}.status-row-completed td{border-bottom-color:#bbf7d0}.status-cell-completed{font-weight:800}.badge.status-completed{background:#16a34a!important;color:#fff!important;border:1px solid #15803d!important;box-shadow:0 0 0 3px rgba(22,163,74,.12)}.badge.status-open{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}.badge.status-processing{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.badge.status-pdf_error{background:#dc2626!important;color:#fff!important;border:1px solid #991b1b!important}.badge.role-main_admin{background:#111;color:#fff}.badge.role-sub_admin{background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd}.badge.role-moderator{background:#e0f2fe;color:#075985;border:1px solid #7dd3fc}.admin-mini{color:#666;font-size:.86rem;align-self:center}select{width:100%;min-height:44px;border:1px solid #ccc;border-radius:12px;padding:8px 12px;background:#fff}

/* V13 branding, landing, clearer completed status */
.brand-logo{display:flex;align-items:center;gap:10px;font-weight:800;text-decoration:none;min-width:0}.brand-logo img{height:42px;width:auto;max-width:170px;object-fit:contain;display:block}.brand-logo span{font-size:.95rem;white-space:nowrap;color:#222}.admin-nav-btn{font-weight:800;border:1px solid #111;border-radius:999px;padding:7px 13px;text-decoration:none}.landing{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:32px 16px}.landing-card{max-width:680px;width:100%;text-align:center;background:#fff;border:1px solid var(--line);border-radius:28px;padding:42px 28px;box-shadow:0 18px 45px rgba(0,0,0,.08)}.landing-logo{max-width:min(560px,92vw);width:100%;height:auto;display:block;margin:0 auto 14px}.landing-mail{font-size:1.25rem;font-weight:800;margin:12px 0 6px}.signed-dot{display:inline-block;width:16px;height:16px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 5px rgba(22,163,74,.16);vertical-align:middle;margin-right:8px}.signed-dot.small-dot{width:12px;height:12px;box-shadow:0 0 0 4px rgba(22,163,74,.16);margin-right:7px}.signed-banner{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#dcfce7,#f0fdf4);border:2px solid #22c55e;border-radius:18px;padding:16px 18px;margin:14px 0 18px;color:#14532d;box-shadow:0 12px 24px rgba(22,163,74,.10)}.signed-banner .signed-dot{width:22px;height:22px;margin-right:0;flex:0 0 auto}.status-row-completed{background:#dcfce7!important;outline:2px solid rgba(22,163,74,.28)}.status-row-completed:hover{background:#bbf7d0!important}.status-cell-completed{font-weight:900;color:#14532d}.badge.status-completed{background:#15803d!important;color:#fff!important;border:1px solid #166534!important;text-transform:uppercase;letter-spacing:.04em;font-weight:900}.card:has(.signed-banner){border-color:#86efac}
@media(max-width:900px){.top{height:auto;min-height:64px;gap:10px;align-items:flex-start;padding:10px 14px}.brand-logo img{height:38px;max-width:120px}.brand-logo span{display:none}.top nav{flex-wrap:wrap;justify-content:flex-end;gap:8px}.landing-card{padding:26px 18px;border-radius:22px}.landing-mail{font-size:1.05rem}.signed-banner{align-items:flex-start}.signed-banner .signed-dot{margin-top:4px}}


/* V14 logo sizing fix: prevent oversized logo on every screen */
.top{min-height:58px;height:auto;padding-top:8px;padding-bottom:8px}
.brand-logo{flex:0 1 auto;max-width:220px;overflow:hidden}
.brand-logo img{height:auto!important;max-height:34px!important;width:auto!important;max-width:145px!important;object-fit:contain!important}
.brand-logo span{font-size:.82rem!important}
.landing{min-height:calc(100vh - 150px);padding:28px 14px}
.landing-card{max-width:520px!important;padding:34px 22px!important}
.landing-logo{width:auto!important;height:auto!important;max-width:min(340px,82vw)!important;max-height:210px!important;object-fit:contain!important;margin:0 auto 16px!important}
@media(max-width:900px){
  .top{min-height:54px;padding:8px 10px;align-items:center}
  .brand-logo{max-width:150px}
  .brand-logo img{max-height:28px!important;max-width:96px!important}
  .landing-card{max-width:360px!important;padding:24px 16px!important}
  .landing-logo{max-width:min(250px,78vw)!important;max-height:155px!important}
}
@media(max-width:480px){
  .top nav{font-size:.78rem;gap:6px}
  .admin-nav-btn{padding:6px 10px}
  .landing-logo{max-width:min(220px,74vw)!important;max-height:135px!important}
  .landing-mail{font-size:.96rem!important}
}

/* V15 visual polish for admin custom contract creation */
.custom-create-card{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#ffffff 0%,#fbfaf7 100%)!important;
  border:1px solid #e6ddc8!important;
  box-shadow:0 18px 42px rgba(92,69,24,.08)!important;
}
.custom-create-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:4px;
  background:linear-gradient(90deg,#d7a847,#111,#d7a847);
}
.create-head{margin-bottom:14px}.create-kicker{display:inline-flex;align-items:center;min-height:24px;padding:3px 10px;border-radius:999px;background:#111;color:#f7d98a;font-size:.74rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}.create-head h2{margin:4px 0 6px}.field-card{display:block;background:#fff;border:1px solid #e5e0d5;border-radius:16px;padding:12px 14px;margin:12px 0;box-shadow:0 8px 18px rgba(0,0,0,.025)}.field-card>span{display:block;font-weight:800;margin-bottom:7px}.field-card input,.field-card textarea{margin-top:6px;border-color:#ddd7ca;background:#fffdf8}.field-card textarea{width:100%;min-height:150px;border:1px solid #ddd7ca;border-radius:14px;padding:12px 13px;font:inherit;resize:vertical;line-height:1.45}.field-card small{display:block;margin-top:8px;color:#777;font-weight:500;line-height:1.35}.modern-upload input[type="file"]{padding:11px;background:#fafafa;border-style:dashed}.modern-upload input[type="file"]::file-selector-button{border:0;border-radius:10px;background:#111;color:#fff;font-weight:800;padding:9px 12px;margin-right:12px;cursor:pointer}.custom-create-card button{box-shadow:0 12px 20px rgba(0,0,0,.10)}
@media(max-width:900px){.field-card textarea{min-height:130px}.custom-create-card{border-radius:18px}}

/* V18 admin search/filter/pagination + mobile cards + double-signing */
.admin-filter{display:grid;grid-template-columns:2fr 1fr 1fr auto auto;gap:12px;align-items:end;margin:20px 0;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fffdf9}.admin-filter label{margin:0}.pagination{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.pagination a{min-width:38px;min-height:38px;border:1px solid var(--line);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:#fff}.pagination a.active{background:#111;color:#fff;border-color:#111}.badge.status-expired{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.status-row-expired{background:#f9fafb;color:#6b7280}.badge.status-company_signed{background:#065f46;color:#fff;border:1px solid #064e3b;text-transform:uppercase;font-weight:900;letter-spacing:.04em}.nested-card{margin:22px 0;background:#fcfffd;border-color:#bbf7d0}.admin-sigpad{height:190px;background:#fff}.status-cell .badge{margin:2px 4px 2px 0}.admin-table td[data-label="Status"]{min-width:160px}@media(max-width:760px){.admin-filter{grid-template-columns:1fr}.admin-filter .btn,.admin-filter button{width:100%}.admin-table{display:block;border-collapse:separate}.admin-table thead,.admin-table tbody{display:block}.admin-table tr:first-child{display:none}.admin-table tr{display:block;margin:14px 0;padding:14px;border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:0 8px 20px rgba(0,0,0,.035)}.admin-table tr.status-row-completed{background:#f0fdf4!important;border-color:#86efac}.admin-table tr.status-row-expired{background:#f9fafb}.admin-table td{display:flex;justify-content:space-between;gap:14px;border:0;border-bottom:1px solid #eee;padding:9px 0;text-align:right}.admin-table td:last-child{border-bottom:0}.admin-table td:before{content:attr(data-label);font-weight:800;color:#555;text-align:left}.admin-table td code{max-width:60%;text-align:right;white-space:normal}.admin-title{align-items:flex-start}.admin-title h1{margin-top:0}.admin-sigpad{height:220px}.nested-card{padding:16px}}

/* V23 refinements */
.danger-zone{border:1px solid #f1b8b8;background:#fffafa}
.danger-zone h2{color:#9f1d1d}
button.danger,.btn.danger{background:#b42318;color:#fff;border-color:#b42318}
button.danger:hover,.btn.danger:hover{background:#8f1a13}
.optional-pdf-details{margin:10px 0;padding:12px;border:1px dashed #d8c99a;border-radius:14px;background:#fffdf6}
.optional-pdf-details summary{cursor:pointer;font-weight:700;color:#6c5319}
.custom-create-card textarea{min-height:210px;font-family:inherit;line-height:1.45}
/* V24 delete visibility + admin safety UI */
.btn.tiny{padding:7px 10px;font-size:12px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;min-height:auto}
.danger-zone{margin-top:24px;padding:20px;border-radius:18px;border:1px solid #fecaca;background:linear-gradient(180deg,#fff7f7,#fff)}
.danger-zone h2{margin-top:0;color:#991b1b}
.danger-summary{cursor:pointer;font-weight:800;color:#991b1b;padding:10px 0}
.delete-form{background:#fff;border:1px solid #fee2e2;border-radius:14px;padding:14px;margin-top:10px}
.checkline{display:flex;gap:10px;align-items:flex-start;font-weight:700}
@media(max-width:760px){.btn.tiny{width:100%;margin-top:8px}.danger-zone{padding:16px}}
