:root{--zp-blue:#1268ff;--zp-blue2:#0aa7e8;--zp-navy:#07152f;--zp-text:#243654;--zp-muted:#6c7b91;--zp-line:#dbe8f7;--zp-soft:#f3f8ff;--zp-card:#fff;--zp-green:#17b568;--zp-red:#ef4444;--zp-shadow:0 24px 70px rgba(20,67,130,.12);--zp-shadow-sm:0 12px 34px rgba(20,67,130,.09);--zp-radius:28px;--zp-radius-sm:18px}*{box-sizing:border-box}html{scroll-behavior:smooth}body.zp-public-page{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--zp-navy);background:radial-gradient(circle at 8% 10%,rgba(14,165,233,.16),transparent 28%),radial-gradient(circle at 92% 0,rgba(18,104,255,.13),transparent 30%),linear-gradient(180deg,#f8fbff 0%,#fff 50%,#f7fbff 100%);min-height:100vh}.zp-page-shell{width:min(1420px,calc(100vw - 56px));margin:0 auto;padding:22px 0 46px}.zp-narrow-shell{width:min(1410px,calc(100vw - 72px))}.zp-topbar{height:72px;border:1px solid rgba(190,211,236,.75);background:rgba(255,255,255,.82);backdrop-filter:blur(18px);border-radius:22px;box-shadow:var(--zp-shadow-sm);display:flex;align-items:center;justify-content:space-between;padding:0 20px;gap:20px}.zp-simple-topbar{box-shadow:none;border:0;background:transparent;border-bottom:1px solid var(--zp-line);border-radius:0}.zp-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--zp-navy)}.zp-brand-mark{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#19b7f6,#1d47d9);display:grid;place-items:center;color:#fff;font-weight:950;font-size:22px;box-shadow:0 12px 26px rgba(18,104,255,.22)}.zp-brand strong{display:block;font-size:20px;letter-spacing:-.04em;line-height:1}.zp-brand b{color:var(--zp-blue)}.zp-brand small{display:block;color:#64748b;font-weight:700;margin-top:5px}.zp-nav{display:flex;align-items:center;gap:44px}.zp-nav a{color:#0e1a32;text-decoration:none;font-weight:800;font-size:14px;position:relative}.zp-nav a.active{color:var(--zp-blue)}.zp-nav a.active:after{content:"";position:absolute;left:50%;bottom:-23px;width:18px;height:3px;border-radius:20px;background:var(--zp-blue);transform:translateX(-50%)}.zp-top-actions{display:flex;align-items:center;gap:14px}.zp-link{font-weight:850;color:var(--zp-navy);text-decoration:none}.zp-btn{border:1px solid var(--zp-line);background:#fff;color:var(--zp-navy);height:48px;padding:0 22px;border-radius:13px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:12px;text-decoration:none;cursor:pointer;transition:.2s ease;box-shadow:0 8px 20px rgba(20,67,130,.05);font-family:inherit}.zp-btn:hover{transform:translateY(-1px);box-shadow:var(--zp-shadow-sm)}.zp-btn-primary{border:0;background:linear-gradient(135deg,#11a7e7 0%,#0f61ff 58%,#1e3aaf 100%);color:#fff;box-shadow:0 18px 36px rgba(18,104,255,.24)}.zp-btn-ghost{background:rgba(255,255,255,.78)}.zp-btn-lg{height:58px;min-width:190px}.zp-btn-block{width:100%;height:56px}.zp-hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(520px,.95fr);gap:54px;align-items:center;padding:58px 70px 34px}.zp-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid #bfdbfe;background:rgba(255,255,255,.7);border-radius:999px;color:#1d4ed8;font-weight:900;font-size:13px}.zp-hero-copy h1,.zp-modules-layout h1,.zp-form-card h1,.zp-otp-card h1,.zp-welcome-title h1,.zp-login-copy h1{font-size:56px;line-height:1.04;letter-spacing:-.065em;margin:24px 0 20px;color:#07142c}.zp-hero-copy h1 span,.zp-register-visual h1 span,.zp-otp-visual h1 span,.zp-login-copy h1 span{color:var(--zp-blue)}.zp-hero-copy p,.zp-page-subtitle,.zp-register-visual p,.zp-otp-visual p,.zp-login-copy p{font-size:18px;line-height:1.72;color:#4e5f78;max-width:680px;margin:0}.zp-hero-actions{display:flex;gap:16px;margin-top:34px}.zp-grid-icon{font-size:22px;color:var(--zp-blue)}.zp-ticks{display:flex;gap:26px;flex-wrap:wrap;color:#51647d;font-size:13px;font-weight:800;margin-top:22px}.zp-hero-visual{min-height:430px;position:relative;display:grid;place-items:center}.zp-team-scene{position:relative;width:min(560px,100%);height:345px;border-radius:42px;background:linear-gradient(135deg,#eaf5ff,#fff 45%,#dfeeff);border:1px solid #d6e7fb;box-shadow:var(--zp-shadow);overflow:hidden}.zp-team-scene:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(18,104,255,.18),transparent 27%),radial-gradient(circle at 86% 28%,rgba(14,165,233,.14),transparent 26%),linear-gradient(120deg,rgba(255,255,255,.25),transparent 60%)}.zp-avatar{position:absolute;border-radius:32px 32px 16px 16px;background:linear-gradient(180deg,#fff,#d8e8fb);border:1px solid #c8dcf5;box-shadow:0 18px 40px rgba(15,23,42,.12)}.zp-avatar:before{content:"";position:absolute;top:-34px;left:50%;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#0f172a,#64748b);transform:translateX(-50%);box-shadow:0 8px 18px rgba(15,23,42,.22)}.zp-a1{left:72px;bottom:80px;width:88px;height:130px;background:linear-gradient(180deg,#f8fafc,#dbeafe)}.zp-a2{left:185px;bottom:72px;width:108px;height:158px;background:linear-gradient(180deg,#dbeafe,#eff6ff)}.zp-a3{right:148px;bottom:86px;width:90px;height:138px;background:linear-gradient(180deg,#f0f9ff,#e0f2fe)}.zp-a4{right:42px;bottom:76px;width:84px;height:126px;background:linear-gradient(180deg,#fff7ed,#e0f2fe)}.zp-laptop{position:absolute;left:50%;bottom:42px;width:170px;height:88px;border-radius:14px;background:linear-gradient(180deg,#fff,#dbeafe);border:1px solid #bed6f3;transform:translateX(-50%);box-shadow:0 16px 30px rgba(15,23,42,.13)}.zp-laptop:after{content:"";position:absolute;left:-28px;right:-28px;bottom:-12px;height:16px;border-radius:20px;background:#bdd3ef}.zp-soft-orb{position:absolute;width:230px;height:230px;border-radius:50%;background:rgba(18,104,255,.08);right:-70px;top:-50px}.zp-team-scene-form{height:430px;width:100%;margin-top:28px;border-radius:30px}.zp-team-scene-form .zp-a1{left:84px}.zp-team-scene-otp{width:520px;height:300px;margin-top:28px}.zp-team-scene-success{width:520px;height:305px;background:linear-gradient(135deg,#ecfeff,#fff,#eaf2ff)}.zp-float-card{position:absolute;z-index:3;background:rgba(255,255,255,.88);border:1px solid #dbe8f7;border-radius:18px;padding:16px 18px;box-shadow:var(--zp-shadow-sm);backdrop-filter:blur(12px)}.zp-float-card small{display:block;color:#64748b;font-weight:800}.zp-float-card strong{display:block;margin:4px 0;font-size:21px}.zp-float-card span{color:#16a34a;font-weight:900;font-size:12px}.zp-revenue-card{left:0;top:45px}.zp-revenue-card i{display:block;width:120px;height:34px;margin-top:4px;background:linear-gradient(135deg,transparent 50%,rgba(18,104,255,.14));border-bottom:3px solid var(--zp-blue);border-radius:0 0 16px 16px}.zp-inventory-card{right:0;bottom:46px}.zp-progress{width:160px;height:8px;border-radius:999px;background:#e2e8f0;margin-top:10px}.zp-progress b{display:block;height:100%;width:72%;background:var(--zp-blue);border-radius:inherit}.zp-module-strip,.zp-stat-row,.zp-feature-cards,.zp-logo-strip{margin:22px auto 0}.zp-module-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:0;background:#fff;border:1px solid var(--zp-line);border-radius:20px;box-shadow:var(--zp-shadow-sm);padding:18px}.zp-module-strip article{display:flex;align-items:center;gap:12px;padding:0 14px;border-right:1px solid #e8eef8}.zp-module-strip article:last-child{border-right:0}.zp-module-strip strong{display:block;font-size:15px}.zp-module-strip small{display:block;color:#617089;font-size:12px;margin-top:3px;line-height:1.35}.zp-module-icon{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-weight:950;flex:0 0 auto;color:#0f4cff;background:#eaf2ff}.zp-icon-pur{background:#e8fff4;color:#10b981}.zp-icon-sal{background:#f1eaff;color:#8b5cf6}.zp-icon-acc{background:#fff4e6;color:#f97316}.zp-icon-crm{background:#e7fffb;color:#14b8a6}.zp-icon-pos{background:#fff0f7;color:#ec4899}.zp-icon-vdr{background:#eaf2ff;color:#3b82f6}.zp-icon-hc{background:#eef2ff;color:#4f46e5}.zp-icon-pay{background:#e6fffb;color:#0e7490}.zp-icon-rpd{background:#fff7e7;color:#f59e0b}.zp-icon-fa{background:#eef6ff;color:#2563eb}.zp-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1120px}.zp-stat-row article{display:grid;grid-template-columns:auto 1fr;gap:0 16px;align-items:center;background:#fff;border:1px solid var(--zp-line);border-radius:18px;padding:18px 24px;box-shadow:var(--zp-shadow-sm)}.zp-stat-row span{grid-row:1/3;width:54px;height:54px;border-radius:50%;background:#eaf2ff;display:grid;place-items:center;color:var(--zp-blue);font-size:22px}.zp-stat-row strong{font-size:24px}.zp-stat-row small,.zp-muted{color:#65758e}.zp-logo-strip{text-align:center;color:#7a8aa3;font-weight:800}.zp-logo-strip div{display:flex;justify-content:center;gap:60px;flex-wrap:wrap;margin-top:18px}.zp-logo-strip b{color:#7a879d}.zp-feature-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1050px}.zp-feature-cards article{background:#fff;border:1px solid var(--zp-line);border-radius:20px;padding:28px;box-shadow:var(--zp-shadow-sm);display:grid;grid-template-columns:auto 1fr;gap:14px}.zp-feature-cards span{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:#eaf2ff;color:var(--zp-blue);font-size:24px}.zp-feature-cards strong{font-size:20px}.zp-feature-cards p{grid-column:2;color:#65758e;margin:0;line-height:1.55}.zp-stepper{display:flex;align-items:center;justify-content:center;gap:18px;margin:44px auto 36px}.zp-stepper span{display:grid;gap:9px;justify-items:center;color:#6b7a90;font-weight:850}.zp-stepper b{width:42px;height:42px;border:1px solid #c8d9ee;border-radius:50%;display:grid;place-items:center;background:#fff;box-shadow:0 8px 20px rgba(20,67,130,.05)}.zp-stepper i{display:block;width:130px;border-top:2px dashed #c8d9ee}.zp-stepper .is-active{color:var(--zp-blue)}.zp-stepper .is-active b,.zp-stepper .is-done b{background:linear-gradient(135deg,#11a7e7,#0f61ff);color:#fff;border:0;box-shadow:0 14px 28px rgba(18,104,255,.25)}.zp-modules-layout{display:grid;grid-template-columns:minmax(0,1fr) 430px;gap:52px}.zp-modules-layout h1{margin:0 0 10px}.zp-module-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}.zp-module-card{min-height:198px;position:relative;background:#fff;border:1px solid var(--zp-line);border-radius:18px;box-shadow:var(--zp-shadow-sm);padding:24px;display:flex;flex-direction:column;gap:13px;cursor:pointer;transition:.2s ease}.zp-module-card:hover{transform:translateY(-3px);border-color:#bcd5f7}.zp-module-card input{position:absolute;opacity:0}.zp-check{position:absolute;right:18px;top:18px;width:22px;height:22px;border-radius:6px;border:2px solid #cbd8e8;background:#fff}.zp-module-card input:checked+.zp-check{background:var(--zp-blue);border-color:var(--zp-blue)}.zp-module-card input:checked+.zp-check:after{content:"✓";color:#fff;font-weight:950;position:absolute;inset:0;display:grid;place-items:center;font-size:13px}.zp-module-card strong{font-size:20px}.zp-module-card small{color:#52637b;line-height:1.55}.zp-selection-card,.zp-form-card,.zp-otp-card,.zp-login-card{background:rgba(255,255,255,.92);border:1px solid var(--zp-line);border-radius:24px;box-shadow:var(--zp-shadow);padding:28px}.zp-selection-card{position:sticky;top:22px;align-self:start}.zp-selection-head{display:flex;align-items:center;justify-content:space-between}.zp-selection-head h2{margin:0}.zp-selection-head b{padding:8px 13px;border-radius:999px;background:#eaf2ff;color:var(--zp-blue)}.zp-selected-list{min-height:180px;margin:22px 0;display:grid;gap:13px}.zp-selected-list article{display:flex;align-items:center;gap:12px}.zp-selected-list article span:first-child{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#eaf2ff;color:var(--zp-blue);font-weight:950}.zp-selected-list strong{display:block}.zp-selected-list small{display:block;color:#66758b}.zp-selected-list button{margin-left:auto;border:0;background:transparent;color:#94a3b8;font-size:22px;cursor:pointer}.zp-selection-card hr{border:0;border-top:1px solid #e5edf7;margin:20px 0}.zp-selection-card h3{font-size:16px;margin:0 0 14px}.zp-branch-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.zp-branch-options button{height:46px;border:1px solid var(--zp-line);background:#fff;border-radius:12px;font-weight:900;color:#40516b;cursor:pointer}.zp-branch-options .is-active{border-color:var(--zp-blue);color:var(--zp-blue);box-shadow:0 0 0 3px rgba(18,104,255,.08)}.zp-secure-note{text-align:center;color:#65758e;font-size:13px}.zp-info-banner{margin-top:26px;display:flex;gap:18px;align-items:center;background:#fff;border:1px solid var(--zp-line);border-radius:18px;padding:20px 24px;max-width:620px}.zp-info-banner span{font-size:28px}.zp-info-banner strong,.zp-info-banner small{display:block}.zp-info-banner small{color:#66758b;margin-top:4px}.zp-register-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px}.zp-register-visual{background:linear-gradient(135deg,#eaf6ff,#fff);border:1px solid var(--zp-line);border-radius:24px;padding:42px;box-shadow:var(--zp-shadow-sm);overflow:hidden}.zp-register-visual h1{font-size:34px;line-height:1.15;letter-spacing:-.04em;margin:0 0 16px}.zp-selected-preview{background:rgba(255,255,255,.88);border:1px solid var(--zp-line);border-radius:18px;padding:18px;margin-top:-36px;position:relative;z-index:2;box-shadow:var(--zp-shadow-sm)}.zp-selected-preview strong{display:block;margin-bottom:12px}.zp-selected-preview span,.zp-chip-row span{display:inline-flex;margin:5px 6px 0 0;padding:8px 12px;border-radius:999px;background:#eef5ff;color:#1d4ed8;font-weight:900;font-size:12px}.zp-form-card h1,.zp-otp-card h1{font-size:38px;margin:0 0 10px;letter-spacing:-.04em}.zp-form-card p,.zp-otp-card p{color:#64748b;margin:0 0 24px}.zp-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 20px}.zp-form-card label,.zp-login-card label{display:grid;gap:8px;color:#334155;font-weight:850;font-size:13px}.zp-form-card input,.zp-form-card select,.zp-login-card input,.zp-login-card select{height:48px;border:1px solid #cfe0f5;border-radius:12px;padding:0 14px;background:#fff;color:#0f172a;font-family:inherit;outline:0}.zp-form-card input:focus,.zp-form-card select:focus,.zp-login-card input:focus,.zp-login-card select:focus{border-color:var(--zp-blue);box-shadow:0 0 0 4px rgba(18,104,255,.1)}.zp-consent{margin-top:18px;display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;gap:8px}.zp-consent input{height:auto!important}.zp-consent a{color:var(--zp-blue)}.zp-form-actions{display:flex;align-items:center;justify-content:space-between;margin-top:24px}.zp-alert{background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;border-radius:14px;padding:12px 14px;font-weight:850;margin:0 0 18px}.zp-otp-layout{display:grid;grid-template-columns:.9fr 1.1fr;background:#fff;border:1px solid var(--zp-line);border-radius:24px;box-shadow:var(--zp-shadow);overflow:hidden}.zp-otp-visual{padding:62px 54px;background:linear-gradient(135deg,#f1f8ff,#fff)}.zp-otp-visual h1{font-size:44px;letter-spacing:-.05em;line-height:1.1;margin:24px 0 16px}.zp-safe-card{display:inline-grid;gap:5px;background:#fff;border:1px solid var(--zp-line);border-radius:17px;padding:16px 18px;margin-top:-46px;position:relative;z-index:2;box-shadow:var(--zp-shadow-sm)}.zp-safe-card small{color:#65758e}.zp-otp-card{box-shadow:none;border:0;border-radius:0;padding:62px 70px;text-align:center}.zp-mail-icon,.zp-lock-icon{width:70px;height:70px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;background:#eaf2ff;color:var(--zp-blue);font-size:30px;position:relative}.zp-mail-icon b{position:absolute;right:4px;bottom:4px;background:var(--zp-green);color:#fff;border-radius:50%;width:24px;height:24px;font-size:14px;display:grid;place-items:center}.zp-code-target{display:flex;align-items:center;gap:14px;border:1px solid #cfe0f5;border-radius:15px;padding:14px 18px;text-align:left;margin:24px 0}.zp-code-target span{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#eaf2ff}.zp-code-target small,.zp-code-target strong{display:block}.zp-code-target a{margin-left:auto;color:var(--zp-blue);font-weight:900;text-decoration:none}.zp-dev-otp{display:inline-flex;align-items:center;gap:6px;margin-bottom:18px;padding:8px 13px;border-radius:999px;background:#fff7ed;color:#9a3412;font-weight:900}.zp-otp-inputs{display:flex;justify-content:center;gap:14px;margin:20px 0}.zp-otp-inputs input{width:76px;height:76px;border:1px solid #cfe0f5;border-radius:14px;text-align:center;font-size:34px;font-weight:950;color:var(--zp-blue);outline:0}.zp-otp-inputs input:focus{border-color:var(--zp-blue);box-shadow:0 0 0 4px rgba(18,104,255,.1)}.zp-otp-meta{display:flex;justify-content:space-between;color:#64748b;margin:0 auto 18px;max-width:560px}.zp-otp-meta span{color:var(--zp-green);font-weight:850}.zp-note{padding:15px 18px;border-radius:14px;background:#eef5ff;color:#52637b;margin:18px 0;line-height:1.5}.zp-otp-actions{display:grid;grid-template-columns:.8fr 1.2fr;gap:16px}.zp-provision-overlay{position:fixed;inset:0;z-index:9999;background:rgba(241,247,255,.78);backdrop-filter:blur(18px);display:grid;place-items:center}.zp-provision-overlay[hidden]{display:none}.zp-provision-overlay>div{width:min(560px,calc(100vw - 36px));border:1px solid #bfdbfe;background:#fff;border-radius:28px;box-shadow:var(--zp-shadow);padding:44px;text-align:center}.zp-spinner{width:70px;height:70px;border-radius:50%;border:6px solid #e2edff;border-top-color:var(--zp-blue);display:inline-block;animation:zpSpin 1s linear infinite}@keyframes zpSpin{to{transform:rotate(360deg)}}.zp-welcome-title{text-align:center}.zp-welcome-title h1{font-size:52px;margin:0 0 10px}.zp-welcome-title p{font-size:18px;color:#66758b;margin:0 0 28px}.zp-welcome-card{display:grid;grid-template-columns:.92fr 1.08fr;gap:24px;align-items:center;background:#fff;border:1px solid var(--zp-line);border-radius:26px;box-shadow:var(--zp-shadow);padding:44px}.zp-success-pill{display:inline-flex;align-items:center;gap:10px;background:#e9fbf0;color:#087b45;border-radius:18px;padding:13px 20px;font-weight:950}.zp-welcome-summary p{color:#53657d}.zp-welcome-summary dl{margin:26px 0;display:grid}.zp-welcome-summary div{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid #e7eff9;padding:14px 0;align-items:center}.zp-welcome-summary dt{font-weight:900;color:#334155}.zp-welcome-summary dd{margin:0;font-weight:850}.zp-green-dot{width:8px;height:8px;border-radius:50%;background:var(--zp-green);display:inline-block;margin-right:8px}.zp-welcome-actions{display:flex;gap:16px}.zp-celebrate{position:relative;min-height:380px;display:grid;place-items:center}.zp-big-check{position:absolute;top:18px;left:50%;width:110px;height:110px;border-radius:50%;background:#fff;border:1px solid #dbe8f7;box-shadow:0 18px 44px rgba(20,67,130,.12);z-index:3;display:grid;place-items:center;color:var(--zp-green);font-size:62px;font-weight:950}.zp-details-card{background:#fff;border:1px solid var(--zp-line);border-radius:22px;box-shadow:var(--zp-shadow-sm);padding:24px;margin-top:22px}.zp-login-layout{display:grid;grid-template-columns:1.12fr .88fr;gap:60px;align-items:center;padding:34px 26px}.zp-login-copy h1{font-size:54px}.zp-security-list{display:grid;gap:28px;margin:34px 0}.zp-security-list article{display:flex;gap:18px;align-items:flex-start}.zp-security-list article>span{width:58px;height:58px;border-radius:16px;background:#fff;border:1px solid var(--zp-line);display:grid;place-items:center;font-size:24px;box-shadow:var(--zp-shadow-sm)}.zp-security-list strong,.zp-security-list small{display:block}.zp-security-list small{color:#66758b;line-height:1.45;margin-top:5px}.zp-dashboard-preview{max-width:420px;background:#fff;border:1px solid var(--zp-line);border-radius:22px;box-shadow:var(--zp-shadow);padding:22px;margin-left:auto;margin-top:-190px}.zp-dashboard-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0}.zp-dashboard-kpis span{background:#f6f9fd;border:1px solid #e6eef9;border-radius:12px;padding:10px;color:#64748b;font-size:12px}.zp-dashboard-kpis b{color:#0f172a;font-size:16px}.zp-dashboard-modules{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.zp-dashboard-modules span{padding:9px;border-radius:10px;background:#eef5ff;color:#1d4ed8;font-weight:900;font-size:12px;text-align:center}.zp-login-card{padding:46px}.zp-login-card h1{font-size:34px;margin:0 0 8px}.zp-login-card p{color:#64748b}.zp-login-card form{display:grid;gap:18px;margin-top:24px}.zp-form-line{display:flex;align-items:center;justify-content:space-between}.zp-checkbox{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;gap:8px}.zp-checkbox input{height:auto!important}.zp-form-line a{color:var(--zp-blue);font-weight:900}.zp-avatar-pill{width:40px;height:40px;border-radius:50%;background:#eaf2ff;color:#1d4ed8;display:grid;place-items:center;font-weight:950}@media(max-width:1100px){.zp-page-shell,.zp-narrow-shell{width:min(100% - 24px,900px)}.zp-nav{display:none}.zp-hero-grid,.zp-modules-layout,.zp-register-layout,.zp-otp-layout,.zp-welcome-card,.zp-login-layout{grid-template-columns:1fr;padding-left:0;padding-right:0}.zp-hero-copy h1,.zp-modules-layout h1{font-size:42px}.zp-module-strip{grid-template-columns:1fr 1fr}.zp-module-strip article{border-right:0}.zp-module-grid{grid-template-columns:1fr 1fr}.zp-stat-row,.zp-feature-cards{grid-template-columns:1fr}.zp-stepper{overflow:auto;justify-content:flex-start}.zp-stepper i{width:70px}.zp-dashboard-preview{margin:20px 0 0}.zp-otp-card{padding:36px 22px}.zp-otp-inputs input{width:48px;height:56px;font-size:26px}.zp-topbar{height:auto;padding:14px;flex-wrap:wrap}.zp-branch-options{grid-template-columns:1fr}.zp-form-grid{grid-template-columns:1fr}}@media(max-width:640px){.zp-module-grid{grid-template-columns:1fr}.zp-module-strip{grid-template-columns:1fr}.zp-hero-actions,.zp-welcome-actions,.zp-otp-actions,.zp-form-actions{grid-template-columns:1fr;display:grid}.zp-hero-copy h1,.zp-login-copy h1,.zp-welcome-title h1{font-size:34px}.zp-hero-grid{gap:20px}.zp-team-scene{height:300px}.zp-welcome-summary div{grid-template-columns:1fr}.zp-logo-strip div{gap:20px}.zp-top-actions{width:100%;justify-content:space-between}}

/* =========================================================
   v40.30 module icon + visible selected text hotfix
   ========================================================= */
.zp-module-card.is-selected{border-color:#bfdbfe;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 18px 42px rgba(18,104,255,.12)}
.zp-module-card .zp-module-icon svg,.zp-module-strip .zp-module-icon svg{width:22px;height:22px;display:block;stroke:currentColor}
.zp-module-card strong{color:#07152f!important;font-weight:950;letter-spacing:-.02em;line-height:1.15}
.zp-module-card small{color:#52637b!important;font-weight:650;line-height:1.45}
.zp-selection-card,.zp-selection-card h2,.zp-selection-card h3{color:#07152f!important}
.zp-selection-head b{color:#0f61ff!important;background:#eaf2ff!important}
.zp-selected-list{min-height:148px}
.zp-selected-list em{color:#64748b!important;font-style:normal;font-weight:750}
.zp-selected-list article{min-height:64px;padding:10px 0;border-bottom:1px solid rgba(219,232,247,.7)}
.zp-selected-list article:last-child{border-bottom:0}
.zp-selected-list article span:first-child{color:#0f61ff!important;background:#eaf2ff!important;font-size:12px;letter-spacing:.02em}
.zp-selected-list strong{color:#07152f!important;font-size:15px;font-weight:950;line-height:1.1}
.zp-selected-list small{color:#52637b!important;font-size:12px;font-weight:700;line-height:1.35;margin-top:5px;max-width:260px}
.zp-selected-list button{color:#94a3b8!important}.zp-selected-list button:hover{color:#ef4444!important}
.zp-branch-options button{color:#334155!important;background:#fff!important}.zp-branch-options .is-active{color:#0f61ff!important;background:#f8fbff!important}
.zp-muted,.zp-secure-note{color:#64748b!important}.zp-btn-primary,.zp-btn-primary *{color:#fff!important}.zp-btn-ghost,.zp-btn-ghost *{color:#07152f!important}
.zp-icon-inv{background:#eaf2ff;color:#2563eb}.zp-icon-pur{background:#e8fff4;color:#10b981}.zp-icon-sal{background:#f1eaff;color:#8b5cf6}.zp-icon-acc{background:#fff4e6;color:#f97316}.zp-icon-crm{background:#e7fffb;color:#14b8a6}.zp-icon-pos{background:#fff0f7;color:#ec4899}.zp-icon-vdr{background:#eaf2ff;color:#3b82f6}.zp-icon-hc{background:#eef2ff;color:#4f46e5}.zp-icon-pay{background:#e6fffb;color:#0e7490}.zp-icon-rpd{background:#fff7e7;color:#f59e0b}.zp-icon-fa{background:#eef6ff;color:#2563eb}

/* =========================================================
   v40.32 registration image replacement
   Replace placeholder illustration with the free onboarding team image.
   ========================================================= */
.zp-register-photo-card{
    position:relative;
    width:100%;
    min-height:330px;
    margin:28px 0 0;
    border-radius:34px;
    overflow:hidden;
    border:1px solid #d6e7fb;
    background:linear-gradient(135deg,#eef7ff,#fff);
    box-shadow:0 26px 70px rgba(20,67,130,.14);
}
.zp-register-photo-card:before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    pointer-events:none;
    background:
        radial-gradient(circle at 88% 12%,rgba(18,104,255,.12),transparent 32%),
        linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.18));
}
.zp-register-photo-card img{
    width:100%;
    height:100%;
    min-height:330px;
    display:block;
    object-fit:cover;
    object-position:center;
    filter:saturate(1.02) contrast(1.02);
}
.zp-photo-stat{
    position:absolute;
    z-index:2;
    min-width:168px;
    border:1px solid rgba(203,218,238,.92);
    background:rgba(255,255,255,.92);
    backdrop-filter:blur(16px);
    border-radius:20px;
    box-shadow:0 18px 40px rgba(20,67,130,.14);
    padding:15px 17px;
}
.zp-photo-stat small{display:block;color:#64748b;font-weight:900;font-size:13px;line-height:1.1}
.zp-photo-stat strong{display:block;color:#07152f;font-size:25px;letter-spacing:-.045em;margin-top:7px;line-height:1}
.zp-photo-stat span{display:inline-flex;margin-top:10px;color:#16a34a;font-weight:950;font-size:14px}
.zp-photo-stat-revenue{left:18px;top:18px}
.zp-photo-stat-stock{right:20px;bottom:18px;min-width:210px}
.zp-photo-stat-stock i{display:block;height:8px;border-radius:999px;background:linear-gradient(90deg,#1268ff 0 70%,#e2e8f0 70% 100%);margin-top:14px}
.zp-register-page .zp-selected-preview{margin-top:-20px;position:relative;z-index:3;background:rgba(255,255,255,.94);backdrop-filter:blur(16px)}
@media(max-width:1100px){.zp-register-photo-card,.zp-register-photo-card img{min-height:290px}.zp-photo-stat{transform:scale(.92);transform-origin:left top}.zp-photo-stat-stock{transform-origin:right bottom}}
@media(max-width:640px){.zp-register-photo-card,.zp-register-photo-card img{min-height:240px}.zp-photo-stat{display:none}.zp-register-page .zp-selected-preview{margin-top:14px}}

/* =========================================================
   v40.35 Branch setup before OTP
   ========================================================= */
.zp-stepper-six i{width:102px}
.zp-branch-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:start;margin-top:8px}
.zp-branch-intro{padding:28px 10px 0 0}
.zp-mini-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid #bfdbfe;background:#fff;border-radius:999px;color:#1d4ed8;font-size:13px;font-weight:950;box-shadow:0 8px 20px rgba(18,104,255,.06)}
.zp-branch-intro h1{font-size:54px;line-height:1.05;letter-spacing:-.065em;margin:24px 0 18px;color:#07142c}
.zp-branch-intro p{font-size:18px;line-height:1.68;color:#52637b;margin:0;max-width:660px}
.zp-branch-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:28px 0}
.zp-branch-summary article{border:1px solid #dbe8f7;background:rgba(255,255,255,.78);border-radius:18px;padding:18px 20px;box-shadow:0 12px 34px rgba(20,67,130,.07)}
.zp-branch-summary small{display:block;color:#64748b;font-weight:900;text-transform:uppercase;font-size:11px;letter-spacing:.04em;margin-bottom:8px}
.zp-branch-summary strong{display:block;color:#07152f;font-size:18px;letter-spacing:-.025em;line-height:1.2}
.zp-branch-module-preview{margin-top:22px!important;background:#fff!important;border:1px solid #dbe8f7!important;box-shadow:0 12px 34px rgba(20,67,130,.07)!important}
.zp-branch-card{padding:34px 38px!important}
.zp-branch-card h1{font-size:38px!important;margin:0 0 8px!important}
.zp-branch-card>p{color:#64748b;margin:0 0 22px;line-height:1.5}
.zp-branch-list{display:grid;gap:14px;margin-top:18px}
.zp-branch-row{display:grid!important;grid-template-columns:72px 1fr!important;gap:14px;align-items:center;border:1px solid #dbe8f7;background:linear-gradient(180deg,#fff,#f8fbff);border-radius:18px;padding:14px!important}
.zp-branch-code{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#11a7e7,#0f61ff);color:#fff;font-size:20px;font-weight:950;display:grid;place-items:center;box-shadow:0 14px 26px rgba(18,104,255,.22)}
.zp-branch-field{display:grid;gap:7px}
.zp-branch-field small{font-size:12px;color:#64748b;font-weight:900;text-transform:uppercase;letter-spacing:.035em}
.zp-branch-field input{width:100%;height:50px;border:1px solid #cfe0f4;border-radius:14px;background:#fff;padding:0 16px;font:inherit;font-weight:750;color:#07152f;outline:0}
.zp-branch-field input:focus{border-color:#1268ff;box-shadow:0 0 0 4px rgba(18,104,255,.1)}
.zp-branch-note{border:1px dashed #bfdbfe;background:#f8fbff;color:#52637b;border-radius:16px;padding:14px 16px;line-height:1.5;margin-top:18px;font-weight:700}
.zp-branch-note b{color:#07152f}
@media(max-width:1100px){.zp-branch-layout{grid-template-columns:1fr}.zp-branch-summary{grid-template-columns:1fr}.zp-stepper-six i{width:70px}}
@media(max-width:640px){.zp-branch-intro h1{font-size:36px}.zp-branch-row{grid-template-columns:1fr!important}.zp-branch-code{width:48px;height:48px}.zp-branch-card{padding:24px!important}}

/* =========================================================
   v40.60 SaaS public mockup refresh
   ========================================================= */
body.zp-public-page{
    background:
        radial-gradient(circle at 6% 52%,rgba(18,104,255,.08),transparent 26%),
        radial-gradient(circle at 86% 10%,rgba(14,165,233,.08),transparent 25%),
        linear-gradient(180deg,#f7fbff 0%,#fff 48%,#f6fbff 100%)!important;
}
.zp-page-shell{width:min(1490px,calc(100vw - 64px));padding-top:24px}
.zp-narrow-shell{width:min(1420px,calc(100vw - 72px))}
.zp-topbar{border:0!important;box-shadow:none!important;background:transparent!important;border-radius:0!important;padding-inline:0!important}
.zp-brand-mark{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#1da9ff,#0f61ff 62%,#1740b4);font-size:24px;box-shadow:0 16px 34px rgba(18,104,255,.22)}
.zp-brand strong{font-size:24px;letter-spacing:-.035em}.zp-brand small{font-size:14px}
.zp-nav{gap:62px}.zp-nav a{font-size:15px}.zp-nav a.active:after{bottom:-22px}
.zp-link{font-size:15px}.zp-btn{height:46px;border-radius:9px;padding-inline:24px}.zp-btn-primary{background:linear-gradient(135deg,#116dff,#0a58f6);box-shadow:0 16px 34px rgba(15,97,255,.24)}
.zp-btn-lg{height:54px;min-width:186px}
.zp-hero-grid{grid-template-columns:minmax(0,1fr) minmax(520px,.95fr);gap:58px;padding:54px 42px 24px 42px}
.zp-hero-copy h1{font-size:58px;line-height:1.06;letter-spacing:-.052em;max-width:760px}
.zp-hero-copy p{font-size:18px;line-height:1.65;max-width:665px}
.zp-pill,.zp-mini-badge{background:rgba(255,255,255,.76);border-color:#c8dcfb;border-radius:11px;color:#105ce5}
.zp-hero-photo-card{
    width:min(620px,100%);
    height:420px;
    border-radius:36px 36px 12px 72px;
    overflow:hidden;
    border:1px solid #d7e6fb;
    background:#edf6ff;
    box-shadow:0 28px 80px rgba(20,67,130,.16);
    transform:skewX(-7deg);
}
.zp-hero-photo{width:118%;height:100%;object-fit:cover;object-position:center;display:block;transform:skewX(7deg) translateX(-7%) scale(1.03)}
.zp-hero-visual:before{
    content:"";
    position:absolute;
    right:22px;
    top:12px;
    width:210px;
    height:210px;
    border:1px solid #d9e8fb;
    border-radius:28px;
    background:rgba(239,247,255,.85);
    z-index:-1;
}
.zp-float-card{border-radius:11px;background:rgba(255,255,255,.94);box-shadow:0 20px 48px rgba(20,67,130,.14)}
.zp-revenue-card{left:12px;top:70px}.zp-inventory-card{right:8px;bottom:42px}
.zp-module-strip{grid-template-columns:repeat(7,minmax(0,1fr));margin-top:16px;padding:22px 20px;border-radius:9px;box-shadow:0 18px 50px rgba(20,67,130,.1)}
.zp-module-strip article{min-width:0}.zp-module-strip strong{font-size:16px}.zp-module-strip small{font-size:12px}
.zp-stat-row{margin-top:24px}.zp-stat-row article,.zp-feature-cards article{border-radius:9px}
.zp-stepper{margin:46px auto 32px}.zp-stepper b{width:44px;height:44px}.zp-stepper i{width:150px;border-top-style:solid}
.zp-stepper-six i{width:100px}
.zp-modules-layout{grid-template-columns:minmax(0,1fr) 470px;gap:54px}
.zp-modules-layout h1{font-size:58px;letter-spacing:-.055em}
.zp-module-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.zp-module-card{border-radius:9px;min-height:184px;padding:24px 20px}.zp-module-card .zp-module-icon{width:56px;height:56px;border-radius:14px}.zp-check{border-radius:5px}
.zp-selection-card,.zp-form-card,.zp-otp-card,.zp-login-card,.zp-register-visual,.zp-otp-layout,.zp-welcome-card,.zp-details-card{border-radius:9px}
.zp-selection-card{padding:30px}.zp-selected-list article{border-bottom:0}.zp-branch-options button{border-radius:7px}
.zp-register-layout{grid-template-columns:.9fr 1.06fr;gap:16px}
.zp-register-visual,.zp-form-card{padding:42px}.zp-register-visual h1{font-size:35px}
.zp-register-photo-card{border-radius:9px;min-height:360px;box-shadow:0 22px 60px rgba(20,67,130,.12)}
.zp-register-photo-card img{min-height:360px;object-position:center}
.zp-photo-stat{border-radius:9px}.zp-selected-preview{border-radius:9px}
.zp-form-card input,.zp-form-card select,.zp-login-card input,.zp-login-card select{border-radius:7px;height:50px}
.zp-otp-layout{grid-template-columns:.9fr 1.1fr}
.zp-otp-photo-card{height:310px;min-height:310px}.zp-otp-photo-card img{min-height:310px}
.zp-safe-card,.zp-code-target,.zp-note,.zp-otp-inputs input{border-radius:9px}
.zp-otp-inputs input{width:78px;height:78px}
.zp-welcome-title h1{font-size:56px;letter-spacing:-.052em}
.zp-welcome-card{max-width:1260px;margin-inline:auto;padding:46px}
.zp-welcome-photo-card{height:360px;min-height:360px;margin-top:0}.zp-welcome-photo-card img{min-height:360px}
.zp-big-check{font-size:52px;top:-12px;border-radius:50%;z-index:5}
.zp-success-pill{border-radius:9px}
.zp-login-layout{padding-top:54px}.zp-login-card{border-radius:9px}
@media(max-width:1180px){
    .zp-page-shell,.zp-narrow-shell{width:min(100% - 28px,940px)}
    .zp-hero-grid,.zp-modules-layout,.zp-register-layout,.zp-otp-layout,.zp-welcome-card,.zp-login-layout{grid-template-columns:1fr}
    .zp-hero-grid{padding-inline:0}.zp-hero-copy h1,.zp-modules-layout h1{font-size:44px}
    .zp-module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .zp-module-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
    .zp-stepper{justify-content:flex-start;overflow:auto;padding-bottom:8px}.zp-stepper i,.zp-stepper-six i{width:70px}
}
@media(max-width:680px){
    .zp-page-shell,.zp-narrow-shell{width:min(100% - 20px,560px)}
    .zp-brand strong{font-size:19px}.zp-brand-mark{width:38px;height:38px}
    .zp-top-actions{width:100%;justify-content:flex-start;gap:10px}.zp-top-actions span{display:none}
    .zp-hero-copy h1,.zp-login-copy h1,.zp-welcome-title h1{font-size:36px}
    .zp-hero-photo-card{height:285px;border-radius:18px;transform:none}.zp-hero-photo{width:100%;transform:none}
    .zp-revenue-card,.zp-inventory-card{display:none}
    .zp-module-grid,.zp-module-strip{grid-template-columns:1fr}
    .zp-register-visual,.zp-form-card,.zp-selection-card,.zp-welcome-card{padding:24px}
    .zp-register-photo-card,.zp-register-photo-card img,.zp-welcome-photo-card,.zp-welcome-photo-card img{min-height:245px;height:245px}
    .zp-otp-inputs{gap:7px}.zp-otp-inputs input{width:44px;height:54px;font-size:24px}
}

/* =========================================================
   v40.67 SaaS registration sub-module selection
   ========================================================= */
.zp-module-group{
    min-height:260px;
}
.zp-module-group-head{
    position:absolute;
    inset:0 0 auto auto;
    width:56px;
    height:56px;
    cursor:pointer;
}
.zp-module-group .zp-check{
    right:18px;
    top:18px;
}
.zp-module-parent:indeterminate + .zp-check{
    background:#7dd3fc;
    border-color:#38bdf8;
}
.zp-module-parent:indeterminate + .zp-check:after{
    content:"-";
    color:#fff;
    font-weight:950;
    position:absolute;
    inset:0;
    display:grid;
    place-items:center;
    font-size:15px;
}
.zp-submodule-list{
    display:grid;
    gap:8px;
    margin-top:4px;
}
.zp-submodule-option{
    display:grid;
    gap:2px;
    min-height:48px;
    padding:9px 11px 9px 34px;
    border:1px solid #dbe8f7;
    border-radius:8px;
    background:#f8fbff;
    position:relative;
    cursor:pointer;
}
.zp-submodule-option input{
    position:absolute;
    opacity:1!important;
    left:11px;
    top:14px;
    width:14px;
    height:14px;
    accent-color:#1268ff;
}
.zp-submodule-option span{
    color:#07152f;
    font-size:13px;
    font-weight:950;
    line-height:1.15;
}
.zp-submodule-option small{
    color:#64748b!important;
    font-size:10.5px!important;
    font-weight:750!important;
    line-height:1.25!important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.zp-submodule-option.is-selected{
    border-color:#bfdbfe;
    background:#eef6ff;
    box-shadow:0 8px 20px rgba(18,104,255,.08);
}


/* =========================================================
   v40.65 Compact public flow pages
   Targets only:
   - /login
   - /client/modules
   - /client/register
   ========================================================= */
body.zp-login-page .zp-page-shell,
body.zp-modules-page .zp-page-shell,
body.zp-register-page .zp-page-shell{
    width:min(1540px,calc(100vw - 34px));
    padding-top:12px;
    padding-bottom:22px;
}

body.zp-login-page .zp-topbar,
body.zp-modules-page .zp-topbar,
body.zp-register-page .zp-topbar{
    min-height:54px!important;
    height:54px!important;
    gap:14px!important;
}

body.zp-login-page .zp-brand,
body.zp-modules-page .zp-brand,
body.zp-register-page .zp-brand{
    gap:9px;
}

body.zp-login-page .zp-brand-mark,
body.zp-modules-page .zp-brand-mark,
body.zp-register-page .zp-brand-mark{
    width:36px;
    height:36px;
    border-radius:9px;
    font-size:20px;
}

body.zp-login-page .zp-brand strong,
body.zp-modules-page .zp-brand strong,
body.zp-register-page .zp-brand strong{
    font-size:19px;
    line-height:1;
}

body.zp-login-page .zp-brand small,
body.zp-modules-page .zp-brand small,
body.zp-register-page .zp-brand small{
    margin-top:2px;
    font-size:11px;
    line-height:1.1;
}

body.zp-login-page .zp-nav,
body.zp-modules-page .zp-nav{
    gap:30px;
}

body.zp-login-page .zp-nav a,
body.zp-modules-page .zp-nav a,
body.zp-login-page .zp-link,
body.zp-modules-page .zp-link,
body.zp-register-page .zp-link{
    font-size:12px;
}

body.zp-login-page .zp-btn,
body.zp-modules-page .zp-btn,
body.zp-register-page .zp-btn{
    height:38px;
    min-height:38px;
    padding-inline:15px;
    border-radius:9px;
    gap:8px;
    font-size:12px;
}

body.zp-login-page .zp-btn-block,
body.zp-modules-page .zp-btn-block,
body.zp-register-page .zp-btn-block{
    height:40px;
}

body.zp-login-page .zp-stepper,
body.zp-modules-page .zp-stepper,
body.zp-register-page .zp-stepper{
    margin:14px auto 16px;
    gap:10px;
}

body.zp-login-page .zp-stepper span,
body.zp-modules-page .zp-stepper span,
body.zp-register-page .zp-stepper span{
    gap:4px;
    font-size:11px;
}

body.zp-login-page .zp-stepper b,
body.zp-modules-page .zp-stepper b,
body.zp-register-page .zp-stepper b{
    width:30px;
    height:30px;
    font-size:12px;
}

body.zp-login-page .zp-stepper small,
body.zp-modules-page .zp-stepper small,
body.zp-register-page .zp-stepper small{
    font-size:10px;
    line-height:1;
}

body.zp-login-page .zp-stepper i,
body.zp-modules-page .zp-stepper i,
body.zp-register-page .zp-stepper i,
body.zp-login-page .zp-stepper-six i,
body.zp-modules-page .zp-stepper-six i,
body.zp-register-page .zp-stepper-six i{
    width:82px;
}

/* /login compact */
body.zp-login-page .zp-login-layout{
    grid-template-columns:minmax(0,1fr) 410px;
    gap:24px;
    align-items:start;
    padding:10px 0 0;
}

body.zp-login-page .zp-login-copy{
    padding-top:4px;
}

body.zp-login-page .zp-pill{
    padding:5px 10px;
    border-radius:9px;
    font-size:11px;
}

body.zp-login-page .zp-login-copy h1{
    max-width:620px;
    margin:12px 0 9px;
    font-size:clamp(30px,3.2vw,40px);
    line-height:1.02;
    letter-spacing:-.05em;
}

body.zp-login-page .zp-login-copy p{
    max-width:590px;
    font-size:13px;
    line-height:1.45;
}

body.zp-login-page .zp-security-list{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
    margin:16px 0 0;
}

body.zp-login-page .zp-security-list article{
    gap:10px;
    padding:11px;
    border:1px solid #dbe8f7;
    border-radius:12px;
    background:rgba(255,255,255,.72);
}

body.zp-login-page .zp-security-list article>span{
    width:34px;
    height:34px;
    border-radius:10px;
    font-size:17px;
    box-shadow:none;
    flex:0 0 auto;
}

body.zp-login-page .zp-security-list strong{
    font-size:12px;
    line-height:1.15;
}

body.zp-login-page .zp-security-list small{
    margin-top:3px;
    font-size:11px;
    line-height:1.25;
}

body.zp-login-page .zp-dashboard-preview{
    max-width:520px;
    margin:14px 0 0;
    padding:14px;
    border-radius:12px;
}

body.zp-login-page .zp-dashboard-kpis{
    gap:8px;
    margin:10px 0;
}

body.zp-login-page .zp-dashboard-kpis span{
    padding:8px;
    border-radius:9px;
    font-size:11px;
}

body.zp-login-page .zp-dashboard-kpis b{
    font-size:13px;
}

body.zp-login-page .zp-dashboard-modules{
    gap:7px;
}

body.zp-login-page .zp-dashboard-modules span{
    padding:7px;
    border-radius:8px;
    font-size:11px;
}

body.zp-login-page .zp-login-card{
    padding:22px;
    border-radius:12px;
}

body.zp-login-page .zp-lock-icon{
    width:42px;
    height:42px;
    margin-bottom:10px;
    font-size:20px;
}

body.zp-login-page .zp-login-card h1{
    font-size:25px;
    margin-bottom:5px;
}

body.zp-login-page .zp-login-card p{
    margin:0;
    font-size:12px;
    line-height:1.35;
}

body.zp-login-page .zp-login-card form{
    gap:10px;
    margin-top:14px;
}

body.zp-login-page .zp-login-card label,
body.zp-login-page .zp-form-line,
body.zp-login-page .zp-note,
body.zp-login-page .zp-muted{
    font-size:12px;
}

body.zp-login-page .zp-login-card input,
body.zp-login-page .zp-login-card select{
    height:38px;
    border-radius:8px;
    padding-inline:11px;
    font-size:12px;
}

body.zp-login-page .zp-note{
    margin:2px 0;
    padding:10px 12px;
    border-radius:9px;
}

/* /client/modules compact */
body.zp-modules-page .zp-modules-layout{
    grid-template-columns:minmax(0,1fr) 360px;
    gap:20px;
    align-items:start;
    margin-top:0;
}

body.zp-modules-page .zp-modules-layout h1{
    margin:0 0 8px;
    font-size:clamp(30px,3.2vw,40px);
    line-height:1.02;
    letter-spacing:-.045em;
}

body.zp-modules-page .zp-page-subtitle{
    max-width:720px;
    font-size:13px;
    line-height:1.4;
    margin-bottom:14px;
}

body.zp-modules-page .zp-module-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:10px;
}

body.zp-modules-page .zp-module-card{
    min-height:118px;
    padding:13px;
    border-radius:10px;
}

body.zp-modules-page .zp-module-card .zp-module-icon{
    width:38px;
    height:38px;
    border-radius:10px;
}

body.zp-modules-page .zp-module-card .zp-module-icon svg{
    width:18px;
    height:18px;
}

body.zp-modules-page .zp-module-card strong{
    font-size:13px;
    line-height:1.13;
}

body.zp-modules-page .zp-module-card small{
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
    font-size:11px;
    line-height:1.28;
}

body.zp-modules-page .zp-check{
    top:10px;
    right:10px;
    width:20px;
    height:20px;
}

body.zp-modules-page .zp-info-banner{
    margin-top:12px;
    padding:10px 12px;
    border-radius:11px;
    font-size:12px;
}

body.zp-modules-page .zp-selection-card{
    position:sticky;
    top:10px;
    padding:16px;
    border-radius:12px;
}

body.zp-modules-page .zp-selection-head{
    gap:8px;
}

body.zp-modules-page .zp-selection-head h2{
    font-size:18px;
}

body.zp-modules-page .zp-selection-head b{
    padding:5px 8px;
    border-radius:8px;
    font-size:11px;
}

body.zp-modules-page .zp-selected-list{
    min-height:84px;
    max-height:198px;
    overflow:auto;
}

body.zp-modules-page .zp-selected-list article{
    min-height:44px;
    padding:7px 0;
}

body.zp-modules-page .zp-selected-list strong{
    font-size:12px;
}

body.zp-modules-page .zp-selected-list small{
    max-width:220px;
    font-size:10px;
    line-height:1.22;
}

body.zp-modules-page .zp-selection-card hr{
    margin:12px 0;
}

body.zp-modules-page .zp-selection-card h3{
    margin:0 0 9px;
    font-size:15px;
}

body.zp-modules-page .zp-branch-options{
    gap:7px;
}

body.zp-modules-page .zp-branch-options button{
    min-height:36px;
    padding:8px;
    border-radius:8px;
    font-size:11px;
}

body.zp-modules-page .zp-muted,
body.zp-modules-page .zp-secure-note{
    margin:10px 0;
    font-size:11px;
    line-height:1.35;
}

/* /client/register compact */
body.zp-register-page .zp-register-layout{
    grid-template-columns:390px minmax(0,1fr);
    gap:18px;
    align-items:start;
    margin-top:0;
}

body.zp-register-page .zp-register-visual,
body.zp-register-page .zp-form-card{
    padding:22px;
    border-radius:12px;
}

body.zp-register-page .zp-register-visual h1{
    margin:0 0 8px;
    font-size:clamp(25px,2.5vw,31px);
    line-height:1.05;
    letter-spacing:-.045em;
}

body.zp-register-page .zp-register-visual p{
    font-size:12px;
    line-height:1.38;
}

body.zp-register-page .zp-register-photo-card{
    min-height:220px;
    margin-top:14px;
    border-radius:12px;
}

body.zp-register-page .zp-register-photo-card img{
    min-height:220px;
}

body.zp-register-page .zp-photo-stat{
    min-width:132px;
    padding:9px 10px;
    border-radius:10px;
}

body.zp-register-page .zp-photo-stat small{
    font-size:10px;
}

body.zp-register-page .zp-photo-stat strong{
    font-size:17px;
    margin-top:4px;
}

body.zp-register-page .zp-photo-stat span{
    margin-top:5px;
    font-size:11px;
}

body.zp-register-page .zp-photo-stat-stock{
    min-width:150px;
}

body.zp-register-page .zp-selected-preview{
    margin-top:10px!important;
    padding:11px 12px;
    border-radius:10px;
}

body.zp-register-page .zp-selected-preview strong{
    font-size:12px;
}

body.zp-register-page .zp-selected-preview div{
    gap:6px;
    margin-top:8px;
}

body.zp-register-page .zp-selected-preview span{
    padding:5px 8px;
    font-size:11px;
    border-radius:8px;
}

body.zp-register-page .zp-form-card h1{
    margin:0 0 5px;
    font-size:28px;
    line-height:1.08;
}

body.zp-register-page .zp-form-card>p{
    margin:0 0 14px;
    font-size:12px;
    line-height:1.35;
}

body.zp-register-page .zp-form-card form{
    margin-top:0;
}

body.zp-register-page .zp-form-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:9px 11px;
}

body.zp-register-page .zp-form-card label{
    gap:5px;
    font-size:11px;
}

body.zp-register-page .zp-form-card input,
body.zp-register-page .zp-form-card select{
    height:38px;
    border-radius:8px;
    padding-inline:10px;
    font-size:12px;
}

body.zp-register-page .zp-consent{
    margin-top:12px;
    font-size:11px!important;
}

body.zp-register-page .zp-form-actions{
    margin-top:14px;
    gap:10px;
}

@media (min-width:1320px){
    body.zp-register-page .zp-form-grid{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }
}

@media (max-width:1180px){
    body.zp-login-page .zp-page-shell,
    body.zp-modules-page .zp-page-shell,
    body.zp-register-page .zp-page-shell{
        width:min(100% - 24px,980px);
    }

    body.zp-login-page .zp-topbar,
    body.zp-modules-page .zp-topbar,
    body.zp-register-page .zp-topbar{
        height:auto!important;
        min-height:54px!important;
    }

    body.zp-login-page .zp-login-layout,
    body.zp-modules-page .zp-modules-layout,
    body.zp-register-page .zp-register-layout{
        grid-template-columns:1fr;
        gap:14px;
    }

    body.zp-login-page .zp-security-list{
        grid-template-columns:1fr;
    }

    body.zp-modules-page .zp-module-grid{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    body.zp-modules-page .zp-selection-card{
        position:static;
    }

    body.zp-register-page .zp-form-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media (max-width:720px){
    body.zp-login-page .zp-page-shell,
    body.zp-modules-page .zp-page-shell,
    body.zp-register-page .zp-page-shell{
        width:min(100% - 18px,560px);
        padding-top:8px;
    }

    body.zp-login-page .zp-stepper,
    body.zp-modules-page .zp-stepper,
    body.zp-register-page .zp-stepper{
        justify-content:flex-start;
        overflow:auto;
        padding-bottom:6px;
    }

    body.zp-login-page .zp-stepper i,
    body.zp-modules-page .zp-stepper i,
    body.zp-register-page .zp-stepper i{
        width:44px;
    }

    body.zp-modules-page .zp-module-grid,
    body.zp-register-page .zp-form-grid{
        grid-template-columns:1fr;
    }

    body.zp-login-page .zp-dashboard-preview,
    body.zp-register-page .zp-register-photo-card{
        display:none;
    }

    body.zp-login-page .zp-login-card,
    body.zp-register-page .zp-register-visual,
    body.zp-register-page .zp-form-card,
    body.zp-modules-page .zp-selection-card{
        padding:18px;
    }
}


/* =========================================================
   v40.66 Public flow readability bump
   Targets only:
   - /login
   - /client/modules
   - /client/register
   Makes compact pages easier to read like the landing module strip.
   ========================================================= */
body.zp-login-page .zp-brand strong,
body.zp-modules-page .zp-brand strong,
body.zp-register-page .zp-brand strong{
    font-size:20px;
}

body.zp-login-page .zp-brand small,
body.zp-modules-page .zp-brand small,
body.zp-register-page .zp-brand small{
    font-size:12px;
    font-weight:750;
}

body.zp-login-page .zp-nav a,
body.zp-modules-page .zp-nav a,
body.zp-login-page .zp-link,
body.zp-modules-page .zp-link,
body.zp-register-page .zp-link{
    font-size:13px;
}

body.zp-login-page .zp-btn,
body.zp-modules-page .zp-btn,
body.zp-register-page .zp-btn{
    font-size:13px;
    font-weight:900;
}

body.zp-login-page .zp-stepper span,
body.zp-modules-page .zp-stepper span,
body.zp-register-page .zp-stepper span{
    font-size:12px;
}

body.zp-login-page .zp-stepper small,
body.zp-modules-page .zp-stepper small,
body.zp-register-page .zp-stepper small{
    font-size:11px;
    font-weight:850;
}

/* /login readability */
body.zp-login-page .zp-pill{
    font-size:12px;
}

body.zp-login-page .zp-login-copy h1{
    font-size:clamp(32px,3.35vw,42px);
}

body.zp-login-page .zp-login-copy p{
    font-size:14px;
    line-height:1.5;
}

body.zp-login-page .zp-security-list strong{
    font-size:13px;
}

body.zp-login-page .zp-security-list small{
    font-size:12px;
    line-height:1.3;
}

body.zp-login-page .zp-dashboard-kpis span,
body.zp-login-page .zp-dashboard-modules span{
    font-size:12px;
}

body.zp-login-page .zp-dashboard-kpis b{
    font-size:14px;
}

body.zp-login-page .zp-login-card h1{
    font-size:27px;
}

body.zp-login-page .zp-login-card p,
body.zp-login-page .zp-login-card label,
body.zp-login-page .zp-form-line,
body.zp-login-page .zp-note,
body.zp-login-page .zp-muted{
    font-size:13px;
}

body.zp-login-page .zp-login-card input,
body.zp-login-page .zp-login-card select{
    font-size:13px;
    font-weight:750;
}

/* /client/modules readability */
body.zp-modules-page .zp-modules-layout h1{
    font-size:clamp(32px,3.35vw,42px);
}

body.zp-modules-page .zp-page-subtitle{
    font-size:14px;
    line-height:1.45;
}

body.zp-modules-page .zp-module-card{
    min-height:130px;
    padding:15px;
    gap:9px;
}

body.zp-modules-page .zp-module-card .zp-module-icon{
    width:42px;
    height:42px;
    border-radius:12px;
}

body.zp-modules-page .zp-module-card .zp-module-icon svg{
    width:20px;
    height:20px;
}

body.zp-modules-page .zp-module-card strong{
    font-size:16px;
    line-height:1.14;
    letter-spacing:-.025em;
}

body.zp-modules-page .zp-module-card small{
    font-size:13px;
    line-height:1.32;
    font-weight:650;
}

body.zp-modules-page .zp-info-banner{
    font-size:13px;
}

body.zp-modules-page .zp-selection-head h2{
    font-size:20px;
}

body.zp-modules-page .zp-selection-head b{
    font-size:12px;
}

body.zp-modules-page .zp-selected-list strong{
    font-size:13px;
}

body.zp-modules-page .zp-selected-list small{
    font-size:12px;
}

body.zp-modules-page .zp-selection-card h3{
    font-size:16px;
}

body.zp-modules-page .zp-branch-options button,
body.zp-modules-page .zp-muted,
body.zp-modules-page .zp-secure-note{
    font-size:12px;
}

/* /client/register readability */
body.zp-register-page .zp-register-visual h1{
    font-size:clamp(27px,2.6vw,33px);
}

body.zp-register-page .zp-register-visual p,
body.zp-register-page .zp-form-card>p{
    font-size:13px;
    line-height:1.43;
}

body.zp-register-page .zp-photo-stat small{
    font-size:11px;
}

body.zp-register-page .zp-photo-stat strong{
    font-size:18px;
}

body.zp-register-page .zp-photo-stat span,
body.zp-register-page .zp-selected-preview span{
    font-size:12px;
}

body.zp-register-page .zp-selected-preview strong{
    font-size:13px;
}

body.zp-register-page .zp-form-card h1{
    font-size:30px;
}

body.zp-register-page .zp-form-card label,
body.zp-register-page .zp-consent{
    font-size:12.5px!important;
}

body.zp-register-page .zp-form-card input,
body.zp-register-page .zp-form-card select{
    font-size:13px;
    font-weight:750;
}

@media (max-width:1180px){
    body.zp-modules-page .zp-module-card{
        min-height:124px;
    }
}

@media (max-width:720px){
    body.zp-login-page .zp-login-copy h1,
    body.zp-modules-page .zp-modules-layout h1,
    body.zp-register-page .zp-form-card h1{
        font-size:30px;
    }

    body.zp-modules-page .zp-module-card strong{
        font-size:16px;
    }

    body.zp-modules-page .zp-module-card small{
        -webkit-line-clamp:3;
        font-size:13px;
    }
}

/* =========================================================
   v40.67 SaaS registration sub-module selection
   ========================================================= */
body.zp-modules-page .zp-module-group{
    min-height:260px;
}
body.zp-modules-page .zp-module-group-head{
    position:absolute;
    inset:0 0 auto auto;
    width:56px;
    height:56px;
    cursor:pointer;
}
body.zp-modules-page .zp-module-group .zp-check{
    right:18px;
    top:18px;
}
body.zp-modules-page .zp-module-parent:indeterminate + .zp-check{
    background:#7dd3fc;
    border-color:#38bdf8;
}
body.zp-modules-page .zp-module-parent:indeterminate + .zp-check:after{
    content:"-";
    color:#fff;
    font-weight:950;
    position:absolute;
    inset:0;
    display:grid;
    place-items:center;
    font-size:15px;
}
body.zp-modules-page .zp-submodule-list{
    display:grid;
    gap:8px;
    margin-top:4px;
}
body.zp-modules-page .zp-submodule-option{
    display:grid;
    gap:2px;
    min-height:48px;
    padding:9px 11px 9px 34px;
    border:1px solid #dbe8f7;
    border-radius:8px;
    background:#f8fbff;
    position:relative;
    cursor:pointer;
}
body.zp-modules-page .zp-submodule-option input{
    position:absolute;
    opacity:1!important;
    left:11px;
    top:14px;
    width:14px;
    height:14px;
    accent-color:#1268ff;
}
body.zp-modules-page .zp-submodule-option span{
    color:#07152f;
    font-size:13px;
    font-weight:950;
    line-height:1.15;
}
body.zp-modules-page .zp-submodule-option small{
    color:#64748b!important;
    font-size:10.5px!important;
    font-weight:750!important;
    line-height:1.25!important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
body.zp-modules-page .zp-submodule-option.is-selected{
    border-color:#bfdbfe;
    background:#eef6ff;
    box-shadow:0 8px 20px rgba(18,104,255,.08);
}
