/* ============================================================
   Yieldbridge Group — shared design system
   One file, one set of rules, applied across every page.
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  --navy:#16232f;
  --navy-soft:#1f3140;
  --gold:#bd9a4e;
  --gold-deep:#a8863c;
  --paper:#faf9f6;
  --paper-2:#f1efe9;
  --ink:#23303a;
  --ink-soft:#5c6770;
  --line:#e2ded4;
  --white:#ffffff;

  /* one type scale, used everywhere */
  --h1:clamp(2.4rem,5vw,3.5rem);
  --h2:clamp(1.7rem,3vw,2.2rem);
  --h3:1.2rem;
  --body:1.05rem;
  --small:0.95rem;
  --eyebrow:0.78rem;

  --maxw:1140px;
  --gap:clamp(1.5rem,4vw,3rem);
  --radius:4px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',system-ui,sans-serif;
  font-size:var(--body);
  line-height:1.7;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Source Serif 4',Georgia,serif;font-weight:600;line-height:1.15;color:var(--navy);}
h1{font-size:var(--h1);letter-spacing:-0.01em;}
h2{font-size:var(--h2);letter-spacing:-0.005em;}
h3{font-size:var(--h3);}
p{color:var(--ink-soft);}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.25rem,5vw,2.5rem);}
.eyebrow{
  font-size:var(--eyebrow);font-weight:600;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--gold-deep);
}

/* ---------- Header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,249,246,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand .mark{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,var(--gold) 0%,var(--gold-deep) 70%);
  flex:none;box-shadow:0 1px 0 rgba(0,0,0,.06);
}
.brand .word{
  font-family:'Source Serif 4',serif;font-weight:600;font-size:1.32rem;
  letter-spacing:0.01em;color:var(--navy);
}
.brand .word span{color:var(--gold-deep);}
nav ul{display:flex;gap:2rem;list-style:none;align-items:center;}
nav ul a{
  font-size:var(--small);font-weight:500;color:var(--ink);
  padding:6px 0;position:relative;transition:color .2s;
}
nav ul a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--gold);transition:width .25s;
}
nav ul a:hover{color:var(--navy);}
nav ul a:hover::after{width:100%;}
nav ul a.active{color:var(--navy);}
nav ul a.active::after{width:100%;}
.nav-cta{
  background:var(--navy);color:var(--white)!important;
  padding:9px 18px;border-radius:var(--radius);font-weight:500;
}
.nav-cta::after{display:none;}
.nav-cta:hover{background:var(--navy-soft);}
.menu-btn{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--navy);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:13px 26px;border-radius:var(--radius);
  font-weight:500;font-size:var(--small);transition:transform .15s,background .2s;
}
.btn-gold{background:var(--gold);color:var(--navy);}
.btn-gold:hover{background:#cead63;}
.btn-ghost{border:1px solid rgba(255,255,255,.4);color:var(--white);}
.btn-ghost:hover{background:rgba(255,255,255,.1);}

/* ---------- Hero (homepage) ---------- */
.hero{
  position:relative;color:var(--white);
  background:linear-gradient(180deg,rgba(16,26,35,.78),rgba(16,26,35,.86)),
    url('https://static.wixstatic.com/media/430ddd_047906d459f946eda3a10d1e8c9e26a5~mv2.png') center/cover no-repeat;
}
.hero .wrap{padding-top:clamp(4.5rem,10vw,7.5rem);padding-bottom:clamp(4.5rem,10vw,7.5rem);}
.hero h1{color:var(--white);max-width:16ch;}
.hero .eyebrow{color:var(--gold);}
.hero p{color:rgba(255,255,255,.82);max-width:54ch;margin-top:1.25rem;font-size:1.15rem;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem;}

/* ---------- Interior page header (sub-hero) ---------- */
.page-header{
  background:var(--navy);color:var(--white);
  padding:clamp(3rem,7vw,5rem) 0 clamp(2.5rem,6vw,4rem);
}
.page-header .eyebrow{color:var(--gold);display:block;margin-bottom:.8rem;}
.page-header h1{color:var(--white);max-width:18ch;}
.page-header p{color:rgba(255,255,255,.8);max-width:60ch;margin-top:1.1rem;font-size:1.12rem;}

/* ---------- Section rhythm ---------- */
section{padding:clamp(3.5rem,8vw,6rem) 0;}
.section-head{max-width:60ch;margin-bottom:3rem;}
.section-head .eyebrow{display:block;margin-bottom:0.7rem;}
.section-head p{margin-top:0.9rem;font-size:1.1rem;}

/* ---------- Divisions grid (homepage) ---------- */
.divisions{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(22,35,47,.10);}
.card .img{aspect-ratio:4/3;width:100%;overflow:hidden;background:var(--paper-2);}
.card .img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.card:hover .img img{transform:scale(1.05);}
.card .body{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1;}
.card .body .num{font-size:var(--eyebrow);font-weight:600;letter-spacing:.1em;color:var(--gold-deep);margin-bottom:.5rem;}
.card h3{margin-bottom:.6rem;}
.card p{font-size:var(--small);flex:1;}
.card .more{margin-top:1rem;font-size:var(--small);font-weight:600;color:var(--navy);}
.card .more::after{content:" →";color:var(--gold-deep);}

/* ---------- Approach / stats band ---------- */
.band{background:var(--navy);color:var(--white);}
.band h2{color:var(--white);}
.band p{color:rgba(255,255,255,.78);}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2.5rem;}
.stat .n{font-family:'Source Serif 4',serif;font-size:2.4rem;color:var(--gold);line-height:1;}
.stat .l{font-size:var(--small);color:rgba(255,255,255,.75);margin-top:.5rem;}

/* ---------- Team rows (management page) ---------- */
.team{display:flex;flex-direction:column;}
.member{
  display:grid;grid-template-columns:200px 1fr;gap:2.5rem;align-items:start;
  padding:2.5rem 0;border-bottom:1px solid var(--line);
}
.member:last-child{border-bottom:0;}
.member .photo{
  position:relative;width:160px;height:160px;border-radius:50%;overflow:hidden;
  background:var(--paper-2);box-shadow:0 0 0 6px var(--paper),0 0 0 7px var(--gold);
}
.member .photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);display:block;}
.member h3{margin-bottom:.25rem;}
.member .role{font-size:var(--small);font-weight:600;color:var(--gold-deep);margin-bottom:1rem;}
.member .bio p{font-size:var(--small);margin-bottom:.85rem;}
.member .bio p:last-child{margin-bottom:0;}

/* ---------- Projects grid (properties page) ---------- */
.intro-cols{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:start;margin-bottom:1rem;}
.intro-cols p{font-size:1.08rem;}
.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.project{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white);
  transition:transform .2s,box-shadow .2s;
}
.project:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(22,35,47,.10);}
.project .img{aspect-ratio:3/2;overflow:hidden;background:var(--paper-2);}
.project .img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.project:hover .img img{transform:scale(1.05);}
.project .label{padding:1rem 1.2rem;font-family:'Source Serif 4',serif;font-weight:600;color:var(--navy);font-size:1.05rem;}

/* ---------- Inquire / contact ---------- */
.inquire{background:var(--paper-2);}
.inquire-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--gap);align-items:start;}
form{display:grid;gap:1rem;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
label{font-size:var(--small);font-weight:500;color:var(--ink);display:block;margin-bottom:.35rem;}
input,textarea{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius);
  font-family:inherit;font-size:var(--small);background:var(--white);color:var(--ink);
}
input:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(189,154,78,.15);}
textarea{min-height:120px;resize:vertical;}
button[type=submit]{
  background:var(--navy);color:var(--white);border:0;padding:13px 28px;
  border-radius:var(--radius);font-weight:500;font-size:var(--small);cursor:pointer;justify-self:start;
}
button[type=submit]:hover{background:var(--navy-soft);}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:rgba(255,255,255,.7);padding:3rem 0 2rem;}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;}
.foot .brand .word{color:var(--white);}
.foot .brand .word span{color:var(--gold);}
.foot nav a{font-size:var(--small);color:rgba(255,255,255,.7);margin-left:1.5rem;}
.foot nav a:hover{color:var(--white);}
.copyright{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1.5rem;font-size:0.85rem;color:rgba(255,255,255,.5);}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .divisions{grid-template-columns:repeat(2,1fr);}
  .projects{grid-template-columns:repeat(2,1fr);}
  .inquire-grid,.intro-cols{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr;gap:1.5rem;}
}
@media(max-width:640px){
  nav ul{display:none;}
  .menu-btn{display:block;}
  .divisions,.projects{grid-template-columns:1fr;}
  .row2{grid-template-columns:1fr;}
  .member{grid-template-columns:1fr;gap:1.25rem;text-align:left;}
  .foot{flex-direction:column;align-items:flex-start;}
  .foot nav a{margin-left:0;margin-right:1.25rem;}
}
