:root{--color-bg:#F9F7F4;--color-text:#2C3E50;--color-text-muted:#7F8C8D;--color-primary:#2B3E50;--color-primary-hover:#1a4d67;--color-secondary:#D4A574;--color-divider:#E8E6E1;--shadow-sm:0 6px 18px rgba(0,0,0,.08);--shadow-md:0 12px 30px rgba(0,0,0,.12);--radius:10px;--radius-sm:6px;--anim:.6s ease}
html{scroll-behavior:smooth}
body{font-family:Inter,"Open Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--color-text);background:var(--color-bg)}
h1,h2,h3,h4{font-family:Montserrat,Raleway,Arial,sans-serif;color:var(--color-text)}
.btn-primary{background:var(--color-primary);border-color:var(--color-primary)}
.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:0 8px 24px rgba(26,77,103,.3)}
.btn-outline-secondary{border-color:var(--color-secondary);color:var(--color-secondary)}
.btn-outline-secondary:hover{background:var(--color-bg)}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(249,247,244,.85);backdrop-filter:saturate(1.2) blur(12px);border-bottom:1px solid var(--color-divider);box-shadow:0 8px 24px rgba(0,0,0,.06);padding-top:18px;padding-bottom:18px}
.site-header .container{padding-top:18px;padding-bottom:18px}
.site-header nav{display:flex;align-items:center;gap:28px}
.brand{font-weight:800;letter-spacing:.5px;font-size:1.25rem;line-height:1;color:var(--color-text)}
.brand i{color:var(--color-secondary);font-size:1.5rem}
.site-header a.link-secondary{font-size:1.125rem;font-weight:600;color:var(--color-text)!important;opacity:.92}
.site-header a.link-secondary:hover{opacity:1;text-decoration:underline;text-underline-offset:4px}
.site-header .btn.btn-primary{font-size:1.125rem;font-weight:700;padding:.625rem 1.125rem;border-radius:9999px;box-shadow:0 10px 22px rgba(43,62,80,.18)}
.site-header .btn.btn-primary.btn-sm{font-size:1.125rem;padding:.625rem 1.125rem}
.site-header .btn.btn-primary:hover{box-shadow:0 14px 26px rgba(26,77,103,.26)}
.site-header::after{content:"";display:block;position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(to right, transparent, rgba(212,165,116,.6), transparent)}

/* Premium header spacing tweaks for small screens */
@media (max-width:768px){
	.site-header{padding-top:16px;padding-bottom:16px}
	.site-header nav{gap:20px}
	.site-header a.link-secondary{font-size:1rem}
	.site-header .btn.btn-primary{font-size:1rem;padding:.55rem 1rem}
	.site-header .btn.btn-primary.btn-sm{font-size:1rem;padding:.55rem 1rem}
}
.hero{position:relative;min-height:60vh;display:flex;align-items:center;overflow:hidden}
.hero::before{content:none}
.hero-bg{position:absolute;inset:0;background:url('images/7.png') center/cover no-repeat;transform:translateZ(0)}
.hero[data-parallax="0.5"] .hero-bg{will-change:transform}
.hero .container{position:relative;z-index:2;color:#fff;padding-top:2rem !important;padding-bottom:2rem !important}
.hero-badges{gap:24px}
.hero-badge{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);background:rgba(0,0,0,.35)}
.hero-stats{position:relative;background:rgba(255,255,255,0.35);border:1px solid rgba(255,255,255,0.5);border-radius:14px;padding:20px 18px;box-shadow:0 12px 30px rgba(0,0,0,.10);backdrop-filter:blur(12px) saturate(1.2)}
.hero-stats__title{
	font-weight:800;
	letter-spacing:.4px;
	margin-bottom:18px;
	color:var(--color-text);
	font-size:1.5rem;
	text-align:center;
}
.hero-stats__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.hero-stat{background:rgba(255,255,255,0.45);border:1px solid rgba(232,230,225,0.9);border-radius:12px;padding:14px 12px;transition:transform .25s ease, box-shadow .25s ease, background .25s ease}
.hero-stat:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(0,0,0,.14);background:rgba(255,255,255,0.6)}
.hero-stat__value{font-family:Montserrat, Raleway, Arial, sans-serif;font-weight:800;font-size:2rem;line-height:1;color:var(--color-primary);text-shadow:0 2px 10px rgba(43,62,80,.12);transition:transform .25s ease}
.hero-stat:hover .hero-stat__value{transform:scale(1.03)}
.hero-stat__label{margin-top:6px;font-weight:600;color:var(--color-text);opacity:.9}
.section{padding:80px 0}
.section-muted{background:#fff}
.section-title{margin-bottom:18px}
.section-sub{color:var(--color-text-muted);max-width:720px}
.benefit{background:#fff;border:1px solid var(--color-divider);border-radius:var(--radius);padding:22px;height:100%;transition:transform .25s ease,box-shadow .25s ease}
.benefit:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.benefit i{color:var(--color-secondary)}
.portfolio-card{background:#fff;border:1px solid var(--color-divider);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.portfolio-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.portfolio-img{height:260px;object-fit:cover;width:100%;transition:transform .4s ease}
.portfolio-card:hover .portfolio-img{transform:scale(1.05)}
.badge-price{background:var(--color-secondary);color:#fff}
.svc-card{height:100%;border:1px solid var(--color-divider);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm)}
.svc-card.popular{outline:2px solid var(--color-secondary)}
.timeline{position:relative}
.timeline::before{content:"";position:absolute;top:22px;left:0;right:0;height:2px;background:var(--color-divider)}
.step{position:relative;text-align:center}
.step .dot{width:44px;height:44px;display:grid;place-items:center;border-radius:50%;background:var(--color-primary);color:#fff;margin:0 auto 10px;box-shadow:0 6px 16px rgba(43,62,80,.3)}
.testi{background:#fff;border:1px solid var(--color-divider);border-radius:var(--radius);padding:22px;height:100%}
.stars{color:#E6B800}
.accordion-button:not(.collapsed){color:var(--color-primary);background:#f4efe7}
.contact{background:#fff;border-top:1px solid var(--color-divider);border-bottom:1px solid var(--color-divider)}
.form-control:focus{box-shadow:0 0 0 .25rem rgba(43,62,80,.15);border-color:var(--color-primary)}
.final-cta{background:linear-gradient(135deg,#2B3E50 0%,#1a4d67 100%);color:#fff;border-radius:var(--radius)}
/* Ensure outline light buttons are white on dark CTA background */
.final-cta a.btn.btn-outline-light{color:#ffffff !important;border-color:#ffffff !important}
.final-cta a.btn.btn-outline-light:hover{background:transparent;color:#ffffff !important;border-color:#ffffff !important}
.final-cta a.btn.btn-outline-light:focus{box-shadow:0 0 0 .25rem rgba(255,255,255,.25) !important;color:#ffffff !important;border-color:#ffffff !important}
footer{border-top:1px solid var(--color-divider);background:#fff}
.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--anim),transform var(--anim)}
.revealed{opacity:1;transform:none}
@media (max-width:768px){.hero{min-height:52vh}.section{padding:56px 0}.portfolio-img{height:220px}}
@media (max-width:992px){
	.hero-stats{margin-top:8px}
}

/* === Accessibility contrast fixes (WCAG 2.1 AAA) === */
/* Error #1: Hero text contrast */
/* Обновлено: текст в hero — белый с тенью для читаемости */
.hero h1 { color: #FFFFFF !important; text-shadow: 0 2px 14px rgba(0,0,0,0.35), 0 1px 2px rgba(0,0,0,0.5); }
.hero .lead, .hero .text-white-50 { color: rgba(255,255,255,0.96) !important; text-shadow: 0 1px 10px rgba(0,0,0,0.3); }
/* Overlay отключен для избежания двойного затемнения */
/* .hero::before background removed */

/* Improve hero text legibility over image */
.hero .col-lg-7 { background: rgba(255,255,255,0.55); border-radius: 12px; padding: 24px; box-shadow: 0 12px 30px rgba(0,0,0,0.10); }
.hero h1 { text-shadow: 0 2px 14px rgba(0,0,0,0.35), 0 1px 2px rgba(0,0,0,0.5); }
.hero .lead { text-shadow: 0 1px 10px rgba(0,0,0,0.3); }
.hero .text-white-50 { color: rgba(255,255,255,0.86) !important; background: transparent !important; padding: 0; border-radius: 0; box-shadow: none; }

/* Error #2: Hero badges contrast */
.hero-badge { background: rgba(43,62,80,0.90) !important; padding: 10px 16px; border-radius: 6px; color: #FFFFFF; }
.hero-badge i { color: #D4A574; }

/* Error #3: Primary button visibility */
.btn-primary { color: #FFFFFF !important; background-color: #2B3E50 !important; border-color: #2B3E50 !important; font-weight: 600; }
.btn-primary:hover { background-color: #1a4d67 !important; border-color: #1a4d67 !important; box-shadow: 0 4px 12px rgba(43,62,80,0.40); }
.btn-primary:focus { box-shadow: 0 0 0 3px rgba(43,62,80,0.25) !important; }

/* Error #4: Section-muted background and text */
.section-muted { background-color: #F5F3F0 !important; }
.section-muted .text-muted { color: #5F6C73 !important; }
.section-muted p { color: #2C3E50; }
.section-muted h3 { color: #2B3E50; }

/* Error #5: Secondary (outline) button */
.btn-outline-secondary { color: #2B3E50 !important; border-color: #2B3E50 !important; }
.btn-outline-secondary:hover { background-color: #2B3E50 !important; color: #FFFFFF !important; }

/* Error #6: Links visibility */
a, .link-secondary { color: #2B3E50 !important; text-decoration: underline; text-decoration-color: #D4A574; text-underline-offset: 3px; }
a:hover { color: #D4A574 !important; }
.hero a { color: #FFFFFF; }

/* Error #7: Footer links on darker backgrounds */
footer a { color: #D4A574 !important; }
footer a:hover { color: #E8D4B8 !important; text-decoration: underline; }

/* Error #8: FAQ Accordion titles */
.accordion-button { color: #2C3E50 !important; font-weight: 500; background-color: #F9F7F4; }
.accordion-button:not(.collapsed) { background-color: #F5F3F0 !important; color: #D4A574 !important; }
.accordion-button:hover { background-color: #F5F3F0 !important; }

/* Error #9: Testimonials stars */
.stars { color: #E67E22 !important; font-weight: bold; font-size: 16px; }
.testi { background-color: #FFFFFF; }

/* Error #10: Badges (warning/popular and price) */
.text-bg-warning { background-color: #E67E22 !important; color: #FFFFFF !important; font-weight: 600; }
.badge-price { background-color: #D4A574 !important; color: #2B3E50 !important; }

/* Final override: полностью отключаем overlay псевдоэлемента hero */
.hero::before{content:none !important;display:none !important;background:none !important}

/* === Gallery lightbox tweaks === */
.portfolio-card[data-gallery]{cursor:pointer}
#imageGalleryModal .modal-body{background:rgba(0,0,0,0.95)}
#imageGalleryModal img{max-height:80vh;object-fit:contain}
@media (max-width:768px){#imageGalleryModal img{max-height:70vh}}

/* Caption and counter background white */
#imageGalleryModal #galleryCaption,
#imageGalleryModal #galleryCounter{background:#ffffff;border-radius:8px}

/* Mobile: blur the backdrop and remove black panel */
@media (max-width:768px){
	.modal-backdrop.show{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:rgba(255,255,255,0.3)!important}
	#imageGalleryModal .modal-content{background:transparent!important;box-shadow:none}
	#imageGalleryModal .modal-body{background:transparent!important}
	/* Center vertically filling the viewport */
	#imageGalleryModal .modal-body>.d-flex{min-height:100vh!important}
}


.text-secondary{
	    color: #2c3e50 !important;
}