@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}:root{--primary:#2c5f8a;--primary-light:#4a7fa5;--accent:#e8834a;--accent-hover:#f09869;--bg:#f8f9fb;--surface:#fff;--text-primary:#1a2332;--text-secondary:#4a5568;--border:#e2e8f0;--success:#38a169;--warning:#d97706;--danger:#e53e3e;--shadow:0 4px 20px #1a23321a;--bg-pearl:#f8f9fb;--bg-mist:#eef2f7;--ink-900:#1a2332;--ink-700:#4a5568;--ink-500:#718096;--ink-300:#a0aec0;--accent-ocean:#2c5f8a;--accent-coral:#e8834a;--accent-leaf:#38a169;--line-soft:#e2e8f0;--shadow-soft:0 4px 20px #1a23321a}body{color:var(--ink-900);background:#f8f9fb;min-height:100vh;font-family:Inter,sans-serif;font-size:16px;line-height:1.6}.shell{max-width:1200px;margin:0 auto;padding:0;animation:.5s ease-out both reveal}.phone{background:#fff;border:none;border-radius:0;flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.tab-bar{gap:10px;margin-bottom:16px;display:flex}.tab{border:1px solid var(--line-soft);color:var(--ink-700);cursor:pointer;background:#ffffffdb;border-radius:999px;padding:10px 16px;font-size:13px;font-weight:600;transition:transform .18s,background .18s,color .18s}.tab:hover{transform:translateY(-1px)}.tab.on{background:linear-gradient(135deg, var(--accent-ocean), #4a7fa5);color:#fff;border-color:#0000}.topbar{z-index:10;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:16px;padding:16px 32px;display:flex;position:sticky;top:0;box-shadow:0 1px 6px #0000000f}.topbar-left{min-width:0}.brand-wrap{color:inherit;cursor:pointer;background:0 0;border:0;align-items:center;gap:10px;display:flex}.brand-logo{object-fit:cover;width:38px;height:38px;box-shadow:none;background:0 0;border:none;border-radius:50%;padding:0;display:block}.topbar-kicker{letter-spacing:.14em;color:var(--ink-500);margin-bottom:4px;font-size:10px;font-weight:700}.topbar-brand{color:var(--ink-900);font-family:Playfair Display,serif;font-size:24px;line-height:1;display:block}.topbar-nav{align-items:center;gap:8px;display:flex}.nav-btn{box-shadow:none;color:var(--ink-700);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-family:Inter,sans-serif;font-size:15px;font-weight:600;transition:color .15s}.btn-p.nav-btn,.btn-s.nav-btn{box-shadow:none;color:var(--ink-700);background:0 0;border:none}.nav-btn:hover,.btn-p.nav-btn:hover,.btn-s.nav-btn:hover{color:var(--accent-ocean);box-shadow:none;background:0 0;transform:none}.signal-dot{background:#95e2bb;border-radius:50%;width:12px;height:12px;box-shadow:0 0 0 6px #95e2bb2e}.topbar-user-area{align-items:center;gap:8px;display:flex}.nav-auth-btn{padding:9px 18px}.nav-auth-btn.admin-btn{color:#fff;background:linear-gradient(135deg,#4a7fa5,#2c5f8a);border-color:#0000;font-weight:600;transition:all .2s}.nav-auth-btn.admin-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2c5f8a4d}.user-chip{color:#fff;white-space:nowrap;text-overflow:ellipsis;background:#ffffff2e;border:1px solid #ffffff4d;border-radius:999px;max-width:200px;padding:6px 10px;font-size:12px;font-weight:600;overflow:hidden}.btn-logout{color:var(--ink-700);background:#fff;border-color:#e2e8f0;padding:8px 12px}.body{flex:1;overflow-y:auto}.hero-band{background:#fff;border-bottom:1px solid #e2e8f0;align-items:stretch;min-height:440px;display:flex;overflow:hidden}.hero-image-panel{flex:0 0 42%;position:relative;overflow:hidden}.hero-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.hero-content{background:linear-gradient(135deg,#ebf2f9 0%,#fff 70%);flex-direction:column;flex:1;justify-content:center;padding:48px 44px 40px;display:flex}.hero-text-wrap{animation:.43s ease-out both floatIn}.hero-eyebrow{color:var(--accent-ocean);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:700}.hero-band h1{color:#1a2332;max-width:560px;margin-bottom:14px;font-family:Playfair Display,serif;font-size:clamp(40px,4.5vw,52px);font-weight:700;line-height:1.05}.hero-sub{color:var(--ink-700);max-width:480px;font-size:18px;line-height:1.65}.hero-actions{flex-wrap:wrap;gap:12px;margin:24px 0 28px;display:flex}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.pro-marquee{background:#f8f9fb;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:12px 0 14px;overflow:hidden}.pro-marquee-head{justify-content:space-between;align-items:center;gap:10px;padding:0 14px 10px;display:flex}.pro-marquee-title{color:#2c5f8a;text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:700}.pro-marquee-controls{gap:8px;display:flex}.marquee-control-btn{color:#2c5f8a;cursor:pointer;background:#fff;border:1px solid #c8dbf0;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700;transition:transform .18s,background .18s}.marquee-control-btn:hover{background:#ebf2f9;transform:translateY(-1px)}.pro-marquee-viewport{scrollbar-width:none;scroll-behavior:smooth;cursor:grab;overflow:auto hidden}.pro-marquee-viewport::-webkit-scrollbar{display:none}.pro-marquee-track{gap:12px;width:max-content;padding:0 14px;display:flex}.pro-marquee-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex:none;width:315px;padding:16px;box-shadow:0 1px 4px #0000000f}.pro-marquee-name{color:#1a2332;font-size:16.5px;font-weight:700}.pro-marquee-role{color:var(--accent-ocean);margin-top:3px;font-size:14.5px;font-weight:700}.pro-marquee-meta{color:var(--ink-500);margin-top:8px;font-size:13.5px}.pro-marquee-review{color:var(--ink-700);margin-top:10px;font-size:14.5px;font-style:italic;line-height:1.55}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:4px;padding:16px;animation:.55s ease-out both riseIn;display:flex;box-shadow:0 1px 4px #0000000d}.stat-card:nth-child(2){animation-delay:.12s}.stat-card:nth-child(3){animation-delay:.22s}.stat-value{color:#1a2332;font-family:Playfair Display,serif;font-size:28px}.stat-label{color:var(--ink-500);font-size:13px;font-weight:500}.section-wrap{padding:60px 40px}.services-section{background:#f8f9fb;padding:60px 40px}.services-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.service-item{border-top:3px solid var(--accent-ocean);margin-bottom:0;transition:box-shadow .2s,transform .2s}.service-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2c5f8a1f}.service-name{color:#1a2332;font-size:18px;font-weight:700}.service-copy{color:var(--ink-500);margin-top:8px;font-size:15px;line-height:1.55}.service-select-btn{width:100%;margin-top:14px}.provider-selection-wrap{padding-top:24px}.selected-service-copy{color:var(--ink-700);margin-bottom:14px;font-size:15px}.location-badge{color:#0f6e8c;background-color:#e8f5ff;border:1px solid #b3deff;border-radius:20px;margin-bottom:16px;padding:8px 12px;font-size:13px;font-weight:500;display:inline-block}.provider-discovery-controls{background-color:#f8fbff;border:1px solid #d3e2f1;border-radius:12px;margin-bottom:20px;padding:16px}.discovery-search{margin-bottom:12px}.provider-selection-grid{gap:20px;display:grid}.provider-selection-card{margin-bottom:0;transition:box-shadow .2s,transform .2s}.provider-selection-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.provider-selection-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.provider-selection-identity{align-items:center;gap:10px;display:flex}.provider-selection-avatar{object-fit:cover;background:#fff;border:2px solid #d3e2f1;border-radius:50%;flex-shrink:0;width:52px;height:52px}.provider-selection-avatar-fallback{color:#fff;background:#2c5f8a;place-items:center;font-size:18px;font-weight:700;display:grid}.provider-selection-name{color:#1a2332;font-size:20px;font-weight:700}.provider-selection-service{color:var(--accent-ocean);margin-top:4px;font-size:15px;font-weight:600}.provider-selection-rate{color:#2c5f8a;white-space:nowrap;background:#ebf2f9;border:1px solid #c8dbf0;border-radius:8px;padding:4px 10px;font-size:13px;font-weight:700}.provider-selection-meta{color:var(--ink-500);margin-top:8px;font-size:15px}.book-now-btn{width:100%;margin-top:16px}.home-footer{color:var(--ink-500);background:#fff;border-top:1px solid #e2e8f0;border-radius:0;gap:8px;margin:0;padding:28px;font-size:14px;display:grid}.social-row{gap:8px;margin-top:2px;display:flex}.social-pill{color:#2c5f8a;background:#f0f6fd;border:1px solid #c8dbf0;border-radius:999px;place-items:center;min-width:36px;height:32px;text-decoration:none;transition:all .2s;display:grid}.social-pill:hover{color:#fff;background:#2c5f8a;border-color:#2c5f8a}.copyright{color:var(--ink-500);margin-top:2px}.profile-card{max-width:560px}.profile-name{color:#1a2332;margin-bottom:8px;font-size:20px;font-weight:700}.profile-line{color:var(--ink-700);margin-bottom:4px;font-size:14px}.customer-profile-wrap{padding:60px 40px}.profile-editor-card{max-width:760px}.profile-editor-title{color:#1a2332;margin-bottom:20px;font-family:Playfair Display,serif;font-size:32px}.profile-editor-grid{grid-template-columns:180px 1fr;gap:24px;display:grid}.profile-photo-col{flex-direction:column;gap:10px;display:flex}.profile-avatar{object-fit:cover;border:1px solid var(--line-soft);border-radius:20px;width:160px;height:160px;box-shadow:0 8px 16px #2c5f8a24}.upload-photo-btn{text-align:center}.profile-input{width:100%;margin-bottom:12px}.profile-editor-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.profile-save-message{color:#2c5f8a;font-size:13px;font-weight:700}.history-scroll-row{scroll-snap-type:x mandatory;gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.history-card{scroll-snap-align:start;flex:none;min-width:360px;max-width:400px}.history-card-head{border-bottom:1px solid #f0f4f8;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:12px;display:flex}.history-id{color:#1a2332;font-size:18px;font-weight:700}.history-status{text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;border-radius:999px;padding:5px 12px;font-size:11px;font-weight:700}.history-status.in_progress{color:#2c5f8a;background:#ebf2f9;border:1px solid #c8dbf0}.history-status.pending{color:#d97706;background:#fff8e8;border:1px solid #f3d394}.history-status.rejected{color:#e53e3e;background:#fff1ef;border:1px solid #f1c0ba}.history-status.completed{color:#38a169;background:#edf9f2;border:1px solid #bee3cf}.history-line{color:var(--ink-700);margin-bottom:10px;font-size:15px;line-height:1.55}.history-in-progress{margin-top:8px}.history-rating-wrap{margin-top:10px}.rating-row{gap:6px;display:flex}.star-btn{border:1px solid var(--line-soft);color:#9db0bd;cursor:pointer;background:#fff;border-radius:10px;width:36px;height:36px;font-size:20px;line-height:1}.star-btn.active{color:#e8834a;background:#fff6f1;border-color:#efc2ac}.service-provider-wrap{padding:60px 40px}.provider-about-card{max-width:760px}.provider-about-title{color:#1a2332;margin-bottom:20px;font-family:Playfair Display,serif;font-size:32px}.provider-about-grid{grid-template-columns:180px 1fr;gap:24px;display:grid}.provider-photo-col{flex-direction:column;gap:10px;display:flex}.provider-avatar{object-fit:cover;border:1px solid var(--line-soft);border-radius:20px;width:160px;height:160px;box-shadow:0 8px 16px #2c5f8a24}.provider-fields-col{display:block}.provider-request-grid{gap:12px;display:grid}.provider-request-card{margin-bottom:0}.provider-request-actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.request-customer-head{align-items:center;gap:8px;display:flex}.request-customer-avatar{object-fit:cover;background:#fff;border:1px solid #d7e3ef;border-radius:50%;flex-shrink:0;width:34px;height:34px}.request-customer-avatar-fallback{color:#fff;background:#4a7fa5;place-items:center;font-size:14px;font-weight:700;display:grid}.modal-overlay{z-index:30;background:#05111880;place-items:center;padding:12px;display:grid;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:min(100%,520px);padding:20px;box-shadow:0 8px 40px #0000001f}.modal-title{color:#1a2332;border-bottom:1px solid #f0f4f8;margin-bottom:16px;padding-bottom:12px;font-family:Playfair Display,serif;font-size:22px}.modal-customer-summary{background:#f8fbff;border:1px solid #deebf8;border-radius:10px;align-items:center;gap:10px;margin-bottom:14px;padding:10px 12px;display:flex}.modal-customer-name{color:#1a2332;font-size:15px;font-weight:700}.modal-customer-sub{color:var(--ink-500);margin-top:1px;font-size:13px}.invoice-wrap{padding:60px 40px}.invoice-card{max-width:680px}.invoice-title{color:#1a2332;border-bottom:2px solid #e2e8f0;margin-bottom:20px;padding-bottom:16px;font-family:Playfair Display,serif;font-size:32px}.invoice-total{color:#1a2332;border-top:2px solid #e2e8f0;margin-top:12px;padding-top:12px;font-size:20px;font-weight:700}.confirmation-wrap{padding-top:22px}.confirmation-card{background:#fff;border-color:#e2e8f0;max-width:700px}.confirmation-title{color:#1a2332;font-family:Playfair Display,serif;font-size:32px;line-height:1.1}.confirmation-copy{color:var(--ink-500);margin-top:10px;font-size:16px;line-height:1.6}.confirmation-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.confirmation-item{border:1px solid var(--line-soft);background:#fff;border-radius:12px;padding:10px 12px}.confirmation-item-label{text-transform:uppercase;letter-spacing:.12em;color:var(--ink-500);margin-bottom:6px;font-size:10px;font-weight:700}.confirmation-item-value{color:var(--ink-700);font-size:13px;line-height:1.45}.confirmation-description{margin-top:10px}.sec-label{color:var(--ink-500);letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;font-size:12px;font-weight:700}.card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;margin-bottom:14px;padding:24px;animation:.3s ease-out both riseIn;box-shadow:0 1px 3px #0000000f,0 4px 12px #0000000a}.card-head{align-items:center;gap:10px;display:flex}.avt{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:14px;font-weight:700;display:flex}.avt-blue{color:#2c5f8a;background:linear-gradient(135deg,#c8dbf0,#b8cfe8)}.card-name{color:var(--ink-900);font-size:18px;font-weight:700}.card-sub{color:var(--ink-500);margin-top:2px;font-size:15px}.card-price{color:#2c5f8a;margin-left:auto;font-size:13px;font-weight:700}.card-meta{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.pill{color:var(--ink-700);background:#f4f8fc;border:1px solid #e0e8ef;border-radius:999px;padding:5px 12px;font-size:12px}.state-card{background:#f0f6fd;border:1px dashed #bfd1df;border-radius:16px;padding:16px}.state-card.error{background:#fff8f7;border-color:#e5b4af}.state-title{color:#1a2332;margin-bottom:6px;font-size:16px;font-weight:700}.state-copy{color:var(--ink-500);font-size:15px;line-height:1.5}.btn-p,.btn-s{cursor:pointer;border:0;border-radius:10px;min-height:48px;padding:13px 28px;font-size:15px;font-weight:600;transition:transform .17s,box-shadow .17s,opacity .17s}.btn-p{color:#fff;background:linear-gradient(135deg,#2c5f8a,#4a7fa5);box-shadow:0 4px 12px #2c5f8a40}.book-now-btn,.hero-actions .btn-p{background:linear-gradient(135deg, var(--accent-coral), #f09869);box-shadow:0 4px 12px #e8834a4d}.btn-s{border:1px solid var(--line-soft);color:var(--ink-700);background:#fff}.btn-p:hover,.btn-s:hover{transform:translateY(-1px)}.btn-p:disabled{opacity:.6;cursor:not-allowed}.form-card{max-width:640px}.provider-highlight{border:1px solid #c8dbf0;border-left:4px solid var(--accent-ocean);background:#ebf2f9;border-radius:10px;margin-bottom:18px;padding:14px 16px}.provider-highlight-kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500);margin-bottom:4px;font-size:10px;font-weight:700}.provider-highlight-name{color:#1a2332;font-size:17px;font-weight:700}.provider-highlight-sub{color:var(--ink-500);margin-top:2px;font-size:15px}.provider-highlight-availability{margin-top:6px}.field-label{color:var(--ink-700);margin-bottom:6px;font-size:13px;font-weight:700;display:block}.input-field{color:var(--ink-900);background:#fafcfe;border:1px solid #dce4ec;border-radius:10px;width:100%;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .15s}.input-field:focus{border-color:var(--accent-ocean);outline:none;box-shadow:0 0 0 3px #2c5f8a1a}.form-actions{flex-wrap:wrap;gap:10px;display:flex}.form-actions .btn-p,.form-actions .btn-s{flex:1;min-width:150px}.auth-shell{min-height:680px}.auth-wrap{place-items:center;min-height:100%;padding:24px 16px;display:grid}.auth-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:min(100%,520px);padding:28px;box-shadow:0 4px 20px #00000014}.auth-kicker{text-transform:uppercase;letter-spacing:.14em;color:var(--accent-ocean);font-size:11px;font-weight:700}.auth-title{color:#1a2332;margin-top:6px;font-family:Playfair Display,serif;font-size:clamp(32px,5vw,42px);line-height:1.05}.auth-copy{color:var(--ink-500);margin-top:8px;font-size:16px;line-height:1.6}.auth-form{flex-direction:column;gap:4px;margin-top:20px;display:flex}.auth-input{width:100%;margin-bottom:10px}.password-checklist-wrap{transition:max-height .22s,opacity .22s,margin-bottom .22s;overflow:hidden}.password-checklist-wrap.expanded{opacity:1;max-height:140px;margin-bottom:10px}.password-checklist-wrap.collapsed{opacity:0;max-height:0;margin-bottom:0}.password-checklist{gap:4px;margin:-2px 0 0;padding:0;font-size:13px;list-style:none;display:grid}.password-checklist li{align-items:center;gap:8px;display:flex}.password-checklist .met{color:var(--success);font-weight:600}.password-checklist .unmet{color:var(--ink-500)}.password-hint-error{color:#8d3728;margin:-4px 0 10px;font-size:12px}.auth-file-input{padding:10px}.signup-photo-preview{object-fit:cover;border:2px solid #e2e8f0;border-radius:50%;width:84px;height:84px;margin-bottom:8px}.auth-submit{width:100%;margin-top:12px;padding:15px 28px;font-size:16px}.auth-error{color:#8d3728;background:#fff0ee;border:1px solid #edc4bc;border-radius:10px;padding:9px 10px;font-size:13px}.auth-switch-text{color:var(--ink-700);margin-top:18px;font-size:13px}.auth-switch-btn{color:var(--accent-ocean);cursor:pointer;background:0 0;border:0;font-weight:700}.auth-switch-btn:hover{text-decoration:underline}.chatbot-shell{z-index:40;flex-direction:column;align-items:flex-end;gap:10px;animation:.5s ease-out chatbotAppear;display:flex;position:fixed;bottom:100px;right:20px}.chatbot-toggle{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2c5f8a,#4a7fa5);border:0;border-radius:999px;padding:12px 18px;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);animation:2s ease-in-out infinite chatbotPulse;box-shadow:0 12px 26px #2c5f8a47}.chatbot-toggle:hover{transform:scale(1.08)translateY(-2px);box-shadow:0 4px 6px #2c5f8a26,0 12px 20px #2c5f8a4d,0 20px 40px #2c5f8a59,0 0 30px #4a7fa540}.chatbot-toggle:active{transform:scale(.96)}.chatbot-panel{background:#fff;border:1px solid #d9e4ef;border-radius:16px;width:min(92vw,380px);overflow:hidden;box-shadow:0 14px 32px #1a23322e}.chatbot-head{border-bottom:1px solid #edf2f7;padding:14px 14px 10px}.chatbot-title{color:#1a2332;font-size:16px;font-weight:700}.chatbot-disclaimer{color:var(--ink-500);margin-top:6px;font-size:12px;line-height:1.4}.chatbot-starters{flex-wrap:wrap;gap:8px;padding:10px 10px 0;display:flex}.chatbot-starter-btn{color:#2c5f8a;cursor:pointer;background:#f3f8fd;border:1px solid #c8dbf0;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:600}.chatbot-starter-btn:disabled{opacity:.7;cursor:not-allowed}.chatbot-thread{gap:8px;max-height:280px;padding:12px 10px 8px;display:grid;overflow-y:auto}.chatbot-message{border-radius:12px;padding:10px 12px;font-size:13px;line-height:1.45}.chatbot-message.assistant{color:#1a2332;background:#eef5fb}.chatbot-message.user{color:#fff;background:#2c5f8a;margin-left:28px}.chatbot-request-section{background:linear-gradient(135deg,#fff9f0,#fef5f0);border:1px solid #f5dcc8;border-radius:10px;margin:8px 10px 0;padding:10px}.chatbot-request-text{color:#573c30;margin:0 0 8px;font-size:12px;line-height:1.4}.chatbot-request-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ef8354,#f5a574);border:0;border-radius:8px;width:100%;padding:10px;font-size:12px;font-weight:600;transition:all .3s}.chatbot-request-btn:hover{transform:translateY(-1px);box-shadow:0 8px 16px #ef83544d}.chatbot-request-btn:active{transform:translateY(0)}.chatbot-error{color:#b23a2d;padding:0 12px 6px;font-size:12px}.chatbot-form{border-top:1px solid #edf2f7;gap:8px;padding:10px;display:flex}.chatbot-input{background:#fafcfe;border:1px solid #dce4ec;border-radius:10px;flex:1;padding:10px 12px;font-family:inherit;font-size:14px}.chatbot-input:focus{border-color:var(--accent-ocean);outline:none;box-shadow:0 0 0 3px #2c5f8a1a}.chatbot-send{min-height:40px;padding:10px 14px;font-size:14px}.role-selector{background:linear-gradient(135deg,#ebf2f9,#ebf2f9);border:1px solid #c8dbf0;border-radius:12px;margin:16px 0 18px;padding:16px}.role-label{color:var(--ink-700);margin-bottom:10px;font-size:12px;font-weight:700}.role-buttons{gap:10px;display:flex}.role-btn{color:var(--ink-700);cursor:pointer;background:#fff;border:2px solid #c8dbf0;border-radius:10px;flex:1;padding:10px 12px;font-size:13px;font-weight:600;transition:all .2s}.role-btn:hover{border-color:var(--accent-ocean);color:var(--accent-ocean);transform:translateY(-2px)}.role-btn.active{background:linear-gradient(135deg, var(--accent-ocean), #4a7fa5);color:#fff;border-color:var(--accent-ocean);box-shadow:0 6px 16px #2c5f8a40}@keyframes reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes floatIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes riseIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes chatbotAppear{0%{opacity:0;transform:translateY(20px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes chatbotPulse{0%,to{box-shadow:0 12px 26px #2c5f8a47}50%{box-shadow:0 14px 32px #2c5f8a66}}@media (width<=760px){.shell{margin:0 auto;padding:0}.phone{min-height:100vh}.hero-band{flex-direction:column;min-height:auto}.hero-image-panel{flex:none;height:220px}.hero-content{padding:28px 20px 24px}.stats-grid{grid-template-columns:repeat(3,1fr)}.services-grid,.confirmation-grid,.profile-editor-grid,.provider-about-grid{grid-template-columns:1fr}.profile-photo-col,.provider-photo-col{align-items:flex-start}.history-card{min-width:300px}.pro-marquee-item{width:240px}.pro-marquee-head{padding:0 10px 10px}.pro-marquee-track{padding:0 10px}.hero-band h1{font-size:30px}.topbar-brand{font-size:22px}.topbar{flex-wrap:wrap;gap:8px;padding:12px 16px}.topbar-nav{justify-content:flex-start;width:100%}.topbar-user-area{flex-wrap:wrap;justify-content:flex-end;width:100%}.section-wrap,.customer-profile-wrap,.service-provider-wrap,.invoice-wrap{padding:20px 16px}.services-section{padding:24px 16px 20px}.auth-card{padding:24px 20px}.chatbot-shell{align-items:flex-end;bottom:60px;left:auto;right:12px}.chatbot-toggle{text-align:left;width:auto}.chatbot-panel{width:min(92vw,360px)}}.messaging-panel{border:1px solid var(--line-soft);background:#fff;border-radius:12px;flex-direction:column;height:100%;display:flex;overflow:hidden}.messaging-header{border-bottom:1px solid var(--line-soft);background-color:#f8fbff;justify-content:space-between;align-items:center;padding:16px;display:flex}.messaging-title{color:var(--ink-900);margin:0 0 4px;font-size:16px;font-weight:600}.messaging-subtitle{color:var(--ink-500);margin:0;font-size:12px}.messaging-close-btn{cursor:pointer;color:var(--ink-700);background:0 0;border:none;padding:4px 8px;font-size:20px;line-height:1}.messaging-close-btn:hover{color:var(--ink-900)}.messaging-body{flex:1;padding:12px;overflow-y:auto}.messages-list{flex-direction:column;gap:12px;display:flex}.message-row{align-items:flex-end;gap:8px;display:flex}.message-row.message-sent{justify-content:flex-end}.message-row.message-received{justify-content:flex-start}.message-avatar{border-radius:50%;flex-shrink:0;width:32px;height:32px;overflow:hidden}.message-avatar img{object-fit:cover;width:100%;height:100%}.message-avatar-fallback{color:#fff;background-color:#0f6e8c;justify-content:center;align-items:center;width:100%;height:100%;font-size:14px;font-weight:600;display:flex}.message-bubble{word-wrap:break-word;border-radius:12px;max-width:70%;padding:10px 12px}.bubble-sent{color:#fff;background-color:#0f6e8c}.bubble-received{color:var(--ink-900);background-color:#f0f0f0}.message-sender-name{opacity:.8;margin:0 0 4px;font-size:12px;font-weight:600}.message-text{white-space:pre-wrap;margin:0;font-size:14px}.message-time{opacity:.7;margin-top:4px;margin-bottom:0;font-size:11px}.messaging-footer{border-top:1px solid var(--line-soft);background-color:#fafbfc;padding:12px}@media (width<=640px){.message-bubble{max-width:85%}}.toast{z-index:10000;border-radius:8px;align-items:center;gap:12px;max-width:90vw;padding:14px 16px;font-size:14px;font-weight:500;animation:.3s ease-out both slideInRight;display:flex;position:fixed;top:20px;right:20px;box-shadow:0 4px 12px #00000026}@keyframes slideInRight{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}.toast-success{background-color:var(--accent-leaf);color:#fff;border-left:4px solid #2d7f4e}.toast-error{background-color:var(--danger);color:#fff;border-left:4px solid #c53030}.toast-info{background-color:var(--accent-ocean);color:#fff;border-left:4px solid #1e4c79}.toast-close{color:inherit;cursor:pointer;opacity:.8;background:0 0;border:none;margin-left:8px;padding:0;font-size:16px;transition:opacity .15s}.toast-close:hover{opacity:1}.notification-badge{background-color:var(--danger);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:700;animation:2s ease-in-out infinite badgePulse;display:flex;position:absolute;top:-8px;right:-8px}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.admin-dashboard{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.admin-header{border-bottom:1px solid var(--line-soft);background:#fff;justify-content:space-between;align-items:center;padding:28px 32px;display:flex;box-shadow:0 2px 8px #0000000a}.admin-header h1{color:var(--ink-900);font-family:Playfair Display,serif;font-size:32px;font-weight:700}.admin-header-actions{align-items:center;gap:16px;display:flex}.admin-user-label{color:var(--ink-700);font-size:14px;font-weight:500}.btn-logout{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.btn-logout:hover{background:#c53030;transform:translateY(-1px)}.admin-error{color:var(--danger);border-left:4px solid var(--danger);background:#fed7d7;border-radius:6px;margin:12px 32px;padding:12px 16px;font-size:14px}.admin-loading{color:var(--ink-700);flex:1;justify-content:center;align-items:center;font-size:16px;display:flex}.admin-nav{border-bottom:1px solid var(--line-soft);background:#fff;gap:0;padding:0;display:flex;overflow-x:auto}.admin-nav-btn{color:var(--ink-700);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;flex:none;padding:16px 24px;font-size:14px;font-weight:600;transition:all .2s}.admin-nav-btn:hover{color:var(--accent-ocean);background:#2c5f8a05}.admin-nav-btn.active{color:var(--accent-ocean);border-bottom-color:var(--accent-ocean)}.admin-content{flex:1;padding:32px;overflow-y:auto}.admin-overview{animation:.3s slideInUp}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{border:1px solid var(--line-soft);background:#fff;border-radius:8px;padding:24px;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.stat-number{color:var(--accent-ocean);margin-bottom:8px;font-size:40px;font-weight:700;line-height:1}.stat-label{color:var(--ink-900);margin-bottom:4px;font-size:14px;font-weight:600}.stat-detail{color:var(--ink-500);font-size:12px}.overview-grid{grid-template-columns:1fr 1fr;gap:24px;margin-top:32px;display:grid}@media (width<=1024px){.overview-grid{grid-template-columns:1fr}}.overview-section{border:1px solid var(--line-soft);background:#fff;border-radius:8px;padding:24px}.overview-section h3{color:var(--ink-900);margin-bottom:20px;font-size:16px;font-weight:600}.status-breakdown{flex-direction:column;gap:12px;display:flex}.status-item{grid-template-columns:100px 1fr 50px;align-items:center;gap:12px;display:grid}.status-label{color:var(--ink-700);font-size:13px;font-weight:500}.status-bar{background:var(--bg);border-radius:4px;height:8px;overflow:hidden}.status-fill{height:100%;transition:width .3s}.status-fill.pending{background:var(--warning)}.status-fill.in-progress{background:var(--primary-light)}.status-fill.completed{background:var(--success)}.status-fill.rejected{background:var(--danger)}.status-count{color:var(--ink-700);text-align:right;font-size:12px;font-weight:600}.metrics-list{flex-direction:column;gap:16px;display:flex}.metric-item{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.metric-item:last-child{border-bottom:none}.metric-label{color:var(--ink-700);font-size:13px;font-weight:500}.metric-value{color:var(--accent-ocean);font-size:18px;font-weight:700}.metric-badge{background:var(--bg);color:var(--ink-700);border-radius:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-block}.admin-table-section{animation:.3s slideInUp}.admin-table-section h2{color:var(--ink-900);margin-bottom:20px;font-size:20px;font-weight:600}.admin-table-wrapper{border:1px solid var(--line-soft);background:#fff;border-radius:8px;overflow:hidden}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table thead{background:var(--bg);border-bottom:1px solid var(--line-soft)}.admin-table th{text-align:left;color:var(--ink-700);padding:12px 16px;font-weight:600}.admin-table tbody tr{border-bottom:1px solid var(--line-soft);transition:background .15s}.admin-table tbody tr:hover{background:#2c5f8a05}.admin-table td{color:var(--ink-700);padding:12px 16px}.admin-table .empty-message{text-align:center;color:var(--ink-500);font-style:italic;padding:40px 16px!important}.rating-badge{color:var(--accent-ocean);font-weight:600}.status-badge{white-space:nowrap;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.status-badge.pending{color:var(--warning);background:#d977061a}.status-badge.in-progress{color:var(--primary-light);background:#4a7fa51a}.status-badge.completed{color:var(--success);background:#38a1691a}.status-badge.rejected{color:var(--danger);background:#e53e3e1a}.status-badge.available{color:var(--success);background:#38a1691a}.status-badge.unavailable{color:var(--warning);background:#d977061a}.admin-revenue-section{animation:.3s slideInUp}.admin-revenue-section h2{color:var(--ink-900);margin-bottom:20px;font-size:20px;font-weight:600}.revenue-cards{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.revenue-card{background:linear-gradient(135deg, var(--accent-ocean) 0%, var(--primary-light) 100%);color:#fff;border-radius:8px;padding:24px;transition:all .2s;box-shadow:0 4px 12px #2c5f8a33}.revenue-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #2c5f8a4d}.revenue-label{opacity:.9;margin-bottom:8px;font-size:12px;font-weight:600}.revenue-value{margin-bottom:8px;font-size:32px;font-weight:700;line-height:1}.revenue-detail{opacity:.85;font-size:12px}.revenue-breakdown{border:1px solid var(--line-soft);background:#fff;border-radius:8px;padding:24px}.revenue-breakdown h3{color:var(--ink-900);margin-bottom:16px;font-size:16px;font-weight:600}.service-revenue-list{flex-direction:column;gap:8px;display:flex}.service-revenue-item{background:var(--bg);border-radius:6px;justify-content:space-between;align-items:center;padding:12px;font-size:13px;display:flex}.service-name{color:var(--ink-700);font-weight:500}.service-amount{color:var(--accent-ocean);font-weight:700}.admin-footer{border-top:1px solid var(--line-soft);text-align:center;background:#fff;padding:24px 32px}.admin-footer .btn-p{padding:12px 32px}.suspended-row{opacity:.7;background:#e53e3e0d}.suspended-row td{color:var(--danger)}.warning-badge{color:var(--warning);background:#d9770626;border-radius:12px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.action-cell{flex-wrap:wrap;gap:6px;display:flex}.btn-action{cursor:pointer;white-space:nowrap;border:1px solid #0000;border:1px solid var(--line-soft);color:var(--ink-700);background:0 0;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .15s}.btn-action:hover{background:var(--bg);transform:translateY(-1px)}.btn-action.suspend{border-color:var(--danger);color:var(--danger)}.btn-action.suspend:hover{background:#e53e3e1a}.btn-action.warn{border-color:var(--warning);color:var(--warning)}.btn-action.warn:hover{background:#d977061a}.btn-action.unsuspend{border-color:var(--success);color:var(--success)}.btn-action.unsuspend:hover{background:#38a1691a}.status-badge.suspended{color:var(--danger);background:#e53e3e1a}.status-badge.active{color:var(--success);background:#38a1691a}.action-badge{background:var(--bg);color:var(--ink-700);text-transform:capitalize;border-radius:12px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-block}.action-badge.user_suspended,.action-badge.provider_suspended{color:var(--danger);background:#e53e3e1a}.action-badge.user_unsuspended,.action-badge.provider_unsuspended{color:var(--success);background:#38a1691a}.action-badge.user_warned,.action-badge.provider_warned{color:var(--warning);background:#d977061a}.details-cell{color:var(--ink-500);font-size:12px;font-style:italic}.admin-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.admin-modal{background:#fff;border-radius:8px;width:90%;max-width:400px;padding:32px;animation:.2s slideInUp;box-shadow:0 20px 60px #0000004d}.admin-modal h3{color:var(--ink-900);margin-bottom:20px;font-size:18px;font-weight:600}.admin-modal .form-group{margin-bottom:20px}.admin-modal .form-group label{color:var(--ink-700);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.admin-modal .form-group textarea{border:1px solid var(--line-soft);width:100%;color:var(--ink-900);resize:vertical;border-radius:6px;min-height:80px;padding:10px;font-family:Inter,sans-serif;font-size:13px}.admin-modal .form-group textarea:disabled{background:var(--bg);color:var(--ink-500)}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.modal-actions .btn-s,.modal-actions .btn-p{padding:10px 18px;font-size:13px}.modal-actions .btn-p.btn-danger{background:var(--danger);color:#fff;border:none}.modal-actions .btn-p.btn-danger:hover{background:#c53030}.modal-actions button:disabled{opacity:.6;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.payment-form{background:#f8f9fb;border:1px solid #dbe4ec;border-radius:8px;margin-top:20px;padding:20px}.card-element-wrapper{background:#fff;border:1px solid #dbe4ec;border-radius:6px;margin-top:8px;padding:12px 16px}.StripeElement{box-sizing:border-box;background-color:#fff;border:1px solid #ced4da;border-radius:4px;height:40px;padding:10px 12px;transition:box-shadow .15s;box-shadow:0 1px 3px #e6ebf1}.StripeElement--focus{border:1px solid #0f6e8c;box-shadow:0 1px 3px #cfd7df}.StripeElement--invalid{border-color:#ef8354}.payment-loading{text-align:center;color:var(--ink-500);padding:20px;font-size:14px}.error-message{color:#c53030;background-color:#fee;border:1px solid #ef8354;border-radius:6px;margin:12px 0;padding:12px 16px;font-size:14px}.success-message{color:#2ecc71;background-color:#eef;border:1px solid #2ecc71;border-radius:6px;margin:12px 0;padding:12px 16px;font-size:14px}.payments-tab-content{min-height:400px}.payments-summary{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.summary-card{background:#fff;border:1px solid #dbe4ec;border-radius:8px;padding:16px}.summary-label{color:var(--ink-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px}.summary-value{color:var(--accent-ocean);font-size:24px;font-weight:600}.payment-filters{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.payment-status-badge{border-radius:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.payment-status-badge.completed{color:#2ecc71;background:#e6ffed}.payment-status-badge.pending{color:#d97706;background:#fff3cd}.payment-status-badge.failed{color:#c53030;background:#fee}.payout-status-badge{border-radius:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.payout-status-badge.pending{color:#d97706;background:#fff3cd}.payout-status-badge.processed{color:#2ecc71;background:#e6ffed}.payout-actions{gap:8px;display:flex}.payout-actions button{cursor:pointer;background:var(--accent-ocean);color:#fff;border:none;border-radius:4px;padding:6px 12px;font-size:12px}.payout-actions button:hover{background:#1e4563}.payout-actions button:disabled{background:var(--ink-300);cursor:not-allowed}.providers-filters{background:#f8f9fb;border:1px solid #dbe4ec;border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;padding:16px;display:flex}.location-badge{color:#0f6e8c;background:#e6f3ff;border:1px solid #b3d9ff;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:flex}.filter-group{align-items:center;gap:8px;display:flex}.filter-group label{color:var(--ink-700);white-space:nowrap;margin:0;font-size:13px;font-weight:500}.filter-select,.filter-input{color:var(--ink-900);background:#fff;border:1px solid #dbe4ec;border-radius:6px;padding:8px 12px;font-family:Inter,sans-serif;font-size:13px}.filter-select:hover,.filter-input:hover{border-color:var(--accent-ocean);background:#f8f9fb}.filter-select:focus,.filter-input:focus{border-color:var(--accent-ocean);outline:none;box-shadow:0 0 0 3px #0f6e8c1a}.filter-result-count{color:var(--ink-500);margin-bottom:16px;font-size:14px;font-weight:500}.card-meta .location-pill,.card-meta .rating-pill{color:#0f6e8c;background:#e6f3ff;border:1px solid #b3d9ff}.card-meta .rating-pill{color:#d97706;background:#fff3cd;border:1px solid #fcd34d}.card-meta .trust-pill{color:#0f7a4d;background:#e8f7ef;border:1px solid #7ed9ab}.card-meta .trust-score-pill,.trust-score-pill{color:#2158a8;background:#e7f0ff;border:1px solid #8bb4ff;border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.card-meta .badge-level-pill{color:#5c2ca4;text-transform:capitalize;background:#f4ecff;border:1px solid #c8adf7}.doc-links-cell{flex-direction:column;gap:4px;font-size:12px;display:flex}.doc-links-cell a{color:var(--accent-ocean);font-weight:500;text-decoration:none}.doc-links-cell a:hover{text-decoration:underline}.location-section{background:#f8f9fb;border:1px solid #dbe4ec;border-radius:8px;margin-top:24px;padding:20px}.location-section h3{color:var(--ink-900);margin-bottom:16px;font-size:16px}.location-form{gap:12px;display:grid}.location-input-group{flex-direction:column;gap:6px;display:flex}.location-input-group label{color:var(--ink-700);font-size:13px;font-weight:500}.location-input-group input{border:1px solid #dbe4ec;border-radius:6px;padding:10px 12px;font-family:Inter,sans-serif;font-size:14px}.location-input-group input:focus{border-color:var(--accent-ocean);outline:none;box-shadow:0 0 0 3px #0f6e8c1a}.location-coordinates{grid-template-columns:1fr 1fr;gap:12px;display:grid}.location-button-group{gap:8px;margin-top:12px;display:flex}.location-button-group button{cursor:pointer;border:none;border-radius:6px;padding:10px 16px;font-size:13px;font-weight:500}.location-button-group .btn-p{background:var(--accent-ocean);color:#fff;flex:1}.location-button-group .btn-p:hover{background:#1e4563}.location-button-group .btn-s{color:var(--ink-900);background:#e2e8f0}.location-button-group .btn-s:hover{background:#cbd5e1}.location-status{border-radius:6px;margin-top:12px;padding:10px 12px;font-size:13px}.location-status.success{color:#2ecc71;background:#e6ffed;border:1px solid #2ecc71}.location-status.error{color:#c53030;background:#fee;border:1px solid #ef8354}.location-status.loading{color:#0f6e8c;background:#e6f3ff;border:1px solid #b3d9ff}.map-container{width:100%;height:300px;color:var(--ink-500);background:#f0f4f8;border:1px solid #dbe4ec;border-radius:8px;justify-content:center;align-items:center;margin-top:16px;font-size:14px;display:flex}
