:root {
    --expert-ink: #203129;
    --expert-muted: #6b756f;
    --expert-soft: #f4f7f0;
    --expert-paper: #fffdf8;
    --expert-line: #e4eadf;
    --expert-green: #203f2b;
    --expert-sage: #9fb59e;
    --expert-teal: #2f7d65;
    --expert-gold: #d79637;
    --expert-shadow: 0 24px 70px rgba(31, 54, 40, .14);
}

* {
    box-sizing: border-box;
}

body.expert-directory-body {
    margin: 0;
    color: var(--expert-ink);
    background:
        radial-gradient(circle at 88% 10%, rgba(159, 181, 158, .28), transparent 32%),
        linear-gradient(180deg, #f8faf4 0%, #fffdf8 48%, #eef5ed 100%);
    font-family: "Source Sans Pro", "Helvetica Neue", Arial, sans-serif;
}

.expert-page {
    min-height: 100vh;
    overflow-x: hidden;
}

.expert-shell {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
}

.expert-nav {
    position: sticky;
    top: 0;
    z-index: 20;
    backdrop-filter: blur(18px);
    background: rgba(255, 253, 248, .86);
    border-bottom: 1px solid rgba(228, 234, 223, .75);
}

.expert-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    min-height: 78px;
}

.expert-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: var(--expert-green);
    font-weight: 800;
    letter-spacing: -.03em;
    font-size: 24px;
}

.expert-brand img {
    width: 44px;
    height: 44px;
    object-fit: contain;
}

.expert-nav__links {
    display: flex;
    align-items: center;
    gap: 24px;
    font-size: 15px;
}

.expert-nav__links a {
    color: var(--expert-muted);
    text-decoration: none;
    font-weight: 700;
}

.expert-nav__links a:hover {
    color: var(--expert-green);
}

.expert-pill-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 999px;
    padding: 13px 22px;
    color: #fff;
    background: var(--expert-green);
    box-shadow: 0 14px 34px rgba(32, 63, 43, .18);
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
}

.expert-pill-button:hover {
    color: #fff;
    transform: translateY(-1px);
}

.expert-hero {
    padding: 64px 0 34px;
}

.expert-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(330px, .72fr);
    gap: 42px;
    align-items: center;
}

.expert-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    color: #255742;
    background: rgba(159, 181, 158, .18);
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: 12px;
}

.expert-hero h1 {
    margin: 22px 0 16px;
    max-width: 760px;
    color: var(--expert-ink);
    font-size: clamp(42px, 5vw, 72px);
    line-height: .95;
    letter-spacing: -.07em;
}

.expert-hero p {
    margin: 0;
    max-width: 640px;
    color: #5f6d65;
    font-size: 20px;
    line-height: 1.55;
}

.expert-search {
    margin-top: 30px;
    padding: 10px;
    display: grid;
    grid-template-columns: 1.3fr .8fr .8fr auto;
    gap: 8px;
    background: #fff;
    border: 1px solid var(--expert-line);
    border-radius: 28px;
    box-shadow: var(--expert-shadow);
}

.expert-search__field {
    padding: 14px 18px;
    border-radius: 20px;
    background: #f7faf5;
    border: 1px solid transparent;
}

.expert-search__field span {
    display: block;
    color: #8a948d;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.expert-search__field strong {
    display: block;
    margin-top: 4px;
    color: var(--expert-ink);
    font-size: 16px;
}

.expert-search__field input,
.expert-search__field select {
    display: block;
    width: 100%;
    margin-top: 4px;
    border: 0;
    outline: 0;
    color: var(--expert-ink);
    background: transparent;
    font: inherit;
    font-size: 16px;
    font-weight: 800;
}

.expert-search__field input::placeholder {
    color: #a0aaa3;
}

.expert-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.expert-chip {
    appearance: none;
    border: 1px solid rgba(159, 181, 158, .34);
    background: rgba(255, 255, 255, .72);
    color: #46544c;
    border-radius: 999px;
    padding: 9px 14px;
    font-weight: 800;
    font-size: 13px;
    cursor: pointer;
}

.expert-chip.is-active,
.expert-chip:hover {
    color: #fff;
    background: var(--expert-green);
    border-color: var(--expert-green);
}

.expert-spotlight {
    position: relative;
    min-height: 500px;
}

.expert-floating-card {
    position: relative;
    overflow: hidden;
    border-radius: 34px;
    padding: 26px;
    background: linear-gradient(150deg, #ffffff, #edf5ec);
    border: 1px solid rgba(228, 234, 223, .85);
    box-shadow: var(--expert-shadow);
}

.expert-floating-card:before {
    content: "";
    position: absolute;
    inset: auto -80px -90px auto;
    width: 240px;
    height: 240px;
    border-radius: 999px;
    background: rgba(47, 125, 101, .16);
}

.expert-preview-photo {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: 26px;
    background: #e9eee6;
}

.expert-preview-meta {
    position: relative;
    margin-top: -42px;
    margin-left: 18px;
    margin-right: 18px;
    padding: 18px;
    background: rgba(255, 253, 248, .94);
    border: 1px solid rgba(228, 234, 223, .9);
    border-radius: 24px;
    box-shadow: 0 18px 42px rgba(31, 54, 40, .12);
}

.expert-preview-meta h3 {
    margin: 4px 0 4px;
    font-size: 22px;
    letter-spacing: -.03em;
}

.expert-stars {
    color: var(--expert-gold);
    letter-spacing: 1px;
    font-weight: 900;
}

.expert-proof-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 18px;
}

.expert-proof {
    padding: 14px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(228, 234, 223, .7);
}

.expert-proof strong {
    display: block;
    font-size: 22px;
    color: var(--expert-green);
}

.expert-proof span {
    display: block;
    margin-top: 2px;
    color: var(--expert-muted);
    font-size: 12px;
    font-weight: 800;
}

.expert-section {
    padding: 34px 0;
}

.expert-section__head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 20px;
    margin-bottom: 22px;
}

.expert-section__head h2 {
    margin: 0;
    font-size: clamp(30px, 3vw, 44px);
    letter-spacing: -.05em;
}

.expert-section__head p {
    margin: 8px 0 0;
    color: var(--expert-muted);
}

.expert-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 24px;
}

.expert-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.expert-card {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 18px;
    padding: 20px;
    border: 1px solid var(--expert-line);
    border-radius: 28px;
    background: rgba(255, 255, 255, .88);
    box-shadow: 0 18px 50px rgba(31, 54, 40, .08);
}

.expert-card__photo {
    width: 96px;
    height: 96px;
    border-radius: 26px;
    object-fit: cover;
    background: #eef3ec;
}

.expert-card h3 {
    margin: 0;
    color: var(--expert-ink);
    font-size: 22px;
    letter-spacing: -.035em;
}

.expert-card__role {
    margin-top: 3px;
    color: var(--expert-muted);
    font-weight: 700;
}

.expert-card__office {
    margin-top: 8px;
    color: #526158;
    font-size: 14px;
}

.expert-card__rating {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-top: 10px;
    font-weight: 900;
}

.expert-card__rating span:last-child {
    color: var(--expert-muted);
    font-weight: 700;
}

.expert-card__desc {
    margin: 12px 0;
    color: #65736b;
    line-height: 1.45;
}

.expert-card__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.expert-card__chips span {
    padding: 7px 10px;
    border-radius: 999px;
    color: #386c53;
    background: #edf6ed;
    font-size: 12px;
    font-weight: 900;
}

.expert-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-top: 16px;
}

.expert-action {
    flex: 1 1 auto;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    min-height: 40px;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid var(--expert-line);
    color: var(--expert-green);
    background: #fff;
    text-decoration: none;
    font-weight: 900;
}

.expert-action--primary {
    color: #fff;
    background: var(--expert-green);
    border-color: var(--expert-green);
}

.expert-action--ghost {
    color: var(--expert-green);
    background: rgba(255, 255, 255, .7);
}

.expert-empty-state {
    grid-column: 1 / -1;
    padding: 28px;
    border: 1px dashed rgba(47, 125, 101, .32);
    border-radius: 28px;
    background: rgba(255, 255, 255, .72);
    text-align: center;
}

.expert-empty-state h3 {
    margin: 0 0 8px;
    font-size: 26px;
    letter-spacing: -.04em;
}

.expert-empty-state p {
    margin: 0 0 18px;
    color: var(--expert-muted);
}

.expert-side {
    position: sticky;
    top: 98px;
    align-self: start;
    padding: 20px;
    border: 1px solid var(--expert-line);
    border-radius: 30px;
    background: rgba(255, 253, 248, .92);
    box-shadow: 0 18px 50px rgba(31, 54, 40, .08);
}

.expert-side h3 {
    margin: 0 0 16px;
    font-size: 22px;
}

.expert-rank {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-top: 1px solid var(--expert-line);
}

.expert-rank:first-of-type {
    border-top: 0;
}

.expert-rank__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    color: #fff;
    background: var(--expert-teal);
    font-weight: 900;
}

.expert-rank strong {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.expert-rank span {
    color: var(--expert-muted);
    font-size: 13px;
}

.expert-qa {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.expert-question {
    min-height: 190px;
    padding: 20px;
    border-radius: 26px;
    border: 1px solid var(--expert-line);
    background: #fff;
    box-shadow: 0 16px 40px rgba(31, 54, 40, .07);
}

.expert-question span {
    color: var(--expert-teal);
    font-weight: 900;
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.expert-question p {
    color: var(--expert-ink);
    line-height: 1.45;
    font-weight: 800;
}

.expert-footer-cta {
    margin: 42px 0 70px;
    padding: 34px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    border-radius: 34px;
    color: #fff;
    background: linear-gradient(135deg, #203f2b, #2f7d65);
    box-shadow: var(--expert-shadow);
}

.expert-footer-cta h2 {
    margin: 0 0 6px;
    font-size: clamp(28px, 3vw, 42px);
    letter-spacing: -.05em;
}

.expert-footer-cta p {
    margin: 0;
    color: rgba(255, 255, 255, .82);
}

.expert-footer-cta .expert-pill-button {
    color: var(--expert-green);
    background: #fff;
}

.expert-profile-hero {
    padding: 54px 0 24px;
}

.expert-profile-hero__grid {
    display: grid;
    grid-template-columns: 420px minmax(0, 1fr);
    gap: 36px;
    align-items: center;
}

.expert-profile-photo-card {
    padding: 18px;
    border: 1px solid var(--expert-line);
    border-radius: 34px;
    background: rgba(255, 255, 255, .9);
    box-shadow: var(--expert-shadow);
}

.expert-profile-photo-card img {
    width: 100%;
    height: 430px;
    object-fit: cover;
    border-radius: 26px;
    background: #eef3ec;
}

.expert-profile-score {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 14px;
    padding: 14px;
    border-radius: 22px;
    background: #f7faf5;
}

.expert-profile-score strong {
    color: var(--expert-green);
    font-size: 22px;
}

.expert-profile-score small {
    color: var(--expert-muted);
    font-weight: 800;
}

.expert-profile-summary {
    padding: 34px;
    border: 1px solid rgba(228, 234, 223, .85);
    border-radius: 38px;
    background:
        radial-gradient(circle at 92% 10%, rgba(47, 125, 101, .12), transparent 34%),
        rgba(255, 253, 248, .9);
    box-shadow: 0 20px 60px rgba(31, 54, 40, .1);
}

.expert-profile-summary h1 {
    margin: 18px 0 8px;
    font-size: clamp(40px, 5vw, 70px);
    line-height: .98;
    letter-spacing: -.07em;
}

.expert-profile-summary p {
    color: var(--expert-muted);
    font-size: 18px;
    line-height: 1.58;
}

.expert-profile-subtitle {
    margin: 0 0 12px;
    color: var(--expert-teal) !important;
    font-weight: 900;
}

.expert-profile-facts {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 20px 0 0;
}

.expert-profile-facts span {
    padding: 10px 13px;
    border-radius: 999px;
    color: #3d4b43;
    background: #eef6ee;
    font-weight: 800;
}

.expert-profile-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.expert-profile-actions .expert-action,
.expert-profile-actions .expert-pill-button {
    flex: 1 1 180px;
}

.expert-service-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.expert-service-card {
    min-height: 240px;
    padding: 24px;
    border: 1px solid var(--expert-line);
    border-radius: 30px;
    background: #fff;
    box-shadow: 0 18px 48px rgba(31, 54, 40, .08);
}

.expert-service-card span {
    color: var(--expert-teal);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.expert-service-card h3 {
    margin: 10px 0 8px;
    font-size: 24px;
    letter-spacing: -.04em;
}

.expert-service-card p {
    color: var(--expert-muted);
    line-height: 1.5;
}

.expert-service-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--expert-line);
}

.expert-service-card__footer strong {
    color: var(--expert-green);
    font-size: 22px;
}

.expert-service-card__footer a {
    color: #fff;
    background: var(--expert-green);
    border-radius: 999px;
    padding: 10px 14px;
    text-decoration: none;
    font-weight: 900;
}

.expert-tip-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.expert-tip-card,
.expert-tip-empty {
    overflow: hidden;
    border: 1px solid var(--expert-line);
    border-radius: 30px;
    background: rgba(255, 255, 255, .94);
    box-shadow: 0 18px 48px rgba(31, 54, 40, .08);
}

.expert-tip-card img {
    width: 100%;
    height: 190px;
    object-fit: cover;
    background: #eef3ec;
}

.expert-tip-card div,
.expert-tip-empty {
    padding: 22px;
}

.expert-tip-card span,
.expert-tip-empty span {
    color: var(--expert-teal);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.expert-tip-card h3,
.expert-tip-empty h3 {
    margin: 10px 0 8px;
    font-size: 23px;
    line-height: 1.15;
    letter-spacing: -.04em;
}

.expert-tip-card p,
.expert-tip-empty p {
    min-height: 66px;
    color: var(--expert-muted);
    line-height: 1.5;
}

.expert-tip-card a,
.expert-tip-empty a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    margin-top: 6px;
    padding: 10px 14px;
    border-radius: 999px;
    color: #fff;
    background: var(--expert-green);
    text-decoration: none;
    font-weight: 900;
}

.expert-profile-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 24px;
}

.expert-review-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.expert-review-card {
    padding: 20px;
    border: 1px solid var(--expert-line);
    border-radius: 26px;
    background: rgba(255, 255, 255, .92);
    box-shadow: 0 16px 40px rgba(31, 54, 40, .07);
}

.expert-review-card div {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.expert-review-card p {
    color: var(--expert-muted);
    line-height: 1.5;
}

.expert-review-card small {
    color: #8a948d;
    font-weight: 800;
}

.expert-register-wrap {
    padding: 58px 0 80px;
}

.expert-register-grid {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(380px, .7fr);
    gap: 34px;
    align-items: center;
}

.expert-register-intro h1 {
    margin: 20px 0 14px;
    font-size: clamp(42px, 5vw, 68px);
    line-height: .98;
    letter-spacing: -.07em;
}

.expert-register-intro p {
    max-width: 620px;
    color: var(--expert-muted);
    font-size: 20px;
    line-height: 1.55;
}

.expert-register-card {
    padding: 30px;
    border: 1px solid var(--expert-line);
    border-radius: 34px;
    background: rgba(255, 255, 255, .94);
    box-shadow: var(--expert-shadow);
}

.expert-register-card h2 {
    margin: 0 0 8px;
    font-size: 32px;
    letter-spacing: -.05em;
}

.expert-register-card p {
    margin: 0 0 20px;
    color: var(--expert-muted);
}

.expert-register-form {
    display: grid;
    gap: 14px;
}

.expert-register-form label {
    display: grid;
    gap: 7px;
    color: var(--expert-ink);
    font-weight: 900;
}

.expert-register-form input[type="text"],
.expert-register-form input[type="email"],
.expert-register-form input[type="password"] {
    width: 100%;
    border: 1px solid var(--expert-line);
    border-radius: 18px;
    padding: 14px 16px;
    color: var(--expert-ink);
    background: #f9fbf7;
    outline: none;
    font: inherit;
}

.expert-register-form input:focus {
    border-color: rgba(47, 125, 101, .45);
    box-shadow: 0 0 0 4px rgba(47, 125, 101, .1);
}

.expert-register-role {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.expert-register-role label,
.expert-register-role span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border: 1px solid var(--expert-line);
    border-radius: 999px;
    background: #fff;
    color: #4d5b53;
    font-weight: 900;
}

.expert-register-form button {
    width: 100%;
    min-height: 52px;
    margin-top: 6px;
}

.expert-login-link {
    text-align: center;
    color: var(--expert-green);
    font-weight: 900;
    text-decoration: none;
}

.expert-questions-hero {
    padding: 56px 0 28px;
}

.expert-questions-grid {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(390px, .68fr);
    gap: 34px;
    align-items: start;
}

.expert-questions-copy {
    padding: 34px;
    border: 1px solid rgba(228, 234, 223, .8);
    border-radius: 38px;
    background:
        radial-gradient(circle at 92% 12%, rgba(47, 125, 101, .13), transparent 34%),
        rgba(255, 253, 248, .88);
    box-shadow: 0 20px 60px rgba(31, 54, 40, .1);
}

.expert-questions-copy h1 {
    margin: 18px 0 14px;
    font-size: clamp(42px, 5vw, 68px);
    line-height: .98;
    letter-spacing: -.07em;
}

.expert-questions-copy p {
    max-width: 650px;
    color: var(--expert-muted);
    font-size: 20px;
    line-height: 1.55;
}

.expert-target-card {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    max-width: 520px;
    margin-top: 24px;
    padding: 14px;
    border: 1px solid var(--expert-line);
    border-radius: 24px;
    background: #fff;
    text-decoration: none;
    box-shadow: 0 16px 40px rgba(31, 54, 40, .08);
}

.expert-target-card img {
    width: 72px;
    height: 72px;
    border-radius: 20px;
    object-fit: cover;
    background: #eef3ec;
}

.expert-target-card strong {
    display: block;
    color: var(--expert-ink);
    font-size: 20px;
}

.expert-target-card small {
    display: block;
    margin-top: 3px;
    color: var(--expert-muted);
    font-weight: 800;
}

.expert-question-form {
    display: grid;
    gap: 14px;
    padding: 28px;
    border: 1px solid var(--expert-line);
    border-radius: 34px;
    background: #fff;
    box-shadow: var(--expert-shadow);
}

.expert-question-form h2 {
    margin: 0;
    font-size: 32px;
    letter-spacing: -.05em;
}

.expert-question-form p {
    margin: 0 0 6px;
    color: var(--expert-muted);
    line-height: 1.45;
}

.expert-question-form label {
    display: grid;
    gap: 8px;
    color: var(--expert-ink);
    font-weight: 900;
}

.expert-question-form select,
.expert-question-form textarea {
    width: 100%;
    border: 1px solid var(--expert-line);
    border-radius: 18px;
    padding: 14px 16px;
    color: var(--expert-ink);
    background: #f9fbf7;
    outline: none;
    font: inherit;
}

.expert-question-form textarea {
    resize: vertical;
    min-height: 150px;
}

.expert-question-feed {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.expert-question-row {
    min-height: 180px;
    padding: 22px;
    border: 1px solid var(--expert-line);
    border-radius: 28px;
    background: rgba(255, 255, 255, .92);
    text-decoration: none;
    box-shadow: 0 16px 42px rgba(31, 54, 40, .07);
}

.expert-question-row span {
    color: var(--expert-teal);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.expert-question-row strong {
    display: block;
    margin: 12px 0;
    color: var(--expert-ink);
    font-size: 20px;
    line-height: 1.35;
}

.expert-question-row small {
    color: var(--expert-muted);
    font-weight: 800;
}

.expert-booking-hero {
    padding: 46px 0 72px;
}

.expert-booking-grid {
    display: grid;
    grid-template-columns: 380px minmax(0, 1fr);
    gap: 28px;
    align-items: start;
}

.expert-booking-summary,
.expert-booking-panel {
    border: 1px solid var(--expert-line);
    border-radius: 34px;
    background: rgba(255, 255, 255, .92);
    box-shadow: var(--expert-shadow);
}

.expert-booking-summary {
    position: sticky;
    top: 98px;
    padding: 24px;
}

.expert-back-link {
    display: inline-flex;
    margin-bottom: 16px;
    color: var(--expert-green);
    font-weight: 900;
    text-decoration: none;
}

.expert-booking-photo {
    width: 100%;
    height: 250px;
    margin-bottom: 18px;
    border-radius: 26px;
    object-fit: cover;
    background: #eef3ec;
}

.expert-booking-summary h1 {
    margin: 16px 0 8px;
    font-size: clamp(34px, 4vw, 52px);
    line-height: 1;
    letter-spacing: -.06em;
}

.expert-booking-summary p {
    color: var(--expert-muted);
    font-size: 18px;
    line-height: 1.45;
}

.expert-booking-panel {
    padding: 26px;
}

.expert-booking-services {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 22px;
}

.expert-booking-service {
    display: grid;
    gap: 7px;
    padding: 18px;
    border: 1px solid var(--expert-line);
    border-radius: 24px;
    color: var(--expert-ink);
    background: #fff;
    text-decoration: none;
}

.expert-booking-service.is-selected,
.expert-booking-service:hover {
    border-color: rgba(47, 125, 101, .45);
    box-shadow: 0 14px 34px rgba(31, 54, 40, .1);
}

.expert-booking-service span {
    color: var(--expert-teal);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.expert-booking-service strong {
    font-size: 21px;
    line-height: 1.18;
    letter-spacing: -.035em;
}

.expert-booking-service small {
    min-height: 40px;
    color: var(--expert-muted);
    line-height: 1.35;
}

.expert-booking-service em {
    justify-self: start;
    padding: 8px 12px;
    border-radius: 999px;
    color: #9a5d12;
    background: #fff3df;
    font-style: normal;
    font-weight: 900;
}

.expert-booking-frame-wrap,
.expert-booking-empty {
    overflow: hidden;
    border: 1px solid var(--expert-line);
    border-radius: 28px;
    background: #f8fbf6;
}

.expert-booking-frame-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 18px;
    border-bottom: 1px solid var(--expert-line);
}

.expert-booking-frame-head span {
    display: block;
    color: var(--expert-teal);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.expert-booking-frame-head strong {
    display: block;
    margin-top: 3px;
    font-size: 20px;
    letter-spacing: -.035em;
}

.expert-booking-frame-head a {
    color: var(--expert-green);
    font-weight: 900;
    text-decoration: none;
}

.expert-booking-frame {
    display: block;
    width: 100%;
    min-height: 980px;
    border: 0;
    background: #fff;
}

.expert-booking-empty {
    padding: 28px;
    text-align: center;
}

.expert-booking-empty h3 {
    margin: 0 0 8px;
    font-size: 26px;
    letter-spacing: -.04em;
}

.expert-booking-empty p {
    margin: 0;
    color: var(--expert-muted);
}

.expert-booking-flow {
    display: grid;
    gap: 18px;
}

.expert-booking-step {
    padding: 22px;
    border: 1px solid var(--expert-line);
    border-radius: 28px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbf6 100%);
}

.expert-booking-step__head {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 18px;
}

.expert-booking-step__head > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 34px;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    color: #fff;
    background: var(--expert-green);
    font-weight: 900;
}

.expert-booking-step h3 {
    margin: 0;
    font-size: 24px;
    line-height: 1.1;
    letter-spacing: -.045em;
}

.expert-booking-step p {
    margin: 5px 0 0;
    color: var(--expert-muted);
}

.expert-booking-date-strip {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
}

.expert-booking-date {
    appearance: none;
    flex: 0 0 94px;
    padding: 14px 12px;
    border: 1px solid var(--expert-line);
    border-radius: 22px;
    color: var(--expert-ink);
    background: #fff;
    text-align: left;
    cursor: pointer;
    scroll-snap-align: start;
}

.expert-booking-date span,
.expert-booking-date small {
    display: block;
    color: var(--expert-muted);
    font-weight: 800;
}

.expert-booking-date strong {
    display: block;
    margin: 5px 0;
    font-size: 30px;
    line-height: 1;
    letter-spacing: -.04em;
}

.expert-booking-date.is-selected {
    color: #fff;
    border-color: var(--expert-teal);
    background: linear-gradient(145deg, var(--expert-green), var(--expert-teal));
}

.expert-booking-date.is-selected span,
.expert-booking-date.is-selected small {
    color: rgba(255, 255, 255, .82);
}

.expert-booking-slots {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 10px;
}

.expert-slot {
    appearance: none;
    padding: 14px;
    border: 1px solid var(--expert-line);
    border-radius: 18px;
    color: var(--expert-ink);
    background: #fff;
    text-align: left;
    cursor: pointer;
}

.expert-slot strong,
.expert-slot span {
    display: block;
}

.expert-slot strong {
    font-size: 20px;
}

.expert-slot span {
    margin-top: 3px;
    color: var(--expert-muted);
    font-weight: 800;
}

.expert-slot.is-selected {
    border-color: rgba(47, 125, 101, .5);
    background: rgba(47, 125, 101, .09);
    box-shadow: 0 12px 30px rgba(31, 54, 40, .1);
}

.expert-booking-hint {
    width: 100%;
    padding: 18px;
    border: 1px dashed rgba(159, 181, 158, .7);
    border-radius: 20px;
    color: var(--expert-muted);
    background: rgba(255, 255, 255, .7);
    font-weight: 800;
}

.expert-booking-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.expert-booking-form label {
    display: grid;
    gap: 7px;
    color: var(--expert-ink);
    font-weight: 900;
}

.expert-booking-form input,
.expert-booking-form select,
.expert-booking-form textarea {
    width: 100%;
    border: 1px solid var(--expert-line);
    border-radius: 18px;
    padding: 13px 14px;
    color: var(--expert-ink);
    background: #fff;
    font: inherit;
    outline: 0;
}

.expert-booking-form input:focus,
.expert-booking-form select:focus,
.expert-booking-form textarea:focus {
    border-color: rgba(47, 125, 101, .55);
    box-shadow: 0 0 0 4px rgba(47, 125, 101, .12);
}

.expert-booking-form__wide,
.expert-booking-check,
.expert-booking-alert,
.expert-booking-submit {
    grid-column: 1 / -1;
}

.expert-booking-check {
    display: flex !important;
    grid-template-columns: none !important;
    align-items: flex-start;
    gap: 10px !important;
    color: var(--expert-muted) !important;
    font-weight: 700 !important;
    line-height: 1.4;
}

.expert-booking-check input {
    width: auto;
    margin-top: 4px;
}

.expert-booking-alert {
    padding: 13px 14px;
    border: 1px solid rgba(204, 88, 73, .2);
    border-radius: 18px;
    color: #8a3429;
    background: #fff1ef;
    font-weight: 800;
}

.expert-booking-submit {
    justify-self: start;
}

.expert-booking-submit:disabled {
    opacity: .72;
    cursor: wait;
}

.expert-booking-success {
    margin-top: 22px;
    padding: 32px;
    border: 1px solid rgba(47, 125, 101, .22);
    border-radius: 30px;
    background:
        radial-gradient(circle at 90% 10%, rgba(47, 125, 101, .18), transparent 30%),
        #fff;
    box-shadow: var(--expert-shadow);
}

.expert-booking-success > span {
    color: var(--expert-teal);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.expert-booking-success h3 {
    margin: 8px 0;
    font-size: clamp(30px, 4vw, 46px);
    letter-spacing: -.06em;
}

.expert-booking-success p {
    color: var(--expert-muted);
    font-size: 18px;
}

.expert-booking-success__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 18px;
}

@media (max-width: 980px) {
    .expert-nav__links {
        display: none;
    }

    .expert-hero__grid,
    .expert-layout,
    .expert-profile-hero__grid,
    .expert-profile-columns,
    .expert-register-grid,
    .expert-questions-grid,
    .expert-booking-grid {
        grid-template-columns: 1fr;
    }

    .expert-search {
        grid-template-columns: 1fr;
    }

    .expert-card-grid,
    .expert-qa,
    .expert-service-grid,
    .expert-tip-grid,
    .expert-review-list,
    .expert-question-feed {
        grid-template-columns: 1fr;
    }

    .expert-side {
        position: static;
    }

    .expert-booking-summary {
        position: static;
    }
}

@media (max-width: 620px) {
    .expert-shell {
        width: min(100% - 24px, 1180px);
    }

    .expert-hero {
        padding-top: 38px;
    }

    .expert-card {
        grid-template-columns: 1fr;
    }

    .expert-card__photo {
        width: 100%;
        height: 210px;
    }

    .expert-profile-photo-card img {
        height: 310px;
    }

    .expert-profile-summary,
    .expert-register-card {
        padding: 22px;
    }

    .expert-proof-grid {
        grid-template-columns: 1fr;
    }

    .expert-footer-cta {
        align-items: stretch;
        flex-direction: column;
    }

    .expert-booking-panel {
        padding: 16px;
    }

    .expert-booking-services {
        grid-template-columns: 1fr;
    }

    .expert-booking-step {
        padding: 18px;
    }

    .expert-booking-form {
        grid-template-columns: 1fr;
    }

    .expert-booking-slots {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .expert-booking-date {
        flex-basis: 84px;
    }

    .expert-booking-submit,
    .expert-booking-success__actions .expert-action {
        width: 100%;
    }

    .expert-booking-frame {
        min-height: 1120px;
    }
}
