:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --accent:#f59e0b;
  --accent-2:#eab308;
  --primary:#0f172a;
  --surface:#f8fafc;
  --ring: 0 0 0 3px rgb(245 158 11 / .35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1152px;margin-inline:auto;padding:0 1rem}
.flex{display:flex}.between{justify-content:space-between}.center{align-items:center}
.grid-2{display:grid;gap:2rem;grid-template-columns:1fr}
.grid-4{display:grid;gap:2rem;grid-template-columns:repeat(1,1fr)}
@media(min-width:900px){.grid-2{grid-template-columns:1.1fr .9fr}.grid-4{grid-template-columns:1.4fr repeat(3,1fr)}}

.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#fff;color:#000;padding:.5rem .75rem;border-radius:.5rem;box-shadow:0 2px 10px rgb(0 0 0 / .2)}

.site-header{position:sticky;top:0;z-index:50;background:rgb(255 255 255 / .9);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid #eee}
.brand{display:inline-flex;gap:.6rem;align-items:center;font-weight:700}
.brand span{font-size:1.1rem}
.nav{display:none;gap:1.25rem;align-items:center}
.nav a{padding:.6rem .2rem}
.nav a.btn{padding:.7rem 1rem}
.nav-toggle{display:inline-flex;flex-direction:column;gap:4px;background:transparent;border:0}
.nav-toggle span{width:26px;height:2px;background:#0f172a;display:block}
@media(min-width:900px){.nav{display:flex}.nav-toggle{display:none}}

.btn{display:inline-flex;gap:.5rem;align-items:center;justify-content:center;padding:.8rem 1rem;border-radius:.6rem;border:1px solid #e5e7eb;transition:transform .1s ease, background .2s ease}
.btn-primary{background:var(--primary);color:#fff;border-color:transparent}
.btn-accent{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#111;border-color:transparent;font-weight:700}
.btn-ghost{background:transparent}
.btn:active{transform:translateY(1px)}

.hero{position:relative;min-height:76vh;display:grid;place-items:center;overflow:hidden}
.hero picture img{position:absolute;inset:0;min-width:100%;min-height:100%;object-fit:cover;filter:saturate(105%) contrast(102%) brightness(95%)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgb(15 23 42 / .65), rgb(15 23 42 / .35))}
.hero-content{position:relative;color:#fff;text-align:left;padding:5rem 0}
.eyebrow{display:inline-block;background:rgb(255 255 255 / .1);padding:.4rem .75rem;border-radius:999px;margin-bottom:1rem;font-weight:600}
.hero h1{font-size:2.2rem;line-height:1.1;margin:0 0 1rem}
.hero h1 .accent{background:linear-gradient(90deg,#fde047,#f59e0b);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:1.1rem;opacity:.92;max-width:52ch}
.cta-row{display:flex;gap:.8rem;margin:1.2rem 0 1.6rem;flex-wrap:wrap}
.stats{list-style:none;display:flex;gap:2rem;padding:0;margin:1rem 0 0}
.stats li{display:grid;gap:.2rem;opacity:.95}
.stats strong{font-size:1.5rem}
@media(min-width:900px){.hero h1{font-size:3.25rem}.lead{font-size:1.175rem}}

.section{padding:4.5rem 0}
.section.alt{background:var(--surface)}
.badge{display:inline-block;background:#fef3c7;color:#92400e;padding:.35rem .7rem;border-radius:999px;font-weight:600;margin-bottom:.75rem}
.muted{color:var(--muted)}

.feature-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem 1rem;padding-left:1rem}
.feature-list li{position:relative}
.feature-list li::before{content:"";position:absolute;left:-1rem;top:.5rem;width:.45rem;height:.45rem;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}

.about-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}
.about-gallery img{border-radius:.75rem;box-shadow:0 10px 24px rgb(0 0 0 / .1)}

.cards{display:grid;grid-template-columns:repeat(1, minmax(0, 1fr));gap:1rem;margin-top:1.25rem}
.card{background:#fff;border:1px solid #eee;border-radius:1rem;padding:1.2rem}
.card h3{margin:.25rem 0 .5rem}
.card ul{margin:.75rem 0 0 1rem}
@media(min-width:800px){.cards{grid-template-columns:repeat(3, minmax(0,1fr))}}

.timeline{display:grid;gap:1rem;list-style:none;padding:0;margin:1rem 0 0}
.timeline li{background:#fff;border:1px solid #eee;border-radius:1rem;padding:1rem}
.timeline h3{margin:.2rem 0 .4rem}

.masonry{columns:1;column-gap:1rem}
.folio{break-inside:avoid;border:1px solid #eee;border-radius:1rem;overflow:hidden;margin:0 0 1rem;background:#fff}
.folio img{width:100%;height:auto;display:block}
.folio-meta{padding:.9rem}
@media(min-width:800px){.masonry{columns:2}}
@media(min-width:1100px){.masonry{columns:3}}

.chips{display:flex;flex-wrap:wrap;gap:.6rem;list-style:none;padding:0;margin:1rem 0}
.chips li{border:1px solid #e5e7eb;border-radius:999px;padding:.4rem .75rem;background:#fff}
.map-card{position:relative;margin-top:1rem;border:1px solid #eee;border-radius:1rem;overflow:hidden}
.map-badges{position:absolute;inset:auto 1rem 1rem auto;display:flex;flex-direction:column;gap:.4rem}
.map-badges span{background:rgb(255 255 255 /.9);backdrop-filter:blur(6px);padding:.35rem .6rem;border-radius:.5rem;border:1px solid #eee;font-size:.85rem}

.contact .contact-cards{list-style:none;padding:0;margin:1rem 0;display:grid;gap:.5rem}
.form{background:#fff;border:1px solid #eee;border-radius:1rem;padding:1rem}
.form .grid{display:grid;grid-template-columns:1fr;gap:.75rem}
label{display:grid;gap:.4rem;font-weight:600}
input,select,textarea{width:100%;border:1px solid #e5e7eb;border-radius:.6rem;padding:.7rem .8rem;font:inherit}
input:focus,select:focus,textarea:focus{outline: none;box-shadow: var(--ring);}
.form-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.75rem}
.tiny{font-size:.85rem;color:var(--muted)}

.site-footer{background:#0f172a;color:#e5e7eb;padding:2.5rem 0;margin-top:2rem}
.site-footer .brand span{color:#fff}
.site-footer h4{margin:.2rem 0 .7rem}
.site-footer .list{list-style:none;padding:0;margin:0;display:grid;gap:.35rem}
.site-footer .muted,.site-footer .tiny{color:#b6c3d3}

.reduce-motion *{animation:none!important;transition:none!important}

/* --- Mobile nav open state fix (added Aug 13, 2025) --- */
.site-header .container{position:relative}
@media(max-width:899px){
  .nav.open{
    display:flex;
    position:absolute;
    right:1rem;
    top:100%;
    background:var(--bg);
    border:1px solid #e5e7eb;
    border-radius:.75rem;
    padding:.75rem;
    box-shadow:0 10px 20px rgb(0 0 0 / .08);
    flex-direction:column;
    gap:.25rem;
    z-index:1000;
  }
  .nav.open a{display:block;padding:.75rem 1rem}
}
/* --- End mobile nav fix --- */


/* Performance: avoid rendering offscreen sections until needed (no visual change) */
.section{content-visibility:auto;contain-intrinsic-size:1px 800px}

/* Hint browser about color scheme */
:root{color-scheme:light}
