:root{
--primary:#c5161d;
--secondary:#142b6f;
--light:#fff8f8;
--white:#ffffff;
--dark:#171717;
--text:#575757;
--border:#ead8d8;
--shadow:0 14px 35px rgba(0,0,0,0.08);
--radius:20px;
--radius-sm:14px;
--max:1180px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
font-family:'Manrope', Arial, Helvetica, sans-serif;
background:var(--light);
color:var(--text);
line-height:1.7;
}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
.container{width:min(92%, var(--max));margin:auto;}
h1,h2,h3{
font-family:'Cormorant Garamond', Georgia, serif;
letter-spacing:0.2px;
}
.topbar{
background:var(--secondary);
color:var(--white);
padding:10px 0;
font-size:14px;
font-weight:600;
line-height:1.4;
}
.topbar-wrap{
display:flex;
justify-content:space-between;
align-items:center;
gap:16px;
flex-wrap:wrap;
}
.topbar a{color:var(--white);font-weight:800;}
header{
position:sticky;
top:0;
z-index:999;
background:rgba(255,255,255,0.97);
border-bottom:1px solid #ececec;
backdrop-filter:blur(10px);
}
.nav{
display:flex;
justify-content:space-between;
align-items:center;
gap:20px;
padding:14px 0;
}
.brand{
display:flex;
align-items:center;
}
.brand img{
height:64px;
width:auto;
display:block;
}
.nav-links{
display:flex;
align-items:center;
gap:24px;
flex-wrap:wrap;
}
.nav-links a{
font-weight:700;
color:#fff;
font-size:15px;
font-family:'Manrope', Arial, sans-serif;
}
.nav-toggle,
.navbar-toggler{
display:none;
width:44px;
height:44px;
border:1px solid #e3e3e3;
border-radius:10px;
background:#fff;
cursor:pointer;
align-items:center;
justify-content:center;
gap:5px;
padding:8px;
}
.nav-toggle span{
display:block;
width:100%;
height:2px;
background:#1d1d1d;
border-radius:999px;
transition:transform 0.25s ease, opacity 0.25s ease;
transform-origin:center;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){
transform:translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] span:nth-child(2){
opacity:0;
}
.nav-toggle[aria-expanded="true"] span:nth-child(3){
transform:translateY(-7px) rotate(-45deg);
}
.btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:8px;
background:var(--primary);
color:var(--white);
padding:14px 24px;
border-radius:999px;
border:none;
cursor:pointer;
font-size:15px;
font-weight:800;
font-family:'Manrope', Arial, sans-serif;
box-shadow:var(--shadow);
transition:0.3s ease;
}
.btn:hover,
.btn:focus-visible{
transform:translateY(-2px);
background:#a81117;
color:var(--white);
}
.btn-outline{
background:transparent;
color:var(--primary);
border:2px solid var(--primary);
box-shadow:none;
}
.btn-outline:hover,
.btn-outline:focus-visible{
background:var(--primary);
border-color:var(--primary);
color:var(--white);
}
.hero{
position:relative;
padding:48px 0 56px;
overflow:hidden;
min-height:min(85vh,800px);
display:flex;
align-items:center;
justify-content:center;
background:#141414;
}
.hero-bg{
position:absolute;
inset:0;
z-index:0;
pointer-events:none;
}
.hero-bg-img{
width:100%;
height:100%;
object-fit:cover;
object-position:center 35%;
}
.hero-bg-overlay{
position:absolute;
inset:0;
background:
linear-gradient(165deg, rgba(0,0,0,0.48) 0%, rgba(0,0,0,0.38) 45%, rgba(0,0,0,0.32) 100%);
}
.hero .container.hero-grid{
position:relative;
z-index:2;
margin-top:0;
padding:0;
}
.hero-grid{
display:grid;
grid-template-columns:minmax(0,1fr) minmax(300px,480px);
gap:clamp(28px,5vw,52px);
align-items:start;
justify-items:stretch;
}
.hero-copy{
position:relative;
justify-self:start;
max-width:520px;
width:100%;
padding:0;
}
.hero-form-card{
justify-self:end;
max-width:480px;
width:100%;
border-radius:22px;
background:var(--white);
border:1px solid var(--border);
box-shadow:0 18px 45px rgba(0,0,0,0.1),var(--shadow);
transform:translateY(2px);
overflow:hidden;
}
.hero .tag{
background:rgba(255,255,255,0.12);
color:#fff;
border:1px solid rgba(255,255,255,0.28);
}
.hero .btn-outline{
color:#fff;
border-color:rgba(255,255,255,0.85);
background:rgba(255,255,255,0.06);
}
.hero .btn-outline:hover{
background:var(--primary);
border-color:var(--primary);
color:#fff;
}
.tag{
display:inline-block;
padding:9px 15px;
background:rgba(197,22,29,0.08);
color:var(--primary);
border-radius:999px;
font-weight:800;
font-size:14px;
font-family:'Manrope', Arial, sans-serif;
margin-bottom:20px;
}
.hero h1{
font-size:clamp(38px, 5vw, 66px);
line-height:0.95;
margin-bottom:22px;
font-weight:700;
color:#fff;
text-shadow:0 2px 16px rgba(0,0,0,0.35);
}
.hero h1 span{color:#ffb8bc;}
.hero p{
font-size:16px;
margin-bottom:24px;
max-width:100%;
font-weight:500;
line-height:1.75;
color:rgba(255,255,255,0.9);
text-shadow:0 1px 8px rgba(0,0,0,0.25);
}
.hero-btns{
display:flex;
flex-wrap:wrap;
gap:12px;
margin-bottom:22px;
}
.hero-points{
display:grid;
grid-template-columns:repeat(3, minmax(0,1fr));
gap:10px;
}
.hero .point{
background:var(--white);
border:1px solid var(--border);
padding:14px 10px;
border-radius:14px;
box-shadow:var(--shadow);
text-align:center;
font-size:13px;
font-weight:600;
line-height:1.55;
color:var(--text);
}
.point{
background:var(--white);
border:1px solid var(--border);
padding:18px 16px;
border-radius:var(--radius-sm);
box-shadow:var(--shadow);
text-align:center;
font-size:14px;
font-weight:600;
line-height:1.6;
}
.point strong{
display:block;
color:var(--primary);
font-size:21px;
margin-bottom:4px;
font-family:'Cormorant Garamond', Georgia, serif;
font-weight:700;
}
.hero-form-top{
background:linear-gradient(135deg, var(--secondary), #23479d);
color:var(--white);
padding:26px 24px;
}
.hero-form-top h3{
font-size:34px;
margin-bottom:8px;
font-weight:700;
line-height:1;
}
.hero-form-top p{
font-size:15px;
font-weight:500;
color:rgba(255,255,255,0.88);
margin:0;
}
.quick-contact{
display:grid;
grid-template-columns:1fr 1fr;
gap:12px;
padding:18px 20px 0;
}
.quick-box{
background:#f8f9ff;
border:1px solid #dde3f6;
border-radius:14px;
padding:14px;
font-size:14px;
}
.quick-box strong{
display:block;
color:var(--secondary);
margin-bottom:4px;
font-size:15px;
font-weight:800;
}
.form-wrap{padding:20px;}
form{display:grid;gap:14px;}
.grid-2{
display:grid;
grid-template-columns:1fr 1fr;
gap:14px;
}
input, select, textarea{
width:100%;
padding:15px 16px;
font-size:14px;
border:1px solid #d8d8d8;
border-radius:12px;
outline:none;
background:#fffdfd;
font-family:'Manrope', Arial, sans-serif;
font-weight:500;
}
textarea{min-height:120px;resize:vertical;}
.note{
font-size:13px;
color:#777;
}
section{padding:74px 0;}
.section-title{
text-align:center;
max-width:760px;
margin:0 auto 42px;
}
.section-title span{
display:inline-block;
color:var(--primary);
font-weight:800;
letter-spacing:1px;
text-transform:uppercase;
font-size:13px;
margin-bottom:10px;
}
.section-title h2{
font-size:clamp(32px, 4vw, 48px);
color:var(--dark);
margin-bottom:10px;
font-weight:700;
line-height:1;
}
.section-title p{
font-size:16px;
color:#666;
line-height:1.7;
}
.about-wrap{
display:grid;
grid-template-columns:0.95fr 1.05fr;
gap:34px;
align-items:center;
}
.about-image{
background:var(--white);
padding:16px;
border-radius:24px;
border:1px solid var(--border);
box-shadow:var(--shadow);
}
.carousel{
position:relative;
width:100%;
max-width:100%;
height:460px;
border-radius:18px;
overflow:hidden;
background:#f3f3f3;
}
.carousel input{
display:none;
}
.carousel-slides{
width:100%;
height:100%;
position:relative;
}
.carousel-slide{
position:absolute;
inset:0;
opacity:0;
transition:opacity 0.5s ease;
z-index:1;
}
.carousel-slide img{
width:100%;
height:100%;
object-fit:cover;
object-position:center;
display:block;
}
#about-slide-1:checked ~ .carousel-slides .slide-1,
#about-slide-2:checked ~ .carousel-slides .slide-2,
#about-slide-3:checked ~ .carousel-slides .slide-3{
opacity:1;
z-index:2;
}
.carousel-dots{
position:absolute;
left:50%;
bottom:16px;
transform:translateX(-50%);
display:flex;
gap:8px;
z-index:5;
}
.carousel-dots label{
width:11px;
height:11px;
border-radius:50%;
background:rgba(255,255,255,0.55);
border:1px solid rgba(255,255,255,0.9);
cursor:pointer;
transition:0.3s ease;
display:block;
}
#about-slide-1:checked ~ .carousel-dots label[for='about-slide-1'],
#about-slide-2:checked ~ .carousel-dots label[for='about-slide-2'],
#about-slide-3:checked ~ .carousel-dots label[for='about-slide-3']{
background:#ffffff;
transform:scale(1.15);
}
.carousel-arrows{
position:absolute;
inset:0;
pointer-events:none;
z-index:6;
}
.arrow{
position:absolute;
top:50%;
transform:translateY(-50%);
width:42px;
height:42px;
border-radius:50%;
background:rgba(255,255,255,0.88);
color:#222;
display:flex;
align-items:center;
justify-content:center;
font-size:20px;
font-weight:800;
cursor:pointer;
box-shadow:0 8px 20px rgba(0,0,0,0.12);
pointer-events:auto;
user-select:none;
}
.arrow-left{left:12px;}
.arrow-right{right:12px;}
.arrow-set{display:none;}
#about-slide-1:checked ~ .carousel-arrows .set-1,
#about-slide-2:checked ~ .carousel-arrows .set-2,
#about-slide-3:checked ~ .carousel-arrows .set-3{
display:block;
}
.about-content h2{
font-size:clamp(32px, 4vw, 48px);
color:var(--dark);
line-height:1;
margin-bottom:16px;
font-weight:700;
}
.about-content p{
font-size:16px;
color:#666;
margin-bottom:18px;
line-height:1.8;
font-weight:500;
}
.check-list{display:grid;gap:12px;}
.check-item{
background:var(--white);
padding:14px 16px;
border-radius:14px;
border:1px solid var(--border);
box-shadow:var(--shadow);
font-weight:600;
color:#333;
font-size:14px;
line-height:1.7;
}
.services-grid{
display:grid;
grid-template-columns:repeat(3, 1fr);
gap:22px;
}
.service-card{
background:var(--white);
border:1px solid var(--border);
border-radius:22px;
padding:0;
box-shadow:var(--shadow);
overflow:hidden;
display:flex;
flex-direction:column;
transition:transform 0.28s ease,box-shadow 0.28s ease;
}
.service-card:hover{
transform:translateY(-5px);
box-shadow:0 20px 45px rgba(20,43,111,0.12),0 8px 24px rgba(0,0,0,0.06);
}
.service-card-visual{
position:relative;
padding:0;
overflow:hidden;
aspect-ratio:16/10;
min-height:140px;
max-height:200px;
background:#e8e4e2;
border-bottom:1px solid rgba(234,216,216,0.85);
}
.service-card-visual::before{
content:'';
position:absolute;
inset:0;
background:linear-gradient(180deg, transparent 35%, rgba(23,23,23,0.25) 100%);
pointer-events:none;
z-index:1;
}
.service-card-visual::after{
content:'';
position:absolute;
inset:auto 14% 0;
height:3px;
border-radius:999px;
background:linear-gradient(90deg, transparent, var(--primary), transparent);
opacity:0.55;
z-index:2;
}
.service-card-img{
width:100%;
height:100%;
object-fit:cover;
object-position:center;
display:block;
}
.service-card-body{
padding:22px 24px 26px;
flex:1;
display:flex;
flex-direction:column;
}
.service-card h3{
color:var(--primary);
font-size:26px;
margin-bottom:10px;
font-weight:700;
line-height:1.1;
}
.service-card p{
color:#666;
margin-bottom:12px;
font-size:15px;
line-height:1.8;
font-weight:500;
}
.service-card-link{
display:inline-flex;
align-items:center;
gap:6px;
margin-top:auto;
font-weight:800;
color:var(--primary);
}
.service-card-link:hover{
color:#a81117;
}
.service-card ul{
padding-left:18px;
font-size:14px;
line-height:1.8;
font-weight:600;
margin-top:auto;
}
.service-card ul li{margin-bottom:8px;}
.service-card ul li::marker{color:var(--secondary);}
.before-after-grid{
display:grid;
grid-template-columns:repeat(2, 1fr);
gap:24px;
align-items:stretch;
}
.ba-card{
background:var(--white);
border-radius:24px;
overflow:hidden;
border:1px solid var(--border);
box-shadow:var(--shadow);
display:flex;
flex-direction:column;
}
.ba-images{
background:#1a1a1a;
padding:0;
line-height:0;
}
.ba-label-row{
display:flex;
justify-content:space-between;
align-items:center;
padding:10px 14px 8px;
background:#1a1a1a;
line-height:1.2;
}
.ba-label-row span{
font-size:11px;
font-weight:800;
letter-spacing:0.4px;
text-transform:uppercase;
padding:7px 12px;
border-radius:999px;
}
.ba-label-before{background:rgba(0,0,0,0.65);color:#fff;}
.ba-label-after{background:rgba(197,22,29,0.92);color:#fff;}
.ba-images img-comparison-slider.ba-ics{
display:block;
width:100%;
max-width:100%;
max-height:min(70vh,700px);
overflow:hidden;
--divider-width:3px;
--divider-color:#fff;
--divider-shadow:0 0 14px rgba(0,0,0,0.4);
--default-handle-width:48px;
--default-handle-color:#fff;
--default-handle-opacity:1;
--default-handle-shadow:0 4px 18px rgba(0,0,0,0.35);
}
.ba-images img-comparison-slider.ba-ics img{
object-fit:cover;
object-position:center center;
max-height:min(70vh,700px);
width:100%;
height:min(70vh,700px);
display:block;
}
.ba-hint{
font-size:12px;
font-weight:700;
color:rgba(255,255,255,0.8);
text-align:center;
padding:8px 12px 10px;
line-height:1.4;
background:#1a1a1a;
margin:0;
}
.ba-content{
padding:22px 22px 24px;
}
.ba-content h3{
color:var(--secondary);
margin-bottom:8px;
font-size:28px;
font-weight:700;
line-height:1;
}
.ba-content p{
font-size:15px;
color:#666;
line-height:1.7;
font-weight:500;
}
.why-grid{
display:grid;
grid-template-columns:repeat(4, 1fr);
gap:20px;
}
.why-card{
background:var(--white);
border:1px solid var(--border);
border-radius:22px;
box-shadow:var(--shadow);
padding:26px 20px;
text-align:center;
}
.why-icon{
width:68px;
height:68px;
border-radius:50%;
background:linear-gradient(135deg, rgba(197,22,29,0.10), rgba(20,43,111,0.12));
display:flex;
align-items:center;
justify-content:center;
margin:0 auto 16px;
font-size:28px;
}
.why-card h3{
font-size:27px;
color:var(--dark);
margin-bottom:8px;
font-weight:700;
line-height:1;
}
.why-card p{
font-size:14px;
color:#666;
line-height:1.7;
font-weight:500;
}
.reviews-wrap{
position:relative;
}
.review-carousel input{
display:none;
}
.review-slides{
position:relative;
min-height:320px;
}
.review-slide{
position:absolute;
inset:0;
opacity:0;
transition:opacity 0.4s ease;
display:grid;
grid-template-columns:1fr 1fr;
gap:22px;
}
#review-slide-1:checked ~ .review-slides .slide-1,
#review-slide-2:checked ~ .review-slides .slide-2,
#review-slide-3:checked ~ .review-slides .slide-3{
opacity:1;
z-index:2;
}
.review-card{
background:var(--white);
border:1px solid var(--border);
border-radius:22px;
padding:28px 24px;
box-shadow:var(--shadow);
}
.review-stars{
color:#f4b400;
font-size:22px;
letter-spacing:2px;
margin-bottom:14px;
font-weight:800;
}
.review-text{
font-size:16px;
color:#555;
line-height:1.9;
margin-bottom:18px;
min-height:110px;
}
.review-name{
font-size:28px;
color:var(--secondary);
margin-bottom:2px;
line-height:1;
}
.review-source{
font-size:13px;
font-weight:700;
color:#888;
text-transform:uppercase;
letter-spacing:0.8px;
}
.review-arrows{
position:absolute;
inset:0;
pointer-events:none;
z-index:5;
}
.review-arrow-set{
display:none;
}
#review-slide-1:checked ~ .review-arrows .set-1,
#review-slide-2:checked ~ .review-arrows .set-2,
#review-slide-3:checked ~ .review-arrows .set-3{
display:block;
}
.review-arrow{
position:absolute;
top:50%;
transform:translateY(-50%);
width:42px;
height:42px;
border-radius:50%;
background:rgba(255,255,255,0.95);
color:#222;
display:flex;
align-items:center;
justify-content:center;
font-size:20px;
font-weight:800;
cursor:pointer;
box-shadow:0 8px 20px rgba(0,0,0,0.12);
pointer-events:auto;
user-select:none;
}
.review-arrow-left{left:-10px;}
.review-arrow-right{right:-10px;}
.review-dots{
display:flex;
justify-content:center;
gap:8px;
margin-top:26px;
}
.review-dots label{
width:11px;
height:11px;
border-radius:50%;
background:#e1cfcf;
cursor:pointer;
transition:0.3s ease;
}
#review-slide-1:checked ~ .review-dots label[for='review-slide-1'],
#review-slide-2:checked ~ .review-dots label[for='review-slide-2'],
#review-slide-3:checked ~ .review-dots label[for='review-slide-3']{
background:var(--primary);
transform:scale(1.15);
}
.contact-section{
background:linear-gradient(180deg, #ffffff 0%, #fff6f6 100%);
}
.contact-grid{
display:grid;
grid-template-columns:0.9fr 1.1fr;
gap:24px;
}
.contact-card, .map-card{
background:var(--white);
border:1px solid var(--border);
border-radius:24px;
padding:26px;
box-shadow:var(--shadow);
}
.contact-card h3, .map-card h3{
font-size:34px;
color:var(--primary);
margin-bottom:16px;
font-weight:700;
line-height:1;
}
.info-item{
padding:16px 0;
border-bottom:1px solid #eee;
font-size:15px;
line-height:1.7;
font-weight:500;
}
.info-item:last-child{
border-bottom:none;
padding-bottom:0;
}
.info-item strong{
display:block;
color:var(--dark);
margin-bottom:5px;
font-weight:800;
}
.map-embed-wrap{
width:100%;
max-width:100%;
min-height:380px;
border-radius:16px;
overflow:hidden;
border:1px solid #e7e7e7;
background:#f8f8f8;
}
.map-embed-wrap iframe{
display:block;
width:100%;
max-width:100%;
height:380px;
border:0;
}
@media (max-width:768px){
.map-embed-wrap{
min-height:260px;
}
.map-embed-wrap iframe{
height:260px;
}
}
.cta{
background:linear-gradient(135deg, var(--primary), #8f0e13);
color:var(--white);
border-radius:28px;
padding:40px;
display:grid;
grid-template-columns:1.1fr 0.9fr;
gap:20px;
align-items:center;
box-shadow:var(--shadow);
}
.cta h2{
font-size:clamp(32px, 4vw, 48px);
line-height:1;
margin-bottom:12px;
font-weight:700;
}
.cta p{
color:rgba(255,255,255,0.92);
font-size:15px;
line-height:1.7;
font-weight:500;
}
.cta-actions{
display:flex;
justify-content:flex-start;
gap:12px;
flex-wrap:wrap;
}
.cta .btn{
background:var(--white);
color:var(--primary);
box-shadow:none;
}
.faq{
display:grid;
gap:16px;
max-width:800px;
margin:auto;
}
details.faq-item{
background:linear-gradient(145deg,#ffffff 0%,#fffbfb 100%);
border:1px solid rgba(234,216,216,0.95);
border-radius:18px;
overflow:hidden;
box-shadow:0 4px 18px rgba(0,0,0,0.05);
transition:border-color 0.25s ease,box-shadow 0.25s ease,background 0.25s ease;
}
details.faq-item:hover{
border-color:rgba(197,22,29,0.22);
box-shadow:0 10px 28px rgba(20,43,111,0.09);
}
details.faq-item[open]{
border-color:rgba(20,43,111,0.2);
background:linear-gradient(145deg,#ffffff 0%,#f8f9ff 55%,#fffafa 100%);
box-shadow:0 14px 36px rgba(20,43,111,0.1);
}
details.faq-item summary{
cursor:pointer;
font-weight:800;
color:var(--dark);
list-style:none;
font-size:16px;
line-height:1.35;
display:flex;
align-items:center;
gap:16px;
padding:20px 22px 20px 20px;
position:relative;
user-select:none;
-webkit-tap-highlight-color:transparent;
}
details.faq-item summary:focus-visible{
outline:2px solid var(--primary);
outline-offset:2px;
border-radius:12px;
}
details.faq-item summary::-webkit-details-marker{display:none;}
details.faq-item summary::marker{content:'';}
.faq-num{
flex-shrink:0;
display:inline-flex;
align-items:center;
justify-content:center;
min-width:40px;
height:40px;
border-radius:12px;
font-size:13px;
font-weight:800;
font-family:'Manrope',Arial,sans-serif;
letter-spacing:0.02em;
color:#fff;
background:linear-gradient(145deg,var(--primary),#9e1218);
box-shadow:0 4px 12px rgba(197,22,29,0.35);
}
.faq-q{
flex:1;
padding-right:8px;
}
details.faq-item summary::after{
content:'';
flex-shrink:0;
width:10px;
height:10px;
margin-left:auto;
border-right:2.5px solid var(--primary);
border-bottom:2.5px solid var(--primary);
transform:rotate(45deg);
transition:transform 0.3s ease;
}
details.faq-item[open] summary::after{
transform:rotate(225deg);
margin-top:4px;
}
.faq-answer{
padding:0 22px 20px 76px;
border-top:1px solid rgba(234,216,216,0.65);
margin:0;
}
details.faq-item .faq-answer p{
margin:0;
padding-top:16px;
color:#555;
font-size:15px;
line-height:1.75;
font-weight:500;
}
details.faq-item .faq-answer p a{
color:var(--secondary);
font-weight:700;
}
footer{
background:var(--secondary);
color:rgba(255,255,255,0.88);
text-align:center;
padding:28px 0 95px;
font-size:14px;
line-height:1.8;
font-weight:500;
}
.site-footer{
background:linear-gradient(145deg,#0e1f52 0%,#142b6f 48%,#0e1f52 100%);
color:rgba(255,255,255,0.9);
padding:55px 0 15px;
text-align:left;
}
.footer-top{
display:grid;
grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
gap:24px;
align-items:start;
padding-bottom:28px;
border-bottom:1px solid rgba(255,255,255,0.16);
}
.footer-brand h3{font-size:36px;line-height:1;color:#fff;margin-bottom:10px;}
.footer-brand p{font-size:14px;line-height:1.8;font-weight:500;color:rgba(255,255,255,0.86);max-width:560px;}
.footer-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;}
.footer-actions .btn{box-shadow:none;}
.footer-actions .btn-outline{color:#fff;border-color:rgba(255,255,255,0.7);}
.footer-actions .btn-outline:hover{
background:var(--primary);
border-color:var(--primary);
color:#fff;
}
.footer-cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;padding:24px 0 18px;}
.footer-col h4{font-size:22px;line-height:1;color:#fff;margin-bottom:12px;}
.footer-col a,.footer-col p{display:block;font-size:14px;line-height:1.8;font-weight:600;color:rgba(255,255,255,0.86);margin-bottom:6px;}
.footer-col a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px;}
.footer-bottom{padding-top:16px;border-top:1px solid rgba(255,255,255,0.12);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
.footer-bottom p{font-size:13px;line-height:1.7;color:rgba(255,255,255,0.74);font-weight:500;}
.sticky-bar{
position:fixed;
left:0;
right:0;
bottom:0;
z-index:999;
background:rgba(255,255,255,0.98);
border-top:1px solid #e8e8e8;
padding:10px 12px;
display:none;
}
.sticky-wrap{
display:grid;
grid-template-columns:1fr 1fr;
gap:10px;
width:min(96%, 560px);
margin:auto;
}
.sticky-btn{
display:block;
text-align:center;
padding:13px 14px;
border-radius:999px;
font-weight:800;
font-size:14px;
}
.call-btn{background:var(--primary);color:var(--white);}
.form-btn{background:#25d366;color:#fff;}
.blogger-section-dummy{display:none;}
@media (max-width:1100px){
.hero-grid,.about-wrap,.contact-grid,.cta{grid-template-columns:1fr;}
.hero-copy,.hero-form-card{justify-self:center;}
.hero-copy{max-width:min(560px,100%);}
.hero-form-card{max-width:min(520px,100%);transform:none;}
.services-grid{grid-template-columns:repeat(2, 1fr);}
.why-grid{grid-template-columns:repeat(2, 1fr);}
}
@media (max-width:768px){
.topbar{
padding:8px 0;
font-size:12px;
}
.topbar-wrap{
gap:6px;
justify-content:center;
text-align:center;
}
.nav{
padding:10px 0;
position:relative;
flex-wrap:wrap;
align-items:center;
justify-content:space-between;
gap:8px;
}
.brand{
justify-content:flex-start;
}
.nav-toggle,
.navbar-toggler{
display:inline-flex;
margin-left:auto;
}
.nav-links{
display:flex;
flex-direction:column;
gap:12px;
width:100%;
align-items:stretch;
max-height:0;
overflow:hidden;
opacity:0;
pointer-events:none;
padding:0;
transition:max-height 0.28s ease, opacity 0.22s ease, padding 0.22s ease;
}
.nav-links.show{
display:flex;
max-height:80vh;
opacity:1;
pointer-events:auto;
padding:10px 0 4px;
}
.nav-links > ul.menu{
display:flex !important;
flex-direction:column;
gap:0;
width:100%;
margin:0;
padding:10px 0;
list-style:none;
background:#fff;
border:1px solid #ebebeb;
border-radius:12px;
box-shadow:0 12px 30px rgba(0,0,0,0.08);
}
.nav-links > ul.menu{
display:flex !important;
flex-direction:column;
gap:0;
width:100%;
}
.nav-links > ul.menu li{
display:block;
border-bottom:1px solid #f0f0f0;
}
.nav-links > ul.menu li:last-child{
border-bottom:none;
}
.nav-links > ul.menu a{
display:block;
text-align:left;
padding:12px 14px;
border-radius:0;
background:transparent;
font-size:14px;
}
.nav-links .btn{
width:100%;
margin-top:2px;
justify-content:center;
}
.brand img{height:52px;}
.hero{padding:40px 0 48px;min-height:unset;}
.hero h1{font-size:clamp(32px,8vw,52px);}
.hero-points,.grid-2,.services-grid,.before-after-grid,.why-grid,.quick-contact{grid-template-columns:1fr;}
.hero-form-top{
padding:20px 18px;
}
.hero-form-top h3{
font-size:30px;
}
.form-wrap{
padding:16px;
}
.service-card-body{
padding:18px 16px 20px;
}
.service-card h3{
font-size:24px;
}
.ba-content{
padding:18px 16px 20px;
}
.ba-content h3{
font-size:24px;
}
.contact-card, .map-card{
padding:18px;
}
.cta{
padding:22px 16px;
border-radius:18px;
}
.cta-actions .btn{
width:100%;
}
.carousel{height:260px;}
.carousel-slide img{height:260px;}
.review-slides{min-height:unset;}
.review-slide{
position:relative;
grid-template-columns:1fr;
display:none;
}
#review-slide-1:checked ~ .review-slides .slide-1,
#review-slide-2:checked ~ .review-slides .slide-2,
#review-slide-3:checked ~ .review-slides .slide-3{
display:grid;
}
.review-text{min-height:auto;}
.review-arrow-left{left:6px;}
.review-arrow-right{right:6px;}
.sticky-bar{display:block;}
footer{padding-bottom:110px;}
.hero h1{line-height:1;}
.ba-images{padding:12px;}
.arrow,.review-arrow{
width:36px;
height:36px;
font-size:18px;
}
details.faq-item summary{padding:16px 14px;font-size:15px;}
.faq-num{min-width:36px;height:36px;font-size:11px;border-radius:10px;}
.faq-answer{padding:0 16px 16px 62px;}
.site-footer{padding:40px 0 110px;}
.footer-top,.footer-cols{grid-template-columns:1fr;}
.footer-actions{justify-content:flex-start;}
.footer-bottom{display:block;}
.footer-bottom p{margin-bottom:6px;}
}
@media (max-width:480px){
.container{
width:min(94%, var(--max));
}
section{
padding:56px 0;
}
.hero{
padding:30px 0 36px;
}
.hero h1{
font-size:clamp(28px,9.2vw,42px);
}
.hero p{
font-size:14px;
line-height:1.65;
}
.hero-btns .btn{
width:100%;
}
.section-title{
margin-bottom:28px;
}
.section-title h2{
line-height:1.08;
}
.review-card{
padding:20px 16px;
}
.review-name{
font-size:24px;
}
.about-content h2{
font-size:clamp(28px,8vw,38px);
}
.about-mast-title{
font-size:clamp(30px,9vw,40px);
}
.about-mast-lead{
font-size:15px;
line-height:1.65;
}
.contact-form-inner{
padding:22px 16px 24px 20px;
}
}

.page-hero{
background:linear-gradient(135deg, var(--secondary) 0%, #1e3a7a 45%, var(--secondary) 100%);
color:#fff;
padding:44px 0 40px;
text-align:center;
}
.page-hero .tag{
margin-bottom:14px;
background:rgba(255,255,255,0.14);
color:#fff;
border-color:rgba(255,255,255,0.28);
}
.page-hero h1{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(32px,5vw,48px);
margin-bottom:12px;
font-weight:700;
line-height:1.05;
color:#fff;
}
.page-hero p{
opacity:0.92;
max-width:640px;
margin:0 auto;
font-size:16px;
font-weight:500;
color:rgba(255,255,255,0.95);
line-height:1.65;
}
.breadcrumb{
font-size:13px;
font-weight:700;
color:rgba(255,255,255,0.75);
margin-bottom:12px;
letter-spacing:0.02em;
}
.breadcrumb a{
color:#fff;
text-decoration:underline;
text-underline-offset:3px;
font-weight:800;
}
.nav-links a.active{color:var(--primary);}
.prose-block{max-width:720px;margin:0 auto;}
.prose-block p{font-size:16px;color:#555;line-height:1.85;margin-bottom:16px;font-weight:500;}
.service-split{
display:grid;
grid-template-columns:minmax(0,1fr) minmax(0,0.95fr);
gap:clamp(24px,4vw,42px);
align-items:center;
}
.service-split--left .service-split-media{order:1;}
.service-split--left > :not(.service-split-media){order:2;}
.service-split--right .service-split-media{order:2;}
.service-split--right > :not(.service-split-media){order:1;}
.service-split-media img{
width:100%;
height:clamp(260px,32vw,420px);
object-fit:cover;
object-position:center;
border-radius:var(--radius);
box-shadow:var(--shadow);
}
.service-split .prose-block{
max-width:none;
margin:0;
}
.service-split .section-title{
margin-bottom:22px;
}
@media (max-width:991px){
.service-split{
grid-template-columns:1fr;
}
.service-split--left .service-split-media,
.service-split--right .service-split-media,
.service-split--left > :not(.service-split-media),
.service-split--right > :not(.service-split-media){
order:initial;
}
}
.section-muted{background:#faf7f7;}
.gallery-extra{margin-top:28px;}

.about-mast{
padding:clamp(40px,6vw,72px) 0 clamp(48px,7vw,88px);
background:
radial-gradient(ellipse 70% 45% at 95% 5%, rgba(197,22,29,0.07), transparent 55%),
linear-gradient(180deg, #ffffff 0%, var(--light) 55%, #fff8f6 100%);
border-bottom:1px solid rgba(234,216,216,0.65);
}
.about-mast-grid{
display:grid;
grid-template-columns:minmax(0,1.05fr) minmax(0,0.95fr);
gap:clamp(28px,5vw,52px);
align-items:center;
}
.about-breadcrumb{
font-size:13px;
font-weight:700;
color:#8a8a8a;
margin-bottom:18px;
letter-spacing:0.02em;
}
.about-breadcrumb a{
color:var(--secondary);
text-decoration:none;
border-bottom:1px solid rgba(20,43,111,0.25);
transition:border-color 0.2s ease,color 0.2s ease;
}
.about-breadcrumb a:hover{
color:var(--primary);
border-bottom-color:rgba(197,22,29,0.45);
}
.about-mast-kicker{
font-size:12px;
letter-spacing:0.14em;
text-transform:uppercase;
font-weight:800;
color:var(--primary);
margin-bottom:12px;
}
.about-mast-title{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(36px,5.5vw,58px);
line-height:1.06;
color:var(--dark);
font-weight:700;
margin-bottom:18px;
max-width:18ch;
}
.about-mast-title .accent{
display:block;
font-style:italic;
font-weight:600;
color:var(--secondary);
margin-top:6px;
font-size:0.92em;
}
.about-mast-title-bar{
width:48px;
height:4px;
border-radius:999px;
background:linear-gradient(90deg, var(--primary), rgba(197,22,29,0.35));
margin-bottom:22px;
}
.about-mast-lead{
font-size:17px;
line-height:1.78;
color:#555;
margin-bottom:26px;
max-width:34rem;
font-weight:500;
}
.about-mast-stats{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:12px;
list-style:none;
margin:0 0 26px;
padding:0;
}
.about-mast-stats li{
background:var(--white);
border:1px solid var(--border);
border-radius:var(--radius-sm);
padding:14px 14px 16px;
box-shadow:0 6px 20px rgba(20,43,111,0.06);
}
.about-mast-stats strong{
display:block;
font-size:14px;
color:var(--dark);
margin-bottom:4px;
font-weight:800;
font-family:'Manrope',Arial,sans-serif;
}
.about-mast-stats span{
font-size:12px;
color:#777;
font-weight:600;
line-height:1.45;
}
.about-mast-actions{
display:flex;
flex-wrap:wrap;
gap:12px;
align-items:center;
}
.about-mast-visual{
position:relative;
justify-self:end;
max-width:480px;
width:100%;
}
.about-mast-frame{
border-radius:22px;
overflow:hidden;
box-shadow:
0 4px 6px rgba(0,0,0,0.04),
0 22px 48px rgba(20,43,111,0.14);
border:1px solid rgba(255,255,255,0.95);
background:#e8e4e2;
}
.about-mast-frame img{
width:100%;
height:min(440px,58vh);
object-fit:cover;
object-position:center;
display:block;
}
.about-mast-badge{
position:absolute;
left:0;
bottom:24px;
background:var(--secondary);
color:#fff;
padding:11px 18px 11px 16px;
border-radius:0 999px 999px 0;
font-size:13px;
font-weight:800;
box-shadow:0 10px 28px rgba(20,43,111,0.25);
max-width:calc(100% - 24px);
}
.about-mast-badge span{
display:block;
font-size:11px;
font-weight:700;
opacity:0.88;
margin-top:2px;
letter-spacing:0.02em;
}
.about-story-section{
padding:clamp(56px,8vw,80px) 0 clamp(48px,7vw,64px);
background:linear-gradient(180deg,#ffffff 0%,var(--light) 100%);
border-top:1px solid rgba(234,216,216,0.55);
}
.about-story-head{
max-width:680px;
margin:0 auto 40px;
padding:0 12px;
text-align:center;
}
.about-story-head .labelish{
display:inline-block;
font-size:12px;
letter-spacing:0.14em;
text-transform:uppercase;
font-weight:800;
color:var(--primary);
margin-bottom:14px;
}
.about-story-head h2{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(28px,3.6vw,42px);
color:var(--dark);
font-weight:700;
line-height:1.18;
margin-bottom:14px;
}
.about-story-head p{
font-size:16px;
color:#5c5c5c;
line-height:1.75;
font-weight:500;
margin:0;
}
.about-pillars{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:20px;
max-width:920px;
margin:0 auto;
}
.about-pillar{
display:grid;
grid-template-columns:auto 1fr;
gap:16px 18px;
align-items:start;
background:var(--white);
border:1px solid rgba(234,216,216,0.95);
border-radius:20px;
border-left:4px solid var(--primary);
padding:22px 22px 24px;
box-shadow:0 4px 20px rgba(20,43,111,0.06);
transition:box-shadow 0.25s ease,border-color 0.25s ease;
}
.about-pillar:hover{
box-shadow:0 12px 36px rgba(20,43,111,0.1);
border-color:rgba(197,22,29,0.2);
}
.about-pillar-num{
flex-shrink:0;
width:48px;
height:48px;
border-radius:14px;
display:flex;
align-items:center;
justify-content:center;
font-size:14px;
font-weight:800;
font-family:'Manrope',Arial,sans-serif;
color:#fff;
background:linear-gradient(145deg,var(--secondary),#23479d);
box-shadow:0 4px 14px rgba(20,43,111,0.2);
}
.about-pillar h3{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(1.25rem,2vw,1.45rem);
color:var(--dark);
font-weight:700;
margin-bottom:8px;
line-height:1.25;
}
.about-pillar p{
font-size:14px;
color:#555;
line-height:1.75;
font-weight:500;
margin:0;
}
@media (max-width:700px){
.about-pillars{
grid-template-columns:1fr;
}
}
.about-why-editorial{
position:relative;
padding:clamp(56px,8vw,88px) 0 clamp(64px,10vw,92px);
background:var(--light);
border-top:1px solid rgba(234,216,216,0.65);
}
.about-why-editorial::before{
content:'';
display:block;
width:min(160px,40%);
height:3px;
margin:0 auto clamp(40px,6vw,56px);
border-radius:999px;
background:linear-gradient(90deg, var(--primary), var(--secondary));
opacity:0.9;
}
.about-why-editorial-inner{
display:grid;
grid-template-columns:minmax(240px,340px) minmax(0,1fr);
gap:clamp(36px,6vw,72px);
align-items:start;
}
.about-why-header-col{
position:relative;
padding-left:20px;
border-left:4px solid var(--primary);
}
.about-why-label{
font-size:11px;
letter-spacing:0.18em;
text-transform:uppercase;
font-weight:800;
color:var(--primary);
margin:0 0 14px;
}
.about-why-headline{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(2rem,3.8vw,2.75rem);
font-weight:700;
line-height:1.12;
color:var(--dark);
margin:0 0 16px;
letter-spacing:-0.02em;
}
.about-why-deck{
font-size:16px;
line-height:1.75;
color:#5a5a5a;
font-weight:500;
margin:0;
max-width:32em;
}
.about-why-steps{
list-style:none;
margin:0;
padding:0;
display:flex;
flex-direction:column;
gap:0;
}
.about-why-step{
display:grid;
grid-template-columns:52px minmax(0,1fr);
gap:clamp(16px,3vw,28px);
align-items:start;
padding:clamp(22px,3.5vw,28px) 0;
border-bottom:1px solid rgba(234,216,216,0.85);
}
.about-why-step:first-child{
padding-top:0;
}
.about-why-step:last-child{
border-bottom:none;
padding-bottom:0;
}
.about-why-step-index{
font-family:'Manrope',Arial,sans-serif;
font-size:13px;
font-weight:800;
letter-spacing:0.06em;
color:#fff;
background:linear-gradient(145deg, var(--secondary), #23479d);
width:52px;
height:52px;
border-radius:14px;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 6px 18px rgba(20,43,111,0.22);
flex-shrink:0;
transition:transform 0.22s ease,box-shadow 0.22s ease;
}
.about-why-step:hover .about-why-step-index{
transform:translateY(-2px);
box-shadow:0 10px 24px rgba(20,43,111,0.28);
}
.about-why-step-title{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(1.35rem,2vw,1.6rem);
font-weight:700;
color:var(--dark);
line-height:1.2;
margin:0 0 10px;
}
.about-why-step-body p{
font-size:15px;
line-height:1.78;
color:#555;
font-weight:500;
margin:0;
max-width:48em;
}
@media (max-width:900px){
.about-why-editorial-inner{
grid-template-columns:1fr;
gap:32px;
}
.about-why-header-col{
padding-left:18px;
}
}
@media (max-width:520px){
.about-why-step{
grid-template-columns:44px minmax(0,1fr);
gap:14px;
}
.about-why-step-index{
width:44px;
height:44px;
font-size:12px;
border-radius:12px;
}
}
@media (max-width:960px){
.about-mast-grid{
grid-template-columns:1fr;
}
.about-mast-visual{
justify-self:center;
max-width:420px;
}
.about-mast-stats{
grid-template-columns:1fr;
}
.about-mast-title{max-width:none;}
}
@media (max-width:768px){
.about-mast{padding-top:32px;}
.about-mast-frame img{height:min(300px,52vh);}
.about-mast-badge{font-size:12px;padding:9px 14px 9px 12px;}
.about-pillar{
grid-template-columns:1fr;
text-align:left;
padding:20px 18px 22px;
}
.about-pillar-num{
width:44px;
height:44px;
font-size:13px;
}
}

.reviews-page-section{
padding:56px 0 72px;
}
.reviews-grid{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:22px;
align-items:stretch;
}
.reviews-page .reviews-grid .review-card{
display:flex;
flex-direction:column;
height:100%;
margin:0;
padding:26px 24px 28px;
border-radius:22px;
border:1px solid rgba(234,216,216,0.95);
background:linear-gradient(165deg,#ffffff 0%,#fffbfb 100%);
box-shadow:0 4px 22px rgba(20,43,111,0.07);
transition:transform 0.25s ease,box-shadow 0.25s ease,border-color 0.25s ease;
}
.reviews-page .reviews-grid .review-card:hover{
transform:translateY(-3px);
box-shadow:0 14px 40px rgba(20,43,111,0.11);
border-color:rgba(197,22,29,0.15);
}
.reviews-page .reviews-grid .review-stars{
margin-bottom:14px;
}
.reviews-page .reviews-grid .review-text{
flex:1 1 auto;
min-height:0;
margin-bottom:16px;
}
@media (max-width:768px){
.reviews-grid{
grid-template-columns:1fr;
gap:16px;
}
}

.contact-page{
background:var(--light);
}
.contact-mast{
background:
radial-gradient(ellipse 80% 80% at 100% 0%, rgba(197,22,29,0.06), transparent 50%),
linear-gradient(180deg,#ffffff 0%,var(--light) 100%);
border-bottom:1px solid rgba(234,216,216,0.65);
padding:clamp(36px,6vw,52px) 0 clamp(40px,6vw,56px);
}
.contact-mast-inner{
display:grid;
grid-template-columns:minmax(0,1fr) minmax(260px,340px);
gap:clamp(24px,4vw,40px);
align-items:end;
}
.contact-mast-breadcrumb{
font-size:13px;
font-weight:700;
margin:0 0 12px;
}
.contact-mast-breadcrumb a{
color:var(--secondary);
text-decoration:none;
border-bottom:1px solid rgba(20,43,111,0.25);
}
.contact-mast-breadcrumb a:hover{
color:var(--primary);
border-bottom-color:rgba(197,22,29,0.45);
}
.contact-mast-title{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(2.25rem,5vw,3.25rem);
font-weight:700;
line-height:1.05;
color:var(--dark);
margin:0 0 14px;
letter-spacing:-0.02em;
}
.contact-mast-lead{
font-size:17px;
line-height:1.7;
color:#555;
font-weight:500;
margin:0;
max-width:36em;
}
.contact-mast-card{
background:var(--white);
border:1px solid var(--border);
border-radius:20px;
padding:22px 22px 24px;
box-shadow:0 12px 40px rgba(20,43,111,0.08);
text-align:center;
}
.contact-mast-label{
font-size:11px;
letter-spacing:0.14em;
text-transform:uppercase;
font-weight:800;
color:var(--primary);
margin:0 0 8px;
}
.contact-mast-tel{
display:block;
font-size:clamp(1.35rem,2.5vw,1.6rem);
font-weight:800;
font-family:'Manrope',Arial,sans-serif;
color:var(--secondary);
margin-bottom:8px;
}
.contact-mast-tel:hover{
color:var(--primary);
}
.contact-mast-note{
font-size:13px;
color:#777;
font-weight:600;
margin:0 0 16px;
line-height:1.45;
}
.contact-mast-btn{
width:100%;
justify-content:center;
}
.contact-hub{
padding:clamp(40px,6vw,64px) 0 clamp(48px,8vw,72px);
}
.contact-hub-inner{
display:grid;
grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
gap:clamp(28px,4vw,44px);
align-items:start;
}
.contact-detail-card{
background:var(--white);
border:1px solid rgba(234,216,216,0.95);
border-radius:20px;
padding:26px 24px 28px;
box-shadow:0 4px 24px rgba(20,43,111,0.05);
margin-bottom:22px;
}
.contact-detail-title{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(1.5rem,2.2vw,1.75rem);
font-weight:700;
color:var(--dark);
margin:0 0 20px;
padding-bottom:16px;
border-bottom:1px solid rgba(234,216,216,0.85);
}
.contact-detail-list{
list-style:none;
margin:0;
padding:0;
}
.contact-detail-row{
display:grid;
gap:6px;
padding:16px 0;
border-bottom:1px solid rgba(234,216,216,0.65);
}
.contact-detail-row:last-child{
border-bottom:none;
padding-bottom:0;
}
.contact-detail-key{
font-size:12px;
font-weight:800;
letter-spacing:0.06em;
text-transform:uppercase;
color:var(--primary);
}
.contact-detail-val{
font-size:15px;
line-height:1.65;
font-weight:500;
color:#444;
}
.contact-detail-val a{
color:var(--secondary);
font-weight:700;
}
.contact-map-panel{
background:var(--white);
border:1px solid rgba(234,216,216,0.95);
border-radius:20px;
padding:20px 20px 22px;
box-shadow:0 4px 24px rgba(20,43,111,0.05);
}
.contact-map-heading{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:1.35rem;
font-weight:700;
color:var(--dark);
margin:0 0 14px;
}
.contact-map-frame{
border-radius:14px;
overflow:hidden;
border:1px solid #e5e5e5;
background:#eef0f5;
min-height:280px;
}
.contact-map-frame iframe{
display:block;
width:100%;
height:min(320px,42vh);
border:0;
}
.contact-form-shell{
position:relative;
background:var(--white);
border-radius:22px;
border:1px solid rgba(234,216,216,0.9);
box-shadow:
0 4px 6px rgba(0,0,0,0.02),
0 24px 56px rgba(20,43,111,0.1);
overflow:hidden;
}
.contact-form-accent{
position:absolute;
left:0;
top:0;
bottom:0;
width:5px;
background:linear-gradient(180deg,var(--primary),var(--secondary));
}
.contact-form-inner{
padding:clamp(26px,4vw,34px) clamp(22px,3vw,32px) clamp(28px,4vw,36px) clamp(28px,3vw,38px);
}
.contact-form-header{
margin-bottom:26px;
}
.contact-form-kicker{
font-size:11px;
letter-spacing:0.16em;
text-transform:uppercase;
font-weight:800;
color:var(--primary);
margin:0 0 10px;
}
.contact-form-title{
font-family:'Cormorant Garamond',Georgia,serif;
font-size:clamp(1.65rem,2.5vw,2rem);
font-weight:700;
color:var(--dark);
margin:0 0 10px;
line-height:1.15;
}
.contact-form-desc{
font-size:14px;
color:#666;
line-height:1.65;
font-weight:500;
margin:0;
}
.contact-page .contact-form{
display:grid;
grid-template-columns:1fr 1fr;
gap:18px 18px;
margin-top:4px;
}
.contact-field{
display:flex;
flex-direction:column;
gap:8px;
}
.contact-field--full{
grid-column:1/-1;
}
.contact-label{
font-size:13px;
font-weight:800;
color:var(--dark);
letter-spacing:0.02em;
}
.contact-optional{
font-weight:600;
color:#888;
font-size:12px;
}
.contact-page .contact-input{
width:100%;
padding:14px 16px;
font-size:14px;
border:1px solid #d4d4d4;
border-radius:12px;
background:#fafafa;
font-family:'Manrope',Arial,sans-serif;
font-weight:500;
transition:border-color 0.2s ease,box-shadow 0.2s ease,background 0.2s ease;
}
.contact-page .contact-input:hover{
border-color:#c5c5c5;
}
.contact-page .contact-input:focus{
outline:none;
border-color:var(--primary);
background:#fff;
box-shadow:0 0 0 3px rgba(197,22,29,0.12);
}
.contact-select{
cursor:pointer;
appearance:auto;
}
.contact-textarea{
min-height:120px;
resize:vertical;
line-height:1.55;
}
.contact-submit{
width:100%;
grid-column:1/-1;
margin-top:4px;
padding:16px 24px;
font-size:16px;
cursor:pointer;
border:none;
}
.contact-form-note{
grid-column:1/-1;
font-size:12px;
color:#888;
text-align:center;
margin:14px 0 0;
line-height:1.5;
}
.contact-bottom-cta{
background:linear-gradient(135deg,var(--secondary) 0%,#1a3568 100%);
color:#fff;
padding:28px 0;
border-top:1px solid rgba(255,255,255,0.08);
}
.contact-bottom-inner{
display:flex;
flex-wrap:wrap;
align-items:center;
justify-content:center;
gap:14px 24px;
text-align:center;
}
.contact-bottom-text{
font-size:16px;
font-weight:600;
margin:0;
color:rgba(255,255,255,0.95);
}
.contact-bottom-cta .btn{
background:#fff;
color:var(--secondary);
box-shadow:none;
}
.contact-bottom-cta .btn:hover{
background:var(--primary);
color:#fff;
}
.contact-bottom-link{
font-size:14px;
font-weight:700;
color:rgba(255,255,255,0.85);
text-decoration:underline;
text-underline-offset:3px;
}
.contact-bottom-link:hover{
color:#fff;
}
@media (max-width:960px){
.contact-mast-inner{
grid-template-columns:1fr;
}
.contact-mast-card{
max-width:400px;
}
.contact-hub-inner{
grid-template-columns:1fr;
}
.contact-form-shell{
max-width:560px;
margin-left:auto;
margin-right:auto;
}
}
@media (max-width:640px){
.contact-page .contact-form{
grid-template-columns:1fr;
}
.contact-field--full{
grid-column:auto;
}
.contact-map-frame iframe{
height:260px;
}
}

.home-why-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:20px;
}
.home-why-card{
background:#fff;
border:1px solid var(--border);
border-radius:var(--radius-sm);
padding:22px 18px;
box-shadow:var(--shadow);
}
.home-why-card-num{
display:inline-flex;
align-items:center;
justify-content:center;
width:40px;
height:40px;
border-radius:999px;
background:rgba(197,22,29,0.1);
color:var(--primary);
font-weight:800;
font-size:13px;
margin-bottom:12px;
}
.home-why-card h3{
font-size:26px;
line-height:1.1;
color:var(--dark);
margin-bottom:10px;
}
.home-process{
background:#fff;
}
.home-process-list{
display:grid;
gap:12px;
}
.home-process-step{
display:grid;
grid-template-columns:72px minmax(0,1fr);
gap:14px;
align-items:start;
padding:18px;
border:1px solid var(--border);
border-radius:16px;
background:linear-gradient(180deg,#fff 0%,#fff8f8 100%);
}
.home-process-index{
width:54px;
height:54px;
display:flex;
align-items:center;
justify-content:center;
border-radius:12px;
font-weight:800;
color:var(--primary);
background:rgba(197,22,29,0.08);
border:1px solid rgba(197,22,29,0.2);
}
.home-process-copy h3{
font-size:30px;
line-height:1;
margin:2px 0 8px;
color:var(--dark);
}
.home-process-copy p{
margin:0;
}
.home-blogs{
background:#fff;
}
.home-blogs-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:20px;
}
.home-blog-card{
background:#fff;
border:1px solid var(--border);
border-radius:var(--radius-sm);
overflow:hidden;
box-shadow:var(--shadow);
display:flex;
flex-direction:column;
}
.home-blog-thumb{
display:block;
aspect-ratio:16/9;
background:#f3f3f3;
}
.home-blog-thumb img{
width:100%;
height:100%;
object-fit:cover;
}
.home-blog-body{
padding:16px;
display:flex;
flex-direction:column;
gap:10px;
}
.home-blog-meta{
font-size:12px;
font-weight:700;
letter-spacing:0.4px;
text-transform:uppercase;
color:#8d8d8d;
margin:0;
}
.home-blog-body h3{
font-size:28px;
line-height:1.08;
margin:0;
color:var(--dark);
}
.home-blog-body p{
margin:0;
}
.home-blog-read{
font-weight:800;
color:var(--primary);
}
.home-blog-empty{
text-align:center;
font-weight:600;
}
@media (max-width:980px){
.home-why-grid,.home-blogs-grid{
grid-template-columns:repeat(2,minmax(0,1fr));
}
}
@media (max-width:768px){
.home-why-grid,.home-blogs-grid{
grid-template-columns:1fr;
}
.home-process-step{
grid-template-columns:56px minmax(0,1fr);
padding:14px;
}
.home-process-copy h3{
font-size:24px;
}
}

.blog-listing{
padding:48px 0 64px;
}
.blog-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:22px;
}
.blog-card{
background:#fff;
border:1px solid var(--border);
border-radius:16px;
overflow:hidden;
box-shadow:var(--shadow);
display:flex;
flex-direction:column;
}
.blog-card-thumb{
display:block;
aspect-ratio:16/9;
background:#f4f4f4;
}
.blog-card-thumb img{
width:100%;
height:100%;
object-fit:cover;
}
.blog-card-body{
padding:16px;
display:flex;
flex-direction:column;
gap:10px;
}
.blog-card-meta{
margin:0;
font-size:12px;
font-weight:700;
letter-spacing:0.05em;
text-transform:uppercase;
color:#8c8c8c;
}
.blog-card-body h2{
font-size:30px;
line-height:1.05;
margin:0;
}
.blog-card-body p{
margin:0;
}
.blog-card-link{
font-weight:800;
color:var(--primary);
}
.blog-pagination{
display:flex;
gap:8px;
justify-content:center;
margin-top:28px;
flex-wrap:wrap;
}
.blog-pagination .page-numbers{
display:inline-flex;
align-items:center;
justify-content:center;
min-width:40px;
height:40px;
padding:0 12px;
border-radius:999px;
border:1px solid #e0e0e0;
background:#fff;
font-weight:700;
}
.blog-pagination .current{
background:var(--primary);
border-color:var(--primary);
color:#fff;
}
.blog-empty{
text-align:center;
font-weight:600;
}
.blog-single{
padding-bottom:64px;
}
.blog-single-hero{
padding:34px 0 24px;
}
.blog-single-hero h1{
font-size:clamp(38px,5vw,58px);
line-height:0.98;
color:var(--dark);
margin:0 0 12px;
}
.blog-single-meta{
margin:0;
font-weight:700;
color:#6f6f6f;
}
.blog-single-wrap{
background:#fff;
border:1px solid var(--border);
border-radius:20px;
box-shadow:var(--shadow);
padding:20px;
}
.blog-single-thumb{
border-radius:14px;
overflow:hidden;
margin-bottom:20px;
}
.blog-single-thumb img{
width:100%;
height:auto;
}
.blog-single-content{
font-size:16px;
line-height:1.8;
color:#3f3f3f;
}
.blog-single-content h2,.blog-single-content h3{
margin:22px 0 10px;
color:var(--dark);
}
.blog-single-content p{
margin:0 0 14px;
}
.blog-single-content ul,.blog-single-content ol{
margin:0 0 14px 22px;
}
.reviews-shortcode-wrap{
margin-top:8px;
}
@media (max-width:980px){
.blog-grid{
grid-template-columns:repeat(2,minmax(0,1fr));
}
}
@media (max-width:768px){
.blog-grid{
grid-template-columns:1fr;
}
.blog-single-wrap{
padding:14px;
}
}
