
:root {
  /* ★ BRAND COLORS — edit to rebrand */
  --ink:     #0b1929;   /* deep ocean navy */
  --navy:    #122542;   /* rich navy */
  --steel:   #1e3a5f;   /* steel blue */
  --wave:    #2a6496;   /* wave blue */
  --sky:     #4a9fd4;   /* sky blue accent */
  --gold:    #c8960c;   /* nautical brass */
  --sand:    #f5f0e8;   /* warm sand */
  --paper:   #fdfcf9;   /* off-white paper */
  --mist:    #e8edf5;   /* light blue mist */
  --slate:   #5a6e84;   /* slate text */
  --rule:    rgba(11,25,41,.1);

  /* Fonts */
  --f-serif:  'Cormorant Garamond', serif;
  --f-sans:   'Barlow', sans-serif;
  --f-cond:   'Barlow Condensed', sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--ink);font-family:var(--f-sans);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:inherit}
.wrap{width:min(100%,1320px);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,4rem)}

/* ═══════════════════════════════════════════════════
  NAV
   ═══════════════════════════════════════════════════ */
#topbar{
  background:var(--ink);
  padding:.45rem 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.72rem;font-family:var(--f-cond);letter-spacing:.08em;font-weight:600;color:rgba(255,255,255,.45)}
.topbar-phones{display:flex;gap:1.5rem}
.topbar-phones a{color:rgba(255,255,255,.7);transition:color .2s}
.topbar-phones a:hover{color:var(--gold)}
.topbar-right{display:flex;gap:1.5rem;align-items:center}
.topbar-right a{color:rgba(255,255,255,.45);transition:color .2s}
.topbar-right a:hover{color:var(--gold)}

#nav{
  position:fixed;top:0;width:100%;z-index:900;
  transition:top .35s,background .35s,box-shadow .35s,padding .3s;
  background:transparent;padding:1.4rem 0;
}
#nav.has-topbar{top:32px}
#nav.scrolled{
  top:0 !important;background:var(--ink);
  box-shadow:0 4px 40px rgba(0,0,0,.35);padding:.8rem 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}

/* LOGO */
/* LOGO */
.logo-wrap{display:flex;align-items:center;flex-shrink:0}
.logo-img{
  height:52px;
  width:auto;
  display:block;
  object-fit:contain;
}

/* cuando el nav hace scroll y se vuelve sólido, el logo puede agrandarse un poco */
#nav.scrolled .logo-img{
  height:44px;
}

.nav-links{display:flex;gap:.1rem;list-style:none}
.nav-links a{
  font-family:var(--f-cond);font-size:.78rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  padding:.5rem .9rem;border-radius:5px;
  transition:color .2s,background .2s;
}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.07)}

.nav-right{display:flex;align-items:center;gap:.9rem;flex-shrink:0}

/* Language toggle */
.lang-pill{
  display:flex;border:1px solid rgba(255,255,255,.18);
  border-radius:100px;overflow:hidden;
}
.lang-pill button{
  font-family:var(--f-cond);font-size:.68rem;font-weight:700;
  letter-spacing:.1em;padding:.38rem .8rem;
  background:transparent;border:none;color:rgba(255,255,255,.4);
  transition:background .2s,color .2s;
}
.lang-pill button.on{background:var(--wave);color:#fff}

.btn-cta{
  font-family:var(--f-cond);font-size:.78rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;
  background:var(--gold);color:var(--ink);
  padding:.6rem 1.5rem;border:none;border-radius:6px;
  transition:background .25s,transform .2s;white-space:nowrap;
}
.btn-cta:hover{background:#daa80d;transform:translateY(-1px)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Drawer */
.drawer{
  display:none;position:fixed;inset:0;z-index:800;
  background:var(--ink);flex-direction:column;align-items:center;justify-content:center;gap:0;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.drawer.open{opacity:1;pointer-events:all}
.drawer ul{list-style:none;display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:2rem}
.drawer ul a{
  font-family:var(--f-serif);font-size:2.2rem;font-style:italic;font-weight:600;
  color:rgba(255,255,255,.8);padding:.3rem 1rem;display:block;transition:color .2s;
}
.drawer ul a:hover{color:var(--gold)}
.drawer-contact{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.drawer-contact a{font-family:var(--f-cond);font-size:1rem;font-weight:700;letter-spacing:.05em;color:var(--gold)}
.drawer .lang-pill{margin-top:1.5rem;border-color:rgba(255,255,255,.2)}

/* ═══════════════════════════════════════════════════
  HERO — split editorial layout
   ═══════════════════════════════════════════════════ */
.hero{
  min-height:100svh;
  display:grid;grid-template-columns:1fr 1fr;
  position:relative;overflow:hidden;
}

/* LEFT dark panel */
.hero-left{
  background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(7rem,10vw,9rem) clamp(2rem,5vw,5rem) clamp(3rem,5vw,5rem);
  position:relative;z-index:2;
}
/* diagonal cut */
.hero-left::after{
  content:'';position:absolute;top:0;right:-80px;bottom:0;width:160px;
  background:var(--ink);
  clip-path:polygon(0 0,55% 0,100% 100%,0 100%);
  z-index:1;
}

.hero-kicker{
  font-family:var(--f-cond);font-size:.72rem;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.6rem;
  display:flex;align-items:center;gap:.8rem;
}
.hero-kicker::before{content:'';width:2.5rem;height:2px;background:var(--gold);flex-shrink:0}

.hero h1{
  font-family:var(--f-serif);
  font-size:clamp(3rem,6vw,6.5rem);
  font-weight:700;line-height:.92;
  letter-spacing:-.02em;color:#fff;
  margin-bottom:2rem;font-style:italic;
}
.hero h1 strong{
  font-style:normal;font-weight:700;
  color:transparent;
  -webkit-text-stroke:1.5px var(--sky);
  display:block;font-family:var(--f-cond);
  font-size:.6em;letter-spacing:.05em;
  text-transform:uppercase;font-style:normal;
  margin-bottom:.3rem;
}
.hero-desc{
  font-size:clamp(.88rem,1.2vw,1rem);font-weight:300;
  color:rgba(255,255,255,.6);line-height:1.8;
  max-width:420px;margin-bottom:2.8rem;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}

.btn-hero-primary{
  font-family:var(--f-cond);font-size:.82rem;font-weight:800;
  letter-spacing:.15em;text-transform:uppercase;
  background:var(--gold);color:var(--ink);
  padding:1.05rem 2.5rem;border:none;border-radius:6px;
  box-shadow:0 6px 28px rgba(200,150,12,.4);
  transition:background .25s,transform .2s,box-shadow .25s;
}
.btn-hero-primary:hover{background:#daa80d;transform:translateY(-2px);box-shadow:0 10px 36px rgba(200,150,12,.5)}

.btn-hero-ghost{
  font-family:var(--f-cond);font-size:.82rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.75);
  border:1.5px solid rgba(255,255,255,.2);
  padding:1rem 2rem;border-radius:6px;
  transition:border-color .25s,color .25s;
}
.btn-hero-ghost:hover{border-color:var(--sky);color:var(--sky)}

/* phone row */
.hero-phones{
  margin-top:2.8rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;gap:.4rem;
}
.hero-phones small{
  font-family:var(--f-cond);font-size:.62rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:.2rem;display:block;
}
.hero-phones a{
  font-family:var(--f-cond);font-size:1.1rem;font-weight:700;
  letter-spacing:.04em;color:rgba(255,255,255,.88);
  transition:color .2s;display:flex;align-items:center;gap:.5rem;
}
.hero-phones a:hover{color:var(--gold)}

/* RIGHT image panel */
.hero-right{position:relative;overflow:hidden}
.hero-right img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.65) saturate(.9);
  animation:hzoom 20s ease-in-out infinite alternate;
}
@keyframes hzoom{from{transform:scale(1)}to{transform:scale(1.07)}}

/* overlay gradient on image */
.hero-right::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(to right, rgba(11,25,41,.6) 0%, transparent 40%),
            linear-gradient(to top, rgba(11,25,41,.7) 0%, transparent 50%);
}

/* Floating stats */
.hero-stats{
  position:absolute;bottom:2.5rem;right:2.5rem;z-index:2;
  display:flex;flex-direction:column;gap:.8rem;align-items:flex-end;
}
.stat-chip{
  background:rgba(11,25,41,.85);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);
  border-left:3px solid var(--gold);
  border-radius:0 8px 8px 0;
  padding:.9rem 1.4rem;display:flex;align-items:center;gap:1rem;
  min-width:160px;
}
.stat-n{font-family:var(--f-cond);font-size:2rem;font-weight:800;color:var(--gold);line-height:1}
.stat-l{font-family:var(--f-cond);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);line-height:1.3}

/* ═══════════════════════════════════════════════════
  MARQUEE RIBBON
   ═══════════════════════════════════════════════════ */
.ribbon{background:var(--wave);padding:1.2rem 0;overflow:hidden}
.ribbon-track{
  display:flex;gap:3rem;
  animation:marquee 28s linear infinite;width:max-content;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ribbon-item{
  font-family:var(--f-cond);font-size:.75rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.9);white-space:nowrap;
  display:flex;align-items:center;gap:.8rem;flex-shrink:0;
}
.rdot{width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0}

/* ═══════════════════════════════════════════════════
  ABOUT
   ═══════════════════════════════════════════════════ */
.about{padding:clamp(5rem,9vw,8rem) 0;background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,7vw,7rem);align-items:center}

/* image stack */
.about-visual{position:relative;height:580px}
.av-main{
  position:absolute;top:0;left:0;right:80px;bottom:80px;
  border-radius:12px;overflow:hidden;
  box-shadow:0 24px 70px rgba(11,25,41,.18);
}
.av-main img{width:100%;height:100%;object-fit:cover}
.av-accent{
  position:absolute;bottom:0;right:0;width:54%;height:52%;
  border-radius:12px;overflow:hidden;
  box-shadow:0 16px 48px rgba(11,25,41,.22);
  border:5px solid var(--paper);
}
.av-accent img{width:100%;height:100%;object-fit:cover}
.av-badge{
  position:absolute;top:2.5rem;right:-1px;
  background:var(--navy);color:#fff;
  font-family:var(--f-cond);font-size:.72rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  padding:.65rem 1.4rem;border-radius:8px 0 0 8px;
  box-shadow:-6px 4px 20px rgba(0,0,0,.25);
  border-left:3px solid var(--gold);
}
.av-year{
  position:absolute;bottom:5rem;left:-1.5rem;
  width:4.5rem;height:4.5rem;border-radius:50%;
  background:var(--gold);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(200,150,12,.4);
  font-family:var(--f-cond);
}
.av-year span:first-child{font-size:1.3rem;font-weight:800;color:var(--ink);line-height:1}
.av-year span:last-child{font-size:.52rem;font-weight:700;letter-spacing:.08em;color:var(--ink);opacity:.7}

/* about text */
.about-text{}
.eyebrow{
  font-family:var(--f-cond);font-size:.72rem;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;color:var(--wave);
  display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;
}
.eyebrow::before{content:'';width:2rem;height:2px;background:var(--wave);flex-shrink:0}
.about-text h2{
  font-family:var(--f-serif);
  font-size:clamp(2.2rem,4vw,3.4rem);
  font-weight:600;font-style:italic;
  line-height:1.1;color:var(--ink);margin-bottom:1.5rem;
}
.about-text h2 em{font-style:normal;color:var(--wave)}
.about-text p{color:var(--slate);line-height:1.85;font-size:.95rem;margin-bottom:1rem;font-weight:300}

.pillars{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-top:2rem}
.pill{
  background:var(--mist);border-radius:10px;padding:1.2rem;
  border-left:3px solid var(--wave);
  display:flex;align-items:flex-start;gap:.8rem;
}
.pill-ico{font-size:1.3rem;flex-shrink:0;margin-top:.1rem}
.pill h4{
  font-family:var(--f-cond);font-size:.75rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--navy);margin-bottom:.25rem;
}
.pill p{font-size:.8rem;color:var(--slate);line-height:1.5}

/* ═══════════════════════════════════════════════════
  PROJECTS
   ═══════════════════════════════════════════════════ */
.projects{padding:clamp(5rem,9vw,8rem) 0;background:var(--sand)}

.sh{margin-bottom:clamp(2rem,4vw,3.5rem)}
.sh-eyebrow{
  font-family:var(--f-cond);font-size:.72rem;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;color:var(--wave);
  display:flex;align-items:center;gap:.7rem;margin-bottom:.8rem;
}
.sh-eyebrow::before{content:'';width:2rem;height:2px;background:var(--wave);flex-shrink:0}
.sh h2{
  font-family:var(--f-serif);font-size:clamp(2rem,4vw,3.2rem);
  font-weight:600;font-style:italic;color:var(--ink);
}
.sh p{color:var(--slate);font-size:.95rem;margin-top:.6rem}

/* Filters */
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.2rem}
.fbtn{
  font-family:var(--f-cond);font-size:.7rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.48rem 1.2rem;border-radius:100px;
  border:1.5px solid rgba(11,25,41,.18);background:transparent;
  color:var(--slate);transition:all .25s;
}
.fbtn:hover{border-color:var(--wave);color:var(--wave)}
.fbtn.on{background:var(--navy);border-color:var(--navy);color:#fff}

/* Grid */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}

.proj{
  background:var(--paper);border-radius:12px;overflow:hidden;
  box-shadow:0 2px 20px rgba(11,25,41,.07);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s;
  display:block;color:inherit;text-decoration:none;
}
.proj:hover{transform:translateY(-7px);box-shadow:0 20px 50px rgba(11,25,41,.15)}

.proj-thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.proj-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease,filter .4s;
  filter:brightness(.88) saturate(.9);
}
.proj:hover .proj-thumb img{transform:scale(1.07);filter:brightness(.75) saturate(.8)}

.proj-cat{
  position:absolute;top:.85rem;left:.85rem;
  font-family:var(--f-cond);font-size:.62rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  background:var(--navy);color:#fff;
  padding:.28rem .75rem;border-radius:100px;
}
.proj-media{
  position:absolute;bottom:.85rem;right:.85rem;
  display:flex;gap:.4rem;
}
.proj-pill{
  font-family:var(--f-cond);font-size:.6rem;font-weight:700;
  background:rgba(11,25,41,.78);backdrop-filter:blur(6px);
  color:rgba(255,255,255,.9);padding:.25rem .65rem;border-radius:100px;
}
/* new tab arrow */
.proj-newtab{
  position:absolute;top:.85rem;right:.85rem;
  width:2rem;height:2rem;border-radius:50%;
  background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:.78rem;color:var(--ink);font-weight:800;
  opacity:0;transform:scale(.6) rotate(-45deg);
  transition:opacity .3s,transform .3s;
}
.proj:hover .proj-newtab{opacity:1;transform:scale(1) rotate(0)}

.proj-body{padding:1.1rem 1.3rem}
.proj-name{
  font-family:var(--f-cond);font-size:1rem;font-weight:800;
  letter-spacing:-.01em;text-transform:uppercase;
  color:var(--navy);margin-bottom:.3rem;line-height:1.2;
}
.proj-desc{font-size:.8rem;color:var(--slate);line-height:1.5}

.proj-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding:.85rem 1.3rem;
  border-top:1px solid var(--rule);
}
.proj-loc{font-family:var(--f-cond);font-size:.68rem;font-weight:600;letter-spacing:.1em;color:var(--slate)}
.proj-link{
  font-family:var(--f-cond);font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--wave);display:flex;align-items:center;gap:.3rem;
  transition:gap .2s,color .2s;
}
.proj:hover .proj-link{gap:.6rem;color:var(--gold)}

/* Social gallery links */
.gal-links{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.8rem}
.gal-link{
  display:flex;align-items:center;gap:.8rem;
  padding:.95rem 1.8rem;border-radius:10px;
  border:1.5px solid rgba(11,25,41,.15);background:var(--paper);
  font-family:var(--f-cond);font-size:.75rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--navy);
  box-shadow:0 2px 14px rgba(11,25,41,.06);
  transition:border-color .25s,box-shadow .25s,transform .2s;
}
.gal-link:hover{border-color:var(--wave);box-shadow:0 8px 28px rgba(42,100,150,.15);transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════
  SERVICES
   ═══════════════════════════════════════════════════ */
.services{
  padding:clamp(5rem,9vw,8rem) 0;
  background:var(--navy);
  position:relative;overflow:hidden;
}
.services::before{
  content:'MARITIME';
  position:absolute;bottom:-2rem;right:-2rem;
  font-family:var(--f-cond);font-size:clamp(6rem,14vw,14rem);
  font-weight:800;color:rgba(255,255,255,.025);
  letter-spacing:-.04em;pointer-events:none;line-height:1;
}
.services .sh-eyebrow{color:var(--gold)}
.services .sh-eyebrow::before{background:var(--gold)}
.services .sh h2{color:#fff}
.services .sh p{color:rgba(255,255,255,.45)}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05)}
.svc{
  background:var(--navy);padding:2.5rem 2rem;position:relative;overflow:hidden;
  transition:background .35s;
}
.svc:hover{background:var(--steel)}
.svc::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:3px;background:var(--gold);transition:width .45s;
}
.svc:hover::after{width:100%}
.svc-n{
  font-family:var(--f-cond);font-size:5rem;font-weight:800;
  color:rgba(255,255,255,.04);line-height:1;
  position:absolute;top:.8rem;right:1.5rem;pointer-events:none;
}
.svc-ico{font-size:2rem;margin-bottom:1.2rem}
.svc h3{
  font-family:var(--f-cond);font-size:.92rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;
  color:#fff;margin-bottom:.7rem;
}
.svc p{font-size:.84rem;color:rgba(255,255,255,.45);line-height:1.75;font-weight:300}

/* ═══════════════════════════════════════════════════
  CONTACT
   ═══════════════════════════════════════════════════ */
.contact{padding:clamp(5rem,9vw,8rem) 0;background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,6rem);align-items:start}

.cinfo h2{
  font-family:var(--f-serif);font-size:clamp(2rem,3.5vw,3rem);
  font-weight:600;font-style:italic;line-height:1.1;
  color:var(--ink);margin-bottom:1rem;
}
.cinfo h2 em{font-style:normal;color:var(--wave)}
.cinfo>p{color:var(--slate);line-height:1.85;font-size:.95rem;margin-bottom:2rem;font-weight:300}

.ccard-list{display:flex;flex-direction:column;gap:.8rem}
.ccard{
  display:flex;align-items:center;gap:1rem;
  background:var(--mist);border-radius:10px;padding:1rem 1.2rem;
  border:1px solid var(--rule);
  transition:border-color .25s,box-shadow .25s;
}
.ccard:hover{border-color:var(--wave);box-shadow:0 4px 22px rgba(42,100,150,.12)}
.ccard-ico{
  width:2.8rem;height:2.8rem;border-radius:8px;
  background:var(--navy);display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.ccard-l{font-family:var(--f-cond);font-size:.6rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--slate)}
.ccard-v{font-family:var(--f-cond);font-size:1.05rem;font-weight:700;color:var(--navy);letter-spacing:.02em}

/* Form */
.cform-wrap{
  background:var(--paper);border-radius:14px;padding:2.5rem;
  box-shadow:0 8px 50px rgba(11,25,41,.1);
  border:1px solid var(--rule);position:relative;overflow:hidden;
}
.cform-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--wave),var(--gold));
}
.cform-tag{
  font-family:var(--f-cond);font-size:.68rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--wave);
  margin-bottom:1.6rem;display:block;
}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.fg{display:flex;flex-direction:column;gap:.35rem}
.fg.full{grid-column:1/-1}
.fg label{font-family:var(--f-cond);font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--slate)}
.fg input,.fg textarea,.fg select{
  background:var(--sand);border:1.5px solid var(--rule);
  color:var(--ink);font-family:var(--f-sans);font-size:.9rem;
  padding:.75rem 1rem;border-radius:8px;outline:none;width:100%;
  transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  border-color:var(--wave);box-shadow:0 0 0 3px rgba(42,100,150,.1);
}
.fg textarea{resize:vertical;min-height:90px}
.btn-send{
  width:100%;margin-top:1.2rem;
  font-family:var(--f-cond);font-size:.82rem;font-weight:800;
  letter-spacing:.18em;text-transform:uppercase;
  background:var(--navy);color:#fff;border:none;
  padding:1.1rem;border-radius:8px;
  transition:background .25s,transform .2s;
}
.btn-send:hover{background:var(--wave);transform:translateY(-1px)}

/* ═══════════════════════════════════════════════════
  LOCATION
   ═══════════════════════════════════════════════════ */
.location{padding:clamp(5rem,9vw,8rem) 0;background:var(--sand)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,5rem);align-items:center}
.loc-info h2{
  font-family:var(--f-serif);font-size:clamp(2rem,3.5vw,3rem);
  font-weight:600;font-style:italic;color:var(--ink);margin-bottom:2rem;
}
.loc-items{display:flex;flex-direction:column;gap:1.2rem}
.loc-item{display:flex;gap:1rem;align-items:flex-start}
.loc-ico{
  width:2.6rem;height:2.6rem;border-radius:8px;
  background:var(--navy);display:flex;align-items:center;justify-content:center;
  font-size:.9rem;flex-shrink:0;
}
.loc-item strong{
  font-family:var(--f-cond);font-size:.67rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--wave);
  display:block;margin-bottom:.25rem;
}
.loc-item span{font-size:.9rem;color:var(--slate);line-height:1.55}
.loc-item a{color:var(--wave);font-weight:600;transition:color .2s}
.loc-item a:hover{color:var(--gold)}

.map-box{
  border-radius:14px;overflow:hidden;height:380px;
  box-shadow:0 14px 50px rgba(11,25,41,.14);
  border:1px solid var(--rule);
}
.map-box iframe{width:100%;height:100%;border:none;display:block}

/* ═══════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════ */
footer{background:var(--ink);padding:clamp(3rem,6vw,5rem) 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;margin-bottom:3rem}

.fbrand .flogo{
  font-family:var(--f-serif);font-size:1.5rem;font-weight:700;
  font-style:italic;color:#fff;display:block;margin-bottom:.9rem;
}
.fbrand .flogo span{color:var(--sky)}
.fbrand p{font-size:.83rem;color:rgba(255,255,255,.38);line-height:1.75;font-weight:300}
.fsocials{display:flex;gap:.6rem;margin-top:1.2rem}
.fsoc{
  width:2.2rem;height:2.2rem;border-radius:7px;
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;color:rgba(255,255,255,.38);
  transition:border-color .25s,color .25s,background .25s;
}
.fsoc:hover{border-color:var(--gold);color:var(--gold);background:rgba(200,150,12,.1)}

.fcol h4{
  font-family:var(--f-cond);font-size:.65rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;
}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.fcol ul a{font-size:.84rem;color:rgba(255,255,255,.42);transition:color .2s}
.fcol ul a:hover{color:#fff}
.fcol p{font-size:.84rem;color:rgba(255,255,255,.42);line-height:1.75}
.fcol a{color:var(--sky);transition:color .2s}
.fcol a:hover{color:var(--gold)}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding:1.5rem 0;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
}
.footer-bottom p{font-size:.7rem;color:rgba(255,255,255,.22);font-family:var(--f-cond);letter-spacing:.06em}

/* ═══════════════════════════════════════════════════
   SCROLL REVEAL
   ═══════════════════════════════════════════════════ */
.rv{opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease}
.rv.in{opacity:1;transform:none}
.rvl{opacity:0;transform:translateX(-32px);transition:opacity .75s ease,transform .75s ease}
.rvl.in{opacity:1;transform:none}
.rvr{opacity:0;transform:translateX(32px);transition:opacity .75s ease,transform .75s ease}
.rvr.in{opacity:1;transform:none}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════ */
@media(max-width:1024px){
  #topbar{display:none}
  #nav{top:0 !important;padding:.9rem 0}
  .nav-links,.btn-cta{display:none}
  .hamburger{display:flex}
  .drawer{display:flex}

  .hero{grid-template-columns:1fr}
  .hero-left{padding:6.5rem 1.5rem 3rem;min-height:65svh}
  .hero-left::after{display:none}
  .hero-right{height:55vw;min-height:300px}
  .hero-stats{right:1.5rem;bottom:1.5rem}

  .about-grid{grid-template-columns:1fr;gap:3rem}
  .about-visual{height:380px;order:-1}

  .proj-grid{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr 1fr}

  .contact-grid{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}

@media(max-width:640px){
  .hero-left{padding:5.5rem 1.2rem 2.5rem}
  .hero h1{font-size:clamp(2.4rem,10vw,3.2rem)}
  .hero-btns{flex-direction:column;align-items:stretch}
  .btn-hero-primary,.btn-hero-ghost{text-align:center;padding:.95rem 1.5rem}
  .hero-right{height:58vw}
  .hero-stats{flex-direction:row;flex-wrap:wrap;right:1rem;bottom:1rem}
  .stat-chip{min-width:130px}

  .about-visual{height:280px}
  .pillars{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .map-box{height:260px}
  .av-year{display:none}
}

/* ═══════════════════════════════════════════════════
    Cradle 120K
   ═══════════════════════════════════════════════════ */

:root{--ink:#0b1929;--navy:#122542;--steel:#1e3a5f;--wave:#2a6496;--sky:#4a9fd4;--gold:#c8960c;--sand:#f5f0e8;--paper:#fdfcf9;--mist:#e8edf5;--slate:#5a6e84;--rule:rgba(11,25,41,.1);--f-serif:'Cormorant Garamond',serif;--f-sans:'Barlow',sans-serif;--f-cond:'Barlow Condensed',sans-serif}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--ink);font-family:var(--f-sans);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:inherit}
.wrap{width:min(100%,1320px);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,4rem)}

/* NAV */
#nav{position:fixed;top:0;width:100%;z-index:900;background:rgba(11,25,41,0.92);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);padding:.85rem 0;transition:background .3s,box-shadow .3s}
#nav.scrolled{background:var(--ink);box-shadow:0 4px 40px rgba(0,0,0,.35)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.logo-wrap{display:flex;align-items:center;gap:.9rem;flex-shrink:0}
.logo-emblem{width:42px;height:42px;flex-shrink:0;background:var(--gold);border-radius:7px;display:flex;align-items:center;justify-content:center}
.logo-emblem svg{width:28px;height:28px}
.logo-name{font-family:var(--f-serif);font-size:1.2rem;font-weight:700;color:#fff;letter-spacing:.01em;line-height:1;font-style:italic}
.logo-sub{font-family:var(--f-cond);font-size:.55rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.38);display:block;margin-top:.18rem}
.nav-links{display:flex;gap:.1rem;list-style:none}
.nav-links a{font-family:var(--f-cond);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);padding:.45rem .85rem;border-radius:5px;transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.07)}
.nav-right{display:flex;align-items:center;gap:.9rem;flex-shrink:0}
.lang-pill{display:flex;border:1px solid rgba(255,255,255,.18);border-radius:100px;overflow:hidden}
.lang-pill button{font-family:var(--f-cond);font-size:.68rem;font-weight:700;letter-spacing:.1em;padding:.38rem .8rem;background:transparent;border:none;color:rgba(255,255,255,.4);transition:background .2s,color .2s}
.lang-pill button.on{background:var(--wave);color:#fff}
.btn-cta{font-family:var(--f-cond);font-size:.75rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;background:var(--gold);color:var(--ink);padding:.55rem 1.3rem;border:none;border-radius:6px;transition:background .25s,transform .2s;white-space:nowrap}
.btn-cta:hover{background:#daa80d;transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.drawer{display:none;position:fixed;inset:0;z-index:800;background:var(--ink);flex-direction:column;align-items:center;justify-content:center;gap:0;opacity:0;pointer-events:none;transition:opacity .3s}
.drawer.open{opacity:1;pointer-events:all}
.drawer ul{list-style:none;display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:2rem}
.drawer ul a{font-family:var(--f-serif);font-size:2rem;font-style:italic;font-weight:600;color:rgba(255,255,255,.8);padding:.3rem 1rem;display:block;transition:color .2s}
.drawer ul a:hover{color:var(--gold)}
.drawer-contact{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.drawer-contact a{font-family:var(--f-cond);font-size:1rem;font-weight:700;letter-spacing:.05em;color:var(--gold)}

/* HERO */
.ph{position:relative;min-height:55vh;display:flex;align-items:flex-end;overflow:hidden;padding-top:70px}
.ph-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.45) saturate(.85);transition:transform 20s ease}
.ph-bg:hover{transform:scale(1.04)}
.ph-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,25,41,.95) 0%,rgba(11,25,41,.3) 60%,transparent 100%)}
.ph-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(42,100,150,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(42,100,150,.05) 1px,transparent 1px);background-size:50px 50px}
.ph-inner{position:relative;z-index:2;padding:0 0 3.5rem;width:100%}
.breadcrumb{font-family:var(--f-cond);font-size:.68rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:1.1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.38);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .cur{color:var(--gold)}
.ph-inner h1{font-family:var(--f-serif);font-size:clamp(2.5rem,6vw,5.5rem);font-weight:700;font-style:italic;line-height:.95;color:#fff;letter-spacing:-.02em}
.ph-inner h1 strong{font-family:var(--f-cond);font-size:.45em;font-style:normal;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.5rem}
.ph-badge{display:inline-flex;align-items:center;gap:.8rem;background:var(--gold);color:var(--ink);font-family:var(--f-cond);font-size:.68rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;padding:.45rem 1.2rem;border-radius:6px;margin-top:1rem}

/* CONTENT */
.proj-content{padding:clamp(3rem,6vw,5rem) 0;background:var(--paper)}
.content-grid{display:grid;grid-template-columns:1fr 320px;gap:4rem;align-items:start}
.proj-desc-area h2{font-family:var(--f-serif);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:600;font-style:italic;color:var(--ink);margin-bottom:1rem}
.proj-desc-area p{color:var(--slate);line-height:1.85;font-size:.95rem;font-weight:300}
.back-link{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-cond);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);border:1.5px solid var(--rule);padding:.5rem 1.1rem;border-radius:6px;margin-top:1.8rem;transition:border-color .25s,color .25s}
.back-link:hover{border-color:var(--wave);color:var(--wave)}

/* CTA card */
.cta-card{background:var(--ink);border-radius:12px;padding:2rem;position:relative;overflow:hidden}
.cta-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--wave),var(--gold))}
.cta-card h3{font-family:var(--f-cond);font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.cta-phone{font-family:var(--f-cond);font-size:1.7rem;font-weight:800;color:var(--gold);letter-spacing:.03em;text-decoration:none;display:block;margin-bottom:.3rem;transition:color .2s}
.cta-phone:hover{color:var(--sky)}
.cta-card>p{font-size:.8rem;color:rgba(255,255,255,.38);font-weight:300;line-height:1.6;margin-bottom:1.5rem}
.btn-cta-full{display:block;text-align:center;font-family:var(--f-cond);font-size:.8rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:.95rem;border-radius:8px;transition:background .25s,transform .2s}
.btn-cta-full:hover{background:#daa80d;transform:translateY(-1px)}

/* PHOTOS */
.photos-sec{padding:clamp(3rem,6vw,5rem) 0;background:var(--sand)}
.sec-head{margin-bottom:2rem}
.sec-eyebrow{font-family:var(--f-cond);font-size:.7rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--wave);display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}
.sec-eyebrow::before{content:'';width:1.8rem;height:2px;background:var(--wave);flex-shrink:0}
.sec-head h2{font-family:var(--f-serif);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:600;font-style:italic;color:var(--ink)}
.sec-head p{font-size:.85rem;color:var(--slate);margin-top:.4rem}
.photo-grid{display:grid;gap:6px;background:rgba(11,25,41,.06)}
.photo-grid.g3{grid-template-columns:repeat(3,1fr)}
.photo-grid.g2{grid-template-columns:repeat(2,1fr)}
.photo-grid.g1{grid-template-columns:1fr;max-width:700px}
.photo-item{position:relative;aspect-ratio:4/3;overflow:hidden;cursor:zoom-in;background:var(--mist)}
.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .3s;filter:brightness(.9)}
.photo-item:hover img{transform:scale(1.05);filter:brightness(1)}
.photo-num{position:absolute;bottom:.7rem;right:.9rem;font-family:var(--f-cond);font-size:1.4rem;font-weight:800;color:rgba(200,150,12,.5);line-height:1}

/* VIDEOS */
.videos-sec{padding:clamp(3rem,6vw,5rem) 0;background:var(--paper)}
.vid-grid{display:grid;gap:1.5rem}
.vid-grid.v2{grid-template-columns:repeat(2,1fr)}
.vid-grid.v1{grid-template-columns:1fr;max-width:780px}
.vid-wrap{position:relative;padding-bottom:56.25%;background:var(--mist);border-radius:10px;overflow:hidden;box-shadow:0 6px 28px rgba(11,25,41,.1)}
.vid-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}

/* BACK STRIP */
.back-strip{background:var(--navy);padding:1.2rem 0;border-top:1px solid rgba(255,255,255,.06)}
.back-strip-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.back-strip p{font-family:var(--f-cond);font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3)}

/* EMPTY STATE */
.empty{padding:3rem 2rem;background:var(--mist);border-radius:10px;border:1.5px dashed rgba(11,25,41,.15);text-align:center}
.empty p{font-family:var(--f-cond);font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--slate)}

/* LIGHTBOX */
.lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:2000;align-items:center;justify-content:center;padding:2rem}
.lb.open{display:flex}
.lb img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:6px}
.lb-close{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--f-cond);font-size:2.2rem;font-weight:800;color:rgba(255,255,255,.6);cursor:pointer;background:none;border:none;line-height:1;transition:color .2s}
.lb-close:hover{color:var(--gold)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--f-cond);font-size:3rem;font-weight:800;color:rgba(255,255,255,.3);cursor:pointer;background:none;border:none;padding:1rem;transition:color .2s}
.lb-prev{left:.5rem}.lb-next{right:.5rem}
.lb-prev:hover,.lb-next:hover{color:var(--gold)}

/* FOOTER */
footer{background:var(--ink);padding:2rem 0}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.7rem;color:rgba(255,255,255,.22);font-family:var(--f-cond);letter-spacing:.06em}
.fsocials{display:flex;gap:.5rem}
.fsoc{width:2rem;height:2rem;border-radius:6px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:rgba(255,255,255,.35);transition:border-color .25s,color .25s}
.fsoc:hover{border-color:var(--gold);color:var(--gold)}

/* REVEAL */
.rv{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  #nav{padding:.75rem 0}
  .nav-links,.btn-cta{display:none}
  .hamburger{display:flex}
  .drawer{display:flex}
  .content-grid{grid-template-columns:1fr;gap:2rem}
  .photo-grid.g3{grid-template-columns:repeat(2,1fr)}
  .vid-grid.v2{grid-template-columns:1fr}
}
@media(max-width:640px){
  .ph{min-height:42vh}
  .ph-inner h1{font-size:clamp(2rem,10vw,3rem)}
  .photo-grid.g3,.photo-grid.g2{grid-template-columns:1fr}
  .back-strip-inner{flex-direction:column;align-items:flex-start}
}