body {
    font-family: 'Poppins', sans-serif;
    font-size: 15px;
    color: #333;
    line-height: 1.6;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    background:#fff;
}

* { box-sizing: border-box; }

a { text-decoration: none; color: inherit; }
a:hover { color: #A4202A; }

img { max-width: 100%; height: auto; display:block; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 15px; }

h1, h2, h3, h4, h5, h6 {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    color: #222;
    margin-top: 0;
}

.material-icons { vertical-align: middle; font-size: 18px;}

.top-bar {
    background:#A4202A;
    color: #fff;
    font-size: 13px;
    padding: 8px 0;
}
.top-bar a { color:#fff; }
.top-bar .contact-info span {
    margin-right: 1.4rem;
    display:inline-flex;
    align-items:center;
    gap:6px;
}
.top-bar .contact-info i { font-size:15px; color:#fff;}
.top-bar .addrline { display:none;}

.site-header{
    background: #fff;
    padding: 15px 0;
    position: relative;
    width: 100%;
    z-index: 99;
    transition: all 0.3s ease;
    border-bottom:1px solid #f0f0f0;
}
.site-header .container{
    display:flex;
    align-items:center;
    justify-content: space-between;
}
.site-header .logo img { max-height: 64px; width:auto;}
.site-header .main-nav ul {
    list-style: none;
    display: flex;
    margin: 0;
    padding: 0;
}
.site-header .main-nav li { margin: 0 13px;}
.site-header .main-nav a {
    font-size: 14px;
    font-weight:500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #222;
    padding: 0.625rem 0;
    display:inline-block;
}
.site-header .main-nav a:hover { color:#A4202A;}

.mob-toggle{
    display:none;
    background:transparent;
    border:none;
    cursor:pointer;
    padding:6px;
    color:#A4202A;
}
.mob-toggle .material-icons{ font-size:30px;}

.btn, .button, .btn-primary {
    display: inline-block;
    background:#A4202A;
    color: #fff !important;
    padding: 12px 27px;
    border: none;
    border-radius: 2px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    transition: background 0.3s;
    cursor: pointer;
}
.btn:hover, .button:hover, .btn-primary:hover{
    background:#8B1B23;
    color:#fff;
}
.btn-outline{
    background:transparent;
    border:1px solid #fff;
    color:#fff !important;
    margin-left: 10px;
}
.btn-outline:hover{ background:#fff; color:#A4202A !important;}

.hero-section {
    position: relative;
    padding: 0;
    overflow:hidden;
    background:#f9f9f9;
}
.hero-section .hero-inner {
    display:flex;
    align-items:center;
    min-height: 32rem;
}
.hero-section .hero-content{
    flex: 0 0 45%;
    padding: 58px 38px 64px 60px;
}
.hero-section .hero-image{
    flex: 1;
    position:relative;
    align-self:stretch;
}
.hero-section .hero-image img{
    width:100%;
    height:100%;
    min-height:32rem;
    object-fit:cover;
}
.hero-section .eyebrow {
    color:#A4202A;
    font-size:13px;
    font-weight:600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.hero-section h1 {
    font-size: 38px;
    line-height:1.18;
    margin-bottom:14px;
    color:#222;
    font-weight:700;
    letter-spacing: -0.3px;
}
.hero-section p.lead{
    font-size: 1rem;
    color:#555;
    margin-bottom: 1.6em;
}
.hero-section ul.hero-list {
    list-style:none;
    padding:0;
    margin: 0 0 28px;
}
.hero-section ul.hero-list li {
    padding: 6px 0 6px 27px;
    position: relative;
    font-size:15px;
    color: #333;
}
.hero-section ul.hero-list li:before {
    content:"✓";
    position:absolute;
    left:0; top:6px;
    color:#A4202A;
    font-weight:700;
    font-size:14px;
}

.trust-strip { background:#fff; padding:32px 0 28px; border-bottom:1px solid #eee; }
.trust-strip .row { display:flex; justify-content:space-between; flex-wrap:wrap;}
.trust-strip .trust-item {
    flex: 1 1 22%;
    display:flex;
    align-items:center;
    gap: 13px;
    padding: 0.75rem 1.25rem;
}
.trust-strip .trust-item .tickMark{
    width:2.4rem; height:2.4rem;
    background:#fff5f5;
    border:1px solid #f3d9db;
    color:#A4202A;
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:18px;
    font-weight:700;
    flex-shrink:0;
}
.trust-strip .trust-item p { margin:0; font-size:14px; color:#333; font-weight:500; }

.about-section{
    padding: 71px 0 78px;
    position: relative;
}
.about-wrap {
    border:1px solid #eaeaea;
    border-radius: 14px;
    padding: 48px;
    display:flex;
    gap: 38px;
    align-items: center;
    background:#fff;
    box-shadow: 0 4px 18px rgba(0,0,0,0.04);
}
.about-wrap .about-text { flex: 1;}
.about-wrap .about-text h2 {
    font-size: 28px;
    margin-bottom: 9px;
}
.about-wrap .about-text h4 {
    font-size:18px;
    margin-bottom:17px;
    color:#A4202A;
    font-weight:500;
}
.about-wrap .about-text p {
    font-size: 0.875rem;
    color:#666;
    line-height:1.72;
    margin-bottom: 0.9em;
}
.about-wrap .about-text .btn{ margin-top: 0.6em;}
.about-wrap .about-img { flex:1;}
.about-wrap .about-img img { border-radius:10px; width:100%; object-fit:cover; max-height:418px;}

.services-section{ padding: 22px 0 78px; }
.services-section h2.section-title{
    text-align:center;
    font-size: 28px;
    margin-bottom: 7px;
}
.services-section .section-sub{
    text-align:center;
    color:#777;
    font-size: 0.875rem;
    margin-bottom: 38px;
}
.services-grid {
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
.service-card {
    background:#fff;
    border:1px solid #ececec;
    border-radius:8px;
    overflow:hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
    transition: transform 0.3s, box-shadow 0.3s;
    text-align: center;
}
.service-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}
.service-card .card-img { width:100%; height:11.25rem; overflow:hidden;}
.service-card .card-img img { width:100%; height:100%; object-fit:cover;}
.service-card .card-body {
    padding: 24px 19px 28px;
}
.service-card h3 { font-size: 18px; margin-bottom: 11px; color:#222; }
.service-card p {
    font-size: 13px;
    color:#777;
    line-height:1.7;
    margin: 0 0 18px;
    min-height: 7rem;
}
.service-card .read-more{
    display:inline-block;
    background:#A4202A;
    color:#fff;
    padding: 9px 23px;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing: 0.07em;
    font-weight:600;
    border-radius:2px;
    margin-bottom: 5px;
}
.service-card .read-more:hover{ background:#8B1B23; color:#fff;}

.procesBlk{
    padding: 67px 0 82px;
    background:#f9f9f9;
}
.procesBlk h2.section-title{
    text-align:center;
    font-size:28px;
    margin-bottom: 7px;
}
.procesBlk .section-sub{
    text-align:center;
    color:#777;
    font-size: 0.875rem;
    margin-bottom: 43px;
}
.pGrid{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 21px;
}
.pStepBox{
    background:#fff;
    border:1px solid #ececec;
    border-radius: 8px;
    padding: 28px 21px 26px;
    position:relative;
    text-align:left;
    transition: transform .3s, box-shadow .3s;
}
.pStepBox:hover{
    transform: translateY(-4px);
    box-shadow: 0 8px 22px rgba(0,0,0,0.06);
}
.pStepBox .numTag{
    font-size: 2.6rem;
    font-weight:700;
    color:#A4202A;
    letter-spacing: -1px;
    line-height: 1;
    margin-bottom: 16px;
    display:inline-block;
    border-bottom: 3px solid #A4202A;
    padding-bottom: 6px;
}
.pStepBox h4{
    font-size:17px;
    margin-bottom:9px;
    color:#222;
}
.pStepBox p{
    font-size:13px;
    color:#666;
    line-height:1.65;
    margin:0;
}
.ctaWrap{ text-align:center; margin-top: 38px;}

.zalBlock{
    padding: 76px 0 71px;
}
.zalBlock h2.section-title{
    text-align:center;
    font-size:28px;
    margin-bottom: 7px;
}
.zalBlock .section-sub{
    text-align:center;
    color:#777;
    font-size: 0.875rem;
    margin-bottom: 44px;
}
.zalGrid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 27px;
}
.zalRow{
    background:#fff;
    border:1px solid #eaeaea;
    border-radius: 10px;
    padding: 27px 25px 25px;
    transition: border-color .3s, transform .3s;
    position: relative;
}
.zalRow:hover{
    border-color:#A4202A;
    transform: translateY(-3px);
}
.zalRow .zalNum{
    font-size: 1.6rem;
    font-weight:700;
    color:#A4202A;
    letter-spacing: -0.5px;
    margin-bottom: 14px;
    display: inline-block;
    padding: 0 0 6px 0;
    border-bottom: 2px solid #f3d9db;
}
.zalRow h4{
    font-size: 16px;
    margin-bottom: 9px;
    color:#222;
}
.zalRow p{
    font-size:13px;
    color:#6a6a6a;
    line-height:1.7;
    margin:0;
}

.bigCntBlk{
    background:#A4202A;
    color:#fff;
    padding: 58px 0 62px;
}
.bigCntBlk h2.section-title{
    text-align:center;
    font-size: 26px;
    color:#fff;
    margin-bottom: 36px;
}
.bigNumGrid{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 28px;
    text-align:center;
}
.numBox{
    padding: 0 0.875rem;
    border-right:1px solid rgba(255,255,255,0.18);
}
.numBox:last-child{ border-right:none;}
.bigDigit{
    font-size: 3rem;
    font-weight:700;
    line-height:1;
    margin-bottom: 0.75em;
    letter-spacing: -1px;
}
.numCap{
    font-size:13px;
    color:rgba(255,255,255,0.88);
    line-height:1.55;
}

.prkBlock{
    padding: 71px 0 84px;
    background:#f9f9f9;
}
.prkBlock h2.section-title{
    text-align:center;
    font-size: 28px;
    margin-bottom: 7px;
}
.prkBlock .section-sub{
    text-align:center;
    color:#777;
    font-size: 0.875rem;
    margin-bottom: 38px;
}
.prkGrid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
}
.prkCard{
    background:#fff;
    border-radius:10px;
    overflow:hidden;
    box-shadow: 0 3px 14px rgba(0,0,0,0.05);
    transition: transform .3s, box-shadow .3s;
}
.prkCard:hover{
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(0,0,0,0.09);
}
.prkCard .prkImg{ height:12.5rem; overflow:hidden;}
.prkCard .prkImg img{ width:100%; height:100%; object-fit:cover;}
.prkCard .prkBody{ padding: 23px 23px 26px;}
.prkCard h3{ font-size:18px; margin-bottom:9px;}
.prkCard p{ font-size:13px; color:#666; line-height:1.7; margin:0;}

.opinie-block{ padding: 64px 0 56px; }
.opinie-block h2{
    font-size:22px;
    margin-bottom: 5px;
}
.opinie-block .sub {
    font-size: 13px;
    color:#777;
    margin-bottom: 28px;
}
.opinie-slider{ position:relative;}
.opinie-slider .slide-track{
    display:flex;
    gap: 17px;
    overflow-x:auto;
    scroll-behavior:smooth;
    scroll-snap-type: x mandatory;
    padding: 6px 4px 12px;
    scrollbar-width: none;
}
.opinie-slider .slide-track::-webkit-scrollbar{ display:none;}
.opinie-slider .slide{
    background:#fff;
    border:1px solid #eaeaea;
    border-radius: 8px;
    padding: 22px 21px 26px;
    flex: 0 0 20rem;
    scroll-snap-align: start;
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
}
.opinie-slider .slide .top { display:flex; align-items:center; gap:12px;}
.opinie-slider .slide .avatar {
    width:44px; height:44px;
    border-radius:50%;
    background:#a4202a;
    color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-weight:600;
    font-size:18px;
}
.opinie-slider .slide h5 { margin: 0; font-size:14px; font-weight:600;}
.opinie-slider .slide span{ font-size:12px; color:#888;}
.opinie-slider .slide .stars { color:#e8a90b; margin: 12px 0 9px; font-size:13px; letter-spacing: 0.05em;}
.opinie-slider .slide p { font-size:13px; color:#444; line-height:1.65; margin:0;}
.slide-arr{
    position:absolute;
    top: 50%;
    transform: translateY(-50%);
    background:#fff;
    border:1px solid #eaeaea;
    width:2.5rem; height:2.5rem;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    cursor:pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    color:#A4202A;
}
.slide-arr.prev{ left: -10px;}
.slide-arr.next{ right: -10px;}
.slide-arr .material-icons{ font-size:22px; color:#A4202A;}
.slide-arr:hover{ background:#A4202A;}
.slide-arr:hover .material-icons{ color:#fff;}

.cta-stripe{
    background:#A4202A;
    color:#fff;
    padding: 72px 0 78px;
}
.cta-stripe .cta-wrap{
    text-align:center;
    max-width: 47.5rem;
    margin: 0 auto;
}
.cta-stripe h2{
    color:#fff;
    font-size:28px;
    margin-bottom: 13px;
}
.cta-stripe p{
    font-size:15px;
    color:rgba(255,255,255,0.92);
    margin-bottom: 27px;
    line-height:1.65;
}
.cta-stripe .actBar .btn{
    background:#fff;
    color:#A4202A !important;
}
.cta-stripe .actBar .btn:hover{ background:#f3f3f3;}
.cta-stripe .actBar{
    display:flex;
    justify-content:center;
    gap:0;
    flex-wrap: wrap;
}
.cta-stripe .phoneNote{
    margin: 18px 0 0;
    font-size: 14px;
    color: rgba(255,255,255,0.85);
    letter-spacing: 0.01em;
}
.cta-stripe .phoneNote strong{
    color:#fff;
    font-weight:700;
    letter-spacing: 0.5px;
    margin-left: 4px;
    font-size: 1rem;
}

.kontakt-strip{
    background:#000;
    color:#fff;
    padding: 26px 0 30px;
}
.kontakt-strip .wrap{
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 18px;
    flex-wrap:wrap;
}
.kontakt-strip .label{
    display:flex;
    align-items:center;
    gap:13px;
    font-size:14px;
}
.kontakt-strip .label .ico{
    width:42px; height:42px;
    border-radius:50%;
    background:#A4202A;
    display:flex; align-items:center; justify-content:center;
    color:#fff;
}
.kontakt-strip .phone-cta{
    font-size: 22px;
    font-weight:700;
    color:#fff;
    letter-spacing: 0.02em;
    user-select: text;
}
.kontakt-strip .sub-btn{
    background:#A4202A;
    color:#fff !important;
    padding: 11px 22px;
    border:none;
    font-weight:600;
    border-radius:2px;
    cursor:pointer;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 12px;
}

.site-footer{
    background:#000;
    color:#bbb;
    padding: 48px 0 22px;
    font-size:13px;
}
.site-footer .cols {
    display:grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 28px;
}
.site-footer h4 { color:#fff; font-size:16px; margin-bottom: 15px; }
.site-footer .contact-line{
    margin-bottom: 9px;
    display:flex;
    gap:8px;
    align-items:flex-start;
}
.site-footer .contact-line i{
    color:#A4202A;
    margin-top:2px;
    font-size:16px;
}
.site-footer .footTxt{
    margin: 0;
    color:#bbb;
    font-size: 13px;
    line-height: 1.75;
}
.site-footer a{ color:#bbb;}
.site-footer a:hover{ color:#fff;}
.site-footer .brand-col img { max-height: 4.6rem; margin: 0 auto 13px; }
.site-footer .brand-col .small{
    font-size:12px;
    margin-top: 0.65rem;
    line-height: 1.9;
}
.site-footer .brand-col .small a{
    display:inline-block;
}
.site-footer .qLinks{
    list-style: none;
    padding: 0;
    margin: 0;
}
.site-footer .qLinks li{
    padding: 4px 0;
    border-bottom: 1px dashed #1f1f1f;
}
.site-footer .qLinks li:last-child{ border-bottom: none;}
.site-footer .sub-footer{
    border-top:1px solid #1a1a1a;
    margin-top: 33px;
    padding-top: 16px;
    text-align:center;
    font-size:12px;
    color:#777;
}

.pull-left{ float:left;}
.pull-right{ float:right;}
.clearfix:after{ content:""; display:table; clear:both;}

@media (max-width: 1100px){
    .top-bar .addrline{ display:none;}
}
@media (max-width: 991px){
    .site-header .main-nav {
        display:none;
        position:absolute;
        top:100%;
        left:0;
        right:0;
        background:#fff;
        border-bottom:1px solid #eee;
    }
    .site-header .main-nav.open{ display:block;}
    .site-header .main-nav ul{ flex-direction:column; padding: 10px 0;}
    .site-header .main-nav li{ margin: 0; padding: 6px 25px;}
    .site-header .header-cta{ display:none;}
    .mob-toggle{ display:inline-flex;}
    .hero-section .hero-inner { flex-direction: column;}
    .hero-section .hero-content { flex: 1 1 100%; padding: 38px 20px 42px;}
    .hero-section .hero-image img{ min-height: 20rem;}
    .services-grid { grid-template-columns: repeat(2, 1fr);}
    .pGrid { grid-template-columns: repeat(2, 1fr);}
    .zalGrid { grid-template-columns: repeat(2, 1fr);}
    .bigNumGrid { grid-template-columns: repeat(2, 1fr);}
    .numBox{ border-right:none; border-bottom:1px solid rgba(255,255,255,0.16); padding-bottom: 18px;}
    .numBox:nth-last-child(-n+2){ border-bottom:none; padding-bottom:0;}
    .prkGrid { grid-template-columns: 1fr;}
    .about-wrap { flex-direction: column; padding: 30px;}
    .site-footer .cols { grid-template-columns: 1fr 1fr;}
    .kontakt-strip .wrap{ justify-content:center; text-align:center;}
}
@media (max-width: 600px){
    .top-bar .contact-info span{ display:block; margin: 0 0 4px;}
    .top-bar { font-size:12px; padding: 10px 0;}
    .services-grid { grid-template-columns: 1fr;}
    .pGrid { grid-template-columns: 1fr;}
    .zalGrid { grid-template-columns: 1fr;}
    .bigNumGrid { grid-template-columns: 1fr;}
    .numBox{ border-right:none; border-bottom:1px solid rgba(255,255,255,0.16); padding-bottom: 18px;}
    .numBox:last-child{ border-bottom:none; padding-bottom:0;}
    .site-footer .cols { grid-template-columns: 1fr;}
    .hero-section h1 { font-size:28px;}
    .about-wrap .about-text h2{ font-size: 24px;}
    .services-section h2.section-title,
    .procesBlk h2.section-title,
    .zalBlock h2.section-title,
    .prkBlock h2.section-title{ font-size:24px;}
    .cta-stripe h2{ font-size:24px;}
    .bigDigit{ font-size:2.4rem;}
    .cta-stripe .actBar{ flex-direction:column;}
    .cta-stripe .actBar .btn{ margin: 6px 0;}
    .btn-outline{ margin-left:0;}
    .kontakt-strip .label{ flex-direction:column; text-align:center;}
}

.hero-section h1 { letter-spacing: -0.3px;}
.service-card .read-more { margin-bottom: 5px;}

html.ck-locked { overflow: hidden;}

.ck-cup{
    position: fixed;
    inset: 0;
    z-index: 9999;
    pointer-events: none;
    visibility: hidden;
}
.ck-cup.show{ visibility: visible;}

.ck-bar{
    position: absolute;
    left: 0; right: 0; bottom: 0;
    background: #0c0c0c;
    color: #f1f1f1;
    pointer-events: auto;
    transform: translateY(110%);
    transition: transform .42s cubic-bezier(.2,.7,.3,1);
    box-shadow: 0 -10px 32px rgba(0,0,0,0.45);
    border-top: 3px solid #A4202A;
}
.ck-cup.show .ck-bar{ transform: translateY(0);}

.ck-bar-grid{
    display: flex;
    align-items: center;
    gap: 26px;
    padding: 22px 0 24px;
    flex-wrap: wrap;
}
.ck-msg{ flex: 1 1 22rem;}
.ck-title{
    color:#fff;
    font-weight:700;
    margin-bottom: 5px;
    font-size: 15px;
    letter-spacing: 0.01em;
}
.ck-msg p{
    margin: 0;
    color:#c4c4c4;
    font-size: 13px;
    line-height: 1.62;
}
.ck-msg a{
    color:#ff8d94;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.ck-msg a:hover{ color:#ffb9be;}

.ck-acts{
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}
.ck-acts button{
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
    font-size: 12px;
    padding: 11px 22px;
    border-radius: 2px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background .25s, color .25s, border-color .25s;
    line-height: 1.2;
}
.ck-acts .ck-allow{
    background:#A4202A;
    color:#fff;
    border-color:#A4202A;
}
.ck-acts .ck-allow:hover{
    background:#8B1B23;
    border-color:#8B1B23;
}
.ck-acts .ck-reject,
.ck-acts .ck-cog{
    background: transparent;
    color:#fff;
    border-color: rgba(255,255,255,0.45);
}
.ck-acts .ck-reject:hover,
.ck-acts .ck-cog:hover{
    background:#fff;
    color:#A4202A;
    border-color:#fff;
}
.ck-acts .ck-cog{
    border-color: rgba(255,255,255,0.28);
    color: #d8d8d8;
}
.ck-acts .ck-cog:hover{
    color:#A4202A;
    border-color:#fff;
}

.ck-modal{
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.66);
    pointer-events: none;
    opacity: 0;
    transition: opacity .28s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 22px;
}
.ck-modal.open{
    pointer-events: auto;
    opacity: 1;
}

.ck-card{
    background:#fff;
    border-radius: 10px;
    max-width: 38rem;
    width: 100%;
    max-height: 88vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-top: 4px solid #A4202A;
    box-shadow: 0 22px 60px rgba(0,0,0,0.45);
    transform: translateY(14px);
    transition: transform .28s ease;
}
.ck-modal.open .ck-card{ transform: translateY(0);}

.ck-card-head{
    padding: 22px 26px 16px;
    border-bottom: 1px solid #eee;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}
.ck-card-head h3{
    margin: 0;
    font-size: 19px;
    color:#222;
    letter-spacing: -0.2px;
}
.ck-close{
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 28px;
    line-height: 1;
    color: #888;
    padding: 0 6px;
    font-family: inherit;
}
.ck-close:hover{ color:#A4202A;}

.ck-card-body{
    overflow-y: auto;
    padding: 18px 26px 8px;
    flex: 1 1 auto;
}
.ck-intro{
    color:#666;
    font-size: 13px;
    line-height: 1.65;
    margin: 0 0 18px;
}

.ck-row{
    border:1px solid #eaeaea;
    border-radius: 7px;
    padding: 15px 17px 16px;
    margin-bottom: 11px;
    transition: border-color .25s, background .25s;
}
.ck-row:hover{ border-color:#cfcfcf; background:#fafafa;}
.ck-row-top{
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    margin-bottom: 8px;
}
.ck-row-meta{
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.ck-row h4{
    margin: 0;
    font-size: 15px;
    color:#222;
}
.ck-locked{
    background:#fff5f5;
    color:#A4202A;
    border:1px solid #f3d9db;
    padding: 4px 9px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.ck-tag{
    background:#f4f4f4;
    color:#666;
    padding: 4px 9px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.ck-row p{
    margin: 0;
    color:#666;
    font-size: 12.5px;
    line-height: 1.62;
}

.ck-switch{
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
    flex-shrink: 0;
    cursor: pointer;
}
.ck-switch input{
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}
.ck-knob{
    display: block;
    width: 44px;
    height: 24px;
    background: #d6d6d6;
    border-radius: 24px;
    transition: background .25s;
    position: relative;
}
.ck-knob:before{
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: transform .25s ease, box-shadow .25s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
}
.ck-switch input:checked + .ck-knob{ background: #A4202A;}
.ck-switch input:checked + .ck-knob:before{
    transform: translateX(20px);
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.ck-switch input:focus-visible + .ck-knob{
    outline: 2px solid #A4202A;
    outline-offset: 2px;
}
.ck-switch-locked{
    cursor: not-allowed;
}
.ck-switch-locked .ck-knob{ background: #c8c8c8; opacity: .85;}
.ck-switch-locked input:checked + .ck-knob{ background: #c8c8c8;}

.ck-card-foot{
    padding: 16px 26px 22px;
    border-top: 1px solid #eee;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
    flex-shrink: 0;
    background:#fafafa;
}
.ck-card-foot button{
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
    font-size: 12px;
    padding: 11px 22px;
    border-radius: 2px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background .25s, color .25s, border-color .25s;
    line-height: 1.2;
}
.ck-card-foot .ck-deny-modal{
    background: transparent;
    color:#666;
    border-color:#d4d4d4;
}
.ck-card-foot .ck-deny-modal:hover{
    background:#A4202A;
    color:#fff;
    border-color:#A4202A;
}
.ck-card-foot .ck-save{
    background:#A4202A;
    color:#fff;
    border-color:#A4202A;
}
.ck-card-foot .ck-save:hover{
    background:#8B1B23;
    border-color:#8B1B23;
}

@media (max-width: 720px){
    .ck-bar-grid{ padding: 18px 0 20px; gap: 14px;}
    .ck-acts{ width: 100%;}
    .ck-acts .ck-allow{ flex: 1 1 100%; text-align:center;}
    .ck-acts .ck-reject,
    .ck-acts .ck-cog{ flex: 1 1 calc(50% - 5px);}
    .ck-card-head{ padding: 18px 20px 14px;}
    .ck-card-body{ padding: 15px 20px 6px;}
    .ck-card-foot{ padding: 14px 20px 18px; justify-content: space-between;}
    .ck-row{ padding: 14px 14px 14px;}
    .ck-row-top{ flex-wrap: wrap;}
}
.pageHead{
    background: linear-gradient(135deg, #A4202A 0%, #8B1B23 100%);
    color: #fff;
    padding: 58px 0 64px;
    position: relative;
    border-bottom: 1px solid #6f1217;
}
.pageHead .container{ max-width: 920px;}
.pageHead .crumbs{
    font-size: 11px;
    color: rgba(255,255,255,0.78);
    margin-bottom: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.pageHead .crumbs a{
    color:#fff;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.pageHead .crumbs a:hover{ opacity: 0.8;}
.pageHead .crumbs span{ margin: 0 7px; opacity: 0.55;}
.pageHead h1{
    color:#fff;
    font-size: 33px;
    line-height: 1.2;
    margin: 0 0 12px;
    font-weight: 700;
    letter-spacing: -0.3px;
}
.pageHead .pHeadSub{
    margin: 0;
    font-size: 15px;
    color: rgba(255,255,255,0.92);
    line-height: 1.6;
    max-width: 660px;
}

.procesIntro{
    padding: 56px 0 30px;
    background: #fff;
}
.procesIntro .introWrap{
    max-width: 880px;
    margin: 0 auto;
}
.procesIntro .leadIntro{
    font-size: 17px;
    line-height: 1.7em;
    color: #444;
    margin: 0 0 18px;
}
.procesIntro .leadIntro:last-of-type{ margin-bottom: 36px;}
.introStats{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-top: 32px;
    padding: 28px 30px;
    background: #fafafa;
    border-left: 3px solid #A4202A;
    border-radius: 4px;
}
.iSt{ text-align: left;}
.iSt strong{
    display: block;
    font-size: 22px;
    color:#A4202A;
    font-weight: 700;
    margin-bottom: 4px;
    letter-spacing: -0.3px;
}
.iSt span{
    font-size: 12.5px;
    color:#666;
    line-height: 1.5;
    display: block;
}

.etapBlock{
    padding: 56px 0;
    background:#fff;
}
.etapBlock-alt{ background:#f9f9f9;}
.etapWrap{
    display: flex;
    align-items: center;
    gap: 50px;
}
.etapWrap.flip{ flex-direction: row-reverse;}
.etapText{ flex: 1.05;}
.etapImg{ flex: 0.95;}
.etapImg img{
    width: 100%;
    height: auto;
    border-radius: 6px;
    display: block;
    box-shadow: 0 14px 32px rgba(0,0,0,0.14);
}
.etapNum{
    display: inline-block;
    font-size: 12px !important;
    font-weight: 700;
    color:#A4202A;
    letter-spacing: 0.18em;
    background:#fff5f5;
    padding: 5px 12px;
    border-radius: 2px;
    margin-bottom: 14px;
    border: 1px solid #f1d3d5;
}
.etapBlock-alt .etapNum{ background:#fff;}
.etapText h2{
    font-size: 26px;
    margin: 0 0 18px;
    color:#1f1f1f;
    line-height: 1.25;
    font-weight: 700;
    letter-spacing: -0.3px;
}
.etapText p{
    color:#555;
    line-height: 1.75;
    font-size: 14.5px;
    margin: 0 0 14px;
}
.etapList{
    list-style: none;
    padding: 0;
    margin: 18px 0 0;
}
.etapList li{
    color:#444;
    font-size: 14px;
    line-height: 1.55;
    padding: 6px 0 6px 22px;
    position: relative;
}
.etapList li::before{
    content: "›";
    color:#A4202A;
    position: absolute;
    left: 4px;
    top: 4px;
    font-weight: 700;
    font-size: 16px;
}

.kontaktInfo{
    padding: 50px 0 40px;
    background:#fff;
}
.kontaktInfo .infoGrid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}
.infoCard{
    background:#fafafa;
    border: 1px solid #ececec;
    border-radius: 6px;
    padding: 28px 26px 24px;
    text-align: center;
    transition: transform .3s, box-shadow .3s, border-color .3s, background .3s;
}
.infoCard:hover{
    transform: translateY(-3px);
    box-shadow: 0 12px 26px rgba(0,0,0,0.07);
    border-color:#ddd;
    background:#fff;
}
.iCardIco{
    width: 52px;
    height: 52px;
    background:#A4202A;
    border-radius: 50%;
    margin: 0 auto 16px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.iCardIco .material-icons{
    color:#fff !important;
    font-size: 24px;
}
.infoCard h4{
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color:#888;
    margin: 0 0 10px;
    font-weight: 600;
}
.infoCard .iBig{
    font-size: 16px;
    color:#1f1f1f;
    font-weight: 600;
    margin: 0 0 12px;
    line-height: 1.45;
}
.infoCard .iNote{
    margin: 0;
    font-size: 13px;
    color:#666;
    line-height: 1.65;
}

.kontaktForm{
    padding: 30px 0 64px;
    background:#fff;
}
.formHead{
    text-align: center;
    margin-bottom: 32px;
}
.formHead h2{
    font-size: 24px;
    color:#1f1f1f;
    margin: 0 0 10px;
    font-weight: 700;
}
.formHead p{
    font-size: 14px;
    color:#777;
    margin: 0;
}
.formCard{
    background:#fff;
    max-width: 760px;
    margin: 0 auto;
    border: 1px solid #ececec;
    border-radius: 8px;
    padding: 38px 40px 36px;
    box-shadow: 0 8px 26px rgba(0,0,0,0.05);
}
.formRow{
    display: flex;
    gap: 18px;
}
.formRow .field{ flex: 1;}
.field{
    margin-bottom: 18px;
    position: relative;
}
.field label{
    display: block;
    font-size: 13px;
    font-weight: 500;
    color:#333;
    margin-bottom: 6px;
}
.field input,
.field textarea{
    width: 100%;
    padding: 11px 14px;
    border: 1px solid #d8d8d8;
    border-radius: 3px;
    font-size: 14px;
    font-family: inherit;
    color:#333;
    background:#fff;
    transition: border-color .25s, background .25s;
    box-sizing: border-box;
}
.field input:focus,
.field textarea:focus{
    outline: none;
    border-color:#A4202A;
}
.field textarea{
    min-height: 130px;
    resize: vertical;
    line-height: 1.55;
}
.field input::placeholder,
.field textarea::placeholder{
    color:#aaa;
    opacity: 1;
}
.field.has-error input,
.field.has-error textarea{
    border-color:#d63a3a;
    background:#fff8f8;
}
.field .err-msg{
    display: none;
    font-size: 12px;
    color:#d63a3a;
    margin-top: 5px;
}
.field.has-error .err-msg{ display: block;}
.fieldHint{
    font-size: 11.5px;
    color:#888;
    margin-top: 4px;
    line-height: 1.45;
}
.hpField{
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0;
}
.rodo-row{
    display: flex;
    align-items: flex-start;
    gap: 11px;
    margin: 18px 0 24px;
    font-size: 12.5px;
    color:#666;
    line-height: 1.6;
}
.rodo-row input{
    margin-top: 3px;
    flex-shrink: 0;
    cursor: pointer;
}
.rodo-row label{
    cursor: pointer;
    margin: 0;
}
.rodo-row a{
    color:#A4202A;
    text-decoration: underline;
}
.rodo-row.has-error{ color:#d63a3a;}
.rodo-row.has-error a{ color:#d63a3a;}
.submit-row{
    text-align: center;
    margin-top: 8px;
}
.submit-row .btn{ min-width: 220px;}
.formSubmitBtn[disabled]{
    opacity: 0.65;
    cursor: wait;
}
.formNote{
    font-size: 12px;
    color:#888;
    margin: 14px 0 0;
    font-style: italic;
}

.thankPopup{
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    z-index: 9998;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s;
}
.thankPopup.show{
    opacity: 1;
    pointer-events: auto;
}
.thankCard{
    background:#fff;
    border-radius: 10px;
    border-top: 4px solid #A4202A;
    max-width: 480px;
    width: 100%;
    padding: 38px 34px 32px;
    text-align: center;
    box-shadow: 0 24px 60px rgba(0,0,0,0.4);
    transform: translateY(14px);
    transition: transform .3s;
    position: relative;
}
.thankPopup.show .thankCard{ transform: translateY(0);}
.thankClose{
    position: absolute;
    top: 12px;
    right: 14px;
    background: transparent;
    border: none;
    font-size: 26px;
    color:#999;
    cursor: pointer;
    width: 32px;
    height: 32px;
    line-height: 1;
    padding: 0;
}
.thankClose:hover{ color:#A4202A;}
.thankIco{
    width: 64px;
    height: 64px;
    margin: 0 auto 18px;
    background:#fff5f5;
    border: 2px solid #A4202A;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.thankIco .material-icons{
    font-size: 32px;
    color:#A4202A !important;
}
.thankCard h3{
    margin: 0 0 12px;
    font-size: 22px;
    color:#1f1f1f;
}
.thankCard p{
    color:#666;
    font-size: 14px;
    line-height: 1.65em;
    margin: 0 0 14px;
}
.thankCard .thankSub{
    font-size: 13px;
    color:#888;
    margin-bottom: 22px;
}
.thankCard .btn{
    min-width: 180px;
    margin-top: 4px;
}

.legalContent{
    padding: 50px 0 70px;
    background:#fff;
}
.legalContent .legalWrap{
    max-width: 820px;
    margin: 0 auto;
}
.legalContent h2{
    font-size: 19px;
    margin: 32px 0 13px;
    color:#1f1f1f;
    padding-bottom: 8px;
    border-bottom: 1px solid #f0d4d6;
    font-weight: 600;
}
.legalContent h2:first-of-type{ margin-top: 0;}
.legalContent p{
    color:#555;
    font-size: 14px;
    line-height: 1.75em;
    margin: 0 0 14px;
}
.legalContent p strong{ color:#1f1f1f;}
.legalContent ul{
    color:#555;
    font-size: 14px;
    line-height: 1.7;
    padding-left: 20px;
    margin: 0 0 16px;
}
.legalContent li{ margin-bottom: 6px;}

@media (max-width: 768px){
    .pageHead{ padding: 44px 0 48px;}
    .pageHead h1{ font-size: 26px;}
    .pageHead .pHeadSub{ font-size: 14px;}
    .procesIntro{ padding: 40px 0 20px;}
    .procesIntro .leadIntro{ font-size: 15px;}
    .introStats{
        grid-template-columns: repeat(2, 1fr);
        padding: 22px 20px;
        gap: 14px;
    }
    .iSt strong{ font-size: 19px;}
    .etapBlock{ padding: 38px 0;}
    .etapWrap, .etapWrap.flip{
        flex-direction: column;
        gap: 28px;
    }
    .etapText h2{ font-size: 22px;}
    .kontaktInfo .infoGrid{
        grid-template-columns: 1fr;
        gap: 14px;
    }
    .formCard{ padding: 28px 22px 26px;}
    .formRow{ flex-direction: column; gap: 0;}
    .thankCard{ padding: 32px 24px 26px;}
    .legalContent{ padding: 36px 0 50px;}
    .legalContent h2{ font-size: 17px;}
}