.patient-portal-page{min-height:calc(100vh - 52px);background:var(--color-bg);padding:var(--space-page-y) 16px 48px}.patient-portal-shell{width:min(var(--card-narrow),100%);margin:0 auto}.patient-portal-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-card);box-shadow:var(--shadow-card);padding:28px 28px 24px}.patient-portal-notice{display:flex;gap:12px;align-items:flex-start;background:#eef6ff;border:1px solid #c5daf8;border-radius:12px;padding:14px 16px;margin-bottom:24px;color:#1a3d6b;font-size:14px;line-height:1.45}.patient-portal-notice-icon{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center}.patient-portal-title{margin:0 0 8px;font-size:1.65rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.patient-portal-subtitle{margin:0 0 22px;color:var(--color-text-muted);font-size:15px;line-height:1.5}.patient-portal-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.patient-portal-field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:var(--color-text)}.patient-portal-field input,.patient-portal-field select{width:100%;border-radius:var(--radius-md);border:1px solid var(--color-border);padding:12px 14px;font-size:15px;min-height:46px}.patient-portal-submit{width:100%;min-height:50px;font-size:16px}.patient-portal-submit:disabled{opacity:.6;cursor:not-allowed}.patient-portal-footer{margin:20px 0 0;text-align:center;font-size:13px;color:var(--color-text-soft);line-height:1.5}.patient-portal-greeting{margin:0 0 4px;font-size:1.65rem;font-weight:700;color:var(--color-text)}.patient-portal-from{margin:0 0 16px;color:var(--color-text-muted);font-size:15px}.patient-portal-appointment{display:inline-flex;align-items:center;gap:8px;background:#eef6ff;border:1px solid #c5daf8;border-radius:var(--radius-pill);padding:8px 14px;font-size:14px;font-weight:600;color:#1a4d8f;margin-bottom:22px}.patient-portal-progress{margin-bottom:24px}.patient-portal-progress-meta{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:8px}.patient-portal-progress-bar{height:8px;background:#e8edf2;border-radius:var(--radius-pill);overflow:hidden}.patient-portal-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),#3b82f6);border-radius:var(--radius-pill);transition:width .3s ease}.patient-portal-section-label{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--color-text-soft);margin:0 0 10px}.patient-portal-form-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.patient-portal-form-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid #e2e8f0;border-radius:12px;background:#fafbfc}.patient-portal-form-item.is-done{background:var(--color-success-bg);border-color:#cfe8d2}.patient-portal-form-icon{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.patient-portal-form-icon.todo{background:var(--color-primary-soft);color:var(--color-primary)}.patient-portal-form-icon.done{background:#dcfce7;color:var(--color-success)}.patient-portal-form-body{flex:1;min-width:0}.patient-portal-form-name{margin:0;font-size:15px;font-weight:700;color:var(--color-text)}.patient-portal-form-desc{margin:2px 0 0;font-size:13px;color:var(--color-text-soft)}.patient-portal-practice-tag{margin:2px 0 0;font-size:12px;font-weight:600;color:var(--color-brand)}.patient-portal-start-btn{flex-shrink:0;width:auto;min-width:72px;padding:8px 18px;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;border:none;font-weight:600;font-size:14px;cursor:pointer;min-height:auto}.patient-portal-start-btn:hover{background:var(--color-primary-hover)}.patient-portal-done-label{flex-shrink:0;display:flex;align-items:center;gap:4px;color:var(--color-success);font-weight:700;font-size:14px}.patient-portal-refresh{display:block;margin:0;background:transparent;border:none;color:var(--color-link);font-size:13px;font-weight:600;cursor:pointer;width:auto;padding:4px 8px;min-height:auto}.patient-portal-refresh:hover{background:transparent}.patient-portal-error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error);border-radius:var(--radius-md);padding:10px 12px;font-size:14px;margin-bottom:14px}@media(max-width:520px){.patient-portal-fields{grid-template-columns:1fr}.patient-portal-card{padding:22px 18px 20px}}.mchat-editor-wrap{width:min(1400px,96vw);margin:0 auto;padding:24px 0 64px}.mchat-editor-wrap .card{padding:20px 24px}.mchat-editor-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}.mchat-editor-actions .mchat-publish-btn{width:auto;min-width:160px;background:#111827;color:#fff}.pdf-visual-mapper{margin-top:8px}.pdf-visual-mapper .pdf-visual-hint{font-size:13px;color:#6b7280;margin:0 0 16px}.pdf-visual-mapper .gridLayout{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}.pdf-visual-mapper .sidePanel{background:#fff;border-radius:12px;padding:18px;position:sticky;top:20px;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.pdf-visual-mapper .sidePanel h2,.pdf-visual-mapper .sidePanel h3{margin-top:0}.pdf-visual-mapper .divider{height:1px;background:#e5e7eb;margin:18px 0}.pdf-visual-mapper .fieldBlock{margin-bottom:14px}.pdf-visual-mapper .fieldBlock label{display:block;font-weight:700;margin-bottom:6px;font-size:14px;color:#111827}.pdf-visual-mapper .fieldBlock input,.pdf-visual-mapper .fieldBlock select{width:100%;padding:9px;border:1px solid #d1d5db;border-radius:8px;min-height:auto;font-size:14px;color:#111827;background:#fff}.pdf-visual-mapper .buttonStack{display:grid;gap:8px;margin-bottom:14px}.pdf-visual-mapper .buttonStack button{width:100%;padding:10px 12px;border-radius:8px;cursor:pointer;border:1px solid #d1d5db;background:#fff;color:#111827;font-weight:600;font-size:14px;min-height:auto}.pdf-visual-mapper .buttonStack button:hover{background:#f9fafb}.pdf-visual-mapper .saveMappingBtn{width:100%;padding:10px 12px;border-radius:8px;cursor:pointer;border:none;background:#111827;color:#fff;font-weight:600;font-size:14px;min-height:auto;margin-bottom:12px}.pdf-visual-mapper .saveMappingBtn:disabled{opacity:.6;cursor:not-allowed}.pdf-visual-mapper .message{background:#ecfdf5;border:1px solid #bbf7d0;color:#166534;padding:10px;border-radius:8px;font-size:14px;margin:0 0 12px}.pdf-visual-mapper .fieldEditor{margin-top:18px;border-top:1px solid #e5e7eb;padding-top:16px}.pdf-visual-mapper .fieldEditor h4{margin:0 0 12px;font-size:15px}.pdf-visual-mapper .smallText{font-size:13px;color:#374151;margin:0 0 10px}.pdf-visual-mapper .deleteFieldBtn{width:100%;padding:10px 12px;border-radius:8px;background:#fee2e2;color:#991b1b;border:1px solid #fecaca;font-weight:600;min-height:auto;margin-top:8px}.pdf-visual-mapper .pdfArea{min-height:600px}.pdf-visual-mapper .pdfLoading,.pdf-visual-mapper .pdfError{padding:24px;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.pdf-visual-mapper .pdfError{color:#991b1b;background:#fef2f2;border-color:#fecaca}.pdf-visual-mapper .pageWrapper{margin-bottom:24px}.pdf-visual-mapper .pageTitle{font-weight:700;margin-bottom:8px;color:#111827}.pdf-visual-mapper .pageCanvas{position:relative;background:#fff;box-shadow:0 2px 12px #0000002e;display:inline-block;line-height:0}.pdf-visual-mapper .pageCanvas .react-pdf__Page,.pdf-visual-mapper .pageCanvas .react-pdf__Page__canvas{display:block}.pdf-visual-mapper .mappedBox{border:2px solid #ef4444;background:#ef44441f;color:#991b1b;font-size:11px;font-weight:700;overflow:hidden;padding:2px;cursor:move;z-index:10;box-sizing:border-box}.pdf-visual-mapper .mappedBox.checkbox{border-color:#2563eb;background:#2563eb1f;color:#1e3a8a}.pdf-visual-mapper .mappedBox.radioBox{border-color:#16a34a;background:#16a34a1f;color:#166534;border-radius:50%}.pdf-overlay-fill .pageWrapper{margin-bottom:24px}.pdf-overlay-fill .pageTitle{font-weight:700;margin-bottom:8px;color:#111827}.pdf-overlay-fill .pageCanvas{position:relative;display:inline-block;line-height:0;background:#fff;box-shadow:0 2px 12px #0000001f}.pdf-overlay-fill .pageCanvas .react-pdf__Page,.pdf-overlay-fill .pageCanvas .react-pdf__Page__canvas{display:block}.pdf-overlay-fill .pageFieldLayer{position:absolute;left:0;top:0;z-index:10;pointer-events:none}.pdf-overlay-fill .pageFieldLayer .pdfTextInput,.pdf-overlay-fill .pageFieldLayer .pdfCheckbox,.pdf-overlay-fill .pageFieldLayer .pdfRadio{pointer-events:auto}.pdf-overlay-fill .pdfTextInput{position:absolute;z-index:20;background:#ffffff40;border:1px solid #2563eb;padding:2px;outline:none;color:#111827;min-height:auto;width:auto}.pdf-overlay-fill .pdfCheckbox{position:absolute;z-index:20;border:1px solid #2563eb;background:#fff3;cursor:pointer;color:#111827;font-weight:700;padding:0;min-height:auto;width:auto}.pdf-overlay-fill .pdfCheckbox.checked{background:#dbeafe80}.pdf-overlay-fill .pdfRadio{position:absolute;z-index:20;border:2px solid #16a34a;background:#16a34a1f;cursor:pointer;border-radius:50%;min-width:22px;min-height:22px;padding:0;box-sizing:border-box}.pdf-overlay-fill .pdfRadio:hover{background:#16a34a38}.pdf-overlay-fill .pdfRadio.selected{border:2px solid #111827;background:#16a34a73;box-shadow:inset 0 0 0 3px #fff}.pdf-overlay-fill .jsonBox{background:#111827;color:#d1d5db;padding:12px;border-radius:8px;overflow:auto;max-height:240px;font-size:12px}@media(max-width:900px){.pdf-visual-mapper .gridLayout{grid-template-columns:1fr}.pdf-visual-mapper .sidePanel{position:static}}:root{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "SF Mono", "SFMono-Regular", Menlo, Consolas, monospace;--color-bg: #e8f4ea;--color-bg-subtle: #f0f9f4;--color-surface: #ffffff;--color-nav: #0b2e68;--color-nav-text: #ffffff;--color-text: #0f2235;--color-text-muted: #5a6b7d;--color-text-soft: #6b7c8f;--color-brand: #2e7d32;--color-link: #2563eb;--color-border: #c5d8e8;--color-border-card: #d4e8d6;--color-border-table: #dce8ee;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-soft: #e8f0ff;--color-success: #16a34a;--color-success-bg: #f3faf4;--color-error: #b91c1c;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px;--shadow-card: 0 10px 32px rgba(15, 34, 53, .06);--shadow-card-hover: 0 12px 40px rgba(15, 34, 53, .08);--space-page-y: 32px;--container-max: 980px;--card-narrow: 520px}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}a{color:var(--color-link);text-decoration:none}a:hover{text-decoration:underline}.container{width:min(var(--container-max),94vw);margin:0 auto;padding:var(--space-page-y) 0 64px}.page-shell{min-height:calc(100vh - 52px);background:var(--color-bg);padding:var(--space-page-y) 16px 48px}.page-shell-narrow{width:min(var(--card-narrow),100%);margin:0 auto}.page-shell-wide{width:min(640px,100%);margin:0 auto}.nav,.portal-nav{background:var(--color-nav);color:var(--color-nav-text);padding:12px 0}.nav .container,.portal-nav .container{width:min(var(--container-max),94vw);margin:0 auto;padding:0 16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.nav a,.portal-nav a,.portal-nav-brand{color:var(--color-nav-text);text-decoration:none;font-weight:600;margin-left:14px}.nav a:first-of-type,.portal-nav a:first-of-type{margin-left:0}.nav a:hover,.portal-nav a:hover{text-decoration:none;opacity:.92}.portal-nav-brand{font-weight:700;font-size:1.05rem}.portal-nav-badge{font-size:.7rem;background:#22a06b;color:#fff;border-radius:var(--radius-pill);padding:3px 10px;font-weight:700}.practice-bar{background:#f0f4f8;border-bottom:1px solid #dce3ea;padding:8px 0}.practice-bar .container.practice-bar-inner{padding:0 16px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.practice-bar-org,.practice-bar-user{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.practice-bar-label{font-size:12px;color:#5a6a7a;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.practice-bar-name{font-size:14px;color:#1a2a3a;font-weight:700}.practice-bar-branch{font-size:13px;color:#2563eb;font-weight:600}.practice-bar-sep{color:#9ca3af;font-weight:300}.practice-bar-meta{font-size:12px;color:#6b7280;font-style:italic}.practice-bar-email{font-size:13px;color:#1a2a3a;font-weight:600}.practice-bar-role{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#1e40af;background:#dbeafe;border-radius:999px;padding:2px 8px}.mode-badge{font-size:.7rem;border-radius:4px;padding:1px 6px;margin-left:8px;vertical-align:middle;font-weight:700}.mode-badge-admin{background:#e67e22;color:#fff}.mode-badge-patient{background:#27ae60;color:#fff}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-card);box-shadow:var(--shadow-card);padding:24px 28px}.card.mobile,.card-centered{width:min(var(--card-narrow),95vw);margin:24px auto}.card-subtle{background:#f8fbff;border-color:var(--color-border)}.brand-kicker{font-size:13px;font-weight:600;color:var(--color-brand);margin-bottom:6px}.text-muted{color:var(--color-text-muted);font-size:14px;line-height:1.5}.text-center{text-align:center}.page-title{margin:0 0 8px;font-size:1.65rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}h1,h2,h3{margin-top:0;color:var(--color-text)}label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:var(--color-text)}input,select,textarea{width:100%;border-radius:var(--radius-md);border:1px solid var(--color-border);padding:12px 14px;min-height:46px;font-size:15px;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color .15s,box-shadow .15s}input::placeholder,textarea::placeholder{color:#9aa8b5}input:focus,select:focus,textarea:focus{outline:none;border-color:#9eb8d4;box-shadow:0 0 0 3px #2563eb1f}textarea{min-height:100px;resize:vertical}.field{margin-bottom:14px}.row{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}button{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-md);padding:12px 18px;min-height:46px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;transition:background .15s,border-color .15s,color .15s}button:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}button:disabled{opacity:.55;cursor:not-allowed}button.secondary{background:var(--color-surface);color:var(--color-link);border:2px solid var(--color-link)}button.secondary:hover:not(:disabled){background:var(--color-primary-soft);border-color:var(--color-link)}button.btn-ghost,.patient-portal-submit{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}button.btn-ghost:hover:not(:disabled),.patient-portal-submit:hover:not(:disabled){background:#f8fbff;border-color:#9eb8d4;color:var(--color-text)}button.btn-sm{width:auto;min-height:36px;padding:8px 14px;font-size:14px}button.btn-inline{width:auto}.btn-outline-link{display:block;text-align:center;padding:12px 16px;border-radius:var(--radius-md);border:2px solid var(--color-link);color:var(--color-link);font-weight:600;text-decoration:none}.btn-outline-link:hover{background:var(--color-primary-soft);text-decoration:none}.divider{margin:24px 0;border:none;border-top:1px solid #e2e8f0}.error,.alert-error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error);border-radius:var(--radius-md);padding:10px 12px;font-size:14px;margin-bottom:14px}.alert-success{background:var(--color-success-bg);border:1px solid #cfe8d2;color:#155724;border-radius:var(--radius-md);padding:10px 12px;font-size:13px}.badge{display:inline-block;border-radius:var(--radius-pill);background:var(--color-primary-soft);color:var(--color-link);padding:4px 10px;font-size:12px;font-weight:700}.table{width:100%;border-collapse:collapse;margin-top:14px;background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden}.table th,.table td{border:1px solid var(--color-border-table);padding:10px 12px;text-align:left;vertical-align:top;font-size:14px}.table th{background:#f8fafc;font-weight:600;color:var(--color-text)}.json-box{font-family:var(--font-mono);background:var(--color-text);color:#e7f0ff;border-radius:var(--radius-md);padding:12px;overflow:auto;max-height:300px;white-space:pre-wrap}.kv{display:flex;gap:10px;align-items:center;margin-bottom:8px}.kv .label{width:180px;font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:16px}.page-header h1,.page-header h2{margin:0}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.toolbar button,.toolbar .btn-inline{width:auto}@media(max-width:640px){.nav .container,.portal-nav .container{flex-direction:column;align-items:flex-start}.nav a{margin-left:0;margin-right:14px}.actions,.row{grid-template-columns:1fr}.table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.kv{flex-direction:column;align-items:flex-start;gap:2px}.kv .label{width:auto}.container{padding:16px 0 40px}.card{padding:20px 18px;border-radius:12px}}
