@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Space+Grotesk:wght@400;500;600;700&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f3ede6;--bg2:#eae4dc;--white:#fff;
  --dark:#1a1a1a;--text:#1a1a1a;--text2:#555;--text3:#999;
  --border:rgba(0,0,0,.08);
  --sans:'DM Sans',-apple-system,sans-serif;
  --display:'Playfair Display',Georgia,serif;
  --brand:'Outfit',-apple-system,sans-serif;
  --max:1200px;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none;transition:.3s}
img{max-width:100%;display:block}

/* NAV */
.nav{position:fixed;top:0;width:100%;z-index:1000;background:var(--bg);border-bottom:1px solid var(--border)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:1.2rem 2rem;display:flex;justify-content:space-between;align-items:center}
.nav-brand{display:flex;align-items:center;gap:.6rem;line-height:1}
.nav-logo{width:78px;height:84px;flex-shrink:0}
.nav-bar{width:4px;height:68px;background:var(--dark);flex-shrink:0;border-radius:1px}
.nav-name{font-family:'Engravers MT','Copperplate Gothic Bold','Copperplate',sans-serif;font-size:3.8rem;font-weight:500;color:var(--text);letter-spacing:.06em;text-transform:uppercase;display:flex;flex-direction:column;line-height:1}
.nav-tagline{font-family:var(--sans);font-size:.8rem;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:var(--text3);margin-top:.4rem}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-size:.8rem;font-weight:500;color:var(--text2)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:20px;height:1.5px;background:var(--text)}

/* PILL BUTTONS */
.btn{display:inline-block;padding:.75rem 1.8rem;font-family:var(--sans);font-size:.8rem;font-weight:600;letter-spacing:.03em;border-radius:50px;cursor:pointer;transition:.3s;background:var(--dark);color:#fff;border:2px solid var(--dark)}
.btn:hover{background:transparent;color:var(--dark)}
.btn-outline{background:transparent;color:var(--dark);border:2px solid var(--dark)}
.btn-outline:hover{background:var(--dark);color:#fff}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center}
.hero>div:first-child{padding:6rem 3rem 4rem 4rem;max-width:600px;margin-left:auto}
.hero h1{font-family:var(--display);font-size:clamp(3rem,6vw,4.5rem);font-weight:400;font-style:italic;line-height:1.05;color:var(--text);margin-bottom:1.5rem}
.hero p{font-size:1rem;color:var(--text2);max-width:420px;line-height:1.7;margin-bottom:2rem}
.hero-img{position:relative;overflow:hidden;height:100%;min-height:100vh}
.hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* AUTHORITY SECTION */
.authority{padding:4rem 2rem;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.authority-inner{max-width:var(--max);margin:0 auto}
.authority-heading{margin-bottom:2.5rem}
.authority-heading h2{font-family:var(--display);font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:400}
.authority-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.authority-item{padding:1.5rem 0}
.authority-number{font-family:var(--display);font-size:1.8rem;font-weight:500;color:var(--text);margin-bottom:.5rem;line-height:1}
.authority-text{font-size:.85rem;color:var(--text2);line-height:1.7}

/* HORIZONTAL CARDS */
.services{padding:4rem 2rem;background:var(--bg)}
.services-inner{max-width:var(--max);margin:0 auto}
.services h2{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);font-weight:400;margin-bottom:2.5rem}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-card{background:var(--bg);overflow:hidden;transition:.3s}
.service-card:hover{transform:translateY(-2px)}
.service-card-img{border-radius:8px;overflow:hidden;margin-bottom:1rem;aspect-ratio:4/3}
.service-card-img img{width:100%;height:100%;object-fit:cover}
.service-card h3{font-size:.95rem;font-weight:600;margin-bottom:.3rem}
.service-card p{font-size:.82rem;color:var(--text3);line-height:1.6}

/* SPLIT */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:500px}
.split--reverse{direction:rtl}
.split--reverse>*{direction:ltr}
.split-img{position:relative;overflow:hidden;min-height:400px}
.split-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split-text{display:flex;align-items:center;padding:4rem 3.5rem}
.split-text h2{font-family:var(--display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:400;line-height:1.1;margin-bottom:1rem}
.split-text p{font-size:.95rem;color:var(--text2);line-height:1.8;margin-bottom:1.5rem}

/* SCROLLING TEXT */
.scroll-banner{padding:2.5rem 0;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.scroll-track{display:flex;animation:scroll 25s linear infinite;white-space:nowrap}
.scroll-track h2{font-family:var(--display);font-size:clamp(2rem,4vw,3.2rem);font-weight:400;font-style:italic;color:var(--text);padding:0 3rem;flex-shrink:0;opacity:.5}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* EVOLVING SECTION */
.evolving{padding:5rem 2rem;background:var(--bg)}
.evolving-inner{max-width:var(--max);margin:0 auto}
.evolving-top{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:3rem;align-items:start}
.evolving-top h2{font-family:var(--display);font-size:clamp(2.2rem,4.5vw,3.5rem);font-weight:400;line-height:1.05}
.evolving-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.evolving-cols p{font-size:.9rem;color:var(--text2);line-height:1.75}
.evolving-cols a{color:var(--text);text-decoration:underline}
.evolving-img{width:100%;border-radius:8px;overflow:hidden;max-height:500px}
.evolving-img img{width:100%;height:100%;object-fit:cover;border-radius:8px}

/* TILTED IMAGE GALLERY */
.gallery{padding:4rem 2rem;background:var(--bg)}
.gallery-inner{max-width:var(--max);margin:0 auto}
.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem}
.gallery-header h2{font-family:var(--display);font-size:clamp(1.5rem,3vw,2rem);font-weight:400}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.gallery-item{border-radius:8px;overflow:hidden;transition:transform .3s;aspect-ratio:3/4}
.gallery-item:hover{transform:scale(1.02)}
.gallery-item img{width:100%;height:100%;object-fit:cover}

/* CTA */
.cta{position:relative;padding:5rem 2rem;text-align:center;min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cta-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-bg::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.75)}
.cta-inner{position:relative;z-index:1;max-width:450px}
.cta h2{font-family:var(--display);font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:400;font-style:italic;margin-bottom:.8rem}
.cta p{color:var(--text2);font-size:.9rem;margin-bottom:1.5rem}

/* PAGE HERO */
.page-hero{display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:50vh}
.page-hero>div:first-child{padding:9rem 3rem 3rem 4rem;max-width:600px;margin-left:auto}
.page-hero h1{font-family:var(--display);font-size:clamp(2.5rem,5vw,3.8rem);font-weight:400;font-style:italic;line-height:1.05;margin-bottom:1rem}
.page-hero p{font-size:1rem;color:var(--text2);line-height:1.7;max-width:450px}
.page-hero-img{position:relative;overflow:hidden;height:100%;min-height:50vh}
.page-hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

.section-tag{font-size:.68rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--text3);margin-bottom:1rem}
.expertise-list{list-style:none;margin-top:1.5rem}
.expertise-list li{padding:.7rem 0;border-bottom:1px solid var(--border);font-size:.9rem;color:var(--text2);padding-left:1.3rem;position:relative}
.expertise-list li::before{content:'→';position:absolute;left:0;color:var(--text3)}
.callout{border-left:3px solid var(--border);padding:1.5rem 2rem;margin-top:1.5rem;background:rgba(0,0,0,.02);border-radius:0 8px 8px 0}
.callout p{font-family:var(--display);font-size:1.05rem;font-style:italic;color:var(--text2);line-height:1.7}

/* CONTACT */
.contact-section{padding:5rem 2rem;background:var(--bg)}
.contact-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem}
.contact-block{margin-bottom:2rem}
.contact-label{font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:.4rem}
.contact-value{font-size:1rem;color:var(--text2);line-height:1.7}
.contact-value a:hover{color:var(--dark)}
.contact-form{margin-top:1rem}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:.4rem}
.form-group input,.form-group textarea{width:100%;padding:.85rem 1rem;background:var(--white);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--sans);font-size:.95rem;outline:none;transition:.3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--dark)}
.form-group textarea{resize:vertical;min-height:120px}

.footer{background:var(--bg2);padding:2.5rem 2rem;text-align:center;border-top:1px solid var(--border)}
.footer p{font-size:.75rem;color:var(--text3);line-height:1.8}
.footer-disclaimer{margin-top:.5rem;max-width:550px;margin-left:auto;margin-right:auto}

.fade-in{opacity:0;transform:translateY(16px);transition:opacity .7s,transform .7s}
.fade-in.visible{opacity:1;transform:translateY(0)}

@media(max-width:900px){
  .hero,.page-hero{grid-template-columns:1fr}
  .hero>div:first-child,.page-hero>div:first-child{padding:5rem 2rem 2rem;margin:0;max-width:none}
  .hero-img{min-height:50vh;height:50vh}
  .page-hero-img{min-height:40vh}
  .split{grid-template-columns:1fr}
  .split--reverse{direction:ltr}
  .split-img{min-height:300px}
  .split-text{padding:3rem 2rem}
  .services-grid{grid-template-columns:1fr}
  .authority-grid{grid-template-columns:1fr 1fr}
  .evolving-top{grid-template-columns:1fr}
  .evolving-cols{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .contact-inner{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--bg);padding:1.5rem 2rem 2rem;gap:1.2rem;border-bottom:1px solid var(--border)}
  .nav-toggle{display:flex}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item,.gallery-item:nth-child(2),.gallery-item:nth-child(3),.gallery-item:nth-child(4){transform:none}
}
