.csc-booking-page{
    --csc-bg:#fffaf0;
    --csc-card:#fffef9;
    --csc-border:#e7d5ad;
    --csc-text:#4b3b1b;
    --csc-muted:#7a6230;
    --csc-primary:#55a536;
    --csc-primary-strong:#2f7f2e;
    --csc-accent:#d7bf8c;
    --csc-accent-soft:#fff8d5;
    --csc-soft:#f4fbef;
    --csc-danger:#b84646;
    max-width:1200px;
    margin:0 auto;
    padding:28px 16px 48px;
    color:var(--csc-text);
}
.csc-booking-hero{
    display:grid;
    grid-template-columns:minmax(0,1.45fr) minmax(300px,.85fr);
    gap:18px;
    margin-bottom:20px;
    padding:24px;
    border-radius:28px;
    border:1px solid #dce7f5;
    background:
        radial-gradient(circle at top left, rgba(255,255,255,.98) 0%, rgba(247,251,255,.96) 56%, rgba(237,244,255,.98) 100%);
    box-shadow:0 20px 50px rgba(18,34,56,.08);
}
.csc-booking-hero__content{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
}
.csc-booking-hero__badge{
    display:inline-flex;
    align-items:center;
    padding:6px 10px;
    border-radius:999px;
    background:#edf4ff;
    color:var(--csc-primary-strong);
    font-size:12px;
    font-weight:700;
    letter-spacing:0;
    text-transform:uppercase;
}
.csc-booking-hero__title{
    margin:12px 0 8px;
    font-size:34px;
    line-height:1.1;
    font-weight:800;
    color:#10233c;
}
.csc-booking-hero__text{
    max-width:none;
    margin:0;
    font-size:16px;
    line-height:1.55;
    color:var(--csc-muted);
}
.csc-booking-hero__facts{
    width:100%;
    max-width:780px;
    margin-top:18px;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
}
.csc-booking-hero__fact{
    padding:14px 15px;
    border-radius:18px;
    border:1px solid #dfe9f5;
    background:rgba(255,255,255,.84);
    backdrop-filter:blur(8px);
}
.csc-booking-hero__fact strong{
    display:block;
    margin-bottom:6px;
    font-size:18px;
    line-height:1.15;
    color:#10233c;
}
.csc-booking-hero__fact span{
    display:block;
    font-size:13px;
    line-height:1.55;
    color:var(--csc-muted);
}
.csc-booking-hero__panel{
    padding:18px;
    border-radius:22px;
    background:linear-gradient(180deg,#16365f 0%, #214a82 100%);
    color:#fff;
    box-shadow:0 18px 32px rgba(22,54,95,.18);
}
.csc-booking-hero__panel-title{
    font-size:12px;
    font-weight:800;
    letter-spacing:0;
    text-transform:uppercase;
    color:rgba(255,255,255,.72);
}
.csc-booking-hero__steps{
    margin-top:12px;
    display:flex;
    flex-direction:column;
}
.csc-booking-hero__step{
    display:grid;
    grid-template-columns:40px minmax(0,1fr);
    gap:12px;
    align-items:flex-start;
    padding:14px 0;
    border-top:1px solid rgba(255,255,255,.14);
}
.csc-booking-hero__step:first-child{
    padding-top:10px;
    border-top:none;
}
.csc-booking-hero__step span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:40px;
    height:40px;
    border-radius:14px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.14);
    font-size:13px;
    font-weight:800;
    letter-spacing:0;
}
.csc-booking-hero__step strong{
    display:block;
    font-size:15px;
    line-height:1.3;
    font-weight:800;
}
.csc-booking-hero__step p{
    margin:4px 0 0;
    font-size:13px;
    line-height:1.55;
    color:rgba(255,255,255,.76);
}
.csc-booking-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr) 340px;
    gap:20px;
    align-items:start;
}
.csc-booking-card{
    background:var(--csc-card);
    border:1px solid var(--csc-border);
    border-radius:18px;
    box-shadow:0 18px 45px rgba(91,73,36,.10);
}
.csc-booking-form{
    padding:0;
    overflow:hidden;
    counter-reset:bookingStep;
}
.csc-booking-section{
    position:relative;
    padding:24px 26px;
}
.csc-booking-section + .csc-booking-section{
    margin-top:0;
    border-top:1px solid #efe3c8;
}
.csc-booking-section--step{
    counter-increment:bookingStep;
    padding-left:78px;
}
.csc-booking-section--step:before{
    content:counter(bookingStep);
    position:absolute;
    top:24px;
    left:24px;
    width:38px;
    height:38px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:linear-gradient(145deg,var(--csc-primary),var(--csc-primary-strong));
    color:#fff;
    font-size:16px;
    font-weight:900;
    box-shadow:0 10px 22px rgba(85,165,54,.20);
}
.csc-booking-section--confirm{
    background:linear-gradient(180deg,#fffdf8 0%, #ffffff 100%);
}
.csc-booking-section__head{
    margin-bottom:16px;
}
.csc-booking-section__head--inline{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
}
.csc-booking-section__head--inline .csc-booking-btn{
    flex:0 0 auto;
}
.csc-booking-pet-actions{
    display:flex;
    align-items:center;
    gap:12px;
    flex-wrap:wrap;
}
.csc-booking-known-pets{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:10px;
    margin-bottom:16px;
    padding:14px;
    border:1px solid #e2d2aa;
    border-radius:14px;
    background:linear-gradient(180deg,#fffdf6 0%, #f6f9ef 100%);
}
.csc-booking-known-pets:before{
    content:"Питомец из профиля";
    grid-column:1/-1;
    font-size:12px;
    font-weight:900;
    letter-spacing:0;
    text-transform:uppercase;
    color:var(--csc-primary);
}
.csc-booking-known-pets select{
    min-width:0;
    width:100%;
    min-height:44px;
    padding:10px 12px;
    border:1px solid #dfcfaa;
    border-radius:10px;
    background:#fff;
    color:var(--csc-text);
    font-size:14px;
    line-height:1.35;
    box-sizing:border-box;
}
.csc-booking-known-pets select:focus{
    outline:none;
    border-color:var(--csc-primary);
    box-shadow:0 0 0 4px rgba(36,95,86,.12);
}
.csc-booking-known-pets .csc-booking-btn{
    min-width:100px;
    min-height:44px;
}
.csc-booking-section__head h2,
.csc-booking-sidebar__head h2{
    margin:0 0 4px;
    font-size:22px;
    line-height:1.2;
    font-weight:900;
    color:#4b3b1b;
}
.csc-booking-section__head p,
.csc-booking-sidebar__head p{
    margin:0;
    font-size:14px;
    line-height:1.5;
    color:var(--csc-muted);
}
.csc-booking-grid{
    display:grid;
    gap:14px;
}
.csc-booking-grid--3{
    grid-template-columns:repeat(3,minmax(0,1fr));
}
.csc-booking-grid--2{
    grid-template-columns:repeat(2,minmax(0,1fr));
}
.csc-booking-field{
    display:flex;
    flex-direction:column;
    gap:8px;
}
.csc-booking-field--wide{
    grid-column:1/-1;
}
.csc-booking-field span{
    font-size:13px;
    font-weight:800;
    color:#5b4924;
}
.csc-booking-field input,
.csc-booking-field select,
.csc-booking-field textarea{
    width:100%;
    min-height:48px;
    padding:12px 14px;
    border:1px solid #dfcfaa;
    border-radius:12px;
    background:linear-gradient(180deg,#ffffff 0%, #fffdf8 100%);
    color:var(--csc-text);
    font-size:15px;
    line-height:1.4;
    box-sizing:border-box;
    transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.csc-booking-field__static{
    display:flex;
    align-items:center;
    width:100%;
    min-height:46px;
    padding:11px 13px;
    border:1px solid #cad8ea;
    border-radius:13px;
    background:#f8fbff;
    color:var(--csc-text);
    font-size:15px;
    line-height:1.4;
    box-sizing:border-box;
}
.csc-booking-field textarea{
    min-height:96px;
    resize:vertical;
}
.csc-booking-field input:focus,
.csc-booking-field select:focus,
.csc-booking-field textarea:focus{
    outline:none;
    border-color:var(--csc-primary);
    background:#fff;
    box-shadow:0 0 0 4px rgba(85,165,54,.14);
}
.csc-booking-field--invalid input,
.csc-booking-field--invalid select,
.csc-booking-field--invalid textarea{
    border-color:var(--csc-danger);
    background:#fffafa;
    box-shadow:0 0 0 4px rgba(184,70,70,.10);
}
.csc-booking-field__error,
.csc-booking-check__error{
    margin-top:3px;
    color:var(--csc-danger);
    font-size:12px;
    line-height:1.35;
    font-weight:700;
}
.csc-booking-rules{
    margin-top:14px;
    padding:14px 16px;
    border-radius:14px;
    background:#fffdf8;
    border:1px solid #e4d6b8;
}
.csc-booking-rules__title{
    font-size:13px;
    font-weight:800;
    color:#213650;
    margin-bottom:8px;
}
.csc-booking-rules__text{
    font-size:14px;
    line-height:1.6;
    color:#6e5b2d;
    max-height:220px;
    overflow:auto;
    white-space:normal;
    scrollbar-width:thin;
    scrollbar-color:#bca97b transparent;
}
.csc-booking-rules__text::-webkit-scrollbar{
    width:8px;
}
.csc-booking-rules__text::-webkit-scrollbar-thumb{
    border-radius:999px;
    background:#bca97b;
}
.csc-booking-item{
    position:relative;
    overflow:hidden;
    border:1px solid #e4d6b8;
    border-radius:16px;
    padding:18px;
    background:linear-gradient(180deg,#ffffff 0%, #fffdf8 100%);
    box-shadow:0 10px 26px rgba(91,73,36,.08);
}
.csc-booking-item:before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    bottom:0;
    width:4px;
    background:linear-gradient(180deg,var(--csc-primary),var(--csc-accent));
}
.csc-booking-item + .csc-booking-item{
    margin-top:16px;
}
.csc-booking-item__head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:14px;
}
.csc-booking-item__title{
    font-size:18px;
    font-weight:900;
    color:#4b3b1b;
}
.csc-booking-item__meta{
    font-size:12px;
    color:var(--csc-muted);
    margin-top:3px;
}
.csc-booking-item__advanced{
    margin-top:12px;
}
.csc-booking-item > .csc-booking-grid--3{
    grid-template-columns:repeat(2,minmax(0,1fr));
}
.csc-booking-item > .csc-booking-grid--3 > .csc-booking-field:nth-child(3){
    grid-column:1/-1;
}
.csc-booking-item__foot{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-top:14px;
    padding:12px 14px;
    border-radius:12px;
    border:1px dashed #dfcfaa;
    background:#fffdf8;
}
.csc-booking-checks{
    display:flex;
    flex-direction:column;
    gap:12px;
}
.csc-booking-check{
    display:flex;
    align-items:flex-start;
    gap:10px;
    font-size:14px;
    line-height:1.55;
    color:#5b4924;
}
.csc-booking-check input{
    margin-top:2px;
    flex:0 0 auto;
    accent-color:var(--csc-primary);
}
.csc-booking-check--boxed{
    position:relative;
    align-items:flex-start;
    gap:10px;
    padding:12px 14px;
    border:1px solid #e4d6b8;
    border-radius:12px;
    background:#fffdf8;
    cursor:pointer;
}
.csc-booking-check--invalid{
    border-color:#e7a4a4!important;
    background:#fff8f8!important;
    box-shadow:0 0 0 4px rgba(184,70,70,.08);
}
.csc-booking-check--boxed input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}
.csc-booking-check__box{
    width:20px;
    height:20px;
    flex:0 0 20px;
    margin-top:1px;
    border:2px solid #d0be91;
    border-radius:6px;
    background:#fff;
    box-sizing:border-box;
    transition:background .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.csc-booking-check--boxed input:checked + .csc-booking-check__box{
    border-color:var(--csc-primary);
    background:var(--csc-primary);
    box-shadow:0 0 0 3px rgba(85,165,54,.14);
}
.csc-booking-check--boxed input:checked + .csc-booking-check__box:after{
    content:"";
    display:block;
    width:9px;
    height:5px;
    margin:4px 0 0 3px;
    border-left:2px solid #fff;
    border-bottom:2px solid #fff;
    transform:rotate(-45deg);
}
.csc-booking-check__text{
    color:#5b4924;
}
.csc-booking-check--consent{
    display:block;
    --consent-accent:var(--csc-primary);
    --consent-accent-soft:rgba(85,165,54,.12);
}
.csc-booking-check--consent .main-user-consent-request{
    width:100%;
    box-sizing:border-box;
    border-color:#e4d6b8;
    background:#fffdf8;
}
.csc-booking-check--consent .consent-checkbox{
    padding:12px 14px;
    border-radius:12px;
    border:1px solid #e4d6b8;
    background:#fffdf8;
    box-shadow:none;
    transform:none;
}
.csc-booking-check--consent .consent-checkbox__text{
    max-width:none;
    color:#5b4924;
    font-size:14px;
    line-height:1.55;
}
.csc-booking-check--consent .consent-checkbox__box{
    width:20px;
    height:20px;
    flex:0 0 20px;
    margin-top:1px;
    border:2px solid #d0be91;
    border-radius:6px;
    background:#fff;
    box-shadow:none;
}
.csc-booking-check--consent .consent-checkbox__checkmark{
    position:relative;
    width:100%;
    height:100%;
    border-radius:4px;
    background:transparent;
}
.csc-booking-check--consent .consent-checkbox__checkmark:before{
    display:none;
}
.csc-booking-check--consent .consent-checkbox__checkmark:after{
    content:"";
    display:block;
    width:9px;
    height:5px;
    margin:5px 0 0 4px;
    border-left:2px solid #fff;
    border-bottom:2px solid #fff;
    transform:rotate(-45deg);
}
.csc-booking-check--consent .consent-checkbox__input:checked + .consent-checkbox__box{
    border-color:var(--csc-primary);
    background:var(--csc-primary);
    box-shadow:0 0 0 3px rgba(85,165,54,.14);
}
.csc-booking-check--consent .consent-checkbox:hover{
    border-color:#d7bf8c;
    background:#fffaf0;
    box-shadow:none;
    transform:none;
}
.main-user-consent-request-popup .consent-modal__button--accept{
    background:linear-gradient(135deg,var(--csc-primary,#55a536),var(--csc-primary-strong,#2f7f2e));
    border-color:transparent;
    color:#fff;
}
.main-user-consent-request-popup .consent-modal__button--reject{
    border-color:#dfcfaa;
    color:#4b3b1b;
}
.csc-booking-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    min-height:42px;
    padding:0 16px;
    border-radius:12px;
    border:1px solid #dfcfaa;
    background:#fff;
    color:#4b3b1b;
    font-size:14px;
    font-weight:800;
    line-height:1;
    white-space:nowrap;
    cursor:pointer;
    transition:transform .12s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.csc-booking-btn:hover{
    transform:translateY(-1px);
    box-shadow:0 8px 20px rgba(91,73,36,.12);
}
.csc-booking-btn--ghost{
    background:#fffdf8;
}
.csc-booking-btn--danger{
    color:#9e3030;
    border-color:#ebc3c3;
    background:#fff8f8;
}
.csc-booking-btn--primary{
    border-color:transparent;
    background:linear-gradient(135deg,var(--csc-primary),var(--csc-primary-strong));
    color:#fff;
    box-shadow:0 14px 28px rgba(85,165,54,.22);
}
.csc-booking-btn--full{
    width:100%;
}
.csc-booking-btn:disabled{
    cursor:not-allowed;
    opacity:1;
    transform:none;
    box-shadow:none;
}
.csc-booking-btn--primary:disabled{
    background:linear-gradient(135deg,#a9bd9d,#8fa982);
    color:#fff;
}
.csc-booking-sidebar{
    padding:20px;
    background:linear-gradient(180deg,#ffffff 0%, #fffdf8 100%);
}
.csc-booking-sidebar__head h2{
    white-space:nowrap;
}
.csc-booking-sidebar__sticky{
    position:sticky;
    top:18px;
}
.csc-booking-sidebar__head{
    margin-bottom:14px;
}
.csc-booking-summary-empty{
    padding:16px;
    border:1px dashed #dfcfaa;
    border-radius:14px;
    background:#fffdf8;
    font-size:14px;
    line-height:1.55;
    color:var(--csc-muted);
}
.csc-booking-kpis{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    margin-bottom:14px;
}
.csc-booking-kpi{
    padding:12px 10px;
    border-radius:12px;
    border:1px solid #e4d6b8;
    background:#fff;
}
.csc-booking-kpi__label{
    display:block;
    font-size:12px;
    color:var(--csc-muted);
    margin-bottom:6px;
}
.csc-booking-kpi strong{
    display:block;
    font-size:18px;
    line-height:1.1;
}
.csc-booking-summary__items{
    display:flex;
    flex-direction:column;
    gap:10px;
}
.csc-booking-summary-item{
    border:1px solid #e4d6b8;
    border-radius:12px;
    padding:12px;
    background:#fff;
}
.csc-booking-summary-item__top{
    display:flex;
    justify-content:space-between;
    gap:10px;
    align-items:flex-start;
}
.csc-booking-summary-item__title{
    font-size:14px;
    font-weight:800;
}
.csc-booking-summary-item__sub{
    margin-top:4px;
    font-size:12px;
    color:var(--csc-muted);
}
.csc-booking-summary-item__price{
    font-size:15px;
    font-weight:800;
    white-space:nowrap;
}
.csc-booking-summary-item__meta{
    margin-top:9px;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    font-size:12px;
    color:#35506f;
}
.csc-booking-summary-item__meta span{
    display:inline-flex;
    align-items:center;
    padding:4px 8px;
    border-radius:999px;
    background:#f4fbef;
}
.csc-booking-total{
    margin-top:14px;
    padding-top:14px;
    border-top:1px solid #eadfc4;
    display:flex;
    flex-direction:column;
    gap:10px;
}
.csc-booking-total div{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    font-size:14px;
}
.csc-booking-total strong{
    font-size:18px;
    font-weight:900;
    color:#4b3b1b;
}
.csc-booking-total div:last-child{
    margin-top:2px;
    padding:12px;
    border-radius:12px;
    background:var(--csc-accent-soft);
    color:#4b3118;
}
.csc-booking-total div:last-child strong{
    color:#2f7f2e;
}
.csc-booking-smartcaptcha{
    margin-top:14px;
}
.csc-booking-smartcaptcha__label{
    margin:0 0 8px;
    font-size:12px;
    font-weight:800;
    color:#314962;
    text-transform:uppercase;
    letter-spacing:0;
}
.csc-booking-smartcaptcha__box{
    min-height:100px;
    border-radius:12px;
    overflow:hidden;
}
.csc-booking-smartcaptcha--invalid .csc-booking-smartcaptcha__box{
    box-shadow:0 0 0 4px rgba(184,70,70,.10);
}
#csc-booking-submit{
    margin-top:18px;
}
.csc-booking-note{
    margin-top:12px;
    font-size:12px;
    line-height:1.55;
    color:var(--csc-muted);
}
.csc-booking-error{
    margin-top:12px;
    padding:12px 14px;
    border-radius:14px;
    border:1px solid #f0caca;
    background:#fff4f4;
    color:var(--csc-danger);
    font-size:14px;
    line-height:1.5;
}
.csc-booking-success{
    margin-top:24px;
    position:relative;
    overflow:hidden;
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    gap:20px;
    padding:28px;
    border-radius:26px;
    border:1px solid rgba(215,191,140,.72);
    background:
        radial-gradient(circle at 8% 0%, rgba(85,165,54,.16) 0%, rgba(85,165,54,0) 34%),
        linear-gradient(135deg,#fffef9 0%,#fff8e7 100%);
    box-shadow:0 24px 55px rgba(75,59,27,.12);
}
.csc-booking-success[hidden]{
    display:none;
}
.csc-booking-success:after{
    content:"";
    position:absolute;
    right:-70px;
    bottom:-90px;
    width:220px;
    height:220px;
    border-radius:50%;
    background:rgba(215,191,140,.22);
    pointer-events:none;
}
.csc-booking-success__icon{
    position:relative;
    z-index:1;
    display:flex;
    align-items:center;
    justify-content:center;
    width:70px;
    height:70px;
    border-radius:22px;
    background:linear-gradient(135deg,var(--csc-primary),var(--csc-primary-strong));
    box-shadow:0 16px 28px rgba(85,165,54,.26);
}
.csc-booking-success__icon span{
    width:28px;
    height:16px;
    border-left:5px solid #fff;
    border-bottom:5px solid #fff;
    transform:rotate(-45deg) translate(2px,-2px);
}
.csc-booking-success__body{
    position:relative;
    z-index:1;
    min-width:0;
}
.csc-booking-success__badge{
    display:inline-flex;
    align-items:center;
    padding:6px 12px;
    border-radius:999px;
    background:rgba(85,165,54,.13);
    color:var(--csc-primary-strong);
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.03em;
}
.csc-booking-success h2{
    margin:14px 0 10px;
    font-size:30px;
    line-height:1.15;
    color:#4b3b1b;
}
.csc-booking-success p{
    margin:0;
    font-size:16px;
    line-height:1.6;
    color:var(--csc-muted);
}
.csc-booking-success__lead{
    max-width:760px;
}
.csc-booking-success__summary{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    margin:20px 0 16px;
}
.csc-booking-success__metric{
    padding:14px 15px;
    border-radius:18px;
    border:1px solid rgba(215,191,140,.64);
    background:rgba(255,255,255,.72);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}
.csc-booking-success__metric span{
    display:block;
    margin-bottom:7px;
    font-size:12px;
    line-height:1.3;
    color:var(--csc-muted);
}
.csc-booking-success__metric strong{
    display:block;
    font-size:18px;
    line-height:1.2;
    color:#223d12;
}
.csc-booking-success__next{
    display:flex;
    gap:10px;
    align-items:flex-start;
    max-width:760px;
    margin:0 0 20px;
    padding:14px 16px;
    border-radius:18px;
    border:1px dashed rgba(85,165,54,.45);
    background:rgba(244,251,239,.74);
    color:var(--csc-muted);
    font-size:14px;
    line-height:1.55;
}
.csc-booking-success__next strong{
    flex:0 0 auto;
    color:#223d12;
}
.csc-booking-hidden{
    display:none!important;
}
@media (max-width: 1040px){
    .csc-booking-hero{
        grid-template-columns:1fr;
    }
    .csc-booking-layout{
        grid-template-columns:1fr;
    }
    .csc-booking-sidebar__sticky{
        position:static;
    }
}
@media (max-width: 760px){
    .csc-booking-page{
        padding:20px 12px 36px;
    }
    .csc-booking-hero{
        padding:18px;
        border-radius:22px;
    }
    .csc-booking-hero__title{
        font-size:28px;
    }
    .csc-booking-hero__facts{
        grid-template-columns:1fr;
    }
    .csc-booking-form,
    .csc-booking-sidebar{
        padding:0;
    }
    .csc-booking-sidebar{
        padding:16px;
    }
    .csc-booking-section{
        padding:20px 16px;
    }
    .csc-booking-section--step{
        padding-left:68px;
    }
    .csc-booking-section--step:before{
        top:20px;
        left:16px;
        width:36px;
        height:36px;
        font-size:14px;
    }
    .csc-booking-grid--3{
        grid-template-columns:1fr;
    }
    .csc-booking-grid--2{
        grid-template-columns:1fr;
    }
    .csc-booking-pet-actions,
    .csc-booking-known-pets{
        width:100%;
        align-items:stretch;
    }
    .csc-booking-known-pets select{
        min-width:0;
    }
    .csc-booking-known-pets{
        grid-template-columns:1fr;
    }
    .csc-booking-section__head--inline,
    .csc-booking-item__head,
    .csc-booking-item__foot,
    .csc-booking-summary-item__top{
        flex-direction:column;
        align-items:flex-start;
    }
    .csc-booking-success{
        grid-template-columns:1fr;
        padding:22px 18px;
    }
    .csc-booking-success__icon{
        width:58px;
        height:58px;
        border-radius:18px;
    }
    .csc-booking-success__summary{
        grid-template-columns:1fr;
    }
    .csc-booking-success__next{
        flex-direction:column;
        gap:4px;
    }
    .csc-booking-kpis{
        grid-template-columns:1fr 1fr 1fr;
    }
}
@media (max-width: 520px){
    .csc-booking-kpis{
        grid-template-columns:1fr;
    }
    .csc-booking-success h2{
        font-size:26px;
    }
    .csc-booking-success .csc-booking-btn{
        width:100%;
    }
}
