/* ================================================
   THE ESSIX EXPERIENCE - Red / Black / White
   Light luxury editorial.
   ================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
:root{
  --red:#C62828;--red-bright:#E53935;--red-dark:#8B1A1A;
  --black:#0A0A0A;--off-black:#1A1A1A;
  --white:#FFFFFF;--off-white:#F7F7F7;
  --gray-100:#F0F0F0;--gray-200:#E0E0E0;--gray-400:#999;--gray-600:#666;--gray-800:#333;
}
body{font-family:'Outfit',sans-serif;background:var(--white);color:var(--gray-800);font-weight:300;line-height:1.7;overflow-x:hidden;}
.container{max-width:1000px;margin:0 auto;padding:0 2rem;}
.container-wide{max-width:1200px;margin:0 auto;padding:0 2rem;}
.container-narrow{max-width:720px;margin:0 auto;padding:0 2rem;}
.label{font-size:.65rem;letter-spacing:3px;text-transform:uppercase;color:var(--red);font-weight:500;margin-bottom:.6rem;}
.section-head{text-align:center;margin-bottom:3rem;}
.section-head h2{font-family:'DM Serif Display',serif;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--black);font-weight:400;}
.section-head h2 em,.page-top h1 em,.hero-text h1 em,.bio-hero-text h1 em,.phil-body em,.pa-block h2 em{font-style:italic;color:var(--red);}

/* BUTTONS */
.btn-dark{display:inline-block;padding:.85rem 2.2rem;background:var(--black);color:var(--white);font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;text-decoration:none;font-weight:400;transition:all .3s;border:none;cursor:pointer;}
.btn-dark:hover{background:var(--red);}
.btn-dark-sm{display:inline-block;padding:.65rem 1.6rem;background:var(--black);color:var(--white);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;text-decoration:none;font-weight:400;transition:all .3s;}
.btn-dark-sm:hover{background:var(--red);}
.btn-ghost{display:inline-block;padding:.85rem 2.2rem;border:1px solid var(--black);color:var(--black);font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;text-decoration:none;font-weight:400;transition:all .3s;background:transparent;}
.btn-ghost:hover{background:var(--black);color:var(--white);}
.btn-ghost-sm{display:inline-block;padding:.65rem 1.6rem;border:1px solid var(--gray-200);color:var(--gray-800);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;text-decoration:none;font-weight:400;transition:all .3s;}
.btn-ghost-sm:hover{border-color:var(--black);color:var(--black);}
.btn-light{display:inline-block;padding:.85rem 2.2rem;background:var(--white);color:var(--black);font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;text-decoration:none;font-weight:400;transition:all .3s;border:none;cursor:pointer;}
.btn-light:hover{background:var(--gray-200);}

/* ANNOUNCE BAR */
.announce-bar{display:flex;justify-content:center;align-items:center;gap:2rem;padding:.6rem 2rem;background:var(--black);font-size:.65rem;letter-spacing:1px;color:var(--gray-400);}
.announce-bar a{color:var(--red-bright);text-decoration:none;transition:color .3s;}
.announce-bar a:hover{color:var(--white);}

/* NAV */
nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 3rem;background:var(--white);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--gray-100);transition:box-shadow .3s;}
nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.05);}
.nav-logo{text-decoration:none;display:flex;flex-direction:column;align-items:center;line-height:1;}
.logo-top{font-size:.45rem;letter-spacing:5px;color:var(--red);font-weight:500;text-transform:uppercase;}
.logo-main{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--black);letter-spacing:6px;}
.logo-bot{font-size:.4rem;letter-spacing:3px;color:var(--gray-400);text-transform:uppercase;font-weight:400;}
.nav-links{list-style:none;display:flex;gap:1.8rem;}
.nav-links a{color:var(--gray-600);text-decoration:none;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:400;transition:color .3s;}
.nav-links a:hover,.nav-links a.active{color:var(--black);}
.nav-cta{padding:.5rem 1.3rem;background:var(--red);color:var(--white);text-decoration:none;font-size:.62rem;letter-spacing:2px;text-transform:uppercase;font-weight:500;transition:background .3s;white-space:nowrap;}
.nav-cta:hover{background:var(--red-dark);}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;}
.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--black);margin:5px 0;}

/* HERO */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:90vh;background:var(--off-white);}
.hero-img{overflow:hidden;}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-text{display:flex;flex-direction:column;justify-content:center;padding:4rem 4rem 4rem 3rem;}
.hero-text h1{font-family:'DM Serif Display',serif;font-size:clamp(2rem,3.5vw,3rem);color:var(--black);font-weight:400;line-height:1.2;margin-bottom:1.2rem;}
.hero-text .subtitle{font-size:.88rem;color:var(--gray-600);line-height:1.9;margin-bottom:2rem;max-width:480px;}
.hero-actions{display:flex;gap:1rem;margin-bottom:3rem;flex-wrap:wrap;}
.hero-stats{display:flex;gap:2.5rem;padding-top:2rem;border-top:1px solid var(--gray-200);}
.hero-stats div{display:flex;flex-direction:column;}
.hero-stats strong{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--black);font-weight:400;}
.hero-stats span{font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:var(--gray-400);margin-top:.2rem;}

/* AS SEEN ON */
.seen-on{padding:1.5rem 2rem;background:var(--off-white);border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);text-align:center;}
.seen-on p{font-size:.55rem;letter-spacing:3px;text-transform:uppercase;color:var(--gray-400);margin-bottom:.8rem;}
.seen-logos{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem 2.5rem;align-items:center;}
.seen-logos span{font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--red);font-weight:500;opacity:.85;transition:opacity .3s;}
.seen-logos span:hover{opacity:1;color:var(--red-dark);}

/* MARQUEE */
.marquee-wrap{overflow:hidden;padding:1.2rem 0;background:var(--black);white-space:nowrap;}
.marquee{display:inline-flex;animation:marquee 30s linear infinite;gap:0;}
.marquee span{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--gray-400);padding:0 1.5rem;font-weight:300;}
.marquee .dot{color:var(--red);font-size:.5rem;}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* PHILOSOPHY QUOTE */
.philosophy-quote{padding:5rem 0;background:var(--white);text-align:center;}
.philosophy-quote h2{font-family:'DM Serif Display',serif;font-size:clamp(1.6rem,3vw,2.2rem);color:var(--black);font-weight:400;margin-bottom:2rem;}
.phil-body{font-size:.92rem;color:var(--gray-600);line-height:2;max-width:750px;margin:0 auto;font-weight:300;}
.phil-sig{font-family:'DM Serif Display',serif;font-style:italic;color:var(--gray-400);margin-top:2rem;font-size:.95rem;}

/* EXPERIENCES GRID */
.experiences{padding:6rem 0;background:var(--off-white);}
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:1.2rem;}
.exp-card{text-decoration:none;display:block;background:var(--white);transition:all .4s;overflow:hidden;}
.exp-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08);}
.exp-img{aspect-ratio:3/4;overflow:hidden;}
.exp-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.exp-card:hover .exp-img img{transform:scale(1.05);}
.exp-info{padding:1.5rem;}
.exp-info h3{font-family:'DM Serif Display',serif;font-size:1rem;color:var(--black);font-weight:400;margin-bottom:.4rem;}
.exp-info p{font-size:.78rem;color:var(--gray-600);line-height:1.6;font-weight:300;}
.exp-price{display:block;margin-top:.8rem;font-size:.65rem;letter-spacing:1.5px;color:var(--red);font-weight:500;text-transform:uppercase;}
.exp-row-bottom{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
.exp-card-wide{text-decoration:none;display:block;padding:2rem;border:1px solid var(--gray-200);transition:all .4s;background:var(--white);}
.exp-card-wide:hover{border-color:var(--red);transform:translateY(-2px);}
.exp-wide-text h3{font-family:'DM Serif Display',serif;font-size:1rem;color:var(--black);font-weight:400;margin-bottom:.4rem;}
.exp-wide-text p{font-size:.78rem;color:var(--gray-600);line-height:1.6;font-weight:300;}

/* PHILOSOPHY BANDS */
.philosophy{padding:5rem 0;background:var(--white);}
.phil-band{display:flex;align-items:flex-start;gap:3rem;max-width:900px;margin:0 auto;padding:2.5rem 2rem;border-bottom:1px solid var(--gray-200);}
.phil-band:last-child{border-bottom:none;}
.phil-num{font-family:'DM Serif Display',serif;font-size:2.5rem;color:var(--gray-200);line-height:1;flex-shrink:0;width:60px;}
.phil-content h3{font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--black);font-weight:400;margin-bottom:.5rem;}
.phil-content p{font-size:.85rem;color:var(--gray-600);font-weight:300;line-height:1.8;}

/* TESTIMONIAL */
.testimonial{padding:6rem 0;background:var(--black);color:var(--white);text-align:center;}
.test-inner{max-width:750px;margin:0 auto;padding:0 2rem;}
.test-quote{font-family:'DM Serif Display',serif;font-size:5rem;color:var(--red);line-height:.5;margin-bottom:1.5rem;}
blockquote{font-family:'DM Serif Display',serif;font-size:1.1rem;font-style:italic;color:var(--gray-200);line-height:2;font-weight:400;}
.test-author{margin-top:2rem;font-size:.8rem;letter-spacing:1px;color:var(--white);font-weight:400;}
.test-author span{color:var(--gray-400);}

/* GALLERY */
.gallery{padding:5rem 0;background:var(--white);}
.gallery-scroll{display:flex;gap:1rem;overflow-x:auto;padding:0 2rem 1rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin;}
.gallery-scroll::-webkit-scrollbar{height:4px;}
.gallery-scroll::-webkit-scrollbar-thumb{background:var(--gray-200);}
.gal-item{flex:0 0 280px;aspect-ratio:4/5;overflow:hidden;flex-shrink:0;}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s;filter:saturate(.9);}
.gal-item:hover img{transform:scale(1.04);filter:saturate(1);}

/* S.P.A.C.E. METHOD */
.space-method{padding:6rem 0;background:var(--off-white);}
.space-logo{text-align:center;margin-bottom:2rem;}
.space-logo img{width:70px;height:auto;opacity:.9;}
.space-intro{text-align:center;font-size:.9rem;color:var(--gray-600);max-width:650px;margin:0 auto 3rem;line-height:1.9;font-weight:300;}
.space-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;}
.space-item{text-align:center;padding:2rem 1.2rem;border:1px solid var(--gray-200);background:var(--white);transition:all .3s;}
.space-item:hover{border-color:var(--red);transform:translateY(-3px);}
.space-letter{font-family:'DM Serif Display',serif;font-size:2.5rem;color:var(--red);display:block;margin-bottom:.5rem;line-height:1;}
.space-item h3{font-family:'DM Serif Display',serif;font-size:.95rem;color:var(--black);font-weight:400;margin-bottom:.6rem;}
.space-item p{font-size:.75rem;color:var(--gray-600);line-height:1.7;font-weight:300;}

/* CTA */
.cta{padding:6rem 0;background:var(--red);text-align:center;color:var(--white);}
.cta .label{color:rgba(255,255,255,.6);}
.cta h2{font-family:'DM Serif Display',serif;font-size:clamp(1.6rem,3vw,2.2rem);color:var(--white);font-weight:400;margin-bottom:1rem;}
.cta-sub{font-size:.9rem;color:rgba(255,255,255,.7);font-style:italic;margin-bottom:2rem;}

/* FOOTER */
footer{background:var(--off-white);border-top:1px solid var(--gray-200);}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.5fr;gap:3rem;max-width:1200px;margin:0 auto;padding:4rem 2rem 3rem;}
.footer-brand p{font-size:.8rem;color:var(--gray-400);margin-top:.5rem;font-style:italic;}
.footer-emblem{width:45px;height:auto;margin-top:.8rem;opacity:.6;}
.footer-col h4{font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--black);font-weight:500;margin-bottom:1rem;}
.footer-col a,.footer-col p{display:block;font-size:.78rem;color:var(--gray-600);text-decoration:none;margin-bottom:.5rem;transition:color .3s;}
.footer-col a:hover{color:var(--red);}
.footer-social{display:flex;gap:1rem;margin-top:.5rem;}
.footer-social a{font-size:.7rem!important;letter-spacing:1px;text-transform:uppercase;font-weight:500;}
.footer-bottom{text-align:center;padding:1.5rem 2rem;border-top:1px solid var(--gray-200);}
.footer-bottom p{font-size:.6rem;color:var(--gray-400);letter-spacing:1px;}

/* PAGE TOP */
.page-top{padding:8rem 2rem 3rem;text-align:center;background:var(--off-white);}
.page-top h1{font-family:'DM Serif Display',serif;font-size:clamp(2rem,4.5vw,3.2rem);color:var(--black);font-weight:400;}
.page-intro{font-size:.88rem;color:var(--gray-600);max-width:600px;margin:1rem auto 0;line-height:1.8;font-weight:300;}

/* BIO HERO */
.bio-hero{display:grid;grid-template-columns:1fr 1fr;min-height:80vh;background:var(--off-white);}
.bio-hero-img{overflow:hidden;}
.bio-hero-img img{width:100%;height:100%;object-fit:cover;display:block;}
.bio-hero-text{display:flex;flex-direction:column;justify-content:center;padding:4rem;}
.bio-hero-text h1{font-family:'DM Serif Display',serif;font-size:clamp(2.2rem,4vw,3.5rem);color:var(--black);font-weight:400;margin-bottom:.3rem;}
.role{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--gray-400);font-weight:400;margin-bottom:2rem;}
.bio-divider{width:40px;height:2px;background:var(--red);margin-bottom:2rem;}
.bio-quote span{font-family:'DM Serif Display',serif;font-size:3rem;color:var(--red);line-height:.5;display:block;margin-bottom:.5rem;}
.bio-quote p{font-family:'DM Serif Display',serif;font-size:1.3rem;font-style:italic;color:var(--gray-800);line-height:1.5;}
.bio-quote cite{font-size:.75rem;color:var(--gray-400);font-style:normal;letter-spacing:1px;}

/* BIO BODY */
.bio-body{padding:5rem 0;background:var(--white);}
.bio-body p{font-size:1rem;color:var(--gray-600);line-height:2.1;margin-bottom:1.5rem;font-weight:300;}

/* CREDENTIALS */
.credentials{padding:4rem 0;background:var(--off-white);}
.cred-row{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 0;border-bottom:1px solid var(--gray-200);max-width:720px;margin:0 auto;}
.cred-row span:first-child{font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--red);font-weight:500;}
.cred-row span:last-child{font-size:.88rem;color:var(--gray-800);text-align:right;font-weight:300;}

/* SERVICES */
.svc-block{padding:5rem 0;background:var(--white);}
.svc-block.alt{background:var(--off-white);}
.svc-header{max-width:800px;margin:0 auto 3rem;text-align:center;padding:0 2rem;}
.svc-name{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem;}
.svc-roman{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--gray-200);font-weight:400;}
.svc-header h2{font-family:'DM Serif Display',serif;font-size:1.8rem;color:var(--black);font-weight:400;}
.svc-header p{font-size:.88rem;color:var(--gray-600);line-height:1.8;font-weight:300;margin-top:.5rem;}

/* TIERS */
.tier-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1000px;margin:0 auto;padding:0 2rem;}
.tier-row-4{grid-template-columns:repeat(4,1fr);max-width:1200px;}
.tier-row-2{grid-template-columns:repeat(2,1fr);max-width:680px;}
.tier{padding:2.5rem 2rem;border:1px solid var(--gray-200);background:var(--white);position:relative;transition:all .3s;}
.tier:hover{border-color:var(--gray-400);}
.tier.featured{border-color:var(--red);}
.tier-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--red);color:var(--white);font-size:.55rem;letter-spacing:2px;text-transform:uppercase;padding:.3rem 1rem;font-weight:500;}
.tier h4{font-family:'DM Serif Display',serif;font-size:1rem;color:var(--black);font-weight:400;margin-bottom:.6rem;}
.tier-price{font-family:'DM Serif Display',serif;font-size:2.2rem;color:var(--red);font-weight:400;line-height:1;}
.tier-price span{font-size:.9rem;color:var(--gray-400);}
.tier-dur{font-size:.7rem;color:var(--gray-400);margin-bottom:1.5rem;letter-spacing:.5px;}
.tier ul{list-style:none;margin-bottom:2rem;}
.tier li{font-size:.78rem;color:var(--gray-600);padding:.4rem 0;border-bottom:1px solid var(--gray-100);font-weight:300;}
.tier li:last-child{border-bottom:none;}

/* ENHANCEMENTS */
.enhancements{padding:4rem 0;background:var(--off-white);}
.enh-row{display:flex;justify-content:space-between;align-items:center;padding:.9rem 0;border-bottom:1px solid var(--gray-200);}
.enh-row span:first-child{font-size:.88rem;color:var(--gray-800);font-weight:300;}
.enh-row span:last-child{font-size:.78rem;color:var(--red);font-weight:500;letter-spacing:.5px;}

/* CONTACT */
.contact-split{display:grid;grid-template-columns:1fr 1.2fr;gap:0;background:var(--white);}
.contact-left{padding:4rem 3rem;background:var(--off-white);}
.contact-left h2{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--black);font-weight:400;margin-bottom:1rem;}
.contact-left>p{font-size:.88rem;color:var(--gray-600);line-height:1.9;margin-bottom:2.5rem;font-weight:300;}
.contact-details{display:flex;flex-direction:column;gap:1.5rem;}
.cd-label{font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:var(--red);font-weight:500;display:block;margin-bottom:.3rem;}
.cd-item a,.cd-item p{font-size:.88rem;color:var(--gray-800);text-decoration:none;transition:color .3s;}
.cd-item a:hover{color:var(--red);}
.cd-note{font-size:.72rem!important;color:var(--gray-400)!important;margin-top:.2rem;}
.cd-socials{display:flex;gap:1.5rem;}
.cd-socials a{font-size:.7rem!important;letter-spacing:1px;text-transform:uppercase;font-weight:500;}

/* FORM */
.contact-right{padding:4rem 3rem;}
.contact-right h3{font-family:'DM Serif Display',serif;font-size:1.3rem;color:var(--black);font-weight:400;margin-bottom:.3rem;}
.form-note{font-size:.78rem;color:var(--gray-400);margin-bottom:2rem;}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.fg{margin-bottom:1.1rem;}
.fg label{display:block;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--gray-400);margin-bottom:.4rem;font-weight:400;}
.fg input,.fg select,.fg textarea{width:100%;padding:.75rem 1rem;background:var(--white);border:1px solid var(--gray-200);color:var(--black);font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:300;outline:none;transition:border-color .3s;border-radius:0;-webkit-appearance:none;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--red);}
.fg textarea{resize:vertical;min-height:100px;}
.fg select{cursor:pointer;}

/* INSTANT BOOKING */
.instant-booking{padding:5rem 0;background:var(--off-white);}
.instant-cards{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;}
.instant-card{padding:2.5rem;border:1px solid var(--gray-200);background:var(--white);text-align:center;min-width:260px;transition:border-color .3s;}
.instant-card:hover{border-color:var(--red);}
.instant-card h3{font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--black);font-weight:400;margin-bottom:.5rem;}
.instant-card p{font-size:.78rem;color:var(--gray-600);font-weight:300;}

/* FAQ */
.faq{padding:5rem 0;background:var(--off-white);}
.faq-item{padding:1.5rem 0;border-bottom:1px solid var(--gray-200);}
.faq-item h4{font-family:'DM Serif Display',serif;font-size:.95rem;color:var(--black);font-weight:400;margin-bottom:.5rem;}
.faq-item p{font-size:.82rem;color:var(--gray-600);font-weight:300;line-height:1.8;}

/* PERSONAL ASSISTANT */
.pa-section{padding:5rem 0;background:var(--white);}
.pa-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;}
.pa-block h2{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--black);font-weight:400;margin-bottom:1rem;}
.pa-block>p{font-size:.88rem;color:var(--gray-600);line-height:1.9;margin-bottom:1.5rem;font-weight:300;}
.pa-list{list-style:none;}
.pa-list li{font-size:.82rem;color:var(--gray-600);padding:.55rem 0;border-bottom:1px solid var(--gray-100);font-weight:300;padding-left:1.2rem;position:relative;}
.pa-list li::before{content:'';position:absolute;left:0;top:50%;width:4px;height:4px;background:var(--red);border-radius:50%;transform:translateY(-50%);}
.pa-pricing{padding:5rem 0;background:var(--off-white);}

/* PARTNERSHIPS */
.partner-section{padding:5rem 0;background:var(--white);}
.partner-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.partner-card{padding:3rem;border:1px solid var(--gray-200);transition:all .3s;}
.partner-card:hover{border-color:var(--red);transform:translateY(-3px);}
.partner-card h3{font-family:'DM Serif Display',serif;font-size:1.2rem;color:var(--black);font-weight:400;margin-bottom:1rem;}
.partner-card p{font-size:.85rem;color:var(--gray-600);line-height:1.8;font-weight:300;margin-bottom:1.5rem;}

/* PORTFOLIO */
.portfolio-gallery{padding:4rem 0;background:var(--white);}
.port-grid{display:columns;column-count:3;column-gap:1rem;}
.port-item{break-inside:avoid;margin-bottom:1rem;overflow:hidden;}
.port-item img{width:100%;display:block;transition:transform .4s;}
.port-item:hover img{transform:scale(1.03);}

/* REVIEWS */
.reviews-section{padding:4rem 0;background:var(--white);}
.review-card{max-width:720px;margin:0 auto 2.5rem;padding:2.5rem;border:1px solid var(--gray-200);transition:border-color .3s;}
.review-card:hover{border-color:var(--red);}
.review-stars{color:var(--red);font-size:1.2rem;margin-bottom:1rem;letter-spacing:2px;}
.review-card blockquote{font-family:'Outfit',sans-serif;font-size:.88rem;color:var(--gray-600);line-height:1.9;font-style:normal;font-weight:300;}
.review-author{margin-top:1.2rem;font-size:.78rem;letter-spacing:1px;color:var(--black);font-weight:400;}
.review-author span{color:var(--gray-400);}
.google-reviews-note{text-align:center;padding:2rem 0;}
.google-reviews-note p{font-size:.82rem;color:var(--gray-400);}
.google-reviews-note a{color:var(--red);text-decoration:none;font-weight:500;}

/* CHAT WIDGET */
.chat-widget{position:fixed;bottom:2rem;right:2rem;z-index:999;}
.chat-btn{display:flex;align-items:center;gap:.5rem;padding:.8rem 1.4rem;background:var(--red);color:var(--white);border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-size:.75rem;letter-spacing:1px;text-transform:uppercase;font-weight:500;transition:background .3s;box-shadow:0 4px 20px rgba(198,40,40,.3);}
.chat-btn:hover{background:var(--red-dark);}
.chat-btn svg{width:18px;height:18px;}
.chat-box{display:none;position:absolute;bottom:60px;right:0;width:350px;background:var(--white);border:1px solid var(--gray-200);box-shadow:0 10px 40px rgba(0,0,0,.1);}
.chat-box.open{display:flex;flex-direction:column;}
.chat-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:var(--black);color:var(--white);}
.chat-header strong{font-size:.75rem;letter-spacing:1px;text-transform:uppercase;}
.chat-header button{background:none;border:none;color:var(--white);font-size:1.2rem;cursor:pointer;}
.chat-messages{padding:1rem;min-height:200px;max-height:300px;overflow-y:auto;}
.chat-msg{font-size:.8rem;line-height:1.6;padding:.6rem .9rem;margin-bottom:.6rem;border-radius:2px;max-width:90%;}
.chat-msg.bot{background:var(--off-white);color:var(--gray-800);}
.chat-msg.user{background:var(--black);color:var(--white);margin-left:auto;}
.chat-input-wrap{display:flex;border-top:1px solid var(--gray-200);}
.chat-input-wrap input{flex:1;padding:.7rem 1rem;border:none;font-family:'Outfit',sans-serif;font-size:.82rem;outline:none;}
.chat-input-wrap button{padding:.7rem 1rem;background:var(--red);color:var(--white);border:none;font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-weight:500;}

/* LOCATION GRID */
.location-grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem 2rem;}
.location-grid li{padding:.5rem 0;border-bottom:1px solid var(--gray-100);}
.location-grid a{font-size:.82rem;color:var(--gray-600);text-decoration:none;font-weight:300;transition:color .3s;}
.location-grid a:hover{color:var(--red);}

/* RESPONSIVE */
@media(max-width:1024px){
  .exp-grid{grid-template-columns:repeat(2,1fr);}
  .exp-row-bottom{grid-template-columns:1fr;}
  .tier-row{grid-template-columns:1fr;max-width:400px;}
  .tier-row-4{grid-template-columns:repeat(2,1fr);max-width:700px;}
  .tier-row-2{grid-template-columns:1fr;max-width:400px;}
  .footer-top{grid-template-columns:repeat(2,1fr);}
  .pa-grid{grid-template-columns:1fr;}
  .partner-grid{grid-template-columns:1fr;}
  .port-grid{column-count:2;}
  .space-grid{grid-template-columns:repeat(3,1fr);}
  .location-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:768px){
  /* NAV */
  nav{padding:.8rem 1rem;}
  .nav-links,.nav-cta{display:none;}
  .menu-toggle{display:block;}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;width:100%;background:var(--white);padding:1.5rem;gap:1rem;border-bottom:1px solid var(--gray-200);box-shadow:0 10px 30px rgba(0,0,0,.05);z-index:200;}
  .logo-main{font-size:1.2rem;letter-spacing:4px;}
  .logo-top{font-size:.4rem;letter-spacing:4px;}
  .logo-bot{font-size:.35rem;letter-spacing:2px;}

  /* ANNOUNCE BAR */
  .announce-bar{flex-direction:column;gap:.3rem;text-align:center;padding:.5rem 1rem;font-size:.6rem;}

  /* HERO */
  .hero{grid-template-columns:1fr;min-height:auto;}
  .hero-img{aspect-ratio:3/4;max-height:50vh;}
  .hero-text{padding:2rem 1.2rem;text-align:center;align-items:center;}
  .hero-text h1{font-size:1.8rem;}
  .hero-text .subtitle{font-size:.82rem;text-align:center;}
  .hero-actions{justify-content:center;}
  .hero-stats{justify-content:center;flex-wrap:wrap;gap:1.5rem;}
  .hero-stats div{align-items:center;text-align:center;}

  /* AS SEEN ON */
  .seen-on{padding:1.2rem 1rem;}
  .seen-logos{gap:.8rem 1.2rem;}
  .seen-logos span{font-size:.55rem;letter-spacing:1.5px;}

  /* MARQUEE */
  .marquee span{font-size:.6rem;padding:0 1rem;}

  /* PHILOSOPHY QUOTE */
  .philosophy-quote{padding:3rem 0;}
  .philosophy-quote h2{font-size:1.4rem;padding:0 1rem;}
  .phil-body{font-size:.82rem;padding:0 .5rem;}
  .phil-sig{font-size:.82rem;}

  /* S.P.A.C.E. */
  .space-method{padding:3rem 0;}
  .space-grid{grid-template-columns:1fr;gap:1rem;max-width:400px;margin:0 auto;}
  .space-letter{font-size:2rem;}
  .space-item{padding:1.5rem 1rem;}
  .space-intro{font-size:.82rem;padding:0 .5rem;}

  /* EXPERIENCES GRID */
  .experiences{padding:3rem 0;}
  .exp-grid{grid-template-columns:1fr;gap:1rem;}
  .exp-row-bottom{grid-template-columns:1fr;gap:1rem;}
  .exp-card-wide{padding:1.5rem;}
  .exp-info{padding:1.2rem;}

  /* PROCESS BANDS */
  .philosophy{padding:3rem 0;}
  .phil-band{flex-direction:column;gap:.5rem;padding:1.5rem 1.2rem;}
  .phil-num{width:auto;font-size:2rem;}
  .phil-content h3{font-size:1rem;}
  .phil-content p{font-size:.8rem;}

  /* TESTIMONIAL */
  .testimonial{padding:3rem 0;}
  .test-quote{font-size:3rem;}
  blockquote{font-size:.92rem;line-height:1.8;}

  /* GALLERY */
  .gallery{padding:3rem 0;}
  .gallery-scroll{padding:0 1rem;}
  .gal-item{flex:0 0 200px;}

  /* CTA */
  .cta{padding:3.5rem 0;}
  .cta h2{font-size:1.3rem;padding:0 1rem;}
  .cta-sub{font-size:.8rem;padding:0 1rem;}

  /* PAGE TOP */
  .page-top{padding:6rem 1.2rem 2rem;text-align:center;}
  .page-top h1{font-size:1.8rem;}
  .page-intro{font-size:.82rem;margin-top:.8rem;}

  /* BIO HERO */
  .bio-hero{grid-template-columns:1fr;min-height:auto;}
  .bio-hero-img{aspect-ratio:3/4;max-height:50vh;}
  .bio-hero-text{padding:2rem 1.2rem;text-align:center;align-items:center;}
  .bio-hero-text h1{font-size:2rem;}
  .bio-divider{margin:1.5rem auto;}
  .bio-quote{text-align:center;}
  .bio-quote p{font-size:1.1rem;}

  /* BIO BODY */
  .bio-body{padding:3rem 0;}
  .bio-body p{font-size:.88rem;line-height:1.9;}

  /* CREDENTIALS */
  .credentials{padding:2.5rem 0;}
  .cred-row{flex-direction:column;align-items:flex-start;gap:.3rem;padding:.8rem 0;}
  .cred-row span:first-child{font-size:.6rem;}
  .cred-row span:last-child{text-align:left;font-size:.82rem;}

  /* VALUES */
  .val-grid{grid-template-columns:1fr;}

  /* SERVICES */
  .svc-block{padding:3rem 0;}
  .svc-header{padding:0 1.2rem;margin-bottom:2rem;}
  .svc-header h2{font-size:1.4rem;}
  .svc-header p{font-size:.82rem;}
  .svc-name{gap:.5rem;}
  .svc-roman{font-size:1.2rem;}

  /* TIERS */
  .tier-row{grid-template-columns:1fr;max-width:100%;padding:0 1.2rem;}
  .tier-row-4{grid-template-columns:1fr;max-width:100%;}
  .tier-row-2{grid-template-columns:1fr;max-width:100%;}
  .tier{padding:2rem 1.5rem;margin-bottom:0;}
  .tier-price{font-size:1.8rem;}
  .tier h4{font-size:.95rem;}

  /* ENHANCEMENTS */
  .enhancements{padding:3rem 0;}
  .enh-row{flex-direction:column;align-items:flex-start;gap:.2rem;padding:.7rem 0;}
  .enh-row span:first-child{font-size:.82rem;}
  .enh-row span:last-child{font-size:.72rem;}

  /* CONTACT */
  .contact-split{grid-template-columns:1fr;}
  .contact-left{padding:2.5rem 1.2rem;}
  .contact-left h2{font-size:1.3rem;}
  .contact-right{padding:2.5rem 1.2rem;}
  .contact-right h3{font-size:1.1rem;}
  .form-2col{grid-template-columns:1fr;}

  /* INSTANT BOOKING */
  .instant-booking{padding:3rem 0;}
  .instant-cards{flex-direction:column;align-items:center;gap:1rem;}
  .instant-card{width:100%;max-width:350px;}

  /* FAQ */
  .faq{padding:3rem 0;}
  .faq-item h4{font-size:.88rem;}
  .faq-item p{font-size:.78rem;}

  /* PA PAGE */
  .pa-section{padding:3rem 0;}
  .pa-grid{grid-template-columns:1fr;gap:2rem;}
  .pa-block h2{font-size:1.3rem;}
  .pa-list li{font-size:.78rem;}
  .pa-pricing{padding:3rem 0;}

  /* PARTNERSHIPS */
  .partner-grid{grid-template-columns:1fr;}
  .partner-card{padding:2rem 1.5rem;}
  .partner-card h3{font-size:1.05rem;}

  /* PORTFOLIO */
  .port-grid{column-count:2;column-gap:.5rem;}
  .port-item{margin-bottom:.5rem;}

  /* REVIEWS */
  .review-card{padding:1.8rem 1.2rem;margin-bottom:1.5rem;}
  .review-card blockquote{font-size:.82rem;}

  /* FOOTER */
  .footer-top{grid-template-columns:1fr;gap:1.5rem;padding:2.5rem 1.2rem 2rem;}
  .footer-brand{text-align:center;}
  .footer-col{text-align:center;}
  .footer-col h4{margin-bottom:.5rem;}
  .footer-social{justify-content:center;}
  .footer-bottom{padding:1rem;}

  /* CHAT */
  .chat-widget{bottom:1rem;right:1rem;}
  .chat-btn{padding:.6rem 1rem;font-size:.65rem;}
  .chat-btn span{display:none;}
  .chat-box{width:calc(100vw - 2rem);right:-0.5rem;}

  /* LOCATION GRID */
  .location-grid{grid-template-columns:1fr 1fr;gap:.3rem 1rem;}

  /* BUTTONS */
  .btn-dark,.btn-ghost,.btn-light{padding:.75rem 1.8rem;font-size:.65rem;}
  .section-head{margin-bottom:2rem;}
  .section-head h2{font-size:1.5rem;}
  .label{font-size:.6rem;letter-spacing:2.5px;}
}

/* EXTRA SMALL - phones under 400px */
@media(max-width:400px){
  .hero-text h1{font-size:1.5rem;}
  .hero-stats{gap:1rem;}
  .hero-stats strong{font-size:1.3rem;}
  .exp-grid{grid-template-columns:1fr;}
  .seen-logos span{font-size:.5rem;}
  .space-grid{max-width:100%;}
  .location-grid{grid-template-columns:1fr;}
  .page-top h1{font-size:1.5rem;}
  .bio-hero-text h1{font-size:1.6rem;}
  .cta h2{font-size:1.1rem;}
  .container,.container-wide,.container-narrow{padding:0 1rem;}
}
