@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.react-calendar{background:#fff;border:1px solid #a0a096;width:350px;max-width:100%;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{margin:-.5em;display:flex}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar :before,.react-calendar :after{box-sizing:border-box}.react-calendar button{border:0;outline:none;margin:0}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{height:44px;margin-bottom:1em;display:flex}.react-calendar__navigation button{background:0 0;min-width:44px}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{font:inherit;justify-content:center;align-items:center;font-size:.75em;font-weight:700;display:flex}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{text-align:center;max-width:100%;font:inherit;background:0 0;padding:10px 6.6667px;font-size:.833em}.react-calendar__tile:disabled{color:#ababab;background-color:#f0f0f0}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{color:#fff;background:#006edc}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}.patient-portal-root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1d1d1f;background-color:#fff;min-height:100vh;padding-top:10px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden}.patient-portal-root *,.patient-portal-root :before,.patient-portal-root :after{box-sizing:border-box}.patient-portal-root .container.py-4{max-width:100%;padding:0 24px!important}.pp-card{-webkit-backdrop-filter:blur(20px)saturate(180%);background:#ffffffd9;border:1px solid #0000000d;border-radius:24px;margin-bottom:16px;padding:24px;transition:transform .2s,box-shadow .2s}.pp-card:hover{box-shadow:0 4px 20px #0000000f}.pp-card-dark{color:#fff;background:#000;border-radius:24px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:24px;display:flex}.pp-card-dark .pp-card-label{opacity:.7;font-size:14px;font-weight:500}.pp-card-dark .pp-card-value{font-size:22px;font-weight:700}.pp-row{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;padding:14px 0;display:flex}.pp-row:last-child{border-bottom:none}.pp-row-label{color:#1d1d1f;font-size:14px;font-weight:500}.pp-row-value{color:#1d1d1f;font-size:14px;font-weight:600}.pp-header{justify-content:space-between;align-items:flex-end;padding:32px 0 16px;display:flex}.pp-header-label{text-transform:uppercase;letter-spacing:.2em;color:#86868b;margin-bottom:4px;font-size:10px;font-weight:800}.pp-header-name{letter-spacing:-.02em;color:#1d1d1f;margin:0;font-size:26px;font-weight:800;line-height:1.15}.pp-header-sub{color:#86868b;margin-top:2px;font-size:12px}.pp-header-action{cursor:pointer;color:#86868b;background:#f2f2f7;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;transition:background .2s;display:flex}.pp-header-action:hover{background:#e5e5ea}.pp-quick-actions{gap:12px;padding:16px 0;display:flex}.pp-btn-primary{color:#fff;text-transform:uppercase;letter-spacing:.15em;cursor:pointer;background:#000;border:none;border-radius:16px;flex:1;padding:16px 20px;font-size:11px;font-weight:800;transition:transform .15s,background .2s;box-shadow:0 4px 14px #00000026}.pp-btn-primary:hover{background:#1d1d1f}.pp-btn-primary:active{transform:scale(.95)}.pp-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.pp-btn-secondary{color:#1d1d1f;text-transform:uppercase;letter-spacing:.15em;cursor:pointer;background:#fff;border:1px solid #0000001f;border-radius:16px;flex:1;padding:16px 20px;font-size:11px;font-weight:800;transition:transform .15s,background .2s}.pp-btn-secondary:hover{background:#f9f9f9}.pp-btn-secondary:active{transform:scale(.95)}.pp-btn-sm{cursor:pointer;border:none;border-radius:10px;padding:8px 16px;font-size:12px;font-weight:600;transition:transform .15s,background .2s}.pp-btn-sm:active{transform:scale(.95)}.pp-btn-sm-primary{color:#fff;background:#000}.pp-btn-sm-primary:hover{background:#1d1d1f}.pp-btn-sm-danger{color:#fff;background:#ff3b30}.pp-btn-sm-danger:hover{background:#e0342b}.pp-btn-sm-success{color:#fff;background:#34c759}.pp-btn-sm-success:hover{background:#2db34e}.pp-btn-sm-outline{color:#86868b;background:0 0;border:1px solid #0000001a}.pp-btn-sm-outline:hover{color:#1d1d1f;background:#f2f2f7}.pp-btn-full{color:#fff;cursor:pointer;background:#000;border:none;border-radius:16px;width:100%;margin-top:8px;padding:18px;font-size:15px;font-weight:700;transition:transform .15s,background .2s;box-shadow:0 4px 20px #0003}.pp-btn-full:hover{background:#1d1d1f}.pp-btn-full:active{transform:scale(.97)}.pp-btn-full:disabled{opacity:.5;cursor:not-allowed;transform:none}.pp-btn-text{color:#86868b;cursor:pointer;background:0 0;border:none;width:100%;padding:10px;font-size:14px;font-weight:700;transition:color .2s}.pp-btn-text:hover{color:#1d1d1f}.pp-segment-container{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:8px 0;overflow-x:auto}.pp-segment-container::-webkit-scrollbar{display:none}.pp-segment{background:#f2f2f7;border-radius:10px;min-width:max-content;padding:2px;display:flex}.pp-segment-btn{color:#86868b;cursor:pointer;white-space:nowrap;text-align:center;background:0 0;border:none;border-radius:8px;flex:1;padding:8px 14px;font-size:11px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.pp-segment-btn.active{color:#000;background:#fff;box-shadow:0 2px 5px #0000001a}.pp-segment-btn:hover:not(.active){color:#1d1d1f}.pp-content{padding:20px 0 100px;animation:.4s pp-fadeIn}@keyframes pp-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pp-empty{text-align:center;padding:60px 20px}.pp-empty-icon{color:#c7c7cc;background:#f5f5f7;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;font-size:18px;display:flex}.pp-empty-text{color:#86868b;font-size:14px;font-weight:500}.pp-input{color:#1d1d1f;appearance:none;background:#f5f5f7;border:none;border-radius:16px;outline:none;width:100%;margin-bottom:12px;padding:16px 18px;font-family:Inter,-apple-system,sans-serif;font-size:16px;transition:box-shadow .2s}.pp-input:focus{box-shadow:0 0 0 2px #00000026}.pp-input::placeholder{color:#86868b}.pp-input-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.pp-input-row .pp-input{margin-bottom:0}.pp-select{color:#1d1d1f;appearance:none;cursor:pointer;background:#f5f5f7 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%2386868b'/%3E%3C/svg%3E") right 18px center no-repeat;border:none;border-radius:16px;outline:none;width:100%;margin-bottom:12px;padding:16px 40px 16px 18px;font-family:Inter,-apple-system,sans-serif;font-size:16px;transition:box-shadow .2s}.pp-select:focus{box-shadow:0 0 0 2px #00000026}.pp-textarea{color:#1d1d1f;resize:vertical;background:#f5f5f7;border:none;border-radius:16px;outline:none;width:100%;min-height:80px;margin-bottom:12px;padding:16px 18px;font-family:Inter,-apple-system,sans-serif;font-size:16px;transition:box-shadow .2s}.pp-textarea:focus{box-shadow:0 0 0 2px #00000026}.pp-label{color:#86868b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.pp-form-text{color:#86868b;margin-top:-8px;margin-bottom:12px;font-size:12px}.pp-checkbox-row{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.pp-checkbox-row input[type=checkbox]{accent-color:#000;flex-shrink:0;width:20px;height:20px;margin-top:2px}.pp-checkbox-row label{color:#86868b;font-size:13px;line-height:1.5}.pp-drawer-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;position:fixed;inset:0}.pp-drawer-overlay.open{opacity:1;pointer-events:auto}.pp-drawer{z-index:101;padding:32px 28px;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px));background:#fff;border-radius:32px 32px 0 0;max-height:90vh;transition:transform .4s cubic-bezier(.32,.72,0,1);position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%)}.pp-drawer.open{transform:translateY(0)}.pp-drawer-handle{cursor:pointer;background:#d1d1d6;border-radius:3px;width:48px;height:5px;margin:0 auto 28px}.pp-drawer-title{letter-spacing:-.02em;color:#1d1d1f;margin-bottom:24px;font-size:24px;font-weight:800}.pp-drawer-section-title{color:#86868b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;font-size:13px;font-weight:700}.pp-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(12px);background:#00000073;justify-content:center;align-items:center;padding:20px;animation:.25s pp-fadeIn;display:flex;position:fixed;inset:0}.pp-modal-card{text-align:center;background:#fff;border-radius:28px;width:100%;max-width:420px;padding:32px;box-shadow:0 20px 60px #00000026}.pp-modal-card h4{color:#1d1d1f;margin:0 0 12px;font-size:20px;font-weight:700}.pp-modal-card p{color:#86868b;margin:0 0 24px;font-size:15px;line-height:1.5}.pp-modal-actions{justify-content:center;gap:12px;display:flex}.pp-modal-actions .pp-btn-sm{border-radius:14px;padding:12px 28px;font-size:14px}.pp-alert{text-align:center;border-radius:14px;margin-bottom:16px;padding:14px 18px;font-size:14px;font-weight:500}.pp-alert-success{color:#1b7a39;background:#e8f8ee}.pp-alert-danger{color:#c53030;background:#fde8e8}.pp-alert-warning{color:#856404;background:#fef3cd}.pp-alert-info{color:#2b6cb0;background:#e8f4fd}.pp-login-container{justify-content:center;align-items:flex-start;min-height:70vh;padding:20px 0 140px;display:flex}.pp-login-card{-webkit-backdrop-filter:blur(20px)saturate(180%);background:#ffffffe6;border:1px solid #0000000d;border-radius:28px;width:100%;max-width:720px;padding:40px 32px;box-shadow:0 8px 30px #0000000f}.pp-login-title{text-align:center;letter-spacing:-.02em;color:#1d1d1f;margin-bottom:8px;font-size:28px;font-weight:800}.pp-login-subtitle{color:#86868b;text-align:center;margin-bottom:32px;font-size:14px}.pp-login-row{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:4px;display:grid}@media (width<=480px){.pp-login-row{grid-template-columns:1fr}}.pp-login-new-fields{grid-template-columns:1fr 1fr;gap:12px;margin-top:4px;animation:.4s pp-fadeIn;display:grid}@media (width<=480px){.pp-login-new-fields{grid-template-columns:1fr}}.pp-procedure-card{-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border:1px solid #0000000a;border-radius:18px;margin-bottom:12px;padding:18px;transition:transform .2s}.pp-procedure-card:hover{transform:translateY(-2px)}.pp-procedure-card h6{color:#1d1d1f;margin:0 0 8px;font-size:15px;font-weight:700}.pp-procedure-meta{color:#86868b;font-size:12px;line-height:1.6}.pp-procedure-meta span{margin-right:4px}.pp-comm-log{-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border:1px solid #0000000a;border-left:3px solid #000;border-radius:14px;margin-bottom:10px;padding:16px 18px}.pp-comm-log p{color:#1d1d1f;margin:0 0 6px;font-size:14px;font-weight:500}.pp-comm-log-meta{color:#86868b;font-size:12px}.pp-appointment-card{-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border:1px solid #0000000a;border-radius:20px;margin-bottom:12px;padding:20px}.pp-appointment-card h5{color:#1d1d1f;margin:0 0 6px;font-size:16px;font-weight:700}.pp-appointment-card .pp-appointment-details{color:#86868b;margin-bottom:14px;font-size:13px}.pp-appointment-actions{gap:10px;display:flex}.pp-appointment-note{color:#86868b;margin-top:4px;font-size:12px}.pp-document-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.pp-document-card{-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border:1px solid #0000000a;border-radius:18px;flex-direction:column;min-height:140px;padding:20px;transition:box-shadow .2s;display:flex}.pp-document-card:hover{box-shadow:0 4px 16px #0000000f}.pp-document-category{color:#86868b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;font-weight:600}.pp-document-card h6{color:#1d1d1f;flex-grow:1;margin:0 0 6px;font-size:15px;font-weight:600}.pp-document-info{color:#86868b;margin-bottom:14px;font-size:12px}.pp-document-actions{gap:8px;margin-top:auto;display:flex}.pp-upload-section{background:#f5f5f7;border-radius:20px;margin-bottom:24px;padding:24px}.pp-upload-section h5{color:#1d1d1f;margin:0 0 16px;font-size:15px;font-weight:700}.pp-upload-row{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;display:grid}@media (width<=480px){.pp-upload-row{grid-template-columns:1fr}}.pp-upload-actions{gap:10px;display:flex}.pp-selected-file{background:#fff;border:1px solid #0000000a;border-radius:14px;margin-bottom:14px;padding:14px 18px}.pp-selected-file .pp-file-name{color:#1d1d1f;font-size:14px;font-weight:600}.pp-selected-file .pp-file-size{color:#86868b;font-size:12px}.pp-treatment-card{-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border:1px solid #0000000a;border-radius:20px;margin-bottom:14px;padding:22px;transition:transform .2s}.pp-treatment-card:hover{transform:translateY(-2px)}.pp-treatment-card h6{color:#1d1d1f;margin:0 0 6px;font-size:15px;font-weight:700}.pp-treatment-heading{color:#1d1d1f;margin-bottom:4px;font-size:14px;font-weight:700}.pp-treatment-note{color:#86868b;margin-bottom:12px;font-size:13px}.pp-treatment-procs{border-top:1px solid #0000000d;margin-top:4px;padding-top:12px}.pp-treatment-proc-item{color:#1d1d1f;border-bottom:1px solid #00000008;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;display:flex}.pp-treatment-proc-item:last-child{border-bottom:none}.pp-treatment-footer{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.pp-badge{letter-spacing:.02em;border-radius:10px;padding:5px 12px;font-size:11px;font-weight:600;display:inline-block}.pp-badge-dark{color:#fff;background:#1d1d1f}.pp-badge-light{color:#86868b;background:#f2f2f7}.pp-details-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;display:grid}.pp-detail-item{background:#f5f5f7;border-radius:14px;padding:14px 16px;transition:transform .2s}.pp-detail-item:hover{transform:translateY(-2px)}.pp-detail-label{color:#86868b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:11px;font-weight:600}.pp-detail-value{color:#1d1d1f;word-break:break-word;font-size:14px;font-weight:600}.pp-planned-item{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;padding:16px 0;display:flex}.pp-planned-item:last-child{border-bottom:none}.pp-planned-title{color:#1d1d1f;margin-bottom:3px;font-size:15px;font-weight:700}.pp-planned-status{color:#86868b;font-size:12px}.pp-charges-card{background:#f5f5f7;border-radius:16px;margin-bottom:16px;padding:18px;overflow-x:auto}.pp-charges-card h6{color:#1d1d1f;margin:0 0 12px;font-size:13px;font-weight:700}.pp-charges-table{border-collapse:collapse;width:100%;font-size:13px}.pp-charges-table th{color:#86868b;text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid #00000014;padding:8px 10px;font-size:10px;font-weight:600}.pp-charges-table td{color:#1d1d1f;border-bottom:1px solid #00000008;padding:10px}.pp-charges-table tfoot td{border-bottom:none;padding-top:12px;font-weight:700}.pp-receipt-details p{color:#1d1d1f;text-align:left;margin:0 0 6px;font-size:14px}.pp-receipt-details strong{color:#86868b;font-weight:600}.pp-receipt-table-wrap{margin:16px 0;overflow-x:auto}.pp-section-title{text-transform:uppercase;letter-spacing:.15em;color:#86868b;margin-bottom:16px;font-size:12px;font-weight:800}.pp-loading{-webkit-backdrop-filter:blur(8px);z-index:1050;background:#ffffffe6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pp-spinner{border:3px solid #e5e5ea;border-top-color:#000;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite pp-spin}@keyframes pp-spin{to{transform:rotate(360deg)}}.pp-spinner-inline{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;margin-right:8px;animation:.8s linear infinite pp-spin;display:inline-block}.pp-spinner-inline-dark{border-color:#1d1d1f #00000026 #00000026}@keyframes pp-shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.pp-skeleton-line{background:linear-gradient(90deg,#f0f0f0 25%,#e4e4e4 37%,#f0f0f0 63%) 0 0/1200px 100%;border-radius:6px;animation:1.4s ease-in-out infinite pp-shimmer;display:block}.pp-skeleton-card{background:#ffffffd9;border:1px solid #0000000d;border-radius:20px;margin-bottom:12px;padding:20px}@media (width<=768px){.patient-portal-root .container.py-4{padding:0 20px!important}.pp-header{padding:24px 0 12px}.pp-header-name{font-size:22px}.pp-card,.pp-card-dark{border-radius:20px;padding:20px}.pp-card-dark .pp-card-value{font-size:20px}.pp-login-card{border-radius:24px;padding:32px 24px}.pp-login-title{font-size:24px}.pp-drawer{border-radius:28px 28px 0 0;padding:28px 24px}.pp-drawer-title{font-size:20px}.pp-modal-card{border-radius:24px;padding:28px 24px}.pp-appointment-card{border-radius:16px;padding:18px}.pp-procedure-card{border-radius:14px;padding:16px}.pp-treatment-card{border-radius:16px;padding:18px}.pp-document-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.pp-details-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.pp-charges-card{border-radius:14px;padding:16px}.pp-upload-section{border-radius:16px;padding:20px}}@media (width<=640px){.patient-portal-root{padding-top:4px}.patient-portal-root .container.py-4{padding:0 16px!important}.pp-header{flex-wrap:wrap;gap:8px;padding:18px 0 10px}.pp-header-label{font-size:9px}.pp-header-name{font-size:20px}.pp-header-sub{font-size:11px}.pp-quick-actions{gap:8px;padding:12px 0}.pp-btn-primary,.pp-btn-secondary{letter-spacing:.1em;border-radius:14px;padding:14px;font-size:10px}.pp-segment-container{margin:0 -16px;padding:6px 16px}.pp-segment{border-radius:8px;padding:2px}.pp-segment-btn{border-radius:6px;padding:7px 10px;font-size:10px}.pp-card{border-radius:18px;margin-bottom:12px;padding:16px}.pp-card-dark{border-radius:18px;margin-bottom:12px;padding:18px}.pp-card-dark .pp-card-label{font-size:12px}.pp-card-dark .pp-card-value{font-size:18px}.pp-row{flex-wrap:wrap;gap:4px;padding:12px 0}.pp-row-label,.pp-row-value{font-size:13px}.pp-content{padding:16px 0 100px}.pp-login-container{min-height:60vh;padding:16px 0}.pp-login-card{border-radius:22px;padding:28px 18px;box-shadow:0 4px 20px #0000000a}.pp-login-title{margin-bottom:6px;font-size:22px}.pp-login-subtitle{margin-bottom:24px;font-size:13px}.pp-login-row{grid-template-columns:1fr;gap:0}.pp-login-row .pp-input{margin-bottom:12px}.pp-login-new-fields{grid-template-columns:1fr;gap:0}.pp-login-new-fields .pp-input{margin-bottom:12px}.pp-input{border-radius:14px;margin-bottom:12px;padding:14px 16px;font-size:16px}.pp-select{background-position:right 14px center;border-radius:14px;margin-bottom:12px;padding:14px 36px 14px 16px;font-size:16px}.pp-textarea{border-radius:14px;margin-bottom:12px;padding:14px 16px;font-size:16px}.pp-label{margin-bottom:6px;font-size:12px}.pp-form-text{margin-top:-8px;font-size:11px}.pp-input-row{grid-template-columns:1fr;gap:0}.pp-input-row .pp-input{margin-bottom:12px}.pp-btn-full{border-radius:14px;padding:16px;font-size:14px}.pp-btn-sm{border-radius:8px;padding:10px 14px;font-size:11px}.pp-btn-text{font-size:13px}.pp-alert{border-radius:12px;padding:12px 14px;font-size:13px}.pp-drawer{padding:24px 18px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));border-radius:24px 24px 0 0;max-height:92vh}.pp-drawer-handle{width:40px;height:4px;margin-bottom:20px}.pp-drawer-title{margin-bottom:18px;font-size:20px}.pp-drawer-section-title{font-size:12px}.pp-modal-overlay{align-items:flex-end;padding:12px}.pp-modal-card{padding:28px 20px;padding-bottom:calc(28px + env(safe-area-inset-bottom,0px));border-radius:22px 22px 0 0;max-width:100%;max-height:90vh;overflow:auto}.pp-modal-card h4{font-size:18px}.pp-modal-actions{flex-direction:column;gap:8px}.pp-modal-actions .pp-btn-sm{text-align:center;border-radius:12px;width:100%;padding:14px 20px;font-size:14px}.pp-appointment-card{border-radius:16px;margin-bottom:10px;padding:16px}.pp-appointment-card h5{font-size:14px}.pp-appointment-card .pp-appointment-details{font-size:12px}.pp-appointment-actions{flex-wrap:wrap;gap:6px}.pp-appointment-note{font-size:11px}.pp-procedure-card{border-radius:14px;margin-bottom:10px;padding:14px}.pp-procedure-card h6{font-size:14px}.pp-procedure-meta{font-size:11px}.pp-comm-log{border-radius:12px;margin-bottom:8px;padding:14px 16px}.pp-comm-log p{font-size:13px}.pp-comm-log-meta{font-size:11px}.pp-treatment-card{border-radius:16px;margin-bottom:10px;padding:16px}.pp-treatment-card h6{font-size:14px}.pp-treatment-heading{font-size:13px}.pp-treatment-note{font-size:12px}.pp-treatment-proc-item{padding:6px 0;font-size:12px}.pp-treatment-footer{flex-wrap:wrap}.pp-badge{padding:4px 10px;font-size:10px}.pp-document-grid{grid-template-columns:1fr;gap:10px}.pp-document-card{border-radius:14px;min-height:auto;padding:16px}.pp-document-category{font-size:10px}.pp-document-card h6{font-size:14px}.pp-document-info{font-size:11px}.pp-document-actions{flex-wrap:wrap}.pp-upload-section{border-radius:16px;margin-bottom:18px;padding:18px}.pp-upload-section h5{font-size:14px}.pp-upload-row{grid-template-columns:1fr;gap:0}.pp-upload-row .pp-input{margin-bottom:12px}.pp-upload-actions{flex-wrap:wrap;gap:8px}.pp-selected-file{border-radius:12px;padding:12px 14px}.pp-selected-file .pp-file-name{font-size:13px}.pp-details-grid{grid-template-columns:1fr;gap:8px}.pp-detail-item{border-radius:12px;padding:12px 14px}.pp-detail-label{font-size:10px}.pp-detail-value{font-size:13px}.pp-planned-item{flex-wrap:wrap;gap:8px;padding:14px 0}.pp-planned-title{font-size:14px}.pp-planned-status{font-size:11px}.pp-charges-card{-webkit-overflow-scrolling:touch;border-radius:12px;padding:14px}.pp-charges-table{min-width:480px;font-size:12px}.pp-charges-table th{padding:6px 8px;font-size:9px}.pp-charges-table td{padding:8px}.pp-receipt-details p{font-size:13px}.pp-receipt-table-wrap{-webkit-overflow-scrolling:touch;margin:12px 0}.pp-section-title{margin-bottom:12px;font-size:11px}.pp-empty{padding:40px 16px}.pp-empty-icon{width:40px;height:40px;font-size:16px}.pp-empty-text{font-size:13px}.pp-checkbox-row{gap:10px;margin-bottom:14px}.pp-checkbox-row label{font-size:12px}}@media (width<=375px){.patient-portal-root .container.py-4{padding:0 12px!important}.pp-header-name{font-size:18px}.pp-card{border-radius:16px;padding:14px}.pp-card-dark{border-radius:16px;flex-direction:column;align-items:flex-start;gap:6px;padding:14px}.pp-card-dark .pp-card-value{font-size:16px}.pp-login-card{border-radius:20px;padding:22px 14px}.pp-login-title{font-size:20px}.pp-btn-primary,.pp-btn-secondary{border-radius:12px;padding:12px 10px;font-size:9px}.pp-segment-btn{padding:6px 8px;font-size:9px}.pp-drawer{padding:20px 14px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}.pp-drawer-title{font-size:18px}.pp-modal-card{padding:22px 14px;padding-bottom:calc(22px + env(safe-area-inset-bottom,0px))}.pp-btn-full{padding:14px;font-size:13px}.pp-appointment-card h5{font-size:13px}.pp-charges-table{min-width:420px}}@media (pointer:coarse){.pp-btn-sm,.pp-btn-full,.pp-btn-text,.pp-btn-primary,.pp-btn-secondary,.pp-input,.pp-select,.pp-textarea,.pp-segment-btn{min-height:44px}.pp-header-action{width:44px;height:44px}.pp-checkbox-row input[type=checkbox]{width:22px;height:22px}}@supports (padding-bottom:env(safe-area-inset-bottom)){.patient-portal-root{padding-bottom:env(safe-area-inset-bottom,0px)}}@media (height<=500px) and (orientation:landscape){.pp-header{padding:10px 0 6px}.pp-quick-actions{padding:8px 0}.pp-content{padding:10px 0 80px}.pp-login-container{min-height:50vh}.pp-modal-overlay{align-items:center}.pp-modal-card{border-radius:22px;max-height:85vh}}.pp-mobile{background-color:#f2f2f7}body.pp-portal-logged-in{padding-top:0!important}body.pp-portal-logged-in>header,body.pp-portal-logged-in header,body.pp-portal-logged-in>footer,body.pp-portal-logged-in footer{display:none!important}@media (width>=769px){body.pp-portal-logged-in footer,body.pp-portal-logged-in .footer-wrapper,body.pp-portal-logged-in .footer-grid-wrapper,body.pp-portal-logged-in .copyright-bar{visibility:hidden!important;pointer-events:none!important;height:0!important;display:none!important;overflow:hidden!important}}.pp-mobile .container.py-4{padding:0 16px!important}.pp-mobile .pp-header-action{-webkit-backdrop-filter:blur(16px)saturate(1.3);background:linear-gradient(#ffffffd1,#ffffffa6);border:1px solid #00000014;border-radius:14px;width:42px;height:42px;box-shadow:0 2px 10px #0000000f}.pp-header-action--loading{opacity:.65;cursor:not-allowed;pointer-events:none}.pp-logout-spinner{border:2.5px solid #0000002e;border-top-color:#000000bf;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite pp-spin;display:block}.pp-mobile .pp-quick-actions{grid-template-columns:1fr 1fr;gap:10px;padding:14px 0;display:grid}.pp-mobile .pp-btn-primary{letter-spacing:.02em;text-transform:none;border-radius:18px;padding:12px;font-size:13px;font-weight:900;box-shadow:0 10px 30px #00000014}.pp-mobile .pp-btn-secondary{letter-spacing:.02em;text-transform:none;background:linear-gradient(#ffffffeb,#ffffffb8);border-radius:18px;padding:12px;font-size:13px;font-weight:900;box-shadow:0 2px 10px #0000000f}.pp-desktop-sticky-header{z-index:8;-webkit-backdrop-filter:blur(24px)saturate(1.4);background:#fffffff0;border-bottom:1px solid #0000000f;padding:0 24px;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 12px #0000000d}.patient-portal-root:not(.pp-mobile) #patientInfoContent{padding-top:250px}.pp-mobile-sticky-header{z-index:8;-webkit-backdrop-filter:blur(24px)saturate(1.4);background:#f2f2f7f0;border-bottom:1px solid #0000000f;padding:10px 16px 0;position:fixed;top:0;left:0;right:0}.pp-mobile-sticky-header .pp-mobile-tabs-wrap{-webkit-backdrop-filter:none;background:0 0;margin:0 -16px;padding:0 16px 10px;position:static}.pp-mobile #patientInfoContent{padding-top:220px;padding-bottom:140px}.pp-mobile #patientDashboard:has(.pp-mobile-sticky-header:not(:has(.pp-mobile-tabs-wrap))) #patientInfoContent{padding-top:145px}.pp-mobile .pp-card{background:linear-gradient(#fffffff2,#fffc);border:1px solid #00000014;border-radius:22px;box-shadow:0 10px 30px #00000014}.pp-mobile .pp-appointment-card{background:linear-gradient(#fffffff2,#fffc);border:1px solid #0000000f;border-radius:16px;box-shadow:0 2px 10px #0000000f}.pp-mobile .pp-procedure-card,.pp-mobile .pp-comm-log,.pp-mobile .pp-treatment-card,.pp-mobile .pp-document-card{background:linear-gradient(#fffffff2,#fffc);border:1px solid #0000000f;box-shadow:0 2px 10px #0000000f}.pp-mobile-tabs-wrap{z-index:5;-webkit-backdrop-filter:blur(18px);background:linear-gradient(#f2f2f7f5,#f2f2f7b3 70%,#f2f2f700);margin:0 -16px;padding:12px 16px 10px;position:sticky;top:0}.pp-mobile-tabs{gap:8px;display:flex}.pp-mobile-tab{color:#5b616b;cursor:pointer;user-select:none;background:linear-gradient(#ffffffd9,#ffffffa6);border:1px solid #00000014;border-radius:999px;flex:1 1 0;justify-content:center;align-items:center;gap:6px;padding:10px;font-family:inherit;font-size:12.5px;font-weight:700;transition:transform .12s,background .12s,color .12s;display:flex}.pp-mobile-tab:active{transform:scale(.99)}.pp-mobile-tab.active{color:#fff;background:#000000eb;border-color:#000000bf;box-shadow:0 6px 20px #00000029}.pp-mobile-bottom-nav{z-index:10;padding:0 16px calc(18px + env(safe-area-inset-bottom));pointer-events:none;justify-content:center;align-items:flex-end;height:160px;display:flex;position:fixed;bottom:0;left:0;right:0}.pp-mobile-nav-capsule{pointer-events:all;width:min(800px,100vw - 32px);height:68px;position:relative}.pp-mobile-nav-svg{filter:drop-shadow(0 8px 24px #0000001f)drop-shadow(0 2px 6px #0000000f);width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.pp-mobile-nav-row{justify-content:space-around;align-items:center;padding:0 6px;display:flex;position:absolute;inset:0}.pp-mobile-nav-item{color:#0000004d;cursor:pointer;user-select:none;background:0 0;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;transition:transform .14s,color .14s;display:flex;position:relative}.pp-mobile-nav-item:active{transform:scale(.86)}.pp-mobile-nav-item.active{color:#05f}.pp-mobile-nav-item.active:after{content:"";background:#05f;border-radius:999px;width:18px;height:3px;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.pp-mobile-nav-gap{pointer-events:none;flex:0 0 80px}.pp-mobile-nav-fab{z-index:2;pointer-events:all;color:#0000008c;cursor:pointer;user-select:none;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:58px;height:58px;transition:transform .14s,color .14s;display:flex;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000021,0 1px 4px #00000012,inset 0 1px #fff}.pp-mobile-nav-fab:active{transform:translate(-50%)scale(.9)}.pp-mobile-nav-fab.active{color:#05f}@media (prefers-reduced-motion:reduce){.pp-mobile-nav-item,.pp-mobile-nav-fab,.pp-mobile-tab{transition:none!important}}.pp-datepicker-wrap{margin-bottom:12px;position:relative}.pp-datepicker-input-row{align-items:center;gap:0;display:flex}.pp-datepicker-input{flex:1;border-top-right-radius:0!important;border-bottom-right-radius:0!important;margin-bottom:0!important}.pp-datepicker-input.pp-datepicker-placeholder{color:#86868b}.pp-datepicker-calendar-btn{cursor:pointer;color:#86868b;background:#f5f5f7;border:none;border-left:1px solid #0000000f;border-top-right-radius:16px;border-bottom-right-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:auto;min-height:52px;padding:0;transition:background .15s;display:flex}.pp-datepicker-calendar-btn:hover{color:#1d1d1f;background:#ebebed}.pp-datepicker-format-hint{color:#86868b;letter-spacing:.02em;margin-top:4px;font-size:11px;font-weight:500;display:block}.pp-datepicker-btn{cursor:pointer;text-align:left;justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.pp-datepicker-btn svg{color:#86868b;flex-shrink:0}.pp-datepicker-placeholder span{color:#86868b}.pp-calendar-dropdown{background:#fff;border-radius:20px;animation:.2s pp-fadeIn;overflow:hidden;box-shadow:0 12px 40px #0000001f,0 0 0 1px #0000000a}.pp-calendar-dropdown .react-calendar{background:#fff;border:none;border-radius:20px;width:320px;max-width:100%;padding:8px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.4}.pp-calendar-dropdown .react-calendar__navigation{height:44px;margin-bottom:4px}.pp-calendar-dropdown .react-calendar__navigation button{color:#1d1d1f;background:0 0;border:none;border-radius:12px;min-width:36px;padding:6px;font-size:15px;font-weight:700;transition:background .15s}.pp-calendar-dropdown .react-calendar__navigation button:hover{background:#f2f2f7}.pp-calendar-dropdown .react-calendar__navigation button:disabled{color:#d1d1d6;background:0 0}.pp-calendar-dropdown .react-calendar__month-view__weekdays{text-transform:uppercase;letter-spacing:.06em;color:#86868b;font-size:10px;font-weight:700}.pp-calendar-dropdown .react-calendar__month-view__weekdays abbr{text-decoration:none}.pp-calendar-dropdown .react-calendar__tile{color:#1d1d1f;background:0 0;border:none;border-radius:12px;padding:10px 6px;font-size:14px;font-weight:500;transition:background .15s,color .15s}.pp-calendar-dropdown .react-calendar__tile:hover{background:#f2f2f7}.pp-calendar-dropdown .react-calendar__tile--now{background:#f2f2f7;font-weight:700}.pp-calendar-dropdown .react-calendar__tile--active,.pp-calendar-dropdown .react-calendar__tile--active:enabled:hover,.pp-calendar-dropdown .react-calendar__tile--active:enabled:focus{color:#fff;background:#000;font-weight:700}.pp-calendar-dropdown .react-calendar__tile:disabled{color:#d1d1d6;background:0 0}.pp-calendar-dropdown .react-calendar__month-view__days__day--neighboringMonth{color:#c7c7cc}.pp-calendar-dropdown .react-calendar__year-view .react-calendar__tile,.pp-calendar-dropdown .react-calendar__decade-view .react-calendar__tile,.pp-calendar-dropdown .react-calendar__century-view .react-calendar__tile{border-radius:14px;padding:16px 6px;font-size:14px}.pp-calendar-overlay{z-index:9998;-webkit-backdrop-filter:blur(6px);background:#0006;position:fixed;inset:0}.pp-calendar-dropdown--mobile{border-radius:20px;box-shadow:0 20px 60px #0000002e,0 0 0 1px #0000000f;z-index:9999!important;position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.pp-calendar-dropdown--mobile .react-calendar{width:min(320px,100vw - 48px)}.pp-otp-section{-webkit-backdrop-filter:blur(12px);text-align:center;background:#f5f5f799;border:1px solid #0000000a;border-radius:20px;padding:28px 24px}.pp-otp-header{margin-bottom:24px}.pp-otp-icon{margin-bottom:12px;font-size:36px}.pp-otp-title{letter-spacing:-.02em;color:#1d1d1f;margin:0 0 6px;font-size:20px;font-weight:800}.pp-otp-subtitle{color:#86868b;margin:0;font-size:14px;line-height:1.4}.pp-otp-subtitle strong{color:#1d1d1f;font-weight:600}.pp-otp-inputs{justify-content:center;gap:8px;display:flex}.pp-otp-digit{color:#1d1d1f;text-align:center;appearance:none;background:#fff;border:2px solid #00000014;border-radius:14px;outline:none;width:48px;height:56px;font-family:Inter,-apple-system,sans-serif;font-size:22px;font-weight:700;transition:border-color .2s,box-shadow .2s,transform .15s}.pp-otp-digit:focus{border-color:#000;transform:scale(1.05);box-shadow:0 0 0 3px #0000001a}.pp-otp-digit-filled{background:#fafafa;border-color:#0003}.pp-otp-digit-error{border-color:#ff3b30;animation:.4s pp-otpShake}.pp-otp-digit-error:focus{border-color:#ff3b30;box-shadow:0 0 0 3px #ff3b3026}@keyframes pp-otpShake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.pp-otp-resend{color:#86868b;justify-content:center;align-items:center;gap:6px;margin-top:20px;font-size:13px;display:flex}.pp-otp-resend-btn{color:#000;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-family:Inter,-apple-system,sans-serif;font-size:13px;font-weight:700;transition:background .2s,color .2s}.pp-otp-resend-btn:hover{background:#0000000d}.pp-otp-resend-btn:disabled{opacity:.5;cursor:not-allowed}@media (width<=480px){.pp-otp-inputs{gap:6px}.pp-otp-digit{border-radius:12px;width:42px;height:50px;font-size:20px}.pp-otp-section{padding:24px 16px}}
