/* =========================================================================
   Ky Cleaning Solutions — Design Tokens
   Brand colors are fixed (kelly green / royal blue / white / black text).
   Everything else (type, spacing, the signature "clean sweep" divider)
   was chosen specifically for a warm, friendly local cleaning business.
   ========================================================================= */
:root{
	--kycs-green:        #4CBB17;
	--kycs-green-dark:   #3C9412;
	--kycs-blue:         #4169E1;
	--kycs-blue-dark:    #2F4FB0;
	--kycs-white:        #FFFFFF;
	--kycs-text:         #1A1A1A;
	--kycs-text-muted:   #5C5C5C;
	--kycs-tint-green:   #EBF7E6;
	--kycs-tint-blue:    #ECF1FC;
	--kycs-border:       #E6E6E6;

	--kycs-font-display: 'Baloo 2', sans-serif;
	--kycs-font-body:    'Nunito Sans', sans-serif;

	--kycs-radius:       16px;
	--kycs-radius-sm:    10px;
	--kycs-shadow:       0 8px 24px rgba(26,26,26,0.08);
	--kycs-shadow-sm:    0 3px 10px rgba(26,26,26,0.06);
	--kycs-container:    1140px;
}

/* =========================================================================
   Reset & base
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
	margin:0;
	font-family:var(--kycs-font-body);
	color:var(--kycs-text);
	background:var(--kycs-white);
	line-height:1.6;
	font-size:17px;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3{
	font-family:var(--kycs-font-display);
	line-height:1.15;
	margin:0 0 .5em;
	font-weight:700;
}
h1{ font-size:clamp(2.1rem,5vw,3.1rem); }
h2{ font-size:clamp(1.6rem,3.5vw,2.2rem); }
h3{ font-size:1.2rem; }
p{ margin:0 0 1em; }
.kycs-container{
	max-width:var(--kycs-container);
	margin:0 auto;
	padding:0 24px;
}
.kycs-sr-only{
	position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0);
}
.kycs-skip-link{
	position:absolute; left:-9999px; top:0; background:var(--kycs-blue); color:#fff; padding:10px 16px; z-index:200;
}
.kycs-skip-link:focus{ left:8px; top:8px; }
:focus-visible{ outline:3px solid var(--kycs-blue-dark); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){
	*{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}

.kycs-icon{ width:1.2em; height:1.2em; flex-shrink:0; }
.kycs-icon--xl{ width:64px; height:64px; }

/* =========================================================================
   Buttons
   ========================================================================= */
.kycs-btn{
	display:inline-flex; align-items:center; gap:8px;
	font-family:var(--kycs-font-body); font-weight:800; font-size:.95rem;
	padding:12px 22px; border-radius:999px; border:2px solid transparent;
	cursor:pointer; transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
	white-space:nowrap;
}
.kycs-btn:hover{ transform:translateY(-1px); }
.kycs-btn--primary{ background:var(--kycs-green); color:#fff; box-shadow:var(--kycs-shadow-sm); }
.kycs-btn--primary:hover{ background:var(--kycs-green-dark); }
.kycs-btn--outline{ background:transparent; border-color:var(--kycs-blue); color:var(--kycs-blue-dark); }
.kycs-btn--outline:hover{ background:var(--kycs-tint-blue); }
.kycs-btn--ghost{ background:transparent; border-color:rgba(255,255,255,.7); color:#fff; }
.kycs-btn--ghost:hover{ background:rgba(255,255,255,.15); }
.kycs-btn--ghost-light{ background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.4); color:#fff; }
.kycs-btn--ghost-light:hover{ background:rgba(255,255,255,.22); }
.kycs-btn--lg{ padding:15px 28px; font-size:1.05rem; }

/* =========================================================================
   Header
   ========================================================================= */
.kycs-header{
	position:sticky; top:0; z-index:100; background:var(--kycs-white);
	border-bottom:1px solid var(--kycs-border);
}
.kycs-header__inner{
	display:flex; align-items:center; gap:24px; min-height:78px;
}
.kycs-brand{ margin-right:auto; }
.kycs-brand img{ max-height:56px; width:auto; }
.kycs-brand__text{
	font-family:var(--kycs-font-display); font-weight:700; font-size:1.35rem; color:var(--kycs-blue-dark);
}
.kycs-brand__text span{ color:var(--kycs-green-dark); }
.kycs-nav__list{ display:flex; gap:28px; }
.kycs-nav__list a{
	font-weight:700; font-size:.97rem; color:var(--kycs-text);
	padding:8px 2px; border-bottom:2px solid transparent;
}
.kycs-nav__list a:hover{ border-color:var(--kycs-green); }
.kycs-header__actions{ display:flex; align-items:center; gap:16px; }
.kycs-call-btn{ display:flex; align-items:center; gap:6px; font-weight:800; color:var(--kycs-blue-dark); }
.kycs-call-btn .kycs-icon{ color:var(--kycs-green); }
.kycs-nav-toggle{
	display:none; background:none; border:0; padding:6px; cursor:pointer; color:var(--kycs-text);
}
.kycs-nav-toggle .kycs-nav-toggle__close{ display:none; }
.kycs-nav-toggle[aria-expanded="true"] .kycs-nav-toggle__open{ display:none; }
.kycs-nav-toggle[aria-expanded="true"] .kycs-nav-toggle__close{ display:block; }

@media (max-width: 880px){
	.kycs-nav{
		position:absolute; top:100%; left:0; right:0; background:var(--kycs-white);
		border-bottom:1px solid var(--kycs-border); box-shadow:var(--kycs-shadow);
		display:none; padding:8px 0;
	}
	.kycs-nav.is-open{ display:block; }
	.kycs-nav__list{ flex-direction:column; gap:0; padding:8px 24px; }
	.kycs-nav__list a{ display:block; padding:14px 0; border-bottom:1px solid var(--kycs-border); }
	.kycs-header__actions .kycs-call-btn span{ display:none; }
	.kycs-nav-toggle{ display:block; }
}
@media (max-width: 560px){
	.kycs-header__actions .kycs-call-btn{ display:none; }
}

/* =========================================================================
   Hero + signature "clean sweep" divider
   ========================================================================= */
.kycs-hero{
	position:relative; background:linear-gradient(135deg, var(--kycs-tint-green) 0%, var(--kycs-tint-blue) 100%);
	padding:72px 0 110px;
	overflow:hidden;
}
.kycs-hero__inner{
	display:grid; grid-template-columns:1.1fr .9fr; align-items:center; gap:40px;
}
.kycs-hero__sub{ font-size:1.15rem; color:var(--kycs-text-muted); max-width:520px; }
.kycs-hero__actions{ display:flex; gap:14px; flex-wrap:wrap; margin:28px 0 18px; }
.kycs-hero__price-note{
	display:flex; align-items:center; gap:8px; font-weight:700; color:var(--kycs-green-dark); margin:0;
}
.kycs-hero-svg{ width:100%; max-width:380px; margin:0 auto; display:block; }

/* the signature element: a single soft diagonal "wipe" at the base of the
   hero, evoking a freshly cleaned swipe across the page. Used exactly once. */
.kycs-clean-sweep{
	position:absolute; left:0; right:0; bottom:-2px; height:70px;
	background:var(--kycs-white);
	clip-path:polygon(0 100%, 100% 100%, 100% 35%, 70% 65%, 40% 20%, 0 55%);
}

@media (max-width: 880px){
	.kycs-hero__inner{ grid-template-columns:1fr; text-align:center; }
	.kycs-hero__sub{ margin-inline:auto; }
	.kycs-hero__actions{ justify-content:center; }
	.kycs-hero__price-note{ justify-content:center; }
}

/* =========================================================================
   Trust bar
   ========================================================================= */
.kycs-trustbar{ background:var(--kycs-white); padding:28px 0; }
.kycs-trustbar__inner{
	display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
}
.kycs-trustbar__item{
	display:flex; align-items:center; gap:10px; font-weight:800; font-size:.95rem; color:var(--kycs-text);
}
.kycs-trustbar__item .kycs-icon{ color:var(--kycs-green); }

/* =========================================================================
   Generic sections
   ========================================================================= */
.kycs-section{ padding:80px 0; }
.kycs-section--tint-green{ background:var(--kycs-tint-green); }
.kycs-section--tint-blue{ background:var(--kycs-tint-blue); }
.kycs-section__head{ text-align:center; max-width:640px; margin:0 auto 44px; }
.kycs-section__foot{ text-align:center; margin-top:40px; }
.kycs-eyebrow{
	display:inline-block; font-weight:800; letter-spacing:.04em; text-transform:uppercase;
	font-size:.8rem; color:var(--kycs-blue-dark); margin-bottom:10px;
}
.kycs-eyebrow--light{ color:rgba(255,255,255,.85); }

/* page hero banners (non-home pages) */
.kycs-page-hero{ padding:64px 0 56px; color:#fff; text-align:center; }
.kycs-page-hero h1{ margin-bottom:.3em; }
.kycs-page-hero__sub{ max-width:560px; margin:0 auto; opacity:.95; }
.kycs-page-hero--green{ background:linear-gradient(135deg, var(--kycs-green-dark), var(--kycs-green)); }
.kycs-page-hero--blue{ background:linear-gradient(135deg, var(--kycs-blue-dark), var(--kycs-blue)); }

/* =========================================================================
   Services
   ========================================================================= */
.kycs-services-grid{
	display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.kycs-services-grid--full{ margin-bottom:48px; }
.kycs-service-card{
	background:#fff; border:1px solid var(--kycs-border); border-radius:var(--kycs-radius);
	padding:28px; box-shadow:var(--kycs-shadow-sm); transition:transform .15s ease, box-shadow .15s ease;
}
.kycs-service-card:hover{ transform:translateY(-3px); box-shadow:var(--kycs-shadow); }
.kycs-service-card__icon{
	width:52px; height:52px; border-radius:50%; background:var(--kycs-tint-green);
	display:flex; align-items:center; justify-content:center; color:var(--kycs-green-dark); margin-bottom:16px;
}
.kycs-service-card__icon .kycs-icon{ width:26px; height:26px; }
.kycs-service-card p{ color:var(--kycs-text-muted); margin-bottom:0; }

.kycs-pricing-banner{
	display:flex; align-items:center; gap:18px; flex-wrap:wrap;
	background:var(--kycs-tint-blue); border-radius:var(--kycs-radius); padding:26px 30px;
}
.kycs-pricing-banner .kycs-icon{ color:var(--kycs-blue); width:28px; height:28px; }
.kycs-pricing-banner p{ flex:1; min-width:220px; margin:0; font-weight:700; }

/* =========================================================================
   About preview (home) + About page
   ========================================================================= */
.kycs-about-preview{
	display:grid; grid-template-columns:.4fr 1fr; align-items:center; gap:44px;
}
.kycs-about-preview__art{
	width:140px; height:140px; border-radius:50%; background:var(--kycs-white);
	display:flex; align-items:center; justify-content:center; color:var(--kycs-blue); margin:0 auto;
	box-shadow:var(--kycs-shadow-sm);
}
.kycs-about-layout{ display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:flex-start; }
.kycs-about-layout__text p{ color:var(--kycs-text); }
.kycs-about-layout__photo img{ border-radius:var(--kycs-radius); box-shadow:var(--kycs-shadow); }
.kycs-photo-placeholder{
	display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center;
	background:var(--kycs-tint-green); border:2px dashed var(--kycs-green); border-radius:var(--kycs-radius);
	padding:40px 20px; color:var(--kycs-green-dark); font-weight:700; min-height:240px;
}
.kycs-photo-placeholder--wide{ min-height:200px; }

.kycs-values-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.kycs-value-card{ background:#fff; border-radius:var(--kycs-radius); padding:26px; box-shadow:var(--kycs-shadow-sm); }
.kycs-value-card__icon{ color:var(--kycs-blue); margin-bottom:12px; }
.kycs-value-card__icon .kycs-icon{ width:30px; height:30px; }
.kycs-value-card p{ color:var(--kycs-text-muted); margin-bottom:0; }

/* =========================================================================
   Reviews
   ========================================================================= */
.kycs-reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.kycs-reviews-grid--full{ margin-bottom:48px; }
.kycs-review-card{
	background:#fff; border:1px solid var(--kycs-border); border-radius:var(--kycs-radius);
	padding:28px; box-shadow:var(--kycs-shadow-sm); position:relative;
}
.kycs-review-card__quote{ color:var(--kycs-tint-blue); width:34px; height:34px; position:absolute; top:18px; right:20px; }
.kycs-stars{ display:flex; gap:3px; color:var(--kycs-green); margin-bottom:10px; }
.kycs-stars .kycs-icon{ width:16px; height:16px; }
.kycs-review-card p{ font-style:italic; color:var(--kycs-text); }
.kycs-review-card strong{ color:var(--kycs-blue-dark); }

/* =========================================================================
   Gallery + lightbox
   ========================================================================= */
.kycs-gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.kycs-gallery-grid--full{ grid-template-columns:repeat(4,1fr); }
.kycs-gallery-item{ display:block; border-radius:var(--kycs-radius-sm); overflow:hidden; aspect-ratio:4/3; }
.kycs-gallery-item img{ width:100%; height:100%; object-fit:cover; transition:transform .25s ease; }
.kycs-gallery-item:hover img{ transform:scale(1.05); }

.kycs-lightbox{
	position:fixed; inset:0; background:rgba(26,26,26,.9); z-index:300;
	display:flex; align-items:center; justify-content:center; padding:40px;
}
.kycs-lightbox[hidden]{ display:none; }
.kycs-lightbox img{ max-width:100%; max-height:100%; border-radius:8px; }
.kycs-lightbox__close{
	position:absolute; top:20px; right:24px; background:none; border:0; color:#fff;
	font-size:2.4rem; line-height:1; cursor:pointer;
}

/* =========================================================================
   Service area section
   ========================================================================= */
.kycs-area-section__inner{ display:grid; grid-template-columns:1fr .8fr; gap:48px; align-items:center; }
.kycs-ky-map-svg{ width:100%; max-width:380px; }
.kycs-map-label{ font-family:var(--kycs-font-display); font-weight:700; font-size:13px; fill:var(--kycs-blue-dark); }

/* =========================================================================
   CTA band
   ========================================================================= */
.kycs-cta-band{ background:linear-gradient(135deg, var(--kycs-green-dark), var(--kycs-blue-dark)); color:#fff; }
.kycs-cta-band__inner{
	display:flex; justify-content:space-between; align-items:center; gap:24px; padding:50px 24px; flex-wrap:wrap;
}
.kycs-cta-band h2{ margin-bottom:.25em; }
.kycs-cta-band p{ margin:0; opacity:.9; }
.kycs-cta-band__actions{ display:flex; gap:14px; flex-wrap:wrap; }

/* =========================================================================
   Footer
   ========================================================================= */
.kycs-footer{ background:#fff; }
.kycs-footer__inner{
	display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding:56px 24px 30px;
}
.kycs-footer__col h3{ font-size:1rem; margin-bottom:14px; }
.kycs-footer__brand p{ color:var(--kycs-text-muted); margin:14px 0 6px; }
.kycs-footer__area{ display:flex; align-items:center; gap:8px; font-weight:700; color:var(--kycs-green-dark); }
.kycs-footer__links li{ margin-bottom:10px; }
.kycs-footer__links a:hover{ color:var(--kycs-green-dark); }
.kycs-footer__contact li{ margin-bottom:12px; }
.kycs-footer__contact a{ display:flex; align-items:center; gap:8px; font-weight:700; }
.kycs-footer__contact a:hover{ color:var(--kycs-blue-dark); }
.kycs-footer__contact .kycs-icon{ color:var(--kycs-green); }
.kycs-footer__bottom{
	border-top:1px solid var(--kycs-border); padding:20px 24px; text-align:center;
	color:var(--kycs-text-muted); font-size:.875rem;
}

/* =========================================================================
   Contact page
   ========================================================================= */
.kycs-contact-layout{ display:grid; grid-template-columns:1.3fr .9fr; gap:48px; align-items:flex-start; }
.kycs-form{ display:flex; flex-direction:column; gap:6px; }
.kycs-form label{ font-weight:800; margin-top:14px; font-size:.92rem; }
.kycs-form input, .kycs-form select, .kycs-form textarea{
	font-family:var(--kycs-font-body); font-size:1rem; padding:12px 14px;
	border:2px solid var(--kycs-border); border-radius:var(--kycs-radius-sm); width:100%;
}
.kycs-form input:focus, .kycs-form select:focus, .kycs-form textarea:focus{
	border-color:var(--kycs-blue); outline:none;
}
.kycs-form button{ margin-top:22px; align-self:flex-start; }
.kycs-form-notice{
	display:flex; align-items:center; gap:10px; padding:14px 18px; border-radius:var(--kycs-radius-sm);
	font-weight:700; margin-bottom:20px;
}
.kycs-form-notice--success{ background:var(--kycs-tint-green); color:var(--kycs-green-dark); }
.kycs-form-notice--error{ background:#FBEAEA; color:#A3342B; }
.kycs-info-card{
	background:var(--kycs-tint-blue); border-radius:var(--kycs-radius); padding:26px; margin-bottom:20px;
}
.kycs-map-embed{ border-radius:var(--kycs-radius); overflow:hidden; box-shadow:var(--kycs-shadow-sm); }

.kycs-prose{ max-width:760px; margin:0 auto; }

/* =========================================================================
   404
   ========================================================================= */
.kycs-404 .kycs-icon--xl{ color:var(--kycs-green); margin-bottom:18px; }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 980px){
	.kycs-services-grid, .kycs-services-grid--full, .kycs-reviews-grid, .kycs-reviews-grid--full,
	.kycs-values-grid, .kycs-gallery-grid{ grid-template-columns:repeat(2,1fr); }
	.kycs-gallery-grid--full{ grid-template-columns:repeat(3,1fr); }
	.kycs-about-layout, .kycs-about-preview, .kycs-area-section__inner, .kycs-contact-layout{
		grid-template-columns:1fr;
	}
	.kycs-about-layout__photo{ order:-1; }
}
@media (max-width: 620px){
	.kycs-services-grid, .kycs-services-grid--full, .kycs-reviews-grid, .kycs-reviews-grid--full,
	.kycs-values-grid, .kycs-gallery-grid, .kycs-gallery-grid--full{ grid-template-columns:1fr; }
	.kycs-cta-band__inner{ text-align:center; justify-content:center; }
	.kycs-cta-band__actions{ justify-content:center; }
	h1{ font-size:2rem; }
}
