/* ============================================================
   CATALYST GROUP INVESTMENTS — design system
   Rich gold · warm black · elegant serif
   ============================================================ */

:root{
  /* surfaces */
  --bg:#0b0a07;
  --bg-2:#100e09;
  --bg-3:#16130c;
  --bg-card:#13110a;
  --black:#000;

  /* ink */
  --ink:#efe9da;          /* warm ivory body */
  --ink-soft:#bcb39d;
  --ink-faint:#857c68;

  /* gold */
  --gold:#c9a24a;
  --gold-bright:#e9d199;
  --gold-deep:#9c7a2e;
  --gold-grad:linear-gradient(118deg,#f6e6ad 0%,#d9b863 34%,#b88c38 64%,#ecd595 100%);

  --line:rgba(201,162,74,.16);
  --line-2:rgba(201,162,74,.30);
  --line-3:rgba(201,162,74,.50);

  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;

  --maxw:1240px;
  --gutter:clamp(20px,5vw,72px);
  --shadow:0 30px 80px -40px rgba(0,0,0,.9);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.slot{background:#0e0c08;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
.section{padding-block:clamp(72px,11vw,150px);position:relative;}
.section.tight{padding-block:clamp(48px,7vw,90px);}
.bg-2{background:var(--bg-2);}
.bg-3{background:var(--bg-3);}
.bg-black{background:var(--black);}
.divider{height:1px;background:var(--line);border:0;margin:0;}

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--sans);font-size:12.5px;font-weight:600;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7;}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--gold);opacity:.7;}
.eyebrow.center{justify-content:center;}

.display{
  font-family:var(--serif);font-weight:500;line-height:1.02;
  letter-spacing:-.005em;color:var(--ink);margin:0;
  font-size:clamp(44px,7vw,86px);
}
h1,h2,h3{font-family:var(--serif);font-weight:500;margin:0;line-height:1.05;color:var(--ink);}
.h2{font-family:var(--serif);font-weight:500;font-size:clamp(31px,4.1vw,52px);line-height:1.1;letter-spacing:-.005em;margin:0;text-wrap:balance;}
.h3{font-family:var(--serif);font-weight:600;font-size:clamp(22px,2.4vw,30px);margin:0;}
.lede{font-size:clamp(18px,1.6vw,21px);line-height:1.6;color:var(--ink-soft);font-weight:400;}
.body{color:var(--ink-soft);}
.gold-text{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  color:transparent;
}
.serif-i{font-family:var(--serif);font-style:italic;font-weight:500;}
.muted{color:var(--ink-faint);}
.tnum{font-variant-numeric:tabular-nums;}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 28px;border-radius:3px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s ease,box-shadow .35s ease,background .3s ease,border-color .3s ease,color .3s ease;
  white-space:nowrap;
}
.btn .ar{font-size:17px;transition:transform .3s ease;}
.btn:hover .ar{transform:translateX(4px);}
.btn-gold{background:var(--gold-grad);color:#241a07;border-color:rgba(246,230,173,.6);box-shadow:0 12px 30px -14px rgba(201,162,74,.7);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 18px 40px -14px rgba(201,162,74,.9);filter:brightness(1.05);}
.btn-ghost{background:transparent;color:var(--gold-bright);border-color:var(--line-2);}
.btn-ghost:hover{border-color:var(--line-3);background:rgba(201,162,74,.07);transform:translateY(-2px);}
.btn-lg{padding:17px 36px;font-size:16px;}
.btn-sm{padding:11px 20px;font-size:14px;}

/* ---------- nav ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;gap:30px;
  padding:18px var(--gutter);
  transition:background .4s ease,backdrop-filter .4s ease,padding .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,7,5,.82);backdrop-filter:blur(16px) saturate(1.2);
  border-bottom-color:var(--line);padding-block:13px;
}
.nav-links{display:flex;gap:30px;margin-inline:auto;}
.nav-links a{
  font-size:14.5px;font-weight:500;color:var(--ink-soft);letter-spacing:.02em;white-space:nowrap;
  position:relative;padding-block:6px;transition:color .25s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .3s ease;}
.nav-links a:hover{color:var(--ink);}
.nav-links a:hover::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:12px;}

/* ---------- logo lockup ---------- */
.logo{display:flex;align-items:center;gap:13px;}
.logo-mark{width:38px;height:42px;flex:none;}
.logo-wm{display:flex;flex-direction:column;line-height:1;}
.logo-wm b{
  font-family:var(--serif);font-weight:600;font-size:23px;letter-spacing:.13em;
  text-transform:uppercase;padding-right:.16em;
  background:linear-gradient(180deg,#f8e9b6 0%,#dcb95f 55%,#c6a043 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.logo-wm small{
  font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.34em;
  text-transform:uppercase;color:var(--ink-faint);margin-top:3px;
}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:clamp(130px,17vw,200px);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,72px);align-items:center;}
.hero h1{font-size:clamp(42px,5.3vw,72px);font-weight:500;letter-spacing:-.01em;line-height:1.03;}
.hero .lede{max-width:30em;margin-top:30px;}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;}
.hero-trust{display:flex;gap:28px;margin-top:46px;flex-wrap:wrap;align-items:center;}
.hero-trust .t{display:flex;flex-direction:column;gap:2px;}
.hero-trust .t b{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--gold-bright);line-height:1;}
.hero-trust .t span{font-size:13px;color:var(--ink-faint);letter-spacing:.03em;}
.hero-trust .vr{width:1px;height:38px;background:var(--line);}

.hero-media{position:relative;}
.hero-media .slot{width:100%;aspect-ratio:4/5;border:1px solid var(--line-2);box-shadow:var(--shadow);}
.hero-frame{position:absolute;inset:-14px;border:1px solid var(--line);pointer-events:none;}
.float-card{
  position:absolute;left:-34px;bottom:42px;background:rgba(12,11,7,.86);
  backdrop-filter:blur(10px);border:1px solid var(--line-2);border-radius:4px;
  padding:18px 22px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);
  max-width:280px;
}
.float-card .av{display:flex;}
.float-card .av .slot{width:42px;height:42px;border-radius:50%;border:2px solid var(--bg);margin-left:-14px;}
.float-card .av .slot:first-child{margin-left:0;}
.float-card p{margin:0;font-size:13.5px;line-height:1.4;color:var(--ink-soft);}
.float-card b{color:var(--ink);font-family:var(--serif);font-size:17px;font-weight:600;}

/* faint hex lattice motif */
.hex-motif{position:absolute;pointer-events:none;opacity:.4;color:var(--gold);}

/* ---------- stat strip ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line);}
.stat{background:var(--bg);padding:38px clamp(16px,2.4vw,34px);text-align:center;}
.stat b{font-family:var(--serif);font-weight:600;font-size:clamp(36px,4vw,52px);line-height:1;display:block;}
.stat span{font-size:13.5px;color:var(--ink-faint);letter-spacing:.04em;margin-top:10px;display:block;}

/* ---------- section header ---------- */
.sec-head{max-width:60ch;display:flex;flex-direction:column;align-items:flex-start;gap:22px;}
.sec-head.center{margin-inline:auto;text-align:center;align-items:stretch;}
.sec-head .lede{max-width:60ch;}

/* ---------- advisor cards ---------- */
.advisors{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,26px);}
.advisor{position:relative;}
.advisor .slot{width:100%;aspect-ratio:3/4;border:1px solid var(--line);filter:grayscale(.2) contrast(1.02);transition:filter .5s ease,transform .5s ease;}
.advisor:hover .slot{filter:grayscale(0);transform:translateY(-4px);}
.advisor .a-name{font-family:var(--serif);font-weight:600;font-size:22px;margin-top:18px;}
.advisor .a-role{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:5px;}
.advisor .a-bio{font-size:14.5px;color:var(--ink-soft);margin-top:11px;line-height:1.55;}
.advisor .a-links{display:flex;gap:14px;margin-top:14px;font-size:13px;color:var(--ink-faint);}
.advisor .a-links a{border-bottom:1px solid var(--line-2);padding-bottom:2px;transition:color .25s,border-color .25s;}
.advisor .a-links a:hover{color:var(--gold-bright);border-color:var(--gold);}

/* ---------- M·E·D pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);}
.pillar{
  position:relative;background:var(--bg-card);border:1px solid var(--line);
  padding:38px 34px 34px;border-radius:5px;overflow:hidden;
  transition:border-color .4s ease,transform .4s ease,background .4s ease;
}
.pillar:hover{border-color:var(--line-3);transform:translateY(-5px);background:#171309;}
.pillar .cap{
  font-family:var(--serif);font-weight:600;font-size:74px;line-height:.8;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.pillar .p-name{font-family:var(--serif);font-size:27px;font-weight:600;margin-top:18px;}
.pillar .p-desc{color:var(--ink-soft);font-size:15.5px;margin-top:12px;line-height:1.6;}
.pillar .p-list{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:9px;}
.pillar .p-list li{font-size:14.5px;color:var(--ink-soft);display:flex;gap:10px;align-items:baseline;}
.pillar .p-list li::before{content:"";width:5px;height:5px;flex:none;border-radius:50%;background:var(--gold);transform:translateY(-2px);}
.pillar .p-link{margin-top:24px;font-size:14px;font-weight:600;color:var(--gold-bright);letter-spacing:.02em;display:inline-flex;gap:8px;align-items:center;white-space:nowrap;}
.pillar .p-link .ar{transition:transform .3s;}
.pillar:hover .p-link .ar{transform:translateX(4px);}
.pillar .ghost-cap{position:absolute;right:-8px;bottom:-30px;font-family:var(--serif);font-weight:700;font-size:170px;color:rgba(201,162,74,.05);line-height:1;pointer-events:none;}

/* ---------- listings rail ---------- */
.rail-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.rail{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:18px;margin-top:42px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;}
.rail::-webkit-scrollbar{height:6px;}
.rail::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:3px;}
.listing{flex:0 0 360px;scroll-snap-align:start;background:var(--bg-card);border:1px solid var(--line);border-radius:5px;overflow:hidden;transition:border-color .4s,transform .4s;}
.listing:hover{border-color:var(--line-3);transform:translateY(-5px);}
.listing .slot{width:100%;aspect-ratio:3/2;display:block;}
.listing .l-media{position:relative;}
.listing .tag{position:absolute;top:14px;left:14px;background:rgba(8,7,5,.78);backdrop-filter:blur(6px);border:1px solid var(--line-2);color:var(--gold-bright);font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;border-radius:2px;}
.listing .l-body{padding:22px 24px 26px;}
.listing .l-price{font-family:var(--serif);font-weight:600;font-size:32px;}
.listing .l-addr{color:var(--ink-soft);font-size:14.5px;margin-top:4px;}
.listing .l-specs{display:flex;gap:18px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);font-size:14px;color:var(--ink-soft);}
.listing .l-specs b{color:var(--ink);font-weight:600;}
.rail-nav{display:flex;gap:10px;}
.rail-btn{width:46px;height:46px;border-radius:50%;border:1px solid var(--line-2);background:transparent;color:var(--gold-bright);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s;}
.rail-btn:hover{border-color:var(--line-3);background:rgba(201,162,74,.08);}

/* ---------- in-house lending band ---------- */
.band{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;}
.band .slot{width:100%;aspect-ratio:5/4;border:1px solid var(--line-2);box-shadow:var(--shadow);}
.band-media{position:relative;}
.band-media .seal{position:absolute;right:-22px;top:-22px;width:120px;height:120px;}
.feat-list{display:flex;flex-direction:column;gap:22px;margin-top:30px;}
.feat{display:flex;gap:18px;align-items:flex-start;}
.feat .fi{width:46px;height:46px;flex:none;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-bright);}
.feat b{font-family:var(--serif);font-size:20px;font-weight:600;display:block;}
.feat p{margin:5px 0 0;color:var(--ink-soft);font-size:15px;}

/* ---------- process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden;}
.step{background:var(--bg);padding:36px 30px 40px;position:relative;transition:background .4s;}
.step:hover{background:var(--bg-3);}
.step .s-num{font-family:var(--serif);font-style:italic;font-weight:500;font-size:18px;color:var(--gold);}
.step .s-title{font-family:var(--serif);font-size:24px;font-weight:600;margin-top:18px;}
.step .s-desc{color:var(--ink-soft);font-size:14.5px;margin-top:10px;line-height:1.55;}

/* ---------- testimonial ---------- */
.quote{max-width:24ch;}
.quote .q-mark{font-family:var(--serif);font-size:120px;line-height:.5;color:var(--line-3);height:48px;display:block;}
.quote blockquote{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.4vw,42px);line-height:1.22;margin:0;color:var(--ink);}
.quote .q-by{display:flex;align-items:center;gap:14px;margin-top:32px;}
.quote .q-by .slot{width:54px;height:54px;border-radius:50%;border:1px solid var(--line-2);}
.quote .q-by b{font-family:var(--serif);font-size:18px;font-weight:600;}
.quote .q-by span{font-size:13.5px;color:var(--ink-faint);display:block;}

/* ---------- CTA ---------- */
.cta{position:relative;text-align:center;overflow:hidden;}
.cta .h2{max-width:18ch;margin-inline:auto;}
.cta-actions{display:flex;gap:16px;justify-content:center;margin-top:38px;flex-wrap:wrap;}
.cta-contact{display:flex;gap:34px;justify-content:center;margin-top:48px;flex-wrap:wrap;color:var(--ink-soft);font-size:15px;}
.cta-contact a{display:inline-flex;gap:9px;align-items:center;}
.cta-contact .ci{color:var(--gold);}

/* ---------- footer ---------- */
.footer{background:var(--black);border-top:1px solid var(--line);padding-block:clamp(56px,7vw,84px) 36px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;}
.foot-col h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;font-family:var(--sans);font-weight:600;}
.foot-col a{display:block;color:var(--ink-soft);font-size:14.5px;margin-bottom:11px;transition:color .25s;}
.foot-col a:hover{color:var(--gold-bright);}
.foot-about{color:var(--ink-soft);font-size:14.5px;line-height:1.6;margin:20px 0 0;max-width:34ch;}
.foot-social{display:flex;gap:12px;margin-top:22px;}
.foot-social a{width:38px;height:38px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:.3s;}
.foot-social a:hover{border-color:var(--line-3);color:var(--gold-bright);}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:54px;padding-top:26px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-faint);}
.foot-legal{max-width:70ch;font-size:12px;color:var(--ink-faint);line-height:1.6;margin-top:20px;}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}
.reveal.d4{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ---------- credibility badges ---------- */
.creds{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;}
.cred{
  display:inline-flex;align-items:center;gap:11px;flex:0 0 auto;
  border:1px solid var(--line);border-radius:3px;padding:13px 20px;background:var(--bg-card);
  transition:border-color .35s ease,transform .35s ease;
}
.cred:hover{border-color:var(--line-3);transform:translateY(-3px);}
.cred .c-ab{font-family:var(--serif);font-weight:700;font-size:21px;line-height:1;color:transparent;background:linear-gradient(180deg,#f8e9b6 0%,#dcb95f 55%,#c6a043 100%);-webkit-background-clip:text;background-clip:text;letter-spacing:.02em;padding-right:6px;}
.cred .c-tx{display:flex;flex-direction:column;line-height:1.15;}
.cred .c-tx b{font-size:13.5px;font-weight:600;color:var(--ink);white-space:nowrap;}
.cred .c-tx span{font-size:11.5px;color:var(--ink-faint);letter-spacing:.02em;}
.creds-label{text-align:center;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:30px;}

/* ---------- founders (father & son) ---------- */
.founders{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3.4vw,48px);}
.founder{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,2.4vw,30px);
  background:var(--bg-card);border:1px solid var(--line);border-radius:6px;
  padding:clamp(22px,2.4vw,32px);transition:border-color .4s ease,transform .4s ease;
}
.founder:hover{border-color:var(--line-2);transform:translateY(-4px);}
.founder .slot{width:clamp(120px,12vw,168px);aspect-ratio:3/4;border:1px solid var(--line-2);filter:grayscale(.18) contrast(1.02);transition:filter .5s;}
.founder:hover .slot{filter:grayscale(0);}
.founder>div{display:flex;flex-direction:column;align-items:flex-start;}
.founder .f-rel{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);}
.founder .f-name{font-family:var(--serif);font-weight:600;font-size:clamp(26px,2.6vw,33px);line-height:1.05;margin-top:7px;}
.founder .f-role{font-size:13.5px;color:var(--ink-soft);margin-top:5px;}
.founder .f-bio{font-size:14.5px;color:var(--ink-soft);line-height:1.6;margin-top:15px;}
.founder .f-creds{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px;}
.founder .f-creds span{font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--gold-bright);border:1px solid var(--line-2);border-radius:2px;padding:4px 9px;}
.founder .f-links{display:flex;gap:14px;margin-top:18px;font-size:13px;color:var(--ink-faint);}
.founder .f-links a{border-bottom:1px solid var(--line-2);padding-bottom:2px;transition:.25s;}
.founder .f-links a:hover{color:var(--gold-bright);border-color:var(--gold);}

/* ---------- story ---------- */
.story{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,80px);align-items:center;}
.story-media{position:relative;}
.story-media .slot{width:100%;aspect-ratio:4/5;border:1px solid var(--line-2);box-shadow:var(--shadow);}
.story-media .stamp{position:absolute;right:-20px;bottom:-20px;background:var(--bg);border:1px solid var(--line-2);border-radius:4px;padding:16px 20px;box-shadow:var(--shadow);}
.story-media .stamp b{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--gold-bright);display:block;line-height:1;}
.story-media .stamp span{font-size:12px;color:var(--ink-faint);letter-spacing:.04em;}
.story p.body{font-size:clamp(16.5px,1.5vw,19px);line-height:1.7;color:var(--ink-soft);margin:22px 0 0;}
.story-text{display:flex;flex-direction:column;gap:24px;}
.story-text>*{margin:0;}
.band-copy{display:flex;flex-direction:column;gap:22px;}
.band-copy>*{margin:0;}
.band-copy>.btn{align-self:flex-start;margin-top:8px;}
.story .pull{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(22px,2.4vw,30px);line-height:1.3;color:var(--ink);margin:26px 0 0;padding-left:22px;border-left:2px solid var(--gold);}
.story .sig{margin-top:26px;font-family:var(--serif);font-style:italic;font-size:21px;color:var(--gold-bright);}

/* ---------- recent results ---------- */
.results{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);}
.result{
  background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:30px 28px 32px;
  display:flex;flex-direction:column;transition:border-color .4s,transform .4s;position:relative;overflow:hidden;
}
.result:hover{border-color:var(--line-3);transform:translateY(-5px);}
.result .r-tag{font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.result .r-metric{font-family:var(--serif);font-weight:600;font-size:clamp(34px,4vw,46px);line-height:1.02;margin-top:16px;}
.result .r-metric .gold-text{display:inline;}
.result .r-label{font-size:14px;color:var(--ink-soft);margin-top:4px;}
.result .r-desc{font-size:14.5px;color:var(--ink-soft);line-height:1.6;margin-top:18px;padding-top:18px;border-top:1px solid var(--line);}

/* ---------- connect / contact ---------- */
.connect{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(36px,4vw,52px);}
.connect-card{
  background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:30px 28px;
  text-align:center;transition:border-color .4s,transform .4s;
}
.connect-card:hover{border-color:var(--line-3);transform:translateY(-4px);}
.connect-card .ci{width:50px;height:50px;margin:0 auto 16px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-bright);}
.connect-card b{font-family:var(--serif);font-size:22px;font-weight:600;display:block;}
.connect-card p{font-size:14px;color:var(--ink-soft);margin:8px 0 16px;line-height:1.5;}
.connect-card .clink{font-size:14.5px;font-weight:600;color:var(--gold-bright);display:inline-flex;gap:7px;align-items:center;}

.lead-form{
  background:var(--bg-card);border:1px solid var(--line);border-radius:8px;
  padding:clamp(28px,3.4vw,44px);margin-top:26px;max-width:760px;margin-inline:auto;
}
.lead-form .fg{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.lead-form .field-l{display:flex;flex-direction:column;gap:8px;}
.lead-form .field-l.full{grid-column:1/-1;}
.lead-form label{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;}
.lead-form input,.lead-form select,.lead-form textarea{
  background:var(--bg);border:1px solid var(--line-2);border-radius:3px;padding:13px 15px;
  color:var(--ink);font-family:var(--sans);font-size:15px;transition:border-color .25s;
}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--line-3);}
.lead-form textarea{resize:vertical;min-height:96px;}
.lead-form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%23c9a24a' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;}
.lead-form .form-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:22px;flex-wrap:wrap;}
.lead-form .form-note{font-size:12.5px;color:var(--ink-faint);max-width:38ch;}
.form-done{text-align:center;padding:30px 10px;}
.form-done .h3{color:var(--gold-bright);}
.form-done p{color:var(--ink-soft);margin-top:10px;}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:48px;}
  .hero-media{max-width:480px;}
  .advisors{grid-template-columns:repeat(2,1fr);}
  .pillars{grid-template-columns:1fr;}
  .steps{grid-template-columns:repeat(2,1fr);}
  .band{grid-template-columns:1fr;}
  .stats{grid-template-columns:repeat(2,1fr);}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .founders{grid-template-columns:1fr;}
  .story{grid-template-columns:1fr;gap:48px;}
  .story-media{max-width:420px;}
  .results{grid-template-columns:1fr;}
  .connect{grid-template-columns:1fr;}
}
@media (max-width:640px){
  body{font-size:16px;}
  .advisors{grid-template-columns:1fr;}
  .listing{flex-basis:280px;}
  .stat b{font-size:38px;}
  .float-card{left:0;}
  .foot-grid{grid-template-columns:1fr;}
  .cta-contact{flex-direction:column;gap:14px;align-items:center;}
  .founder{grid-template-columns:1fr;}
  .founder .slot{width:140px;}
  .lead-form .fg{grid-template-columns:1fr;}
}

/* ============================================================
   NAV DROPDOWN + MOBILE DRAWER
   ============================================================ */
.nav-item{position:relative;}
.nav-item .nav-top{display:inline-flex;align-items:center;gap:7px;cursor:pointer;}
.caret{font-size:9px;color:var(--gold);transition:transform .3s ease;}
.nav-item:hover .caret,.nav-item:focus-within .caret{transform:rotate(180deg);}
/* hover bridge so the gap doesn't drop the menu */
.nav-item.has-drop::after{content:"";position:absolute;top:100%;left:-20px;right:-20px;height:20px;}
.nav-drop{
  position:absolute;top:calc(100% + 16px);left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:320px;background:rgba(11,10,7,.97);backdrop-filter:blur(20px) saturate(1.2);
  border:1px solid var(--line-2);border-radius:7px;padding:8px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:2px;z-index:120;
  opacity:0;visibility:hidden;transition:opacity .26s ease,transform .26s ease,visibility .26s;
}
.nav-item:hover .nav-drop,.nav-item:focus-within .nav-drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-drop a{display:flex !important;flex-direction:column;gap:3px;padding:13px 16px;border-radius:4px;transition:background .2s;white-space:nowrap;}
.nav-drop a::after{display:none;}
.nav-drop a:hover{background:rgba(201,162,74,.09);}
.nav-drop a b{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);}
.nav-drop a span{font-size:12.5px;color:var(--ink-faint);letter-spacing:.01em;text-transform:none;font-weight:400;}
.nav-drop .drop-foot{border-top:1px solid var(--line);margin-top:6px;padding-top:15px;}
.nav-drop .drop-foot b{color:var(--gold-bright);}
.nav-links a[aria-current="page"]{color:var(--gold-bright);}
.nav-links a[aria-current="page"]::after{width:100%;}

/* hamburger */
.nav-toggle{
  display:none;flex-direction:column;gap:5px;width:44px;height:44px;
  border:1px solid var(--line-2);border-radius:5px;background:transparent;cursor:pointer;
  align-items:center;justify-content:center;flex:none;
}
.nav-toggle span{display:block;width:19px;height:1.6px;background:var(--gold-bright);transition:transform .3s ease,opacity .2s ease;}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(6.6px) rotate(45deg);}
body.nav-open .nav-toggle span:nth-child(2){opacity:0;}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg);}
.nav-scrim{position:fixed;inset:0;background:rgba(0,0,0,.62);z-index:98;opacity:0;visibility:hidden;transition:.35s;}
body.nav-open .nav-scrim{opacity:1;visibility:visible;}
.drawer-only{display:none;}

@media (max-width:980px){
  .nav-toggle{display:flex;order:3;}
  .nav-cta{display:none;}
  .nav{gap:16px;}
  .logo{margin-right:auto;}
  .nav-links{
    position:fixed;top:0;right:0;bottom:0;width:min(87vw,390px);z-index:101;margin:0;
    background:#0a0906;border-left:1px solid var(--line-2);box-shadow:-30px 0 80px -30px rgba(0,0,0,.9);
    flex-direction:column;align-items:stretch;gap:0;padding:100px 30px 40px;
    transform:translateX(106%);transition:transform .42s cubic-bezier(.4,0,.1,1);
    overflow-y:auto;
  }
  body.nav-open .nav-links{transform:none;}
  .nav-links>a,.nav-item{border-bottom:1px solid var(--line);}
  .nav-links>a{padding-block:16px;font-size:17px;}
  .nav-item .nav-top{padding-block:16px;font-size:17px;justify-content:space-between;width:100%;}
  .nav-item .caret{font-size:11px;}
  .nav-drop{
    position:static;transform:none;opacity:1;visibility:visible;min-width:0;
    background:transparent;border:none;box-shadow:none;backdrop-filter:none;
    padding:0 0 14px 8px;
  }
  .nav-drop a{padding:9px 8px;}
  .nav-drop a b{font-size:16px;}
  .drawer-only{display:flex;flex-direction:column;gap:12px;margin-top:28px;}
  .drawer-only .btn{width:100%;}
  .drawer-contact{margin-top:26px;font-size:14px;color:var(--ink-soft);display:flex;flex-direction:column;gap:8px;}
  .drawer-contact a{color:var(--gold-bright);}
}

/* ============================================================
   INNER PAGE HERO
   ============================================================ */
.page-hero{padding-top:clamp(140px,16vw,210px);padding-bottom:clamp(36px,5vw,64px);position:relative;overflow:hidden;}
.page-hero .wrap{position:relative;z-index:1;}
.page-hero .eyebrow{margin-bottom:22px;}
.page-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(42px,6vw,80px);line-height:1.0;letter-spacing:-.01em;max-width:17ch;}
.page-hero .lede{margin-top:24px;max-width:56ch;}
.page-hero.center{text-align:center;}
.page-hero.center h1,.page-hero.center .lede,.page-hero.center .eyebrow{margin-inline:auto;}
.page-hero .ph-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
.page-hero.center .ph-cta{justify-content:center;}
.ph-deco{position:absolute;font-family:var(--serif);font-weight:700;line-height:.7;
  font-size:min(46vw,640px);color:rgba(201,162,74,.045);right:-3%;top:8%;pointer-events:none;z-index:0;user-select:none;}
.page-hero .crumbs{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--ink-faint);margin-bottom:26px;letter-spacing:.04em;}
.page-hero .crumbs a:hover{color:var(--gold-bright);}
.page-hero .crumbs .sep{opacity:.5;}

/* mini stat row under hero */
.minibar{display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,52px);margin-top:clamp(34px,4vw,52px);padding-top:30px;border-top:1px solid var(--line);}
.minibar .m{display:flex;flex-direction:column;gap:3px;}
.minibar .m b{font-family:var(--serif);font-size:clamp(26px,3vw,36px);font-weight:600;color:var(--gold-bright);line-height:1;}
.minibar .m span{font-size:13px;color:var(--ink-faint);letter-spacing:.02em;}

/* ============================================================
   LENDING DETAIL BLOCKS
   ============================================================ */
.lblock{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(34px,5vw,76px);align-items:start;scroll-margin-top:90px;}
.lblock + .lblock{margin-top:clamp(64px,9vw,128px);}
.lblock-aside{position:sticky;top:118px;}
.lblock-cap{font-family:var(--serif);font-weight:700;font-size:clamp(130px,17vw,220px);line-height:.74;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;}
.lblock-kicker{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-top:20px;display:block;}
.lblock-name{font-family:var(--serif);font-weight:600;font-size:clamp(30px,3.4vw,44px);margin-top:10px;line-height:1.04;}
.lblock-for{display:inline-flex;align-items:center;gap:9px;margin-top:18px;font-size:13.5px;color:var(--ink-soft);
  border:1px solid var(--line-2);border-radius:20px;padding:7px 15px;}
.lblock-for .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex:none;}
.lblock-intro{font-size:clamp(17px,1.6vw,20px);line-height:1.6;color:var(--ink);}
.lblock-body{color:var(--ink-soft);line-height:1.7;margin-top:18px;font-size:15.5px;}
.lgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,30px);margin-top:34px;}
.lcard{background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:26px 26px 28px;}
.lcard h4{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0 0 16px;font-family:var(--sans);font-weight:600;}
.lcard ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.lcard li{font-size:15px;color:var(--ink-soft);display:flex;gap:11px;align-items:baseline;line-height:1.45;}
.lcard li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);flex:none;transform:translateY(-2px);}
.lcard.plain{background:transparent;}
.lsteps{display:flex;flex-direction:column;gap:0;margin-top:34px;counter-reset:ls;}
.lstep{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:20px 0;border-top:1px solid var(--line);counter-increment:ls;}
.lstep:last-child{border-bottom:1px solid var(--line);}
.lstep .ls-n{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--gold-bright);}
.lstep .ls-n::before{content:"0" counter(ls);}
.lstep b{font-family:var(--serif);font-size:21px;font-weight:600;display:block;}
.lstep p{margin:5px 0 0;font-size:14.5px;color:var(--ink-soft);line-height:1.55;}
.lblock-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:34px;}
.lblock-note{font-size:12.5px;color:var(--ink-faint);margin-top:18px;line-height:1.6;max-width:60ch;}

/* feature row of small icon cards */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);}
.trio .t-card{background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:30px 28px;transition:border-color .4s,transform .4s;}
.trio .t-card:hover{border-color:var(--line-3);transform:translateY(-4px);}
.trio .t-ic{width:48px;height:48px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-bright);margin-bottom:18px;}
.trio .t-card b{font-family:var(--serif);font-size:21px;font-weight:600;display:block;}
.trio .t-card p{margin:9px 0 0;font-size:14.5px;color:var(--ink-soft);line-height:1.6;}

/* ============================================================
   DISCLOSURE BLOCK
   ============================================================ */
.disclosure{border:1px solid var(--line);border-radius:7px;padding:clamp(22px,2.6vw,32px);background:var(--bg-2);}
.disclosure h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 14px;font-family:var(--sans);font-weight:600;}
.disclosure p{font-size:12.5px;color:var(--ink-faint);line-height:1.7;margin:0 0 10px;}
.disclosure p:last-child{margin-bottom:0;}
.disclosure .lic-row{display:flex;flex-wrap:wrap;gap:10px 26px;margin-bottom:16px;}
.disclosure .lic-row span{font-size:13px;color:var(--ink-soft);}
.disclosure .lic-row b{color:var(--gold-bright);font-weight:600;}

/* ============================================================
   CALCULATOR
   ============================================================ */
.calc-tabs{display:inline-flex;border:1px solid var(--line-2);border-radius:5px;padding:4px;gap:4px;background:var(--bg-card);}
.calc-tab{padding:11px 24px;border-radius:3px;cursor:pointer;color:var(--ink-soft);font-weight:600;font-size:14px;font-family:var(--sans);border:none;background:transparent;transition:.25s;white-space:nowrap;}
.calc-tab:hover{color:var(--ink);}
.calc-tab.active{background:var(--gold-grad);color:#241a07;}
.calc-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,60px);align-items:start;margin-top:clamp(34px,4vw,52px);}
.calc-panel{display:none;}
.calc-panel.active{display:block;}
.calc-inputs{display:flex;flex-direction:column;gap:26px;}
.cfield label{display:flex;justify-content:space-between;align-items:baseline;gap:8px 14px;margin-bottom:12px;flex-wrap:wrap;}
.cfield .clab{font-size:14px;color:var(--ink-soft);font-weight:500;letter-spacing:.01em;white-space:nowrap;}
.cfield .cval{font-family:var(--serif);font-size:23px;font-weight:600;color:var(--gold-bright);font-variant-numeric:tabular-nums;white-space:nowrap;margin-left:auto;}
.cfield .cval.sm{font-size:18px;}
.cseg{display:inline-flex;border:1px solid var(--line-2);border-radius:4px;overflow:hidden;}
.cseg button{background:transparent;border:none;color:var(--ink-soft);font-family:var(--sans);font-weight:600;font-size:14px;padding:9px 18px;cursor:pointer;transition:.2s;}
.cseg button.active{background:var(--gold-grad);color:#241a07;}
.cnum{display:flex;align-items:center;border:1px solid var(--line-2);border-radius:4px;background:var(--bg);overflow:hidden;}
.cnum .pre{padding:0 0 0 14px;color:var(--ink-faint);font-size:16px;}
.cnum input{flex:1;background:transparent;border:none;color:var(--ink);font-family:var(--sans);font-size:16px;padding:13px 14px;width:100%;font-variant-numeric:tabular-nums;}
.cnum input:focus{outline:none;}
.cnum .suf{padding:0 14px 0 0;color:var(--ink-faint);font-size:15px;}

input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:5px;
  background:linear-gradient(to right,var(--gold) 0%,var(--gold) var(--pct,40%),var(--fill-track,#2a2417) var(--pct,40%),#2a2417 100%);
  cursor:pointer;outline:none;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--gold-grad);border:2px solid #1a160d;box-shadow:0 2px 8px rgba(0,0,0,.5);cursor:pointer;}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#e3c069;border:2px solid #1a160d;box-shadow:0 2px 8px rgba(0,0,0,.5);cursor:pointer;}

.result-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:9px;padding:clamp(28px,3vw,40px);position:sticky;top:104px;box-shadow:var(--shadow);}
.result-card .r-eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.result-amount{font-family:var(--serif);font-weight:600;font-size:clamp(50px,7vw,76px);line-height:1;margin-top:12px;font-variant-numeric:tabular-nums;}
.result-amount .per{font-size:.32em;color:var(--ink-soft);font-family:var(--sans);font-weight:500;}
.result-sub{font-size:14px;color:var(--ink-soft);margin-top:8px;}
.rbar{display:flex;height:10px;border-radius:5px;overflow:hidden;margin:28px 0 20px;background:#241f13;}
.rbar i{display:block;height:100%;}
.rbar i.s1{background:var(--gold);}
.rbar i.s2{background:var(--gold-deep);}
.rbar i.s3{background:#6f5a2c;}
.rbar i.s4{background:#473a1d;}
.rbreak{display:flex;flex-direction:column;gap:0;}
.rrow{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-top:1px solid var(--line);font-size:14.5px;}
.rrow:first-child{border-top:none;}
.rrow .rk{display:flex;align-items:center;gap:11px;color:var(--ink-soft);}
.rrow .sw{width:10px;height:10px;border-radius:3px;flex:none;}
.rrow .rv{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;}
.rrow.total{border-top:1px solid var(--line-2);margin-top:4px;padding-top:16px;}
.rrow.total .rk{color:var(--ink);font-weight:600;}
.rrow.total .rv{color:var(--gold-bright);font-size:23px;}
.result-card .btn{width:100%;margin-top:26px;}
.result-note{font-size:12px;color:var(--ink-faint);line-height:1.6;margin-top:16px;}
.metric-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-top:8px;}
.metric-strip .ms{background:var(--bg);padding:20px 18px;text-align:center;}
.metric-strip .ms b{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--gold-bright);display:block;line-height:1;font-variant-numeric:tabular-nums;}
.metric-strip .ms span{font-size:12px;color:var(--ink-faint);letter-spacing:.04em;margin-top:8px;display:block;}
.metric-strip .ms.flag b{color:#d98a5a;}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(34px,5vw,70px);align-items:start;}
.contact-side{display:flex;flex-direction:column;gap:26px;}
.cinfo{background:var(--bg-card);border:1px solid var(--line);border-radius:7px;padding:28px 30px;}
.cinfo h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;font-family:var(--sans);font-weight:600;}
.cinfo .cline{display:flex;gap:15px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--line);}
.cinfo .cline:first-of-type{border-top:none;}
.cinfo .cline .ci{width:42px;height:42px;flex:none;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-bright);}
.cinfo .cline .ct b{font-family:var(--serif);font-size:19px;font-weight:600;display:block;color:var(--ink);}
.cinfo .cline .ct a{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--ink);transition:color .25s;}
.cinfo .cline .ct a:hover{color:var(--gold-bright);}
.cinfo .cline .ct span{font-size:13.5px;color:var(--ink-faint);display:block;margin-top:3px;}
.hours-tag{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--gold-bright);border:1px solid var(--line-2);border-radius:20px;padding:7px 15px;margin-top:6px;}
.hours-tag .pulse{width:8px;height:8px;border-radius:50%;background:#7bb37a;box-shadow:0 0 0 0 rgba(123,179,122,.6);animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(123,179,122,.55);}70%{box-shadow:0 0 0 8px rgba(123,179,122,0);}100%{box-shadow:0 0 0 0 rgba(123,179,122,0);}}
.map-slot{width:100%;aspect-ratio:4/3;border:1px solid var(--line-2);border-radius:7px;}

/* progressive form extra fields */
.form-more{display:grid;grid-template-columns:1fr;gap:18px;overflow:hidden;max-height:0;opacity:0;transition:max-height .5s ease,opacity .4s ease,margin .4s ease;}
.form-more.open{max-height:600px;opacity:1;margin-top:18px;}
.toggle-more{background:none;border:none;color:var(--gold-bright);font-family:var(--sans);font-weight:600;font-size:14px;cursor:pointer;display:inline-flex;gap:7px;align-items:center;padding:0;margin-top:16px;}
.toggle-more .caret{transition:transform .3s;}
.toggle-more.open .caret{transform:rotate(180deg);}

/* ============================================================
   ABOUT PAGE — values + service area
   ============================================================ */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);}
.value{background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:30px 28px;transition:border-color .4s,transform .4s;}
.value:hover{border-color:var(--line-3);transform:translateY(-4px);}
.value .v-n{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold);}
.value b{font-family:var(--serif);font-size:23px;font-weight:600;display:block;margin-top:12px;}
.value p{margin:10px 0 0;font-size:14.5px;color:var(--ink-soft);line-height:1.6;}
.area{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,70px);align-items:center;}
.area-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.area-list span{font-size:14px;color:var(--ink-soft);border:1px solid var(--line-2);border-radius:20px;padding:8px 16px;}
.area .slot{width:100%;aspect-ratio:4/3;border:1px solid var(--line-2);border-radius:7px;box-shadow:var(--shadow);}

@media (max-width:980px){
  .lblock{grid-template-columns:1fr;gap:30px;}
  .lblock-aside{position:static;display:flex;align-items:baseline;gap:20px;flex-wrap:wrap;}
  .lblock-cap{font-size:clamp(80px,14vw,120px);}
  .calc-wrap{grid-template-columns:1fr;}
  .result-card{position:static;}
  .contact-layout{grid-template-columns:1fr;}
  .values{grid-template-columns:1fr;}
  .trio{grid-template-columns:1fr;}
  .area{grid-template-columns:1fr;gap:36px;}
}
@media (max-width:640px){
  .lgrid{grid-template-columns:1fr;}
  .metric-strip{grid-template-columns:1fr;}
  .minibar{gap:22px 32px;}
}

/* ============================================================
   IMAGE SLOTS — production rendering
   Real photos use <img class="slot">; not-yet-supplied photos
   use <div class="slot img-ph"> placeholders in the same boxes.
   ============================================================ */
img.slot{object-fit:cover;display:block;height:100%;}
.img-ph{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:9px;text-align:center;padding:18px;box-sizing:border-box;overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% 0%,rgba(201,162,74,.07),transparent 60%),
    #0e0c08;
  color:var(--ink-faint);position:relative;
}
.img-ph::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(135deg,rgba(201,162,74,.04) 0 12px,transparent 12px 24px);
  opacity:.6;
}
.img-ph .ph-ic{width:30px;height:30px;color:var(--gold);opacity:.5;position:relative;z-index:1;}
.img-ph .ph-cap{
  font-family:var(--sans);font-size:12px;line-height:1.45;font-weight:500;
  letter-spacing:.04em;color:var(--ink-faint);max-width:24ch;position:relative;z-index:1;
}
/* tiny circular slots (hero avatars) hide the caption/icon for clarity */
.float-card .av .img-ph{gap:0;padding:0;}
.float-card .av .img-ph .ph-ic{width:18px;height:18px;}
.float-card .av .img-ph .ph-cap{display:none;}
