.forgot-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px 44px;background:#f8f9fa;box-sizing:border-box;margin-top:15%}.forgot-password-shell{width:100%;max-width:430px;margin:0 auto;box-sizing:border-box}.forgot-password-header{margin-bottom:18px;text-align:center}.forgot-password-header h1{margin:12px 0 0;color:#63abb2;font-size:30px;font-weight:900;line-height:1.2}.forgot-password-header p{margin:8px 0 0;color:#666;font-size:15px;line-height:1.55}.forgot-password-logo{width:76px;height:76px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#e6f3f5;border:2px solid rgba(99,171,178,.45);color:#63abb2;font-size:32px;font-weight:900;box-shadow:0 4px 12px #00000014}.forgot-password-card{width:100%;display:flex;flex-direction:column;gap:4px;padding:24px;border-radius:22px;background:#fff;border:1px solid #e6f3f5;box-shadow:0 4px 12px #00000014;box-sizing:border-box}.forgot-password-field-block{width:100%;min-width:0;box-sizing:border-box}.forgot-password-field-label{display:block;margin-bottom:8px;color:#333;font-size:14px;font-weight:500;line-height:1.4}.forgot-password-phone-row{display:grid;grid-template-columns:112px minmax(0,1fr);gap:10px;width:100%;box-sizing:border-box}.forgot-password-country-block,.forgot-password-phone-input{min-width:0}.forgot-password-form-control{display:block;width:100%;max-width:100%;min-width:0;min-height:48px;padding:12px 14px;border:1px solid #dddddd;border-radius:12px;background:#fff;color:#333;font-size:16px;line-height:1.4;outline:none;box-sizing:border-box;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.forgot-password-form-control:focus{border-color:#63abb2;box-shadow:0 0 0 3px #63abb22e}.forgot-password-form-control.is-error{border-color:#ff5252;box-shadow:0 0 0 3px #ff52521f}.forgot-password-form-control:disabled{opacity:.75;cursor:not-allowed}.forgot-password-form-control::placeholder{color:#666}.forgot-password-country-select{height:48px;padding-left:12px;padding-right:10px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.forgot-password-field-error{min-height:18px;margin:6px 0 8px;color:#ff5252;font-size:12px;line-height:1.5}.forgot-password-helper{margin:0 0 18px;color:#666;font-size:13px;line-height:1.65}.forgot-password-alert{display:flex;flex-direction:column;gap:4px;padding:12px 14px;margin-bottom:12px;border-radius:12px;font-size:14px;line-height:1.5}.forgot-password-alert-error{background:#fff0f0;color:#ff5252;border:1px solid rgba(255,82,82,.22)}.forgot-password-alert-success{background:#eefaf5;color:#2eaf7d;border:1px solid rgba(46,175,125,.24)}.forgot-password-submit-button{width:100%;min-height:54px;padding:14px 18px;border:none;border-radius:999px;background:#63abb2;color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #00000014;transition:opacity .16s ease,transform .16s ease,background .16s ease}.forgot-password-submit-button:not(:disabled):hover{transform:translateY(-1px);background:#4e8f95}.forgot-password-submit-button:disabled{opacity:.65;cursor:not-allowed}.forgot-password-back-link{display:inline-flex;justify-content:center;margin-top:16px;color:#63abb2;font-size:14px;font-weight:700;text-decoration:none}.forgot-password-back-link:hover{color:#4e8f95;text-decoration:underline}@media(max-width:640px){.forgot-password-page{align-items:flex-start;padding:34px 14px 32px}.forgot-password-shell{max-width:100%}.forgot-password-header{margin-bottom:18px}.forgot-password-header h1{font-size:28px}.forgot-password-card{padding:20px 18px;border-radius:18px}.forgot-password-phone-row{grid-template-columns:104px minmax(0,1fr);gap:8px}.forgot-password-form-control{min-height:47px;padding:11px 12px;font-size:15px}.forgot-password-country-select{height:47px}}@media(max-width:380px){.forgot-password-page{padding-left:12px;padding-right:12px}.forgot-password-card{padding:18px 16px}.forgot-password-phone-row{grid-template-columns:96px minmax(0,1fr)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px 44px;background:#f8f9fa;box-sizing:border-box;margin-top:15%}.login-shell{width:100%;max-width:430px;margin:0 auto;box-sizing:border-box}.login-brand-card{margin-bottom:18px;text-align:center}.login-brand-card h1{margin:12px 0 0;color:#63abb2;font-size:30px;font-weight:900;line-height:1.2}.login-brand-card p{margin:8px 0 0;color:#666;font-size:15px;line-height:1.5}.login-logo-wrap{width:50%;height:50%;display:inline-flex;align-items:center;justify-content:center}.login-logo-image{display:block;width:100%;height:100%;object-fit:contain}.login-card{width:100%;display:flex;flex-direction:column;gap:4px;padding:24px;border-radius:22px;background:#fff;border:1px solid #e6f3f5;box-shadow:0 4px 12px #00000014;box-sizing:border-box}.login-field-block{width:100%;min-width:0;box-sizing:border-box}.login-field-label{display:block;margin-bottom:8px;color:#333;font-size:14px;font-weight:500;line-height:1.4}.login-phone-row{display:grid;grid-template-columns:112px minmax(0,1fr);gap:10px;width:100%;box-sizing:border-box}.login-country-block,.login-phone-input{min-width:0}.login-form-control{display:block;width:100%;max-width:100%;min-width:0;min-height:48px;padding:12px 14px;border:1px solid #dddddd;border-radius:12px;background:#fff;color:#333;font-size:16px;line-height:1.4;outline:none;box-sizing:border-box;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.login-form-control:focus{border-color:#63abb2;box-shadow:0 0 0 3px #63abb22e}.login-form-control.is-error{border-color:#ff5252;box-shadow:0 0 0 3px #ff52521f}.login-form-control::placeholder{color:#666}.login-country-select{height:48px;padding-left:12px;padding-right:10px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.login-field-error{min-height:18px;margin:6px 0 10px;color:#ff5252;font-size:12px;line-height:1.5}.login-alert{display:flex;flex-direction:column;gap:4px;padding:12px 14px;margin-bottom:12px;border-radius:12px;font-size:14px;line-height:1.5}.login-alert-error{background:#fff0f0;color:#ff5252;border:1px solid rgba(255,82,82,.22)}.login-links-row{display:flex;justify-content:flex-end;margin:-2px 0 14px}.login-text-link,.login-register-link{color:#63abb2;font-size:14px;font-weight:700;text-decoration:none}.login-text-link:hover,.login-register-link:hover{color:#4e8f95;text-decoration:underline}.login-submit-button{width:100%;min-height:54px;padding:14px 18px;border:none;border-radius:999px;background:#63abb2;color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #00000014;transition:opacity .16s ease,transform .16s ease,background .16s ease}.login-submit-button:not(:disabled):hover{transform:translateY(-1px);background:#4e8f95}.login-submit-button:disabled{opacity:.65;cursor:not-allowed}.login-register-link{display:inline-flex;justify-content:center;margin-top:16px}@media(max-width:640px){.login-page{align-items:flex-start;padding:34px 14px 32px}.login-shell{max-width:100%}.login-brand-card{margin-bottom:18px}.login-brand-card h1{font-size:28px}.login-card{padding:20px 18px;border-radius:18px}.login-phone-row{grid-template-columns:104px minmax(0,1fr);gap:8px}.login-form-control{min-height:47px;padding:11px 12px;font-size:15px}.login-country-select{height:47px}}@media(max-width:380px){.login-page{padding-left:12px;padding-right:12px}.login-card{padding:18px 16px}.login-phone-row{grid-template-columns:96px minmax(0,1fr)}}:root{--mission-primary: #63abb2;--mission-primary-dark: #4e8f95;--mission-primary-light: #e6f3f5;--mission-secondary: #ffb347;--mission-bg: #f8f9fa;--mission-surface: #ffffff;--mission-text: #333333;--mission-text-muted: #666666;--mission-border: #dddddd;--mission-error: #ff5252;--mission-success: #2eaf7d;--mission-warning: #f5a524}.mission-page{min-height:100vh;background:radial-gradient(circle at top left,rgba(99,171,178,.18),transparent 30%),var(--mission-bg);color:var(--mission-text);padding:24px 16px 40px;box-sizing:border-box}.mission-page--center{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px}.mission-shell{width:100%;max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.mission-hero-card,.mission-card,.mission-member-card{background:var(--mission-surface);border:1px solid rgba(99,171,178,.14);border-radius:28px;box-shadow:0 12px 32px #1e484e14;overflow:hidden}.mission-hero-image-wrap{position:relative;min-height:260px;background:var(--mission-primary-light)}.mission-hero-image,.mission-hero-placeholder{width:100%;display:block;object-fit:cover}.mission-hero-placeholder{display:flex;align-items:center;justify-content:center;color:var(--mission-primary-dark);font-size:22px;font-weight:800}.mission-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000000d,#0000002e 42%,#0000009e)}.mission-hero-copy{position:absolute;left:22px;right:22px;bottom:22px;color:#fff}.mission-hero-copy h1{margin:12px 0 8px;font-size:30px;line-height:1.15;letter-spacing:-.02em}.mission-hero-copy p{margin:0;font-size:15px;opacity:.92}.mission-category-pill,.mission-section-kicker{display:inline-flex;align-items:center;width:fit-content;font-size:12px;font-weight:800;letter-spacing:.02em;border-radius:999px}.mission-category-pill{padding:7px 12px;background:#63abb2f5;color:#fff}.mission-section-kicker{margin:0 0 8px;color:var(--mission-primary-dark);text-transform:none}.mission-member-card{padding:20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.mission-member-card h2{margin:0 0 6px;font-size:22px;line-height:1.25}.mission-member-card p{margin:0;color:var(--mission-text-muted);font-size:14px}.member-status{min-width:116px;border-radius:20px;padding:12px 14px;text-align:center;border:1px solid var(--mission-border);background:#fafafa}.member-status span,.member-status strong{display:block}.member-status span{font-size:11px;color:var(--mission-text-muted);margin-bottom:4px}.member-status strong{font-size:16px}.member-status--approved{background:#2eaf7d1a;border-color:#2eaf7d3d;color:var(--mission-success)}.member-status--pending{background:#f5a5241f;border-color:#f5a52447;color:#a86900}.member-status--rejected{background:#ff52521a;border-color:#ff52523d;color:var(--mission-error)}.mission-card{padding:22px}.mission-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}.mission-card-header--simple{margin-bottom:14px}.mission-card h2,.mission-card h3{margin:0;color:var(--mission-text)}.mission-card h2{font-size:22px;line-height:1.25}.mission-card h3{font-size:18px}.mission-join-card{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#fff,#f2fbfc)}.mission-join-card p{margin:8px 0 0;color:var(--mission-text-muted);line-height:1.55}.mission-primary-btn,.mission-secondary-btn{border:0;border-radius:999px;min-height:46px;padding:0 18px;font-size:15px;font-weight:800;cursor:pointer;transition:transform .16s ease,opacity .16s ease,box-shadow .16s ease;white-space:nowrap}.mission-primary-btn{color:#fff;background:var(--mission-primary);box-shadow:0 10px 22px #63abb23d}.mission-secondary-btn{color:var(--mission-primary-dark);background:var(--mission-primary-light)}.mission-primary-btn:hover,.mission-secondary-btn:hover{transform:translateY(-1px)}.mission-primary-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.mission-status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:32px;border-radius:999px;padding:0 12px;font-size:13px;font-weight:800;color:var(--mission-primary-dark);background:var(--mission-primary-light);white-space:nowrap}.mission-status-pill--completed,.mission-status-pill--approved{color:var(--mission-success);background:#2eaf7d1f}.mission-status-pill--rejected,.mission-status-pill--expired{color:var(--mission-error);background:#ff52521a}.mission-status-pill--under_review,.mission-status-pill--submitted{color:#a86900;background:#f5a52424}.mission-qr-content{display:flex;flex-direction:column;align-items:center;text-align:center}.mission-qr-frame{width:270px;height:270px;max-width:100%;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid rgba(99,171,178,.18);border-radius:28px;box-shadow:inset 0 0 0 10px #f8fbfb,0 12px 32px #14323714;margin:4px auto 18px}.mission-qr-expire,.mission-qr-token,.mission-qr-hint{margin:0}.mission-qr-expire{font-weight:800;color:var(--mission-text)}.mission-qr-token{margin-top:8px;font-size:12px;color:var(--mission-text-muted);letter-spacing:.05em;word-break:break-all}.mission-qr-hint{max-width:430px;margin-top:12px;color:var(--mission-text-muted);line-height:1.6}.mission-qr-content .mission-secondary-btn{margin-top:18px}.mission-completed-box,.mission-empty-qr-box,.mission-error-card{border-radius:22px;padding:20px;text-align:center}.mission-completed-box{background:#2eaf7d1a;color:var(--mission-success)}.mission-completed-box p,.mission-completed-box span,.mission-empty-qr-box p{color:var(--mission-text-muted);line-height:1.6}.mission-empty-qr-box{background:#f9fbfb;border:1px dashed rgba(99,171,178,.35)}.mission-info-list{display:flex;flex-direction:column;border-top:1px solid rgba(221,221,221,.72)}.mission-info-row{display:grid;grid-template-columns:120px minmax(0,1fr);gap:14px;padding:14px 0;border-bottom:1px solid rgba(221,221,221,.72)}.mission-info-row span{color:var(--mission-text-muted);font-size:14px}.mission-info-row strong{font-size:14px;text-align:right;word-break:break-word}.mission-body-text{margin:0;color:var(--mission-text-muted);line-height:1.75;white-space:pre-line}.mission-error-banner{border-radius:18px;padding:14px 16px;color:var(--mission-error);background:#ff525214;border:1px solid rgba(255,82,82,.18);font-weight:700}.mission-error-card{width:min(420px,100vw - 32px);background:#fff;border:1px solid rgba(255,82,82,.18);box-shadow:0 12px 32px #1e484e14}.mission-error-card h1{margin:0 0 10px;font-size:22px}.mission-error-card p{color:var(--mission-text-muted);line-height:1.6}.mission-loader{width:34px;height:34px;border-radius:999px;border:4px solid var(--mission-primary-light);border-top-color:var(--mission-primary);animation:missionSpin .8s linear infinite}@keyframes missionSpin{to{transform:rotate(360deg)}}.mission-logout-area{margin-top:22px;padding-top:18px;border-top:1px solid rgba(221,221,221,.9);display:flex;justify-content:center}.mission-logout-area--no-border{margin-top:0;padding-top:0;border-top:0}.mission-card--logout-only{padding-top:18px;padding-bottom:18px}.mission-logout-btn{border:0;background:transparent;color:#ff5252;font-size:14px;font-weight:700;cursor:pointer;padding:10px 14px;border-radius:999px;transition:background .2s ease,transform .2s ease}.mission-logout-btn:hover{background:#ff525214;transform:translateY(-1px)}.mission-logout-btn:active{transform:translateY(0)}@media(max-width:640px){.mission-page{padding:14px 12px 32px}.mission-shell{gap:14px}.mission-hero-card,.mission-card,.mission-member-card{border-radius:24px}.mission-hero-copy{left:18px;right:18px;bottom:18px}.mission-hero-copy h1{font-size:25px}.mission-member-card,.mission-join-card,.mission-card-header{flex-direction:column;align-items:stretch}.mission-member-card{padding:18px}.member-status{width:100%;box-sizing:border-box}.mission-card{padding:18px}.mission-primary-btn,.mission-secondary-btn{width:100%}.mission-status-pill{width:fit-content}.mission-qr-frame{width:248px;height:248px}.mission-info-row{grid-template-columns:1fr;gap:6px}.mission-info-row strong{text-align:left}}.register-page{min-height:100vh;background:#f8f9fa;padding:24px 16px 44px;box-sizing:border-box}.register-shell{width:100%;max-width:760px;margin:0 auto;box-sizing:border-box}.register-header{text-align:center;margin-bottom:24px}.register-header h1{margin:0;color:#63abb2;font-size:28px;font-weight:900;line-height:1.2}.register-header p{max-width:520px;margin:10px auto 0;color:#666;font-size:16px;line-height:1.6}.register-form{display:flex;flex-direction:column;gap:18px}.section-card,.submit-card{width:100%;background:#fff;border:1px solid #e6f3f5;border-radius:22px;box-shadow:0 4px 12px #00000014;padding:24px;box-sizing:border-box}.section-heading{margin-bottom:18px}.section-heading h2{margin:0;color:#333;font-size:18px;font-weight:700;line-height:1.35}.section-heading p{margin:6px 0 0;color:#666;font-size:14px;line-height:1.5}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;width:100%;box-sizing:border-box}.birthday-email-row{grid-template-columns:minmax(0,220px) minmax(0,1fr)}.field-block{width:100%;min-width:0;margin-bottom:4px;box-sizing:border-box}.birthday-field{max-width:220px}.field-label{display:block;margin-bottom:8px;color:#333;font-size:14px;font-weight:500;line-height:1.4}.form-control{display:block;width:100%;max-width:100%;min-width:0;min-height:48px;padding:12px 14px;border:1px solid #dddddd;border-radius:12px;background:#fff;color:#333;font-size:16px;line-height:1.4;outline:none;box-sizing:border-box;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.form-control:focus{border-color:#63abb2;box-shadow:0 0 0 3px #63abb22e}.form-control.is-error{border-color:#ff5252;box-shadow:0 0 0 3px #ff52521f}.form-control::placeholder{color:#666}.form-control[type=date]{max-width:100%;min-width:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.document-upload.is-error,.checkbox-row.is-error{border-color:#ff5252;box-shadow:0 0 0 3px #ff52521f}.field-error{min-height:18px;margin:6px 0 0;color:#ff5252;font-size:12px;line-height:1.5}.field-hint{margin:6px 0 0;color:#666;font-size:12px;line-height:1.5}.form-alert{padding:12px 14px;border-radius:12px;font-size:14px;line-height:1.5}.form-alert-error{background:#fff0f0;color:#ff5252;border:1px solid rgba(255,82,82,.22)}.form-alert-success{background:#e6f3f5;color:#4e8f95;border:1px solid rgba(99,171,178,.28);font-weight:600}.profile-upload-row{display:flex;align-items:center;gap:16px;margin-bottom:18px}.profile-upload-button{cursor:pointer}.profile-upload-button input{display:none}.profile-preview{width:96px;height:96px;display:flex;align-items:center;justify-content:center;border-radius:999px;border:2px solid #63abb2;background:#e6f3f5;color:#63abb2;overflow:hidden;font-size:30px;font-weight:700}.profile-preview img{width:100%;height:100%;object-fit:cover}.upload-title{margin:0;color:#333;font-size:16px;font-weight:700;line-height:1.4}.upload-hint{margin:4px 0 0;color:#666;font-size:13px;line-height:1.5}.step-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;color:#666;font-size:13px;line-height:1.4}.phone-card{padding:18px;border-radius:18px;background:#e6f3f5;border:1px solid rgba(99,171,178,.5);box-sizing:border-box}.phone-row{display:grid;grid-template-columns:118px minmax(0,1fr);gap:10px;width:100%}.country-select{height:48px;padding-left:12px;padding-right:10px;-moz-appearance:none;appearance:none;-webkit-appearance:none}.phone-input{min-width:0}.otp-button{width:100%;min-height:48px;margin-top:4px;border:none;border-radius:12px;background:#ffb347;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .16s ease,transform .16s ease}.otp-button:not(:disabled):hover{transform:translateY(-1px)}.otp-button:disabled{opacity:.65;cursor:not-allowed}.otp-field-block{margin-top:16px}.otp-header-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.otp-badge{padding:4px 8px;border-radius:999px;background:#fff;color:#4e8f95;font-size:12px;font-weight:700}.otp-hidden-error{margin-top:10px}.document-upload{width:100%;min-height:150px;display:flex;align-items:center;justify-content:center;padding:18px;border:1.5px dashed #63abb2;border-radius:18px;background:#e6f3f5;color:#666;cursor:pointer;text-align:center;box-sizing:border-box;overflow:hidden}.document-upload input{display:none}.document-upload span{color:#666;font-size:14px;font-weight:600}.document-upload img{width:100%;max-height:230px;object-fit:contain;border-radius:12px}.checkbox-row{display:flex;align-items:flex-start;gap:10px;margin-top:12px;padding:13px 14px;border:1px solid transparent;border-radius:12px;background:#f8f9fa;color:#666;font-size:14px;line-height:1.5;cursor:pointer;box-sizing:border-box}.checkbox-row input{width:18px;height:18px;margin-top:1px;accent-color:#63abb2;flex:0 0 auto}.submit-card{display:flex;flex-direction:column;align-items:stretch;gap:14px}.submit-button{width:100%;min-height:54px;padding:14px 18px;border:none;border-radius:999px;background:#63abb2;color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #00000014;transition:opacity .16s ease,transform .16s ease}.submit-button:not(:disabled):hover{transform:translateY(-1px)}.submit-button:disabled{opacity:.65;cursor:not-allowed}.back-link{display:inline-flex;justify-content:center;color:#63abb2;font-size:14px;font-weight:700;text-decoration:none}@media(max-width:640px){.register-page{padding:18px 14px 32px}.register-shell{max-width:100%}.section-card,.submit-card{padding:18px;border-radius:18px}.register-header{margin-bottom:20px}.register-header h1{font-size:26px}.register-header p{font-size:15px}.form-row,.birthday-email-row{grid-template-columns:minmax(0,1fr);gap:0}.birthday-field{max-width:100%}.phone-card{padding:16px}.phone-row{grid-template-columns:104px minmax(0,1fr);gap:8px}.form-control{min-height:47px;padding:11px 12px;font-size:15px}.country-select{height:47px}.profile-upload-row{align-items:flex-start}.profile-preview{width:82px;height:82px}}@media(max-width:380px){.register-page{padding-left:12px;padding-right:12px}.section-card,.submit-card{padding:16px}.phone-row{grid-template-columns:96px minmax(0,1fr)}}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:#f8f9fa;color:#333}.route-loading{min-height:100vh;display:grid;place-items:center;padding:24px;color:#666;background:#f8f9fa;box-sizing:border-box}
