.frappe-login{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);min-height:100dvh;width:100%;max-width:100vw;overflow-x:hidden;background:linear-gradient(180deg,hsla(0,0%,100%,.7),rgba(238,246,248,.92)),#f5f8f9}.frappe-login-intro{position:relative;display:grid;align-content:space-between;gap:30px;overflow:hidden;padding:48px;color:#edf7f6;background:linear-gradient(140deg,#0c6861f5,#0f766ef0 58%,#0f766eee);min-width:0}.frappe-login-intro-frame{position:absolute;inset:18px;border:1px solid hsla(0,0%,100%,.09);border-radius:8px;pointer-events:none}.frappe-login-brand{position:relative;z-index:1;display:flex;align-items:center;gap:14px;min-width:0}.frappe-login-logo{width:52px;height:52px;border-radius:8px;background:#fff;box-shadow:0 18px 42px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.frappe-login-brand-text strong{display:block;font-size:18px;font-weight:700}.frappe-login-brand-text span{color:hsla(0,0%,100%,.74);font-size:13px}.frappe-login-hero{position:relative;z-index:1;min-width:0}.frappe-login-eyebrow{margin:0 0 7px;color:#a7f3d0;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.frappe-login-hero h1{margin:0;font-size:clamp(1.5rem,4vw,2.625rem);line-height:1.12;font-weight:700;word-break:break-word}.frappe-login-desc{max-width:640px;color:hsla(0,0%,100%,.78);line-height:1.65;margin:16px 0 0;font-size:15px}.frappe-login-features{position:relative;z-index:1;display:flex;gap:12px;min-width:0}.frappe-login-feature{flex:1;min-width:0;background:hsla(0,0%,100%,.1);backdrop-filter:blur(8px);border-radius:8px;padding:16px;border:1px solid hsla(0,0%,100%,.2)}.frappe-login-feature p:first-child{font-size:22px;margin:0 0 6px}.frappe-login-feature p:last-child{font-size:13px;font-weight:600;margin:0;opacity:.9;word-break:break-word}.frappe-login-form-wrap{display:grid;place-items:center;padding:42px 24px;min-width:0;align-content:center}.frappe-login-card{position:relative;display:grid;gap:20px;width:min(460px,100%);max-width:100%;border:1px solid #d7e5ea;border-radius:8px;padding:34px 28px;background:#fff;box-shadow:0 28px 90px rgba(23,33,43,.15);box-sizing:border-box}.frappe-login-card-accent{position:absolute;inset:0 0 auto;height:5px;border-radius:8px 8px 0 0;background:linear-gradient(90deg,#0c6861,#0f766e)}.frappe-login-card-icon{display:inline-grid;width:54px;height:54px;place-items:center;border:1px solid #0f766e44;border-radius:8px;color:#0c6861;background:#0f766e15;font-size:24px}.frappe-login-form-eyebrow{margin:0 0 7px;color:#0c6861;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.frappe-login-card h2{margin:0 0 6px;line-height:1.15;font-size:24px;font-weight:700}.frappe-login-form-sub{color:#687784;font-size:14px}.frappe-login-error{margin:0;border:1px solid #ffd2cc;border-radius:6px;padding:12px 14px;color:#8b1d18;background:#fff2ef;font-size:14px;word-break:break-word}.frappe-login-btn{display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border-radius:6px;width:100%;font-weight:700;font-size:14px;cursor:pointer;box-sizing:border-box;text-align:center}.frappe-login-btn:disabled{opacity:.6;cursor:not-allowed}.frappe-login-btn-primary{border:0;color:#fff;background:#0c6861;box-shadow:0 12px 26px #0c686138}.frappe-login-btn-secondary{min-height:40px;border:1px solid transparent;color:#52616d;background:#f7fafb}.frappe-login-btn-outline{min-height:40px;border:1px solid #cbd8df;color:#263642;background:#fff}.frappe-login-chevron-open{transform:rotate(180deg);transition:transform .16s}.frappe-login-local-form{display:grid;gap:14px;border-top:1px solid #e5edf1;padding-top:18px}.frappe-login-local-form label span{display:block;margin-bottom:7px;color:#334250;font-size:13px;font-weight:700}.frappe-login-input-wrap{display:flex;align-items:center;gap:9px;border:1px solid #c9d6dc;border-radius:6px;padding:0 10px;background:#fff;min-width:0}.frappe-login-input-wrap input{border:0;flex:1;min-width:0;padding:10px 0;font-size:14px;outline:none;background:transparent}@keyframes frappe-login-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.frappe-login-spin{animation:frappe-login-spin 1s linear infinite}@media (max-width:900px){.frappe-login{grid-template-columns:1fr;grid-template-rows:auto 1fr}.frappe-login-intro{padding:28px 20px 24px;gap:20px}.frappe-login-intro-frame{inset:10px}.frappe-login-hero h1{font-size:1.65rem}.frappe-login-desc{font-size:14px;margin-top:12px}.frappe-login-form-wrap{padding:20px 16px 28px;place-items:stretch}.frappe-login-card{width:100%;padding:28px 20px;box-shadow:0 16px 48px rgba(23,33,43,.12)}.frappe-login-card h2{font-size:1.35rem}}@media (max-width:600px){.frappe-login-intro{padding:20px 16px;gap:16px}.frappe-login-brand-text strong{font-size:16px}.frappe-login-hero h1{font-size:1.35rem}.frappe-login-desc{display:none}.frappe-login-features{flex-direction:column;gap:8px}.frappe-login-feature{display:flex;align-items:center;gap:10px;padding:10px 12px}.frappe-login-feature p:first-child{font-size:18px;margin:0}.frappe-login-feature p:last-child{font-size:12px}.frappe-login-form-wrap{padding:16px 12px 24px}.frappe-login-card{padding:24px 16px;gap:16px}.frappe-login-btn{font-size:13px;min-height:42px}.frappe-login-btn-primary{white-space:normal;line-height:1.35;padding:10px 12px}}