/* CMS – Concierge Maintenance Services – Premium Design System */
*{
	box-sizing:border-box;
	margin:0;
	padding:0
}

:root{
	--navy:#0F2A47;
	--navy-deep:#0a1f36;
	--teal:#2BB3B0;
	--teal-deep:#1f8a87;
	--gold:#C9A24A;
	--gold-soft:#d9b86a;
	--gold-deep:#8a6a22;
	--gold-bright:#f3dc8a;
	--gold-metal:linear-gradient(135deg,#8a6a22 0%,#c9a24a 22%,#f3dc8a 48%,#c9a24a 72%,#8a6a22 100%);
	--gold-metal-soft:linear-gradient(135deg,#a6802e 0%,#d9b86a 30%,#f7e9b5 50%,#d9b86a 70%,#a6802e 100%);
	--ivory:#F6F2E8;
	--ivory-soft:#faf7ef
	}
	
html{
	scroll-behavior:smooth
	}
	
body{
	font-family:'Inter',-apple-system,sans-serif;
	color:#1a2235;
	background:var(--ivory-soft);
	line-height:1.7;
	font-weight:400;
	-webkit-font-smoothing:antialiased;
	}
	
h1,h2,h3,h4{
	font-family:'Cormorant Garamond',serif;
	font-weight:500;
	color:var(--navy);
	line-height:1.1;
	letter-spacing:-0.005em;
	}
    
p {
    display: block;
    margin-block-start: 1em;
    margin-block-end: 1em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    unicode-bidi: isolate;
}    
	
a{
	color:inherit;
	text-decoration:none;
	}
	
img{
	max-width:100%;
	display:block;
	}
	
.container{
	max-width:1240px;
	margin:0 auto;
	padding:0 32px;
	}
	
.eyebrow{
	color:var(--gold);
	font-family:'Inter',sans-serif;
	font-size:11px;
	letter-spacing:6px;
	text-transform:uppercase;
	font-weight:600;
	display:block;
	margin-bottom:24px;
	text-shadow:0 1px 0 rgba(0,0,0,.25),0 0 12px rgba(243,220,138,.15);
	}
	
.gold-line{
	width:60px;
	height:1px;
	background:var(--gold-metal);
	margin-bottom:32px;
	box-shadow:0 0 6px rgba(243,220,138,.35);
	}
	
.btn{
	display:inline-block;
	font-family:'Inter',sans-serif;
	font-weight:500;
	font-size:13px;
	letter-spacing:2px;
	text-transform:uppercase;
	transition:all .35s ease;
	cursor:pointer;
	border:none;
    padding:18px 42px;
    min-width:220px;
    text-align:center;
	}
	
.btn-gold{
	background:var(--gold-metal);
	color:var(--navy-deep);
	box-shadow:inset 0 1px 0 rgba(255,255,255,.45),inset 0 -1px 0 rgba(0,0,0,.18),0 6px 18px rgba(138,106,34,.28);
	text-shadow:0 1px 0 rgba(255,255,255,.25);
	}
	
.btn-gold:hover{
	background:var(--gold-metal-soft);
	transform:translateY(-1px);
	box-shadow:inset 0 1px 0 rgba(255,255,255,.55),inset 0 -1px 0 rgba(0,0,0,.15),0 10px 28px rgba(201,162,74,.4);
	}
	
.btn-outline{
	background:transparent;
	color:var(--ivory);
	border:1px solid var(--gold);
	}
	
.btn-outline:hover{
	background:var(--gold-metal);
	color:var(--navy-deep);
	border-color:transparent;
	}
	
.btn-teal{
	background:var(--teal);
	color:var(--ivory);
	box-shadow:0 6px 18px rgba(43,179,176,.28);
	}
	
.btn-teal:hover{
	background:var(--teal-deep);
	transform:translateY(-1px);
	box-shadow:0 10px 28px rgba(31,138,135,.36);
	}
	
.btn-dark{
	background:var(--navy);
	color:var(--ivory);
	}
	
.btn-dark:hover{
	background:var(--navy-deep);
	}

/* NAV */
.nav{
	position:fixed;
	top:0;
	left:0;
	right:0;
	background:rgba(15,42,71,.92);
	backdrop-filter:blur(14px);
	z-index:100;
	border-bottom:1px solid rgba(201,162,74,.15);
	}
	
.nav-inner{
	max-width:1320px;
	margin:0 auto;
	padding:20px 32px;
	display:flex;
	align-items:center;
	justify-content:space-between;
	gap:24px;
	}
	
.logo img{
	height:48px;
	width:auto;
	}
	
.nav-links{
	display:flex;
	gap:36px;
	list-style:none;
	align-items:center;
	}
	
.nav-links a{
	color:rgba(246,242,232,.78);
	font-size:12px;
	letter-spacing:2.5px;
	text-transform:uppercase;
	font-weight:400;
	transition:color .25s;
	position:relative;
	padding:6px 0;
	}
	
.nav-links a:hover,
.nav-links a.active{
	color:var(--gold);
	}
	
.nav-links a.active::after{
	content:"";
	position:absolute;
	bottom:0;
	left:0;
	right:0;
	height:1px;
	background:var(--gold-metal);
	}
	
.nav-cta{
	background:var(--gold-metal);
	color:var(--navy-deep);
	padding:12px 24px;
	font-size:11px;
	letter-spacing:2px;
	text-transform:uppercase;
	font-weight:600;
	transition:all .3s;
	box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 4px 14px rgba(138,106,34,.25);
	}
	
.nav-cta:hover{
	background:var(--gold-metal-soft);
	box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 6px 18px rgba(201,162,74,.35);
	}
	
.menu-toggle{
	display:none;
	background:none;
	color:var(--ivory);
	border:none;
	font-size:24px;
	cursor:pointer;
	}
	
@media(max-width:1020px){
	
	.nav-links{
		gap:24px;
		}
		
	.nav-links a{
		font-size:11px;
		letter-spacing:2px;
	}
}

@media(max-width:920px){

  .nav-links{
      position:fixed;
      top:84px;
      left:0;
      right:0;

      background:var(--navy-deep);

      flex-direction:column;
      padding:28px 32px;
      gap:20px;

      display:none; /* IMPORTANT */

      border-top:1px solid rgba(201,162,74,.15);

      z-index:99999;
  }

  .nav-links.open{
      display:flex !important;
  }

  .nav-cta{
      display:none;
  }

  .menu-toggle{
      display:block;
      position:relative;
      z-index:100000;
  }

}

/* ==========================================
   HOME HERO
========================================== */

.hero{
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    color: var(--ivory);
    overflow: hidden;
    padding: 140px 0 80px;
}

.home-hero{
    background:
        linear-gradient(135deg, rgba(10, 31, 54, .85) 0%, rgba(15, 42, 71, .6) 50%, rgba(31, 138, 135, .4) 100%),
        url('hero-luxury.jpg');
	position:relative;
    background-size:cover;
    background-position:center center;
    background-repeat:no-repeat;
    align-items:center;
}


.hero .container{
    
    max-width:900px;

    display:flex;
    flex-direction:column;

    align-items:flex-start;
    text-align:left;

    margin:0 auto;

}

.hero .gold-line{
    margin:0 0 32px;
}

.hero h1{
    font-size: clamp(44px, 7vw, 84px);
    color: var(--ivory);
    margin-bottom: 28px;
    font-weight: 400;
    text-align:left;
}

.hero h1 em{
    color:var(--gold);
    font-style:italic;
}

.hero .sub{
    font-size: 19px;
    color: rgba(246, 242, 232, .82);
    max-width: 620px;
    margin-bottom: 44px;
    font-weight: 300;
    line-height: 1.7;
    text-align:left;
}

.actions{
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* ==========================================
   PROMISE SECTION
========================================== */

.promise{
    background:var(--ivory-soft);
}

.promise-grid{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:80px;
    align-items:center;
}

.promise-grid img{
    width:100%;
    height:560px;
    object-fit:cover;
}

.promise-text h2{
    font-size: clamp(34px, 4.6vw, 52px);
    margin-bottom: 28px;
}

.promise-text h2 em{
    color:var(--teal);
    font-style:italic;
}

.promise-text p{
    color: #4a5468;
    font-size: 16px;
    margin-bottom: 18px;
    font-weight: 300;
}

/* ==========================================
   SERVICES
========================================== */

.services{
    
    background: var(--navy);
    color: var(--ivory);

}

.svc-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:32px;
}

.svc-card{
    background:#fff;
    border:1px solid rgba(201,162,74,.15);
    overflow:hidden;
    transition:.35s ease;
}

.svc-card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 40px rgba(15,42,71,.12);
}

.svc-card .img{
    overflow:hidden;
}

.svc-card .img img{
    width:100%;
    height:280px;
    object-fit:cover;
    transition:transform .8s ease;
}

.svc-card:hover .img img{
    transform:scale(1.05);
}

.svc-card .body{
    padding:38px;
}

.svc-card h3{
    font-size:34px;
    margin-bottom:18px;
}

.svc-card p{
    color:#5a6478;
}

/* ==========================================
   WHY CMS
========================================== */

.why{
    background:var(--navy);
    color:var(--ivory);
}

.why .section-head h2{
    color:var(--ivory);
}

.why .section-head h2 em{
    color:var(--gold);
}

.why-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:40px;
}

.why-item{
    padding-top:28px;
    border-top:1px solid rgba(201,162,74,.7);
}

.why-item .num{
    color:var(--gold);
    display:block;
    margin-bottom:18px;
    font-style:italic;
}

.why-item h4{
    color:var(--ivory);
    font-size:28px;
    margin-bottom:16px;
}

.why-item p{
    color:rgba(246,242,232,.7);
}

/* ==========================================
   TESTIMONIAL
========================================== */

.testimonial{
    text-align:center;
    background:var(--ivory);
}

.testimonial blockquote{
    max-width:1000px;
    margin:0 auto 30px;
    font-family:'Cormorant Garamond',serif;
    font-size:clamp(34px,4vw,52px);
    line-height:1.4;
    font-style:italic;
}

.testimonial cite{
    color:var(--gold);
    letter-spacing:3px;
    text-transform:uppercase;
    font-size:12px;
}

/* ==========================================
   SERVICE AREAS
========================================== */

.areas-preview{
    text-align:center;
    background:var(--navy);
    color:var(--ivory);
}

.areas-preview h2{
    color:var(--ivory);
    font-size:clamp(44px,5vw,70px);
}

.areas-preview h2 em{
    color:var(--gold);
}

.areas-preview .lead{
    max-width:760px;
    margin:0 auto 40px;
    color:rgba(246,242,232,.8);
}

.areas-list{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:16px;
    margin-bottom:40px;
}

.areas-list span{
    border:1px solid rgba(201,162,74,.35);
    padding:12px 24px;
    color:var(--ivory);
}


.page-hero {
    position: relative;
    min-height: 60vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    text-align: center;
    padding: 180px 0 100px;
}

.about-hero {
    background:
        linear-gradient(
            135deg,
            rgba(10,31,54,.85),
            rgba(31,138,135,.55)
        ),
        url('lux-4.jpg');

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.page-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
}

.page-hero .container {
    position: relative;
    z-index: 2;
} 
	
.page-hero .gold-line{
	margin-left:auto;
	margin-right:auto;
	}
	
.page-hero h1{
	font-size:clamp(40px,6vw,72px);
	color:var(--ivory);
	font-weight:400;
	margin-bottom:24px;
	}
	
.page-hero h1 em{
	font-style:italic;
	color:var(--gold);
	font-weight:500;
	}
	
.page-hero .sub{
	font-size:18px;
	color:rgba(246,242,232,.82);
	max-width:680px;
	margin:0 auto;
	font-weight:300;
	}

/* Sections */
section{
	padding:120px 0;
	}
	
.section-head{
	text-align:center;
	max-width:760px;
	margin:0 auto 80px;
	}
	
.section-head .gold-line{
	margin-left:auto;
	margin-right:auto;
	}
	
.section-head h2{
	font-size:clamp(36px,5vw,56px);
	margin-bottom:20px;
    color: var(--ivory);
	}
	
.section-head h2 em{
	font-style:italic;
	color:var(--gold);
	font-weight:500;
	}
	
.section-head p{
	color: rgba(246, 242, 232, .7);
    font-size: 17px;
    font-weight: 300;
    line-height: 1.8;
	}
    
    .story-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.story-grid img {
    width: 100%;
    height: 600px;
    object-fit: cover;
    display: block;
}

.story-grid h2 {
    font-size: clamp(34px, 4.6vw, 52px);
    margin-bottom: 28px;
    font-weight: 500;
}

.story-grid h2 em {
    color: var(--teal);
    font-style: italic;
    font-weight: 500;
}

.story-grid p {
    color: #4a5468;
    font-size: 16px;
    margin-bottom: 18px;
    font-weight: 300;
}

@media (max-width: 992px) {
    .story-grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .story-grid img {
        height: auto;
    }
}

/* ==========================================
   VALUES SECTION
========================================== */

.values {
    background: var(--navy);
    color: var(--ivory);
    padding: 140px 0;
}

.values .section-head {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 80px;
}

.values .section-head h2 {
    color: var(--ivory);
    font-size: clamp(36px, 5vw, 56px);
    margin-bottom: 20px;
}

.values .section-head h2 em {
    color: var(--gold);
    font-style: italic;
    font-weight: 500;
}

.values-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
}

.value {
    padding-top: 28px;
    border-top: 1px solid var(--gold);
}


.value .roman {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    color: var(--gold);
    font-size: 13px;
    letter-spacing: 3px;
    margin-bottom: 14px;
    display: block;
}

.value h4 {
    color: var(--ivory);
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px;
    font-weight: 500;
    margin-bottom: 14px;
}

.value p {
    color: rgba(246, 242, 232, .65);
    font-size: 14.5px;
    font-weight: 300;
}

/* Tablet */
@media (max-width: 1200px) {
    .values-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Mobile */
@media (max-width: 768px) {
    .values-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .values .section-head h2 {
        font-size: 44px;
    }
}

.quote blockquote {
	font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: clamp(28px, 3.6vw, 40px);
    line-height: 1.4;
    max-width: 880px;
    margin: 0 auto 24px;
    color: var(--navy);
    font-weight: 400;
}

.quote cite {
    font-style: normal;
    color: var(--teal);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    text-align: center;
}

/* CTA band */
.cta-band{
	background:linear-gradient(135deg,var(--navy) 0%,var(--teal-deep) 100%);
	text-align:center;
	padding:120px 0;
	color:var(--ivory);
	}
.cta-band h2{
	color:var(--ivory);
	font-size:clamp(36px,5vw,56px);
	margin-bottom:20px;
	font-weight:400;
	}
	
.cta-band h2 em{
	font-style:italic;
	color:var(--gold);
	font-weight:500;
	}
	
.cta-band p{
	color:rgba(246,242,232,.82);
	font-size:17px;
	margin-bottom:40px;
	max-width:580px;
	margin-left:auto;
	margin-right:auto;
	font-weight:300;
	}

/* FOOTER */
footer{
	background:var(--navy-deep);
	color:var(--ivory);
	padding:80px 0 32px;
	position:relative;
	}
	
footer::before{
	content:"";
	position:absolute;
	top:0;
	left:0;
	right:0;
	height:1px;
	background:linear-gradient(90deg,transparent,var(--gold-deep) 20%,var(--gold-bright) 50%,var(--gold-deep) 80%,transparent);
	}
	
.footer-grid{
	display:grid;
	grid-template-columns:1.6fr 1fr 1fr 1fr;
	gap:56px;
	margin-bottom:56px;
	}
	
.footer-logo img{
	height:60px;
	margin-bottom:20px;
	}
	
.footer-tag{
	color:var(--gold);
	font-size:10px;
	letter-spacing:5px;
	text-transform:uppercase;
	margin-bottom:16px;
	font-weight:500;
	}
	
.footer-about{
	color:rgba(246,242,232,.55);
	font-size:14px;
	line-height:1.8;
	font-weight:300;
	max-width:340px;
	}
	
.footer-col h4{
	font-family:'Inter',sans-serif;
	color:var(--gold);
	font-weight:500;
	font-size:11px;
	letter-spacing:3px;
	text-transform:uppercase;
	margin-bottom:22px;
	}
	
.footer-col ul{
	list-style:none;
	}
	
.footer-col li{
	margin-bottom:12px;
	}
	
.footer-col a,.footer-col span{
	color:rgba(246,242,232,.6);
	font-size:14px;
	transition:color .25s;
	font-weight:300;
	}
	
.footer-col a:hover{
	color:var(--gold);
	}
	
.footer-col .esp{
	color:var(--gold);
	font-style:italic;
	font-family:'Cormorant Garamond',serif;
	font-size:16px;
	}
	
.footer-bottom{
	border-top:1px solid rgba(201,162,74,.15);
	padding-top:28px;
	text-align:center;
	color:rgba(246,242,232,.45);
	font-size:12px;
	letter-spacing:1.5px;
	font-weight:300;
	}
	
@media(max-width:880px){
	
	.footer-grid{
		grid-template-columns:1fr 1fr;
		gap:36px;
	}
}

@media(max-width:520px){
	
	.footer-grid{
		grid-template-columns:1fr;
	}
}

/* Page hero stays photographic — no marble overlay */
section{
	position:relative;
	}
	
section > *{
	position:relative;
	z-index:1;
	}

/* Footer — deep marble */
footer{
  background:
    linear-gradient(rgba(10,31,54,.94),rgba(10,31,54,.97)),
    url('marble-dark.jpg') center/cover !important;
}

/* Nav — subtle marble sheen */
.nav{
  background:
    linear-gradient(rgba(15,42,71,.88),rgba(15,42,71,.92)),
    url('marble-dark.jpg') center/cover !important;
}

/* Cards / principles — soft marble panel */
.principle,.faq-item,.service-card,.area-card,.value-card{
  background:
    linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.92)),
    url('marble-light.jpg') center/cover;
  border:1px solid rgba(201,162,74,.18);
  box-shadow:0 8px 30px -16px rgba(15,42,71,.18);
}

/* Metallic gold shimmer line */
.gold-line{
  background:linear-gradient(90deg,transparent,var(--gold-deep) 15%,var(--gold-bright) 50%,var(--gold-deep) 85%,transparent);
  box-shadow:0 0 8px rgba(243,220,138,.4);
}


/* ==========================================
   RESPONSIVE - LARGE TABLETS
========================================== */

@media (max-width: 1200px) {

    .container {
        padding: 0 24px;
    }

    .svc-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .why-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 50px;
    }

    .promise-grid {
        gap: 50px;
    }

    .promise-grid img {
        height: 480px;
    }
}


/* ==========================================
   RESPONSIVE - TABLETS
========================================== */

@media (max-width: 992px) {

    section {
        padding: 90px 0;
    }

    .section-head {
        margin-bottom: 60px;
    }

    .section-head h2 {
        font-size: clamp(32px, 5vw, 48px);
    }

    .promise-grid {
        grid-template-columns: 1fr;
        gap: 50px;
    }

    .promise-grid img {
        height: auto;
        max-height: 600px;
    }

    .svc-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .why-grid {
        grid-template-columns: 1fr 1fr;
        gap: 40px;
    }

    .svc-card h3 {
        font-size: 30px;
    }
}


/* ==========================================
   RESPONSIVE - MOBILE
========================================== */

@media (max-width: 768px) {

    section {
        padding: 70px 0;
    }

    .container {
        padding: 0 20px;
    }

    .section-head {
        margin-bottom: 50px;
    }

    .section-head h2 {
        font-size: 38px;
        line-height: 1.15;
    }

    .section-head p {
        font-size: 16px;
    }

    .promise-grid {
        gap: 40px;
    }

    .promise-grid img {
        width: 100%;
        height: auto;
        display: block;
    }

    .promise-text h2 {
        font-size: 36px;
        line-height: 1.15;
    }

    .promise-text p {
        font-size: 15px;
        line-height: 1.8;
    }

    .svc-grid {
        grid-template-columns: 1fr;
    }

    .svc-card .body {
        padding: 28px;
    }

    .svc-card h3 {
        font-size: 28px;
    }

    .why-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .why-item {
        padding-top: 20px;
    }

    .why-item h4 {
        font-size: 24px;
    }
}


/* ==========================================
   RESPONSIVE - SMALL MOBILE
========================================== */

@media (max-width: 480px) {

    .container {
        padding: 0 16px;
    }

    section {
        padding: 60px 0;
    }

    .section-head {
        margin-bottom: 40px;
    }

    .section-head h2 {
        font-size: 32px;
    }

    .promise-text h2 {
        font-size: 30px;
    }

    .svc-card .body {
        padding: 24px;
    }

    .svc-card h3 {
        font-size: 24px;
    }

    .why-item h4 {
        font-size: 22px;
    }

    .why-item p,
    .svc-card p,
    .promise-text p {
        font-size: 14px;
    }
}

/* ==========================================
   SERVICES PAGE
========================================== */

/* Hero background */
.services-hero{
    background:
        linear-gradient(
            135deg,
            rgba(10,31,54,.85),
            rgba(31,138,135,.55)
        ),
        url('hero-luxury.jpg');

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
/* Service rows */

.svc-row{
    padding:110px 0;
    border-bottom:1px solid rgba(15,42,71,.08);
}

.svc-row:nth-child(even){
    background:var(--ivory);
}

.svc-inner{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:80px;
    align-items:center;

    max-width:1180px;
    margin:0 auto;
    padding:0 32px;
}

/* Alternate layout */

.svc-row.reverse .svc-inner{
    direction:rtl;
}

.svc-row.reverse .svc-text{
    direction:ltr;
}

/* Images */

.svc-img{
    height:520px;
    overflow:hidden;
}

.svc-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

/* Content */

.svc-text h2{
    font-size:clamp(32px,4vw,46px);
    margin-bottom:20px;
    font-weight:500;
}

.svc-text h2 em{
    font-style:italic;
    color:var(--teal);
}

.svc-text p{
    color:#4a5468;
    font-size:16px;
    line-height:1.9;
    margin-bottom:16px;
    font-weight:300;
}

/* Service bullet list */

.svc-text ul{
    list-style:none;
    margin:20px 0 28px;
    padding:0;
}

.svc-text li{
    position:relative;
    padding:8px 0 8px 22px;

    color:#4a5468;
    font-size:15px;
    font-weight:300;

    border-bottom:1px solid rgba(15,42,71,.06);
}

.svc-text li::before{
    content:"";
    position:absolute;

    left:0;
    top:18px;

    width:10px;
    height:1px;

    background:var(--gold);
}

.svc-text .btn{
    margin-top:8px;
}

/* ==========================================
   SERVICES RESPONSIVE
========================================== */

@media (max-width: 1024px){

    .svc-inner{
        gap:60px;
    }

    .svc-img{
        height:460px;
    }
}

@media (max-width: 880px){

    .svc-inner{
        grid-template-columns:1fr;
        gap:40px;
    }

    .svc-row.reverse .svc-inner{
        direction:ltr;
    }

    .svc-img{
        height:360px;
    }
}

@media (max-width: 768px){

    .svc-row{
        padding:80px 0;
    }

    .svc-inner{
        padding:0 20px;
    }

    .svc-text h2{
        font-size:36px;
        line-height:1.15;
    }

    .svc-img{
        height:320px;
    }
}

@media (max-width: 480px){

    .svc-row{
        padding:60px 0;
    }

    .svc-inner{
        padding:0 16px;
    }

    .svc-img{
        height:260px;
    }

    .svc-text h2{
        font-size:30px;
    }

    .svc-text p,
    .svc-text li{
        font-size:14px;
    }
}


/* ==========================================
   PRICING HERO
========================================== */

.pricing-hero{
    background:
        linear-gradient(
            135deg,
            rgba(10,31,54,.85),
            rgba(31,138,135,.55)
        ),
        url('lux-3.jpg');

    background-size:cover;
    background-position:center center;
    background-repeat:no-repeat;
}

/* ==========================================
   PRICING INTRO
========================================== */

.pricing-intro{
    background:var(--ivory-soft);
    text-align:center;
}

.pricing-intro .container{
    max-width:780px;
}

.pricing-intro h2{
    font-size: clamp(34px, 4.5vw, 52px);
    margin-bottom:28px;
    color:var(--navy);
    font-weight:400;
    line-height:1.1;
}

.pricing-intro h2 em{
    color:var(--teal);
    font-style:italic;
    font-weight:500;
}

.pricing-intro p{
    font-size:18px;
    line-height:1.9;
    color:#5a6478;
    font-weight:300;
    margin-bottom:20px;
}

/* ==========================================
   PRICING PRINCIPLES
========================================== */


.principles{
    background: var(--ivory-soft);
    color:var(--ivory);
}

.principles .section-head{
    margin-bottom:100px;
}

.principles .section-head h2{
    color:var(--navy);
    font-size: clamp(36px, 5vw, 56px);
    margin-bottom: 20px;

}

.principles .section-head h2 em{
    font-style: italic;
    color: var(--teal);
    font-weight: 500;
}
.principles-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:70px;
}

.principle{
    position:relative;
    padding:0 16px;
    text-align:center;
    border: 1px solid rgba(201, 162, 74, .18);
    box-shadow: 0 8px 30px -16px rgba(15, 42, 71, .18);
}

.principle::before{
    content:"";
    position:absolute;
    top:0;
    left:0;

    width:100%;
    height:1px;

    background:
        linear-gradient(
            90deg,
            rgba(201,162,74,.85),
            rgba(201,162,74,.35)
        );
}

.principle .num{
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    color: var(--gold);
    font-size: 46px;
    display: block;
    margin-bottom: 16px;
    line-height: 1;
}

.principle h3{
    font-family:'Cormorant Garamond',serif;
    font-size:24px;
    line-height:1.15;
   

    color:var(--navy);
    margin-bottom: 14px;
    font-weight: 500;
}

.principle p{
    color: #5a6478;
    font-size: 14.5px;
    font-weight: 300;
}

/* ==========================================
   PRICING RESPONSIVE
========================================== */

@media (max-width: 992px){

    .principles-grid{
        grid-template-columns:1fr;
        gap:50px;
    }

    .pricing-intro h2{
        font-size:52px;
    }

}

@media (max-width: 768px){

    .pricing-intro{
        padding:80px 0;
    }

    .pricing-intro h2{
        font-size:42px;
    }

    .pricing-intro p{
        font-size:16px;
    }

    .principle h3{
        font-size:28px;
    }

}

@media (max-width: 480px){

    .pricing-intro h2{
        font-size:34px;
    }

    .principle h3{
        font-size:24px;
    }

    .principle p{
        font-size:15px;
    }

}

/* ==========================================
   SERVICE AREAS PAGE
========================================== */

.service-areas-hero{
    background:
        linear-gradient(
            135deg,
            rgba(10,31,54,.85),
            rgba(31,138,135,.55)
        ),
        url('hero-areas.jpg');

    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
}

.service-areas-hero{
    min-height:78vh;
}

.areas-intro{
    padding:130px 0 60px;
    background:var(--ivory);
    text-align:center;
}

.areas-intro h2{
    font-size:clamp(34px,4.5vw,52px);
    margin-bottom:24px;
    font-weight:500;
}

.areas-intro h2 em{
    font-style:italic;
    color:var(--teal);
}

.areas-intro p{
    color:#4a5468;
    font-size:17px;
    max-width:680px;
    margin:0 auto;
    font-weight:300;
}

.areas-grid{
    padding:60px 0 130px;
    background:var(--ivory);
}

.areas-grid .container{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:32px;
}

.area{
    background:#fff;
    border:1px solid rgba(15,42,71,.08);
    padding:42px 36px;
    transition:all .4s;
}

.area:hover{
    border-color:var(--gold);
    transform:translateY(-4px);
    box-shadow:0 12px 30px rgba(15,42,71,.06);
}

.area .num{
    font-family:'Cormorant Garamond',serif;
    font-style:italic;
    color:var(--gold);
    font-size:16px;
    letter-spacing:3px;
    display:block;
    margin-bottom:14px;
}

.area h3{
    font-size:28px;
    margin-bottom:10px;
    font-weight:500;
}

.area .county{
    color:var(--teal);
    font-size:11px;
    letter-spacing:3px;
    text-transform:uppercase;
    margin-bottom:18px;
    font-weight:500;
}

.area p{
    color:#5a6478;
    font-size:14.5px;
    font-weight:300;
}

@media(max-width:880px){
    .areas-grid .container{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:600px){
    .areas-grid .container{
        grid-template-columns:1fr;
    }
}


/* ==========================================
   FAQ PAGE
========================================== */

.faq-hero{
    background:
        linear-gradient(
            135deg,
            rgba(10,31,54,.85),
            rgba(31,138,135,.55)
        ),
        url('lux-6.jpg');

    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
}

.faqs{
    padding:140px 0;
    background:var(--ivory);
}

.faqs .container{
    max-width:880px;
}

details{
    border-bottom:1px solid rgba(15,42,71,.1);
    padding:32px 0;
    cursor:pointer;
    transition:all .3s;
}

details[open]{
    padding-bottom:36px;
}

summary{
    font-family:'Cormorant Garamond',serif;
    font-size:24px;
    color:var(--navy);
    font-weight:500;

    list-style:none;

    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:24px;

    line-height:1.3;
}

summary::-webkit-details-marker{
    display:none;
}

summary::after{
    content:"+";
    color:var(--gold);
    font-size:28px;
    font-weight:300;
    transition:transform .3s;
    flex-shrink:0;
}

details[open] summary::after{
    content:"–";
}

details p{
    color:#4a5468;
    font-size:15.5px;
    margin-top:18px;
    font-weight:300;
    line-height:1.8;
    padding-right:48px;
}

.faq-cat{
    font-family:'Inter',sans-serif;
    color:var(--teal);

    font-size:10px;
    letter-spacing:4px;
    text-transform:uppercase;

    margin:48px 0 8px;

    font-weight:500;
}

.faq-cat:first-of-type{
    margin-top:0;
}

/* ==========================================
   FAQ RESPONSIVE
========================================== */

/* Large Tablets */
@media (max-width: 1024px){

    .faqs{
        padding:120px 0;
    }

    .faqs .container{
        max-width:800px;
        padding:0 24px;
    }

    summary{
        font-size:22px;
    }

}

/* Tablets */
@media (max-width: 768px){

    .faqs{
        padding:90px 0;
    }

    .faqs .container{
        max-width:100%;
        padding:0 20px;
    }

    details{
        padding:24px 0;
    }

    summary{
        font-size:20px;
        line-height:1.4;
        padding-right:12px;
    }

    summary::after{
        font-size:24px;
    }

    details p{
        font-size:15px;
        padding-right:0;
        margin-top:14px;
    }

    .faq-cat{
        margin:36px 0 6px;
        letter-spacing:3px;
    }

}

/* Mobile */
@media (max-width: 480px){

    .faqs{
        padding:70px 0;
    }

    .faqs .container{
        padding:0 16px;
    }

    details{
        padding:20px 0;
    }

    summary{
        font-size:18px;
        gap:12px;
    }

    summary::after{
        font-size:22px;
    }

    details p{
        font-size:14px;
        line-height:1.8;
    }

    .faq-cat{
        font-size:9px;
        letter-spacing:2.5px;
        margin:28px 0 4px;
    }

}


/* ==========================================
   CONTACT PAGE
========================================== */

.contact-hero{
    background:
        linear-gradient(
            135deg,
            rgba(10,31,54,.85),
            rgba(31,138,135,.55)
        ),
        url('lux-2.jpg');

    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;

    min-height:54vh;
    padding:160px 0 80px;
}

.contact-wrap{
    padding:130px 0;
    background:var(--ivory);
}

.contact-grid{
    display:grid;
    grid-template-columns:1fr 1.4fr;
    gap:80px;
    align-items:start;
}

.contact-info h2{
    font-size:clamp(30px,3.6vw,42px);
    margin-bottom:24px;
    font-weight:500;
}

.contact-info h2 em{
    font-style:italic;
    color:var(--teal);
}

.contact-info > p{
    color:#4a5468;
    font-size:16px;
    margin-bottom:32px;
    font-weight:300;
}

.contact-info .info-block{
    padding:22px 0;
    border-top:1px solid rgba(15,42,71,.1);
}

.contact-info .info-block:last-child{
    border-bottom:1px solid rgba(15,42,71,.1);
}

.contact-info .label{
    color:var(--gold);
    font-size:10px;
    letter-spacing:3px;
    text-transform:uppercase;
    font-weight:500;
    margin-bottom:8px;
    display:block;
}

.contact-info .value{
    font-family:'Cormorant Garamond',serif;
    font-size:22px;
    color:var(--navy);
    font-weight:500;
}

.contact-info .value a{
    transition:color .25s;
}

.contact-info .value a:hover{
    color:var(--teal);
}

.contact-info .esp{
    font-style:italic;
    color:var(--teal);
    font-family:'Cormorant Garamond',serif;
    font-size:20px;
}

.form{
    background:#fff;
    padding:48px 44px;
    border:1px solid rgba(15,42,71,.08);
}

.form h3{
    font-size:28px;
    margin-bottom:8px;
    font-weight:500;
}

.form .sub{
    color:#5a6478;
    font-size:14px;
    margin-bottom:32px;
    font-weight:300;
}

.field{
    margin-bottom:20px;
}

.field label{
    display:block;
    font-size:10px;
    letter-spacing:2.5px;
    text-transform:uppercase;
    color:var(--navy);
    margin-bottom:8px;
    font-weight:500;
}

.field input,
.field select,
.field textarea{
    width:100%;
    padding:14px 16px;
    border:1px solid rgba(15,42,71,.18);
    background:var(--ivory-soft);

    font-family:'Inter',sans-serif;
    font-size:14.5px;
    color:var(--navy);

    transition:border-color .25s,background .25s;
}

.field input:focus,
.field select:focus,
.field textarea:focus{
    outline:none;
    border-color:var(--gold);
    background:#fff;
}

.field textarea{
    min-height:110px;
    resize:vertical;
}

.field-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
}

.form button{
    width:100%;
    margin-top:12px;
}

.form .response-note {
    text-align: center;
    color: var(--teal);
    font-style: italic;
    font-family: 'Cormorant Garamond', serif;
    font-size: 17px;
    margin-top: 24px;
}

.success{
    display:none;
}

.success.show{
    display:block;

    background:#f7faf7;
    border:1px solid rgba(43,179,176,.25);

    padding:40px;
    text-align:center;
}

.success h3{
    margin-bottom:12px;
}

.success p{
    margin:0;
}

@media(max-width:880px){

    .contact-grid{
        grid-template-columns:1fr;
        gap:48px;
    }

    .field-row{
        grid-template-columns:1fr;
    }

    .form{
        padding:36px 28px;
    }
}