:root{
    --bg:#06111f;
    --bg-soft:#0d1b2c;
    --card:#101c2b;
    --line:rgba(255,255,255,.08);
    --text:#f1f5f9;
    --muted:#9db0c7;
    --primary:#1e63ff;
    --accent:#46d6c6;
    --warning:#f7a84b;
}

*{box-sizing:border-box}
body{
    background:
        radial-gradient(circle at top left, rgba(30,99,255,.22), transparent 22%),
        radial-gradient(circle at bottom right, rgba(247,168,75,.12), transparent 18%),
        linear-gradient(180deg, #06111f 0%, #071423 100%);
    color:var(--text);
    min-height:100vh;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.topbar{
    border-bottom:1px solid var(--line);
    background:rgba(6,17,31,.72);
    backdrop-filter: blur(12px);
    position:sticky;
    top:0;
    z-index:30;
}
.brand{
    display:flex;
    flex-direction:column;
    color:#fff;
}
.brand-badge{
    font-weight:800;
    letter-spacing:.08em;
    color:var(--accent);
}
.brand-subtitle{
    font-size:.9rem;
    color:var(--muted);
}
.nav-link-custom{
    color:var(--text);
    text-decoration:none;
    opacity:.9;
}
.nav-link-custom:hover{color:#fff}
.hero-section{
    padding: 2rem 0 1rem;
}
.hero-card,
.panel-card,
.form-shell,
.pricing-card{
    border:1px solid var(--line);
    border-radius:24px;
    box-shadow:0 18px 50px rgba(0,0,0,.25);
}
.hero-card{
    padding:3rem;
}
.hero-card h1{
    font-size:clamp(2.2rem,5vw,4rem);
    line-height:1.02;
    font-weight:800;
    max-width:900px;
}
.hero-text{
    max-width:760px;
    color:var(--muted);
    font-size:1.1rem;
}
.section-kicker{
    display:inline-block;
    color:var(--accent);
    text-transform:uppercase;
    letter-spacing:.12em;
    font-weight:700;
    font-size:.85rem;
    margin-bottom:.75rem;
}
.section-head h1,
.section-head h2{
    font-weight:800;
    margin-bottom:0;
}
.panel-card,
.pricing-card{
    padding:1.5rem;
}
.form-shell{
    padding:2rem;
}
.pricing-value{
    font-size:2rem;
    font-weight:800;
    color:#fff;
}
.timeline-list{
    display:grid;
    gap:1rem;
}
.timeline-item{
    padding:1rem 1.25rem;
    border:1px solid var(--line);
    background:rgba(255,255,255,.02);
    border-radius:18px;
}
.badge-soft{
    display:inline-flex;
    align-items:center;
    padding:.45rem .85rem;
    border-radius:999px;
    background:rgba(247,168,75,.12);
    color:#ffc57f;
    border:1px solid rgba(247,168,75,.18);
    font-size:.85rem;
}
.profile-side-card{
    min-width:280px;
    border:1px solid var(--line);
    border-radius:20px;
    padding:1.25rem;
    background:rgba(255,255,255,.02);
}
.empty-state{
    border:1px dashed var(--line);
    border-radius:24px;
    padding:3rem;
    text-align:center;
    color:var(--muted);
    background:rgba(255,255,255,.02);
}
.form-control,
.form-select{
    min-height:50px;
    border-radius:14px;
    border:1px solid rgb(0 0 0);
    color:#000000;
}
.form-control:focus,
.form-select:focus{
    background:#0b1727;
    color:#fff;
    border-color:rgba(30,99,255,.7);
    box-shadow:0 0 0 .2rem rgba(30,99,255,.15);
}
.form-label{
    color:#c8d4e2;
    font-weight:600;
}
.btn{
    border-radius:14px;
    min-height:35px;
    font-weight:700;
    padding-inline:1.2rem;
}
.btn-primary{
    background:linear-gradient(180deg,#2e73ff,#1652d1);
    border-color:#1652d1;
}
.btn-outline-light{
    border-color:rgba(255,255,255,.18);
}
.text-secondary,
.text-secondary.small,
.text-secondary-subtle{
    color:var(--muted)!important;
}
.pagination{
    gap:.4rem;
}
.page-link{
    background:#0b1727;
    border-color:var(--line);
    color:#fff;
    border-radius:12px;
}
@media (max-width: 768px){
    .hero-card{padding:2rem}
    .form-shell{padding:1.25rem}
    .topbar .container{
        flex-direction:column;
        align-items:flex-start!important;
        gap:.8rem;
    }
}


.form-shell-lg{
    max-width: 980px;
}
.divider-label{
    display:inline-flex;
    align-items:center;
    gap:.5rem;
    color:#737373;
    font-weight:800;
    font-size:1rem;
}
.divider-label::before{
    content:"";
    width:34px;
    height:2px;
    border-radius:999px;
    background:linear-gradient(90deg,var(--accent),transparent);
}
.metric-value{
    font-size:2.2rem;
    font-weight:800;
    line-height:1;
    margin-bottom:.55rem;
}
.metric-label{
    color:var(--muted);
}
.quick-actions{
    display:grid;
    gap:1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.quick-action-card{
    background:rgba(255,255,255,.03);
    border:1px solid var(--line);
    border-radius:22px;
    padding:1.25rem;
    color:var(--text);
    display:flex;
    flex-direction:column;
    gap:.35rem;
    transition: .2s ease;
}
.quick-action-card span{
    color:var(--muted);
}
.quick-action-card:hover{
    transform:translateY(-2px);
    border-color:rgba(70,214,198,.28);
}
.invalid-feedback{
    display:block;
}
@media (max-width: 768px){
    .quick-actions{
        grid-template-columns:1fr;
    }
}


.register-shell{
    max-width: 980px;
}
.register-switch{
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap:.75rem;
    padding:.35rem;
    border-radius:18px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line);
}
.register-switch-link{
    min-height:52px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:14px;
    text-decoration:none;
    color:var(--muted);
    font-weight:800;
    transition:.2s ease;
}
.register-switch-link:hover{
    color:#fff;
    background:rgba(255,255,255,.04);
}
.register-switch-link.active{
    color:#fff;
    background:linear-gradient(180deg,#2e73ff,#1652d1);
    box-shadow:0 12px 24px rgba(22,82,209,.22);
}
.register-section-card{
    background:rgba(255,255,255,.03);
    border:1px solid var(--line);
    border-radius:22px;
    padding:1.35rem;
}
@media (max-width: 768px){
    .register-section-card{
        padding:1rem;
    }
}

.professional-filter-card{
    padding:1.25rem;
}
.professionals-summary{
    margin-top:.25rem;
}
.professional-card{
    display:flex;
    flex-direction:column;
}
.professional-card-topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem;align-items:flex-start}
.professional-card-category{max-width:100%;justify-self:flex-start}
.professional-card-badges{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;align-items:flex-start;max-width:100%}
.professional-card-badges .status-badge{max-width:100%;white-space:normal;text-align:center}

.professional-meta-list{
    display:grid;
    gap:.45rem;
    color:var(--muted);
}
.status-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:.38rem .75rem;
    border-radius:999px;
    font-size:.78rem;
    font-weight:700;
    border:1px solid transparent;
}
.status-badge.verified{
    color:#8df6d1;
    background:rgba(70,214,198,.12);
    border-color:rgba(70,214,198,.24);
}
.status-badge.featured{
    color:#ffd39b;
    background:rgba(247,168,75,.12);
    border-color:rgba(247,168,75,.24);
}
.professional-profile-header{
    padding:2rem;
}
.professional-contact-card .contact-line + .contact-line{
    margin-top:.65rem;
}
.schedule-list{
    display:grid;
    gap:.85rem;
}
.schedule-item{
    display:flex;
    justify-content:space-between;
    gap:1rem;
    align-items:center;
    padding:.95rem 1rem;
    background:rgba(255,255,255,.03);
    border:1px solid var(--line);
    border-radius:16px;
}
@media (max-width: 768px){
    .schedule-item{
        flex-direction:column;
        align-items:flex-start;
    }
    .professional-profile-header{
        padding:1.25rem;
    }
}

.client-body{
    background:#dfe4ec;
    color:#18212f;
}
.client-layout{
    --client-bg:#e6ebf2;
    --client-surface:#ffffff;
    --client-surface-soft:#f4f6fa;
    --client-border:#d3dae6;
    --client-text:#1c2431;
    --client-muted:#677489;
    --client-primary:#2453ff;
    --client-primary-2:#3f1edf;
    --client-sidebar:#ffffff;
    --client-sidebar-active:#dce6f8;
    --client-danger:#f4dddd;
    min-height:100vh;
    display:grid;
    grid-template-columns:320px 1fr;
    background:var(--client-bg);
    color:var(--client-text);
}
.client-layout[data-client-theme="dark"]{
    --client-bg:#071423;
    --client-surface:#0d1b2c;
    --client-surface-soft:#0f2033;
    --client-border:rgba(255,255,255,.08);
    --client-text:#f1f5f9;
    --client-muted:#9fb0c7;
    --client-primary:#2453ff;
    --client-primary-2:#5027f2;
    --client-sidebar:#0b1727;
    --client-sidebar-active:#172945;
    --client-danger:rgba(240,82,82,.12);
}
.client-layout[data-client-theme="dark"] .form-control,
.client-layout[data-client-theme="dark"] .form-select{
    background:#0b1727;
    color:#fff;
    border-color:rgba(255,255,255,.08);
}
.client-layout[data-client-theme="dark"] .form-control::placeholder{ color:#89a; }
.client-sidebar{
    background:var(--client-sidebar);
    border-right:1px solid var(--client-border);
    padding:1.5rem 1rem;
    display:flex;
    flex-direction:column;
    gap:1.25rem;
}
.client-logo-card{
    border-radius:24px;
    padding:0px 0px 10px 15px;
    color:#fff;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    box-shadow:0 12px 34px rgba(0,0,0,.12);
}
.client-logo-mark{
    font-size:2rem;
    font-weight:800;
    margin-bottom:.35rem;
}
.client-logo-subtitle{color:#ff8c02}
.client-nav{display:grid;gap:.45rem}
.client-nav-link{
    display:flex;
    align-items:center;
    gap:.85rem;
    text-decoration:none;
    color:var(--client-text);
    padding:1rem;
    border-radius:16px;
    font-weight:700;
}
.client-nav-link.active{background:var(--client-sidebar-active); color:var(--client-primary)}
.client-nav-link:hover{background:var(--client-sidebar-active); color:var(--client-primary)}
.client-sidebar-actions{margin-top:auto; display:grid; gap:.8rem}
.client-theme-toggle,
.client-logout-btn{
    border:none;
    min-height:50px;
    border-radius:16px;
    width:100%;
    text-align:left;
    padding:0 1rem;
    font-weight:700;
}
.client-theme-toggle{background:var(--client-surface-soft); color:var(--client-text); border:1px solid var(--client-border)}
.client-logout-btn{background:var(--client-danger); color:#cc2626}
.client-main{display:flex;flex-direction:column;min-width:0}
.client-topbar{
    min-height:72px;
    padding:2.5rem 1.5rem;
    background:linear-gradient(90deg,var(--client-primary),var(--client-primary-2));
    color:#fff;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:1rem;
}
.client-topbar-title{font-size:1.7rem;font-weight:800;margin:0}
.client-topbar-subtitle{font-size:.95rem;color:rgba(255,255,255,.86)}
.client-topbar-actions{display:flex;align-items:center;gap:1rem}
.client-topbar-link{color:#fff;text-decoration:none;font-weight:700}
.client-notify-btn{border:none;background:transparent;color:#fff;font-size:1.25rem}
.client-alert{margin:1rem 1.5rem 0;padding:1rem 1.2rem;border-radius:16px}
.client-alert.success{background:#d8f6e4;color:#165d34}
.client-layout[data-client-theme="dark"] .client-alert.success{background:rgba(46,204,113,.12);color:#8ff0b8}
.client-services-page,
.client-section-shell{padding:1.25rem 1.25rem 1.75rem}
.client-map-filter-card,
.client-form-card,
.client-list-shell,
.client-chat-shell{
    background:var(--client-surface);
    border:1px solid var(--client-border);
    border-radius:24px;
    box-shadow:0 12px 24px rgba(15,23,42,.04);
}
.client-filter-header{
    display:flex;justify-content:space-between;align-items:center;
    padding:1rem 1rem .35rem;
}
.client-filter-collapse{border:none;background:transparent;color:var(--client-primary);font-size:1.4rem;font-weight:700}
.client-filter-body{padding:0 1rem 1rem;transition:.2s ease}
.client-filter-body.collapsed{display:none}
.client-filter-inline{display:flex;justify-content:flex-start;gap:.85rem;flex-wrap:wrap}
.client-toggle-card{display:flex;align-items:center;gap:1rem;padding:.7rem 1rem;border-radius:16px;background:var(--client-surface-soft);border:1px solid var(--client-border)}
.client-center-map-btn{min-width:190px;background:var(--client-surface-soft);border-color:var(--client-border);color:var(--client-text);font-weight:700}
.client-center-map-btn:hover{background:var(--client-surface);color:var(--client-text);border-color:var(--client-primary)}
.client-switch{position:relative;width:50px;height:28px;display:inline-block}
.client-switch input{display:none}
.client-switch span{position:absolute;inset:0;background:#cfd5de;border-radius:999px;transition:.2s}
.client-switch span::after{content:"";position:absolute;top:3px;left:4px;width:22px;height:22px;border-radius:50%;background:#fff;transition:.2s}
.client-switch input:checked + span{background:var(--client-primary)}
.client-switch input:checked + span::after{transform:translateX(20px)}
.client-radius-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.client-radius-scale{display:flex;align-items:center;gap:1rem;color:var(--client-muted)}
.client-radius-scale input{width:min(440px,60vw)}
.client-radius-badge{padding:.45rem .85rem;border-radius:999px;background:rgba(36,83,255,.12);color:var(--client-primary);font-weight:700}
.client-btn-search{min-width:100px}
.client-map-shell{position:relative;margin-top:1rem;border-radius:24px;overflow:hidden;border:1px solid var(--client-border)}
.client-services-map{height:520px;background:#cfd8e3}
.client-map-overlay-note{position:absolute;left:1rem;bottom:1rem;max-width:380px;background:rgba(7,20,35,.78);color:#fff;padding:.85rem 1rem;border-radius:16px;font-size:.92rem}
.client-layout[data-client-theme="light"] .client-map-overlay-note{background:rgba(28,36,49,.76)}
.client-services-summary{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:.85rem 0;color:var(--client-text)}
.client-mini-stats{display:flex;gap:1rem;flex-wrap:wrap;color:var(--client-muted)}
.client-professionals-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.client-professional-card{background:var(--client-surface);border:1px solid var(--client-border);border-radius:24px;padding:1.15rem;display:flex;flex-direction:column;gap:1rem}
.client-professional-card-top{display:flex;justify-content:space-between;gap:1rem}
.client-professional-card-identity{display:flex;align-items:center;gap:.9rem;min-width:0}
.client-professional-card-avatar{width:68px;height:68px;border-radius:50%;background:#d7deea;color:#334155;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:3px solid rgba(36,83,255,.12)}
.client-professional-card-avatar.has-image{padding:0;background:#d7deea}
.client-professional-card-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.client-professional-card h3{font-size:1.15rem;font-weight:800;margin:.45rem 0 .2rem}
.client-tag{display:inline-flex;padding:.35rem .7rem;border-radius:999px;background:rgba(36,83,255,.12);color:var(--client-primary);font-weight:700;font-size:.82rem}
.client-badges-stack{display:grid;gap:.45rem;justify-items:end}
.client-chip{display:inline-flex;padding:.35rem .7rem;border-radius:999px;font-size:.78rem;font-weight:800;border:1px solid var(--client-border)}
.client-chip.verified{background:rgba(34,197,94,.12);color:#16803d;border-color:rgba(34,197,94,.18)}
.client-verified-icon-badge{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.22);color:#16803d;font-size:.95rem;font-weight:900;line-height:1;cursor:help}
.client-verified-icon-badge:hover{background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.32)}
.client-map-popup-verified-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.22);color:#16803d;font-size:.88rem;font-weight:900;line-height:1;cursor:help;margin-right:.35rem;vertical-align:middle}
.client-chip.featured{background:rgba(251,191,36,.12);color:#b7791f;border-color:rgba(251,191,36,.18)}
.client-chip.outline{background:transparent;color:var(--client-muted)}
.client-professional-meta{display:flex;flex-wrap:wrap;gap:.85rem;color:var(--client-muted);font-size:.92rem}
.client-professional-bio{color:var(--client-text);opacity:.86;margin:0}
.client-professional-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:auto}
.client-empty-card{background:var(--client-surface);border:1px dashed var(--client-border);border-radius:24px;padding:2rem;text-align:center;color:var(--client-muted);grid-column:1/-1}
.client-empty-card.large{padding:4rem 1.5rem}
.client-tabs-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.2rem}
.client-tab-pill{display:inline-flex;align-items:center;gap:.6rem;padding:.85rem 1rem;border-radius:999px;background:var(--client-surface);border:1px solid var(--client-border);text-decoration:none;color:var(--client-muted);font-weight:800}
.client-tab-pill.active{background:var(--client-primary);color:#fff;border-color:var(--client-primary)}
.client-schedule-card{display:flex;gap:1rem;padding:1rem;border-bottom:1px solid var(--client-border)}
.client-schedule-card:last-child{border-bottom:none}
.client-schedule-avatar{width:52px;height:52px;border-radius:50%;background:#ced6e4;color:#334155;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.client-schedule-avatar.has-image{padding:0;background:#d6deea}
.client-schedule-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.client-layout[data-client-theme="dark"] .client-schedule-avatar{background:#172945;color:#f1f5f9}
.client-schedule-content h3{font-size:1rem;font-weight:800;margin-bottom:.35rem}
.client-schedule-meta{display:flex;flex-wrap:wrap;gap:1rem;color:var(--client-muted);font-size:.92rem}
.client-chat-shell{display:grid;grid-template-columns:340px 1fr;overflow:hidden}
.client-chat-sidebar{border-right:1px solid var(--client-border);padding:1rem;display:flex;flex-direction:column;gap:1rem;background:var(--client-surface)}
.client-search-box .form-control{background:var(--client-surface-soft);border-color:var(--client-border);color:var(--client-text)}
.client-chat-list{display:grid;gap:.75rem}
.client-chat-list-item{display:flex;gap:.85rem;align-items:center;padding:.85rem;border-radius:18px;background:var(--client-surface-soft);border:1px solid var(--client-border)}
.client-chat-avatar{width:44px;height:44px;border-radius:50%;background:#cfd8e3;display:flex;align-items:center;justify-content:center;font-weight:800}
.client-layout[data-client-theme="dark"] .client-chat-avatar{background:#172945}
.client-chat-stage{display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--client-surface-soft)}
.client-empty-chat{text-align:center;color:var(--client-muted)}
.client-empty-chat-icon{font-size:2.4rem;margin-bottom:1rem}
.client-empty-mini{padding:2rem 1rem;border:1px dashed var(--client-border);border-radius:18px;text-align:center;color:var(--client-muted)}
.client-notification-card{display:flex;gap:1rem;padding:1rem;border-bottom:1px solid var(--client-border);background:var(--client-surface);align-items:flex-start}
.client-notification-card.unread{background:rgba(36,83,255,.05)}
.client-notification-card:last-child{border-bottom:none}
.client-notification-icon,.client-notification-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(36,83,255,.12);flex-shrink:0;overflow:hidden}
.client-notification-avatar{background:#d7deea;color:#334155;font-weight:800}
.client-notification-avatar.has-image{padding:0}
.client-notification-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.client-notification-heading{display:flex;flex-direction:column;gap:.08rem;margin-bottom:.25rem}
.client-notification-heading span{font-size:.85rem;color:var(--client-muted)}
.client-form-title{font-size:1.05rem;font-weight:800;color:var(--client-text)}
.client-form-card{padding:1.25rem}
.client-form-card .form-control,
.client-form-card .form-select{background:var(--client-surface-soft);color:var(--client-text);border-color:var(--client-border)}
.client-form-card .btn-outline-secondary{border-radius:14px}
@media (max-width: 1200px){
    .client-layout{grid-template-columns:280px 1fr}
    .client-professionals-grid{grid-template-columns:1fr}
}
@media (max-width: 991px){
    .client-layout{grid-template-columns:1fr}
    .client-sidebar{border-right:none;border-bottom:1px solid var(--client-border)}
    .client-chat-shell{grid-template-columns:1fr}
    .client-chat-sidebar{border-right:none;border-bottom:1px solid var(--client-border)}
}
@media (max-width: 768px){
    .client-topbar{padding:1rem;flex-direction:column;align-items:flex-start}
    .client-services-page,.client-section-shell{padding:25px 0px 0px 0px;}
    .client-services-map{height:420px}
    .client-professional-card-top{flex-direction:column}
    .client-schedule-card{flex-direction:column}
    .client-radius-scale input{width:100%}
}


.client-map-pin-wrap{background:transparent;border:none}
.client-map-pin{
    position:relative;
    display:block;
    width:18px;
    height:18px;
    border-radius:999px;
    border:3px solid #fff;
    box-shadow:0 8px 20px rgba(0,0,0,.22);
}
.client-map-pin::after{
    content:"";
    position:absolute;
    left:50%;
    bottom:-11px;
    width:10px;
    height:10px;
    transform:translateX(-50%) rotate(45deg);
    border-right:3px solid #fff;
    border-bottom:3px solid #fff;
    box-shadow:4px 4px 8px rgba(0,0,0,.08);
}
.client-map-pin.red,
.client-map-pin.red::after{background:#ef4444}
.client-map-pin.blue,
.client-map-pin.blue::after{background:#2563eb}
.client-map-popup-card{min-width:240px;display:grid;gap:.45rem;color:#0f172a}
.client-map-popup-head{display:flex;align-items:flex-start;gap:.75rem}
.client-map-popup-avatar{width:52px;height:52px;border-radius:50%;background:#d7deea;color:#334155;font-weight:800;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;border:2px solid rgba(36,83,255,.12)}
.client-map-popup-avatar.has-image{padding:0}
.client-map-popup-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.client-map-popup-card h4{font-size:1rem;font-weight:800;margin:0;color:#0f172a}
.client-map-popup-card p{margin:0;color:#334155;font-weight:600}
.client-map-popup-kicker{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#2563eb}
.client-map-popup-location,.client-map-popup-address,.client-map-popup-bio{font-size:.84rem;color:#475569}
.client-map-popup-bio{line-height:1.35}
.client-map-popup-actions{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.2rem}
.client-popup-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .8rem;border-radius:12px;text-decoration:none;font-weight:700;font-size:.78rem;border:1px solid rgba(15,23,42,.08);background:#fff;color:#0f172a}
.client-popup-btn.phone{background:#f8fafc}
.client-popup-btn.whatsapp{background:#dcfce7;color:#166534}
.client-popup-btn.profile{background:#e2e8f0;color:#0f172a}
.client-popup-btn.primary{background:#2563eb;color:#fff}


.client-layout .form-control,
.client-layout .form-select,
.client-layout .client-form-card .form-control,
.client-layout .client-form-card .form-select,
.client-layout .client-search-box .form-control{
    background:#ffffff !important;
    color:#18212f !important;
    border:1px solid #233044 !important;
}
.client-layout .form-control::placeholder,
.client-layout .client-search-box .form-control::placeholder{
    color:#6b7280 !important;
}
.client-layout .form-control:focus,
.client-layout .form-select:focus,
.client-layout .client-form-card .form-control:focus,
.client-layout .client-form-card .form-select:focus,
.client-layout .client-search-box .form-control:focus{
    background:#ffffff !important;
    color:#18212f !important;
    border-color:#233044 !important;
    box-shadow:none !important;
}
.client-layout[data-client-theme="dark"] .form-control,
.client-layout[data-client-theme="dark"] .form-select,
.client-layout[data-client-theme="dark"] .client-form-card .form-control,
.client-layout[data-client-theme="dark"] .client-form-card .form-select,
.client-layout[data-client-theme="dark"] .client-search-box .form-control{
    background:#ffffff !important;
    color:#18212f !important;
    border-color:#233044 !important;
}
.client-layout[data-client-theme="dark"] .form-control::placeholder,
.client-layout[data-client-theme="dark"] .client-search-box .form-control::placeholder{
    color:#6b7280 !important;
}
.client-map-popup-label{
    font-size:.74rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:#64748b;
    margin-top:.1rem;
}
.client-map-popup-actions{
    flex-wrap:nowrap;
    overflow-x:auto;
    padding-bottom:.15rem;
}
.client-map-popup-actions .client-popup-btn{
    white-space:nowrap;
    flex:0 0 auto;
}

.client-nav-counter{
    min-width:24px;
    height:24px;
    padding:0 .4rem;
    border-radius:999px;
    background:var(--client-primary);
    color:#fff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:.76rem;
    font-weight:800;
    line-height:1;
}
.client-topbar-bell{
    position:relative;
    width:42px;
    height:42px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    text-decoration:none;
    background:rgba(255,255,255,.14);
}
.client-topbar-bell:hover{color:#fff;background:rgba(255,255,255,.2)}
.client-topbar-badge{
    position:absolute;
    top:-4px;
    right:-4px;
    min-width:22px;
    height:22px;
    padding:0 .35rem;
    border-radius:999px;
    background:#ffcf33;
    color:#172033;
    font-size:.72rem;
    font-weight:900;
    display:flex;
    align-items:center;
    justify-content:center;
    border:2px solid rgba(36,83,255,.6);
}
.client-chat-shell--thread{
    min-height:calc(100vh - 180px);
}
.client-chat-shell--thread .client-chat-sidebar{
    padding:1rem;
    gap:1rem;
}
.client-chat-list-item{
    transition:.18s ease;
}
.client-chat-list-item.active{
    background:rgba(36,83,255,.08);
    border-color:rgba(36,83,255,.22);
}
.client-chat-list-item:hover{
    transform:translateY(-1px);
    border-color:rgba(36,83,255,.18);
}
.client-chat-list-title{
    font-size:.85rem;
    color:var(--client-text);
    opacity:.88;
}
.client-chat-list-preview{
    color:var(--client-muted);
    font-size:.88rem;
}
.client-chat-stage--thread{
    align-items:stretch;
    justify-content:stretch;
    padding:1rem;
}
.client-chat-panel{
    display:grid;
    grid-template-rows:auto 1fr auto;
    gap:1rem;
    width:100%;
    min-height:100%;
}
.client-chat-header-card{
    background:var(--client-surface);
    border:1px solid var(--client-border);
    border-radius:22px;
    padding:1rem 1.1rem;
    display:flex;
    justify-content:space-between;
    gap:1rem;
    align-items:flex-start;
    flex-wrap:wrap;
}
.client-chat-panel-title{
    font-size:1.4rem;
    font-weight:800;
}
.client-chat-panel-subtitle{
    font-size:1rem;
    color:var(--client-text);
}
.client-chat-panel-meta{
    display:flex;
    gap:.6rem;
    flex-wrap:wrap;
}
.client-chat-panel-meta span{
    display:inline-flex;
    align-items:center;
    gap:.35rem;
    padding:.45rem .7rem;
    border-radius:999px;
    background:var(--client-surface-soft);
    border:1px solid var(--client-border);
    color:var(--client-muted);
    font-size:.84rem;
    font-weight:700;
}
.client-chat-header-actions{
    display:flex;
    gap:.6rem;
    flex-wrap:wrap;
    align-items:center;
}
.client-chat-messages-scroll{
    background:var(--client-surface-soft);
    border:1px solid var(--client-border);
    border-radius:22px;
    padding:1rem;
    min-height:360px;
    max-height:calc(100vh - 420px);
    overflow:auto;
    display:grid;
    gap:.9rem;
}
.client-message-row{
    display:flex;
    width:100%;
}
.client-message-row.mine{justify-content:flex-end}
.client-message-row.theirs{justify-content:flex-start}
.client-message-bubble{
    max-width:min(100%, 760px);
    border-radius:18px;
    padding:.95rem 1rem;
    border:1px solid var(--client-border);
    box-shadow:0 8px 18px rgba(15,23,42,.04);
}
.client-message-bubble.mine{
    background:rgba(36,83,255,.08);
    border-color:rgba(36,83,255,.2);
}
.client-message-bubble.theirs{
    background:var(--client-surface);
}
.client-message-meta{
    display:flex;
    justify-content:space-between;
    gap:1rem;
    align-items:center;
    margin-bottom:.45rem;
    color:var(--client-muted);
}
.client-message-text{
    color:var(--client-text);
    white-space:normal;
    word-break:break-word;
    line-height:1.55;
}
.client-chat-composer{
    width:100%;
}
.client-chat-composer-box{
    background:var(--client-surface);
    border:1px solid var(--client-border);
    border-radius:22px;
    padding:1rem;
}
.client-chat-composer .form-control{
    min-height:120px;
    resize:vertical;
}
.client-chat-composer-actions{
    display:flex;
    justify-content:space-between;
    gap:1rem;
    align-items:center;
    flex-wrap:wrap;
    margin-top:.85rem;
}
.min-w-0{min-width:0}
.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width: 991px){
    .client-chat-shell--thread{min-height:auto}
    .client-chat-messages-scroll{max-height:none;min-height:280px}
}

.client-overview-grid{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:1rem;
    margin-bottom:1.2rem;
}
.client-overview-card{
    background:var(--client-surface);
    border:1px solid var(--client-border);
    border-radius:22px;
    padding:1rem 1.1rem;
    display:grid;
    gap:.45rem;
}
.client-overview-card span{
    color:var(--client-muted);
    font-size:.88rem;
    font-weight:700;
}
.client-overview-card strong{
    font-size:1.9rem;
    line-height:1;
    font-weight:900;
    color:var(--client-text);
}
.client-overview-card.primary{border-color:rgba(36,83,255,.18);background:rgba(36,83,255,.06)}
.client-overview-card.warning{border-color:rgba(245,158,11,.22);background:rgba(245,158,11,.08)}
.client-overview-card.success{border-color:rgba(22,163,74,.2);background:rgba(22,163,74,.08)}
.client-overview-card.danger{border-color:rgba(220,38,38,.18);background:rgba(220,38,38,.06)}
.client-appointments-shell{
    display:grid;
    grid-template-columns:360px 1fr;
    background:var(--client-surface);
    border:1px solid var(--client-border);
    border-radius:28px;
    overflow:hidden;
    min-height:calc(100vh - 255px);
}
.client-appointments-shell.professional{grid-template-columns:400px 1fr}
.client-appointments-sidebar{

    background:var(--client-surface);
    padding:1rem;
    display:flex;
    flex-direction:column;
    gap:1rem;
}
.client-appointments-sidebar-head h2{
    font-size:1.12rem;
    font-weight:800;
    margin:0 0 .25rem;
}
.client-appointments-sidebar-head p{
    margin:0;
    color:var(--client-muted);
    font-size:.92rem;
}
.client-appointments-list{display:grid;gap:.8rem}
.client-appointment-list-item{
    background:var(--client-surface-soft);
    border:1px solid var(--client-border);
    border-radius:20px;
    padding:30px 5px 5px 0px;
    display:grid;
    gap:.85rem;
    transition:.18s ease;
}
.client-appointment-list-item:hover{
    transform:translateY(-1px);
    border-color:rgba(36,83,255,.2);
}
.client-appointment-list-item.active{
    background:rgba(36,83,255,.07);
    border-color:rgba(36,83,255,.26);
}
.client-appointment-list-top{
    display:flex;
    gap:.8rem;
    align-items:flex-start;
}
.client-appointment-list-meta{
    display:flex;
    flex-wrap:wrap;
    gap:.7rem;
    color:var(--client-muted);
    font-size:.88rem;
}
.client-appointments-stage{
    padding:1rem;
    background:var(--client-surface-soft);
}
.client-detail-header-card,
.client-detail-card{
    background:var(--client-surface);
    border:1px solid var(--client-border);
    border-radius:24px;
}
.client-detail-header-card{
    padding:1.15rem 1.2rem;
    display:flex;
    justify-content:space-between;
    gap:1rem;
    flex-wrap:wrap;
    align-items:flex-start;
}
.client-detail-kicker{
    color:var(--client-primary);
    text-transform:uppercase;
    letter-spacing:.08em;
    font-size:.76rem;
    font-weight:900;
    margin-bottom:.35rem;
}
.client-detail-title{
    font-size:1.6rem;
    font-weight:900;
    margin:0;
}
.client-detail-subtitle{
    color:var(--client-muted);
    font-size:1rem;
    margin-top:.25rem;
}
.client-detail-header-actions{
    display:flex;
    align-items:center;
    gap:.65rem;
    flex-wrap:wrap;
}
.client-detail-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:1rem;
    margin-top:1rem;
}
.client-detail-grid.two-columns{grid-template-columns:repeat(2,minmax(0,1fr))}
.client-detail-grid.three-columns{grid-template-columns:1.05fr 1fr 1.2fr}
.client-detail-card{padding:1.1rem}
.client-detail-card-head{
    display:flex;
    justify-content:space-between;
    gap:1rem;
    align-items:flex-start;
    margin-bottom:1rem;
}
.client-detail-card-head h3{
    margin:0;
    font-size:1.05rem;
    font-weight:800;
}
.client-detail-card-head span{
    color:var(--client-muted);
    font-size:.85rem;
    font-weight:700;
}
.client-detail-info-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:.8rem;
}
.client-detail-info-grid span,
.client-address-stack span{
    display:block;
    color:var(--client-muted);
    font-size:.82rem;
    margin-bottom:.18rem;
}
.client-detail-info-grid strong,
.client-address-stack strong{
    display:block;
    color:var(--client-text);
    font-size:.96rem;
    font-weight:800;
}
.client-address-stack{display:grid;gap:.9rem}
.client-inline-note{
    padding:1rem;
    border-radius:18px;
    background:var(--client-surface-soft);
    border:1px solid var(--client-border);
    color:var(--client-text);
    line-height:1.55;
}
.client-inline-note.success{background:rgba(22,163,74,.08);border-color:rgba(22,163,74,.16)}
.client-inline-note.danger{background:rgba(220,38,38,.07);border-color:rgba(220,38,38,.14)}
.client-status-pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:32px;
    padding:.45rem .8rem;
    border-radius:999px;
    font-size:.78rem;
    font-weight:900;
    border:1px solid transparent;
    text-transform:uppercase;
    letter-spacing:.02em;
}
.client-status-pill.default{background:var(--client-surface-soft);border-color:var(--client-border);color:var(--client-muted)}
.client-status-pill.primary{background:rgba(36,83,255,.1);border-color:rgba(36,83,255,.16);color:var(--client-primary)}
.client-status-pill.warning{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.16);color:#b25d00}
.client-status-pill.success{background:rgba(22,163,74,.1);border-color:rgba(22,163,74,.16);color:#187a3c}
.client-status-pill.danger{background:rgba(220,38,38,.1);border-color:rgba(220,38,38,.16);color:#b42318}
.client-history-timeline{display:grid;gap:.95rem}
.client-history-item{
    display:grid;
    grid-template-columns:14px 1fr;
    gap:.85rem;
    align-items:flex-start;
}
.client-history-dot{
    width:14px;
    height:14px;
    margin-top:.2rem;
    border-radius:999px;
    background:var(--client-border);
    box-shadow:0 0 0 6px rgba(36,83,255,.05);
}
.client-history-item.primary .client-history-dot{background:var(--client-primary);box-shadow:0 0 0 6px rgba(36,83,255,.08)}
.client-history-item.warning .client-history-dot{background:#f59e0b;box-shadow:0 0 0 6px rgba(245,158,11,.08)}
.client-history-item.success .client-history-dot{background:#16a34a;box-shadow:0 0 0 6px rgba(22,163,74,.08)}
.client-history-item.danger .client-history-dot{background:#dc2626;box-shadow:0 0 0 6px rgba(220,38,38,.08)}
.client-history-item strong{display:block;font-size:.96rem;margin-bottom:.22rem}
.client-history-item p{margin:0 0 .2rem;color:var(--client-text);line-height:1.5}
.client-history-item small{color:var(--client-muted)}
.client-detail-actions-row{display:flex;gap:.65rem;flex-wrap:wrap}
.client-action-grid{display:grid;gap:.9rem}
.client-action-card{
    padding:1rem;
    border-radius:20px;
    border:1px solid var(--client-border);
    background:var(--client-surface-soft);
}
.client-action-card.primary{border-color:rgba(36,83,255,.16);background:rgba(36,83,255,.05)}
.client-action-card.warning{border-color:rgba(245,158,11,.18);background:rgba(245,158,11,.05)}
.client-action-card.success{border-color:rgba(22,163,74,.18);background:rgba(22,163,74,.05)}
.client-action-card.danger{border-color:rgba(220,38,38,.16);background:rgba(220,38,38,.04)}
.client-action-card-head{display:grid;gap:.12rem;margin-bottom:.75rem}
.client-action-card-head strong{font-size:.96rem}
.client-action-card-head span{color:var(--client-muted);font-size:.85rem}
@media (max-width: 1400px){
    .client-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
    .client-detail-grid.three-columns{grid-template-columns:1fr 1fr}
}
@media (max-width: 1200px){
    .client-appointments-shell,
    .client-appointments-shell.professional{grid-template-columns:1fr}
    .client-appointments-sidebar{border-right:none;border-bottom:1px solid var(--client-border)}
    .client-detail-grid.two-columns,
    .client-detail-grid.three-columns{grid-template-columns:1fr}
}
@media (max-width: 768px){
    .client-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .client-detail-info-grid{grid-template-columns:1fr}
    .client-detail-title{font-size:1.3rem}
}

.professional-avatar-section{
    background:var(--client-surface-soft);
}
.professional-avatar-upload-shell{
    display:flex;
    align-items:center;
    gap:1.25rem;
    flex-wrap:wrap;
}
.professional-avatar-preview-lg,
.public-profile-avatar,
.professional-list-avatar{
    border-radius:50%;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(180deg,#dbe7ff,#c8d5ec);
    color:#1b2a42;
    font-weight:900;
    flex-shrink:0;
}
.professional-avatar-preview-lg{
    width:112px;
    height:112px;
    font-size:2rem;
    border:4px solid rgba(36,83,255,.12);
    box-shadow:0 12px 24px rgba(15,23,42,.08);
}
.professional-avatar-upload-content{
    flex:1 1 320px;
    min-width:min(100%, 320px);
}
.professional-avatar-help{
    margin-top:.55rem;
    color:var(--client-muted);
    font-size:.92rem;
}
.professional-avatar-preview-lg img,
.public-profile-avatar img,
.professional-list-avatar img,
.client-chat-avatar img,
.professional-topbar-avatar img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.professional-card-identity{
    display:flex;
    gap:1rem;
    align-items:center;
}
.professional-list-avatar{
    width:72px;
    height:72px;
    font-size:1.35rem;
    border:3px solid rgba(36,83,255,.12);
}
.professional-profile-identity{
    display:flex;
    gap:1.25rem;
    align-items:flex-start;
}
.public-profile-avatar{
    width:128px;
    height:128px;
    font-size:2.4rem;
    border:4px solid rgba(36,83,255,.12);
    box-shadow:0 12px 24px rgba(15,23,42,.08);
}
.client-chat-avatar.has-image{
    padding:0;
    background:#d4dded;
    overflow:hidden;
}
.client-chat-avatar--lg{
    width:64px;
    height:64px;
    font-size:1.2rem;
}
.client-chat-header-identity{
    display:flex;
    gap:1rem;
    align-items:flex-start;
}
.professional-topbar-profile{
    display:inline-flex;
    align-items:center;
    gap:.75rem;
    color:#fff;
    text-decoration:none;
    font-weight:800;
}
.professional-topbar-profile:hover{
    color:#fff;
}

.client-detail-identity-wrap{display:flex;align-items:flex-start;gap:1rem;min-width:0}
.client-detail-identity-avatar{width:64px;height:64px;font-size:1.15rem;border:3px solid rgba(36,83,255,.12)}
.client-detail-inline-identity{display:flex;align-items:center;gap:.85rem}
.client-layout[data-client-theme="dark"] .client-professional-card-avatar,
.client-layout[data-client-theme="dark"] .client-notification-avatar,
.client-layout[data-client-theme="dark"] .client-map-popup-avatar{background:#172945;color:#f1f5f9}
.professional-topbar-avatar{
    width:42px;
    height:42px;
    border:2px solid rgba(255,255,255,.35);
    background:rgba(255,255,255,.18);
    color:#fff;
}
.client-layout[data-client-theme="dark"] .professional-avatar-preview-lg,
.client-layout[data-client-theme="dark"] .public-profile-avatar,
.client-layout[data-client-theme="dark"] .professional-list-avatar{
    background:linear-gradient(180deg,#172945,#0f2033);
    color:#f1f5f9;
}
@media (max-width: 768px){
    .professional-profile-identity,
    .client-chat-header-identity,
    .client-detail-identity-wrap{
        flex-direction:column;
    }
    .public-profile-avatar{
        width:104px;
        height:104px;
    }
    .professional-topbar-profile span:last-child{
        display:none;
    }
}


.public-rating-row{display:grid;gap:.55rem}
.public-rating-inline,
.client-rating-inline{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;color:var(--client-text)}
.public-rating-inline strong,
.client-rating-inline strong{font-size:1rem;font-weight:800;color:var(--client-text)}
.public-rating-inline.large strong,
.client-rating-inline.large strong{font-size:1.25rem}
.public-rating-inline span:last-child,
.client-rating-inline span:last-child{color:var(--client-muted);font-size:.92rem}
.public-rating-star,
.client-rating-stars{color:#f59e0b;font-size:1rem;line-height:1;font-weight:900}
.public-rating-inline.large .public-rating-star,
.client-rating-inline.large .client-rating-stars{font-size:1.25rem}
.public-review-snippet,
.client-review-comment-preview{padding:.8rem 1rem;border-radius:16px;background:var(--client-surface-soft);border:1px solid var(--client-border);color:var(--client-text);line-height:1.5;font-size:.92rem}
.public-review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.public-review-card{padding:1rem 1.1rem;border-radius:20px;border:1px solid var(--client-border);background:var(--client-surface-soft);display:grid;gap:.65rem}
.public-review-card-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}
.public-review-card-head small{color:var(--client-muted);white-space:nowrap}
.public-review-stars{display:flex;align-items:center;gap:.55rem;color:#f59e0b;font-weight:900}
.public-review-stars span{color:var(--client-muted);font-weight:700;font-size:.9rem}
.public-review-card p{margin:0;color:var(--client-text);line-height:1.55}
.client-review-form{display:grid;gap:.65rem}
.client-review-stars-input{display:flex;flex-direction:row-reverse;justify-content:flex-end;gap:.25rem}
.client-review-stars-input input{display:none}
.client-review-stars-input label{font-size:2rem;line-height:1;color:#cbd5e1;cursor:pointer;transition:transform .18s ease,color .18s ease}
.client-review-stars-input label:hover,
.client-review-stars-input label:hover ~ label,
.client-review-stars-input input:checked ~ label{color:#f59e0b;transform:translateY(-1px)}
.client-review-summary{display:grid;gap:.85rem}
.client-map-popup-rating{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;padding:.55rem .7rem;border-radius:14px;background:#f8fafc;border:1px solid rgba(15,23,42,.06);font-size:.85rem;color:#0f172a}
.client-map-popup-rating span{color:#f59e0b;font-weight:900}
.client-map-popup-rating strong{font-size:.95rem}
.client-map-popup-rating small{color:#475569}
.client-map-popup-review{font-size:.83rem;line-height:1.45;color:#334155;padding:.55rem .7rem;border-radius:14px;background:#f8fafc;border-left:3px solid #f59e0b}
.client-layout[data-client-theme="dark"] .public-review-snippet,
.client-layout[data-client-theme="dark"] .client-review-comment-preview,
.client-layout[data-client-theme="dark"] .public-review-card,
.client-layout[data-client-theme="dark"] .client-map-popup-rating,
.client-layout[data-client-theme="dark"] .client-map-popup-review{background:rgba(12,22,38,.72);color:#e2e8f0;border-color:rgba(148,163,184,.18)}
.client-layout[data-client-theme="dark"] .client-map-popup-rating small,
.client-layout[data-client-theme="dark"] .public-review-stars span{color:#cbd5e1}
@media (max-width: 992px){
    .public-review-grid{grid-template-columns:1fr}
}

.status-badge.portfolio{
    background:rgba(70,214,198,.12);
    color:#9ef3e9;
    border:1px solid rgba(70,214,198,.25);
}
.portfolio-counter-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:.55rem .95rem;
    border-radius:999px;
    background:rgba(70,214,198,.12);
    color:#dffcf9;
    border:1px solid rgba(70,214,198,.22);
    font-weight:800;
}
.portfolio-counter-badge.large{
    min-height:54px;
    padding:.7rem 1.2rem;
}
.portfolio-upload-preview{
    min-height:120px;
    border-radius:18px;
    border:1px dashed rgba(255,255,255,.16);
    background:rgba(255,255,255,.03);
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    color:var(--muted);
    font-weight:700;
}
.portfolio-upload-preview.has-image{padding:0;border-style:solid}
.portfolio-upload-preview img,
.portfolio-manage-image,
.portfolio-public-image{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.portfolio-manage-grid,
.portfolio-public-grid{
    display:flex;
    flex-wrap:wrap;
    gap:1rem;
    align-items:flex-start;
}
.portfolio-manage-card,
.portfolio-public-card{
    background:rgba(255,255,255,.03);
    border:1px solid var(--line);
    border-radius:22px;
    overflow:hidden;
}
.portfolio-manage-card{
    flex:0 0 230px;
    max-width:230px;
}
.portfolio-public-card{
    flex:0 0 180px;
    max-width:180px;
}
.portfolio-manage-image-shell,
.portfolio-public-image-shell{
    height:220px;
    background:rgba(255,255,255,.04);
}
.portfolio-public-image-shell.compact{
    height:92px;
}
.portfolio-public-card.compact{
    border-radius:16px;
}
.portfolio-manage-image--empty,
.portfolio-public-image--empty{
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--muted);
    font-weight:700;
}
.portfolio-manage-body,
.portfolio-public-body{
    padding:1rem 1rem 1.1rem;
}
.portfolio-manage-body h3,
.portfolio-public-body h3{
    font-size:1.05rem;
    font-weight:800;
    margin-bottom:.5rem;
}
.portfolio-public-body.compact{
    padding:.65rem .7rem .8rem;
}
.portfolio-public-body.compact h3{
    font-size:.88rem;
    line-height:1.25;
    min-height:2.2em;
    margin-bottom:.35rem;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.portfolio-manage-body p,
.portfolio-public-body p{
    color:var(--muted);
    margin-bottom:0;
}
.portfolio-public-body.compact p{
    font-size:.78rem;
    line-height:1.35;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.portfolio-manage-meta{
    color:var(--muted);
    font-size:.85rem;
    margin-top:.75rem;
}
.client-layout[data-client-theme="light"] .portfolio-counter-badge{
    background:rgba(36,83,255,.08);
    color:#2453ff;
    border-color:rgba(36,83,255,.14);
}
.client-layout[data-client-theme="light"] .portfolio-upload-preview,
.client-layout[data-client-theme="light"] .portfolio-manage-card,
.client-layout[data-client-theme="light"] .portfolio-public-card{
    background:#fff;
    border-color:rgba(15,23,42,.08);
}
.client-layout[data-client-theme="light"] .portfolio-manage-body p,
.client-layout[data-client-theme="light"] .portfolio-public-body p,
.client-layout[data-client-theme="light"] .portfolio-manage-meta{
    color:#64748b;
}
@media (max-width: 768px){
    .portfolio-manage-card{flex:0 0 calc(50% - .5rem);max-width:calc(50% - .5rem)}
    .portfolio-public-card{flex:0 0 150px;max-width:150px}
    .portfolio-manage-image-shell{height:190px}
    .portfolio-public-image-shell{height:92px}
}

.client-professional-card.has-commercial-highlight{
    position:relative;
    border-color:rgba(36,83,255,.18);
    box-shadow:0 18px 38px rgba(36,83,255,.08);
}
.client-professional-card.tier-professional.has-commercial-highlight{
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
}
.client-professional-card.tier-premium{
    background:linear-gradient(180deg,#fffdf7 0%,#fff9eb 100%);
    border-color:rgba(245,158,11,.28);
    box-shadow:0 24px 44px rgba(245,158,11,.16);
}
.client-professional-card.tier-premium::before,
.client-professional-card.tier-professional.has-commercial-highlight::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:24px;
    pointer-events:none;
}
.client-professional-card.tier-premium::before{
    box-shadow:inset 0 0 0 2px rgba(245,158,11,.15);
}
.client-professional-card.tier-professional.has-commercial-highlight::before{
    box-shadow:inset 0 0 0 2px rgba(59,130,246,.10);
}
.client-badges-stack{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;align-items:flex-start}
.client-professional-card-tags{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem;align-items:flex-start}
.client-card-category{justify-self:flex-start;max-width:100%}
.client-card-badges{justify-content:flex-end;max-width:100%}
.client-card-badges .client-chip{max-width:100%;white-space:normal;text-align:center}

@media (max-width: 575.98px){
    .professional-card-topbar,
    .client-professional-card-tags{grid-template-columns:1fr}
    .professional-card-badges,
    .client-card-badges{justify-content:flex-start}
}
.client-chip.premium{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.38rem;
    min-height:30px;
    padding:.52rem .9rem;
    border-radius:999px;
    background:linear-gradient(180deg,#fff6db 0%,#ffefbe 100%);
    color:#a24d0a;
    border:1px solid rgba(245,158,11,.28);
    box-shadow:0 10px 20px rgba(245,158,11,.14);
    font-size:.76rem;
    font-weight:900;
    letter-spacing:.02em;
    line-height:1;
    white-space:nowrap;
}
.client-chip.premium::before{
    content:"★";
    font-size:.74rem;
    line-height:1;
    color:#d97706;
}
.client-map-pin.featured,
.client-map-pin.featured::after{background:#3b82f6}
.client-map-pin.premium,
.client-map-pin.premium::after{background:#f59e0b}
.client-map-pin.premium{
    width:22px;
    height:22px;
    border-width:4px;
    box-shadow:0 0 0 9px rgba(245,158,11,.20),0 14px 28px rgba(0,0,0,.24);
}
.client-map-pin.premium::after{
    bottom:-13px;
    width:12px;
    height:12px;
    border-right-width:4px;
    border-bottom-width:4px;
}
.client-map-pin.featured{box-shadow:0 0 0 6px rgba(59,130,246,.16),0 10px 22px rgba(0,0,0,.2)}
.client-map-popup-card.tier-premium{border-radius:18px;padding:.3rem;background:linear-gradient(180deg,#fffdfa 0%,#fffaf0 100%)}
.client-map-popup-card.tier-professional{border:1px solid rgba(59,130,246,.14);border-radius:18px;padding:.3rem;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)}
.client-map-popup-plan{display:inline-flex;align-items:center;justify-content:center;padding:.28rem .62rem;border-radius:999px;font-size:.72rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;margin:0 5px 5px 0;}
.client-map-popup-plan.premium{background:rgba(245,158,11,.14);color:#b45309;border:1px solid rgba(245,158,11,.22)}
.client-map-popup-plan.featured{background:rgba(59,130,246,.10);color:#1d4ed8;border:1px solid rgba(59,130,246,.18)}
.client-map-pin-wrap:has(.client-map-pin.premium){z-index:1200}
.client-map-popup-portfolio{font-size:.82rem;color:#475569;padding:.45rem .65rem;border-radius:14px;background:#fff;border:1px solid rgba(15,23,42,.06)}
.client-layout[data-client-theme="dark"] .client-professional-card.tier-premium{background:linear-gradient(180deg,#2b1f08 0%,#1f1a10 100%);border-color:rgba(245,158,11,.22);box-shadow:0 24px 44px rgba(0,0,0,.32)}
.client-layout[data-client-theme="dark"] .client-professional-card.tier-professional.has-commercial-highlight{background:linear-gradient(180deg,#122134 0%,#0e1b2b 100%)}
.client-layout[data-client-theme="dark"] .client-chip.premium{
    background:linear-gradient(180deg,rgba(245,158,11,.24) 0%,rgba(217,119,6,.24) 100%);
    color:#fde68a;
    border-color:rgba(245,158,11,.34);
    box-shadow:0 12px 24px rgba(0,0,0,.28);
}
.client-layout[data-client-theme="dark"] .client-chip.premium::before{color:#fbbf24}
.client-layout[data-client-theme="dark"] .client-map-popup-card.tier-premium{background:linear-gradient(180deg,#2b1f08 0%,#1c170d 100%);border-color:rgba(245,158,11,.28)}
.client-layout[data-client-theme="dark"] .client-map-popup-card.tier-professional{background:linear-gradient(180deg,#122134 0%,#0e1b2b 100%);border-color:rgba(59,130,246,.22)}
.client-layout[data-client-theme="dark"] .client-map-popup-portfolio{background:rgba(12,22,38,.72);color:#e2e8f0;border-color:rgba(148,163,184,.18)}



.client-mobile-menu-utilities{display:none}
@media (max-width: 991px){
    .client-mobile-hide{display:none !important}
    .client-mobile-menu-utilities{display:flex;gap:.85rem;align-items:center;justify-content:flex-start;padding:.4rem 0 0.2rem}
    .client-mobile-utility-btn{position:relative;width:44px;height:44px;border-radius:12px;border:1px solid var(--client-border);background:var(--client-surface);color:var(--client-text);display:inline-flex;align-items:center;justify-content:center;padding:0;text-decoration:none;box-shadow:0 8px 18px rgba(15,23,42,.06)}
    .client-mobile-utility-btn svg{width:20px;height:20px;display:block}
    .client-mobile-utility-link{overflow:visible}
    .client-mobile-utility-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:.68rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--client-surface)}
    .client-layout[data-client-theme="dark"] .client-mobile-utility-btn{background:#13263b;color:#e2e8f0;border-color:rgba(255,255,255,.08);box-shadow:0 10px 24px rgba(0,0,0,.22)}
    .client-layout[data-client-theme="dark"] .client-mobile-utility-badge{border-color:#13263b}
}

.client-mobile-drawer,
.client-mobile-drawer-overlay{display:none}
@media (max-width: 991px){
    body.client-mobile-menu-open{overflow:hidden}
    .client-sidebar{padding:1rem 1rem .35rem;background:transparent;border:none;gap:0}
    .client-logo-card{background:var(--client-surface);border:1px solid var(--client-border);border-radius:26px;padding:1.1rem 1.1rem 1rem;box-shadow:0 18px 38px rgba(15,23,42,.08)}
    .client-mobile-drawer-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.46);opacity:0;transition:opacity .22s ease;z-index:1040;pointer-events:none}
    .client-mobile-drawer-overlay.is-visible{opacity:1;pointer-events:auto}
    .client-mobile-drawer-overlay[hidden]{display:none !important;pointer-events:none !important}
    .client-mobile-drawer{display:block;position:fixed;inset:0 auto 0 0;width:min(360px,86vw);max-width:100%;z-index:1045;transform:translateX(-104%);transition:transform .24s ease;pointer-events:none}
    .client-mobile-drawer[data-open="true"]{transform:translateX(0);pointer-events:auto}
    .client-mobile-drawer-panel{height:100%;background:var(--client-surface);border-right:1px solid var(--client-border);box-shadow:0 18px 48px rgba(15,23,42,.24);display:flex;flex-direction:column;padding:1.15rem 1rem 1rem;overflow-y:auto}
    .client-mobile-drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--client-border);margin-bottom:1rem}
    .client-mobile-drawer-subtitle{font-size:1.55rem;font-weight:800;color:var(--client-text);line-height:1.15}
    .client-mobile-drawer-close{border:none;background:transparent;color:var(--client-text);font-size:2rem;line-height:1;padding:0 .2rem;cursor:pointer}
    .client-mobile-drawer-nav{display:grid;gap:.45rem}
    .client-mobile-drawer .client-nav-link{padding:1rem;border-radius:16px}
    .client-mobile-drawer .client-nav-form{margin:0}
    .client-mobile-drawer .client-mobile-menu-utilities{display:flex;padding:.5rem 0 0;gap:.85rem}
    .client-mobile-drawer .client-mobile-utility-btn{background:var(--client-surface);border-color:var(--client-border)}
    .client-layout[data-client-theme="dark"] .client-logo-card{background:#0f1d31;border-color:rgba(255,255,255,.08);box-shadow:0 18px 38px rgba(0,0,0,.28)}
    .client-layout[data-client-theme="dark"] .client-mobile-drawer-panel{background:#0f1d31;border-right-color:rgba(255,255,255,.08)}
}

/* Fix visual regressions after map premium highlight */
.client-nav-form{margin:0}
.client-nav-link-button{
    width:100%;
    border:0;
    background:transparent;
    text-align:left;
    cursor:pointer;
}
.client-nav-link-danger{
    color:#c62828;
    background:rgba(198,40,40,.10);
    border:1px solid rgba(198,40,40,.12);
}
.client-layout[data-client-theme="dark"] .client-nav-link-danger{
    color:#ffb4b4;
    background:rgba(239,68,68,.14);
    border-color:rgba(239,68,68,.18);
}
.client-nav-icon{
    width:22px;
    height:22px;
    flex:0 0 22px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:inherit;
}
.client-nav-icon svg,
.client-topbar-icon svg,
.client-theme-icon{
    width:20px;
    height:20px;
    display:block;
}
.client-topbar-icon-btn{
    width:42px;
    height:42px;
    padding:0;
    border:0;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    color:#fff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    position:relative;
}
.client-topbar-icon-btn:hover{background:rgba(255,255,255,.22)}
.client-theme-icon-sun{display:none}
.client-layout[data-client-theme="dark"] .client-theme-icon-moon{display:none}
.client-layout[data-client-theme="dark"] .client-theme-icon-sun{display:block}
.client-topbar-icon{display:inline-flex;align-items:center;justify-content:center}

.client-detail-tab-shell{
    margin-top:1rem;
    border-top:1px solid var(--client-border);
    padding-top:1rem;
}
.client-detail-tab-nav{
    display:flex;
    gap:.7rem;
    flex-wrap:wrap;
    padding:0;
    margin:0 0 1rem;
    list-style:none;
}
.client-detail-tab-btn{
    appearance:none;
    border:1px solid var(--client-border);
    background:var(--client-surface);
    color:var(--client-muted);
    border-radius:999px;
    padding:.78rem 1.1rem;
    font-weight:800;
    line-height:1;
    box-shadow:none;
}
.client-detail-tab-btn.active,
.client-detail-tab-btn[aria-selected="true"]{
    background:var(--client-primary);
    border-color:var(--client-primary);
    color:#fff;
}
.client-detail-tab-btn:hover{color:var(--client-primary);border-color:rgba(36,83,255,.22)}
.client-detail-tab-btn.active:hover,
.client-detail-tab-btn[aria-selected="true"]:hover{color:#fff}
.client-detail-tab-content>.tab-pane{padding-top:.15rem}

.client-layout[data-client-theme="light"] .client-topbar-icon-btn,
.client-layout[data-client-theme="light"] .client-topbar-bell{
    background:rgba(255,255,255,.16);
}
.client-layout[data-client-theme="light"] .client-detail-tab-btn{
    background:#fff;
    color:#5c718f;
    border-color:rgba(15,23,42,.10);
    border: 1px solid;
}
.client-layout[data-client-theme="light"] .client-detail-tab-btn.active,
.client-layout[data-client-theme="light"] .client-detail-tab-btn[aria-selected="true"]{
    background:var(--client-primary);
    color:#fff;
    border-color:var(--client-primary);
}
.client-layout[data-client-theme="dark"] .client-detail-tab-btn{
    background:#13263b;
    color:#c6d3e2;
    border-color:rgba(255,255,255,.08);
}
.client-layout[data-client-theme="dark"] .client-detail-tab-btn.active,
.client-layout[data-client-theme="dark"] .client-detail-tab-btn[aria-selected="true"]{
    background:var(--client-primary);
    color:#fff;
    border-color:var(--client-primary);
}

/* Public professional pages restored to light layout */
.public-site-view.public-profile-view[data-public-theme="light"],
.public-site-view.professional-directory-view[data-public-theme="light"]{
    --public-bg:#eef3fb;
    --public-bg-alt:#f6f9ff;
    --public-surface:#ffffff;
    --public-surface-soft:#f3f6fb;
    --public-border:#d9e2f0;
    --public-text:#0f172a;
    --public-muted:#64748b;
    --public-primary:#3556f7;
    --public-accent:#2ed3c4;
    background:#eef3fb;
    color:var(--public-text);
}
.public-site-view.public-profile-view[data-public-theme="light"] body,
.public-site-view.professional-directory-view[data-public-theme="light"] body{background:#eef3fb;}
.public-site-view.public-profile-view[data-public-theme="light"] .topbar,
.public-site-view.professional-directory-view[data-public-theme="light"] .topbar{
    background:rgba(255,255,255,.96);
    border-bottom:1px solid var(--public-border);
    backdrop-filter:blur(12px);
}
.public-site-view.public-profile-view[data-public-theme="light"] .brand,
.public-site-view.professional-directory-view[data-public-theme="light"] .brand{color:var(--public-text)}
.public-site-view.public-profile-view[data-public-theme="light"] .brand-subtitle,
.public-site-view.professional-directory-view[data-public-theme="light"] .brand-subtitle,
.public-site-view.public-profile-view[data-public-theme="light"] .nav-link-custom,
.public-site-view.professional-directory-view[data-public-theme="light"] .nav-link-custom{color:var(--public-text)}
.public-site-view.public-profile-view[data-public-theme="light"] .nav-link-custom:hover,
.public-site-view.professional-directory-view[data-public-theme="light"] .nav-link-custom:hover{color:var(--public-primary)}
.public-site-view.public-profile-view[data-public-theme="light"] .public-topbar-login,
.public-site-view.professional-directory-view[data-public-theme="light"] .public-topbar-login,
.public-site-view.public-profile-view[data-public-theme="light"] .topbar .btn-outline-light,
.public-site-view.professional-directory-view[data-public-theme="light"] .topbar .btn-outline-light{
    color:var(--public-text);
    border-color:var(--public-border);
    background:#fff;
}
.public-site-view.public-profile-view[data-public-theme="light"] .topbar .btn-light,
.public-site-view.professional-directory-view[data-public-theme="light"] .topbar .btn-light{
    background:#fff;
    color:var(--public-text);
    border:1px solid var(--public-border);
}
.public-site-view.public-profile-view[data-public-theme="light"] .public-theme-toggle-btn,
.public-site-view.professional-directory-view[data-public-theme="light"] .public-theme-toggle-btn{
    width:44px;height:44px;border-radius:999px;border:1px solid var(--public-border);background:#fff;color:var(--public-text);display:inline-flex;align-items:center;justify-content:center;
}
.public-theme-toggle-btn .public-theme-icon-sun{display:none}
.public-site-view[data-public-theme="dark"] .public-theme-toggle-btn .public-theme-icon-sun{display:block}
.public-site-view[data-public-theme="dark"] .public-theme-toggle-btn .public-theme-icon-moon{display:none}
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-page,
.public-site-view.professional-directory-view[data-public-theme="light"] .professional-directory-page{background:transparent}
.public-site-view.public-profile-view[data-public-theme="light"] .panel-card,
.public-site-view.professional-directory-view[data-public-theme="light"] .panel-card{
    background:#fff;
    border:1px solid var(--public-border);
    box-shadow:none;
    color:var(--public-text);
}
.public-site-view.public-profile-view[data-public-theme="light"] .section-kicker,
.public-site-view.professional-directory-view[data-public-theme="light"] .section-kicker{color:var(--public-accent)}
.public-site-view.public-profile-view[data-public-theme="light"] .badge-soft,
.public-site-view.professional-directory-view[data-public-theme="light"] .badge-soft{background:#fff7ed;border-color:#fed7aa;color:#c2410c}
.public-site-view.public-profile-view[data-public-theme="light"] .status-badge,
.public-site-view.professional-directory-view[data-public-theme="light"] .status-badge{display:inline-flex;align-items:center;padding:.45rem .85rem;border-radius:999px;font-size:.85rem;font-weight:700;border:1px solid var(--public-border);background:#fff;color:var(--public-muted)}
.public-site-view.public-profile-view[data-public-theme="light"] .status-badge.featured,
.public-site-view.professional-directory-view[data-public-theme="light"] .status-badge.featured{background:#fff7ed;border-color:#fdba74;color:#c2410c}
.public-site-view.public-profile-view[data-public-theme="light"] .status-badge.portfolio,
.public-site-view.professional-directory-view[data-public-theme="light"] .status-badge.portfolio{background:#ecfeff;border-color:#99f6e4;color:#0f766e}
.public-site-view.public-profile-view[data-public-theme="light"] .status-badge.verified,
.public-site-view.professional-directory-view[data-public-theme="light"] .status-badge.verified{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.public-site-view.professional-directory-view[data-public-theme="light"] .verified-icon-badge{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:rgba(34,197,94,.18);border:1px solid rgba(34,197,94,.32);color:#15803d;font-size:.95rem;font-weight:900;line-height:1;cursor:help}
.public-site-view.professional-directory-view[data-public-theme="light"] .verified-icon-badge:hover{background:rgba(34,197,94,.24);border-color:rgba(34,197,94,.42)}
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-hero-main,
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-cta,
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-content-card,
.public-site-view.professional-directory-view[data-public-theme="light"] .professional-card,
.public-site-view.professional-directory-view[data-public-theme="light"] .professional-filter-card{
    background:#fff;
    color:var(--public-text);
}
.public-profile-tabs-shell{padding:1.5rem}
.public-profile-tabs-nav{display:flex;gap:.75rem;flex-wrap:wrap;padding-bottom:1rem;border-bottom:1px solid rgba(148,163,184,.25);margin-bottom:1.25rem}
.public-profile-tab-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.75rem 1rem;font-weight:800;border:1px solid rgba(148,163,184,.35);background:#fff;color:#51627f;line-height:1;text-decoration:none;cursor:pointer;transition:all .18s ease}
.public-profile-tab-btn.is-active,.public-profile-tab-btn[aria-selected="true"]{background:#3556f7;color:#fff;border-color:#3556f7;box-shadow:0 10px 20px rgba(53,86,247,.22)}
.public-profile-tab-btn:hover{border-color:#3556f7;color:#3556f7}
.public-profile-tab-btn.is-active:hover,.public-profile-tab-btn[aria-selected="true"]:hover{color:#fff}
.public-profile-tab-pane{display:none}
.public-profile-tab-pane.is-active{display:block}
.public-profile-hero .row{align-items:stretch}
.public-profile-hero-main,.public-profile-cta{height:100%;border-radius:24px}
.public-profile-hero-identity{display:flex;gap:1.5rem;align-items:flex-start;flex-wrap:wrap}
.public-profile-hero-copy{flex:1 1 300px;min-width:280px}
.public-profile-hero-copy h1{font-size:3rem;line-height:1.05;margin:0 0 .4rem;font-weight:800;color:#0f172a}
.public-profile-hero-subtitle,.public-profile-location,.contact-line,.public-profile-hero-bio p,.public-review-card-head small,.public-review-card p,.professional-meta-list div,.text-secondary,.hero-text{color:#64748b!important}
.public-profile-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-top:1.5rem}
.public-profile-stat-card{padding:1.2rem;border-radius:20px;background:#fff;border:1px solid rgba(148,163,184,.22)}
.public-profile-stat-card span{display:block;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#94a3b8;margin-bottom:.5rem}
.public-profile-stat-card strong{font-size:1.1rem;color:#0f172a}
.public-profile-hero-bio{margin-top:1.4rem;padding:1.3rem;border-radius:22px;background:#fff;border:1px solid rgba(148,163,184,.22)}
.public-profile-hero-bio h2{font-size:1.1rem;font-weight:800;margin-bottom:.65rem;color:#0f172a}
.public-profile-content-card{padding:1.35rem;border-radius:24px;border:1px solid rgba(148,163,184,.22)}
.public-profile-summary-stack{display:grid;gap:.85rem}
.public-profile-summary-item{display:flex;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;border-radius:18px;background:#f8fbff;border:1px solid rgba(148,163,184,.18)}
.public-profile-summary-item span{color:#94a3b8;font-weight:700}
.public-profile-summary-item strong{color:#0f172a}
.public-profile-contact-grid{display:grid;gap:.65rem}
.public-profile-highlight-box{padding:1rem 1.1rem;border-radius:18px;background:#f0fdfa;border:1px solid rgba(45,212,191,.18)}
.public-profile-highlight-box p{color:#0f766e}
.professional-directory-page .section-head,.professional-directory-page .professional-filter-card{max-width:100%}
.professional-directory-page .professional-filter-submit{display:flex;align-items:flex-end}
.professional-directory-page .professional-filter-submit-btn{min-height:50px;border-radius:16px}
.public-site-view.professional-directory-view[data-public-theme="light"] .form-control,
.public-site-view.professional-directory-view[data-public-theme="light"] .form-select{background:#fff;border:1px solid #1f2a44;color:#0f172a}
.public-site-view.professional-directory-view[data-public-theme="light"] .form-control::placeholder{color:#64748b}
.public-site-view.professional-directory-view[data-public-theme="light"] .btn-outline-light{color:#0f172a;border-color:#cbd5e1;background:#fff}
.public-site-view.professional-directory-view[data-public-theme="light"] .professional-card .btn-outline-light,
.public-site-view.professional-directory-view[data-public-theme="light"] .professional-card .btn-primary,
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-cta .btn-outline-light,
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-cta .btn-primary{border-radius:16px}
.public-site-view.public-profile-view[data-public-theme="light"] .public-profile-page .btn-outline-light{color:#0f172a;border-color:#cbd5e1;background:#fff}
.public-site-view.public-profile-view[data-public-theme="light"] .public-review-snippet,
.public-site-view.public-profile-view[data-public-theme="light"] .public-review-card,
.public-site-view.professional-directory-view[data-public-theme="light"] .public-review-snippet{background:#f8fbff;border-color:rgba(148,163,184,.18);color:#334155}
@media (max-width: 992px){
  .public-profile-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 768px){
  .public-profile-hero-copy h1{font-size:2.3rem}
  .public-profile-stat-grid{grid-template-columns:1fr}
  .public-profile-tabs-nav{gap:.55rem}
  .public-profile-tab-btn{padding:.68rem .9rem}
}
