/* =========================================================
   Baljit Singh Bhandal — Estate heritage design system
   Palette: deep estate green · antique gold · ivory
   Display: Cormorant Garamond  ·  Body: Manrope
   ========================================================= */

:root{
  --ink:#0E1812;          /* estate green-black (deepest bg)   */
  --forest:#16271D;       /* panel green                       */
  --forest-2:#1E3327;     /* raised panel                      */
  --gold:#C6A053;         /* antique gold                      */
  --gold-soft:#DCC384;    /* light gold                        */
  --gold-deep:#9A7B33;    /* shadowed gold                     */
  --ivory:#F6F2E8;        /* parchment text on dark            */
  --ivory-dim:#CFC9B8;    /* muted parchment                   */
  --stone:#9AA39A;        /* muted sage/grey                   */
  --paper:#FBF9F3;        /* light section bg                  */
  --paper-ink:#23271F;    /* text on light                     */
  --line:rgba(198,160,83,.24);
  --line-soft:rgba(246,242,232,.12);
  --shadow:0 30px 80px -30px rgba(0,0,0,.65);
  --maxw:1200px;
  --display:"Cormorant Garamond", Georgia, serif;
  --body:"Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--body);background:var(--ink);color:var(--ivory);
  line-height:1.6;font-weight:400;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.08;margin:0;letter-spacing:.01em}

.wrap{width:min(100% - 3rem,var(--maxw));margin-inline:auto}
.eyebrow{
  font-family:var(--body);font-size:.72rem;font-weight:700;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.centered{justify-content:center}
.eyebrow.centered::after{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--gold);--fg:#1a1408;
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--body);font-weight:600;font-size:.86rem;letter-spacing:.04em;
  padding:.95rem 1.7rem;border:1px solid var(--bg);background:var(--bg);color:var(--fg);
  border-radius:2px;cursor:pointer;transition:.35s cubic-bezier(.2,.7,.2,1);position:relative;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(198,160,83,.6)}
.btn.ghost{--bg:transparent;--fg:var(--ivory);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold-soft);box-shadow:none}
.btn.block{width:100%;justify-content:center}
.btn.lg{padding:1.05rem 2.1rem}

/* ---------- Monogram crest (signature) ---------- */
.crest{
  --s:46px;width:var(--s);height:var(--s);flex:0 0 auto;position:relative;
  display:grid;place-items:center;border:1px solid var(--gold);border-radius:50%;
}
.crest::before{content:"";position:absolute;inset:4px;border:1px solid var(--line);border-radius:50%}
.crest span{font-family:var(--display);font-weight:600;color:var(--gold-soft);
  font-size:calc(var(--s) * .42);letter-spacing:.02em;line-height:1}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:50;padding:1.1rem 0;
  transition:background .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(14,24,18,.86);backdrop-filter:blur(12px);
  border-bottom-color:var(--line);padding:.7rem 0;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.2rem}
.brand{display:flex;align-items:center;gap:.85rem}
.brand .name{font-family:var(--display);font-size:1.18rem;font-weight:600;letter-spacing:.04em;line-height:1}
.brand .sub{font-family:var(--body);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--stone);margin-top:.25rem}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;margin:0;padding:0}
.nav-links a{
  font-size:.82rem;font-weight:500;letter-spacing:.04em;color:var(--ivory-dim);
  position:relative;padding:.3rem 0;transition:color .3s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--gold);transition:width .35s}
.nav-links a:hover,.nav-links a[aria-current=page]{color:var(--ivory)}
.nav-links a:hover::after,.nav-links a[aria-current=page]::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-auth{display:none}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line);background:transparent;border-radius:3px;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:18px;height:1.5px;background:var(--ivory);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--ivory);transition:.3s}
.burger span::before{top:-6px}.burger span::after{top:6px}
body.menu-open .burger span{background:transparent}
body.menu-open .burger span::before{top:0;transform:rotate(45deg)}
body.menu-open .burger span::after{top:0;transform:rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  padding:9rem 0 5rem;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(120% 90% at 75% 10%,rgba(30,51,39,.35),transparent 60%),
    linear-gradient(180deg,rgba(14,24,18,.55) 0%,rgba(14,24,18,.82) 55%,var(--ink) 100%),
    url("../img/hero.jpg") center/cover no-repeat,
    linear-gradient(160deg,#1b3023,#0e1812);
}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(140% 120% at 50% 120%,transparent 55%,rgba(0,0,0,.55))}
.hero-inner{position:relative;z-index:2;max-width:760px}
.hero h1{font-size:clamp(3rem,8vw,6.4rem);margin:1.4rem 0 .4rem;letter-spacing:.005em}
.hero h1 .thin{font-style:italic;color:var(--gold-soft);font-weight:500}
.hero .lead{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--ivory-dim);max-width:48ch;margin:.6rem 0 2.2rem;font-weight:300}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.scroll-cue{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:2;
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--stone);
  display:flex;flex-direction:column;align-items:center;gap:.6rem}
.scroll-cue i{display:block;width:1px;height:38px;background:linear-gradient(var(--gold),transparent);animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- Sections ---------- */
section{position:relative}
.section{padding:clamp(4.5rem,9vw,8rem) 0}
.section.light{background:var(--paper);color:var(--paper-ink)}
.section.light .eyebrow{color:var(--gold-deep)}
.section.light .eyebrow::before,.section.light .eyebrow.centered::after{background:var(--gold-deep)}
.section.forest{background:linear-gradient(180deg,var(--ink),var(--forest))}
.section-head{max-width:640px;margin-bottom:3rem}
.section-head.centered{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(2.1rem,4.6vw,3.4rem);margin:1.1rem 0 .9rem}
.section-head p{color:var(--ivory-dim);font-weight:300;font-size:1.05rem}
.section.light .section-head p{color:#5d6356}
.lead-rule{width:60px;height:2px;background:var(--gold);margin:1.4rem 0}
.centered .lead-rule{margin-inline:auto}

/* ---------- Stat band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:4px;overflow:hidden}
.stat{background:var(--forest);padding:2.2rem 1.4rem;text-align:center}
.section.light .stat{background:#fff}
.stat .num{font-family:var(--display);font-size:clamp(2.2rem,5vw,3.2rem);color:var(--gold);line-height:1}
.stat .lbl{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-top:.7rem}
.section.light .stat .lbl{color:#7a8073}

/* ---------- Feature split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.flip .media{order:2}
.media{position:relative;border-radius:4px;overflow:hidden;aspect-ratio:4/3;
  background:linear-gradient(150deg,var(--forest-2),var(--ink));border:1px solid var(--line)}
.media img{width:100%;height:100%;object-fit:cover}
.media .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--gold);opacity:.5;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-align:center;padding:1rem}
.media .frame{position:absolute;inset:14px;border:1px solid rgba(246,242,232,.25);pointer-events:none}
.prose p{color:var(--ivory-dim);font-weight:300;margin:0 0 1.1rem}
.section.light .prose p{color:#4f5549}
.prose h3{font-size:1.6rem;margin:.4rem 0 1rem}

/* ---------- Cards ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{background:var(--forest);border:1px solid var(--line);border-radius:4px;padding:2rem;
  transition:.4s;position:relative;overflow:hidden}
.section.light .card{background:#fff;box-shadow:0 12px 40px -24px rgba(0,0,0,.25)}
.card:hover{transform:translateY(-4px);border-color:var(--gold)}
.card .k{font-family:var(--display);font-size:1.05rem;color:var(--gold);letter-spacing:.18em;opacity:.6}
.card h3{font-size:1.45rem;margin:.8rem 0 .7rem}
.card p{color:var(--ivory-dim);font-weight:300;font-size:.96rem;margin:0}
.section.light .card p{color:#5d6356}

/* ---------- Press list ---------- */
.press{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.press li{display:flex;gap:1.5rem;align-items:baseline;padding:1.6rem 0;border-bottom:1px solid var(--line)}
.press .src{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);flex:0 0 130px}
.press .txt{font-family:var(--display);font-size:1.3rem;color:var(--ivory)}
.section.light .press .txt{color:var(--paper-ink)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(160deg,var(--forest-2),var(--ink));border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);text-align:center;padding:clamp(4rem,8vw,7rem) 0}
.cta-band h2{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:1rem}
.cta-band p{color:var(--ivory-dim);max-width:46ch;margin:0 auto 2rem;font-weight:300}

/* ---------- Footer ---------- */
.site-footer{background:#0a120d;border-top:1px solid var(--line);padding:4rem 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid var(--line-soft)}
.site-footer .brand .name{font-size:1.3rem}
.foot-col h4{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-family:var(--body);font-weight:700;margin-bottom:1.1rem}
.foot-col a,.foot-col p{display:block;color:var(--ivory-dim);font-size:.9rem;font-weight:300;margin-bottom:.7rem;transition:color .3s}
.foot-col a:hover{color:var(--gold-soft)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.8rem;color:var(--stone);font-size:.78rem}

/* ---------- Forms / Auth ---------- */
.auth-shell{min-height:100svh;display:grid;grid-template-columns:1.1fr .9fr}
.auth-aside{position:relative;background:linear-gradient(160deg,#16271d,#0a120d);padding:4rem;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.auth-aside .glow{position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(198,160,83,.18),transparent 70%);top:-120px;right:-120px}
.auth-aside h2{font-size:2.4rem;margin:1.2rem 0;position:relative}
.auth-aside p{color:var(--ivory-dim);font-weight:300;position:relative;max-width:36ch}
.auth-main{display:grid;place-items:center;padding:3rem;background:var(--ink)}
.auth-card{width:min(100%,400px)}
.auth-card h1{font-size:2rem;margin-bottom:.4rem}
.auth-card .muted{color:var(--stone);font-size:.92rem;margin-bottom:2rem}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-bottom:.55rem}
.input{
  width:100%;padding:.95rem 1.05rem;background:var(--forest);border:1px solid var(--line);
  color:var(--ivory);font-family:var(--body);font-size:.98rem;border-radius:3px;transition:.3s;
}
.input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(198,160,83,.14)}
.input::placeholder{color:#6f7770}
.alert{padding:.85rem 1.05rem;border-radius:3px;font-size:.9rem;margin-bottom:1.3rem;border:1px solid}
.alert.err{background:rgba(176,58,46,.12);border-color:rgba(176,58,46,.5);color:#f0b8b2}
.alert.ok{background:rgba(86,140,90,.12);border-color:rgba(86,140,90,.5);color:#bfe2c0}
.auth-foot{margin-top:1.6rem;font-size:.85rem;color:var(--stone);text-align:center}
.auth-foot a{color:var(--gold-soft)}

/* ---------- Account / documents ---------- */
.acct-head{padding:10.5rem 0 2.8rem;background:linear-gradient(180deg,var(--forest),var(--ink));border-bottom:1px solid var(--line)}
.acct-head .who{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem}
.acct-head h1{font-size:clamp(2rem,5vw,3rem)}
.acct-head .hi{color:var(--stone);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}
.doc-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin:2.5rem 0 1.5rem}
.doc-bar .count{color:var(--stone);font-size:.9rem}
.doc-list{border:1px solid var(--line);border-radius:5px;overflow:hidden;background:var(--forest)}
.doc-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:1.2rem;align-items:center;
  padding:1.3rem 1.6rem;border-bottom:1px solid var(--line);transition:background .3s}
.doc-row:last-child{border-bottom:none}
.doc-row:hover{background:var(--forest-2)}
.doc-ic{width:40px;height:48px;flex:0 0 auto;border:1px solid var(--line);border-radius:3px;display:grid;place-items:center;
  font-size:.58rem;font-weight:700;letter-spacing:.06em;color:var(--gold);background:rgba(198,160,83,.06)}
.doc-meta .t{font-weight:600;color:var(--ivory);font-size:.98rem;line-height:1.35}
.doc-meta .s{color:var(--stone);font-size:.8rem;margin-top:.2rem}
.doc-size{color:var(--ivory-dim);font-size:.85rem;white-space:nowrap}
.doc-actions{display:flex;gap:.6rem;align-items:center}
.dl{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:var(--gold-soft);
  border:1px solid var(--line);padding:.6rem 1.1rem;border-radius:3px;transition:.3s;white-space:nowrap}
.dl:hover{border-color:var(--gold);background:rgba(198,160,83,.08)}
.dl.primary{background:var(--gold);color:#1a1408;border-color:var(--gold)}
.dl.primary:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
.note{margin-top:1.4rem;font-size:.82rem;color:var(--stone);line-height:1.7}

/* page intro for inner pages */
.page-hero{padding:11rem 0 4rem;background:linear-gradient(180deg,var(--forest),var(--ink));border-bottom:1px solid var(--line);text-align:center}
.page-hero h1{font-size:clamp(2.6rem,7vw,4.4rem);margin:1.1rem 0 .6rem}
.page-hero p{color:var(--ivory-dim);max-width:54ch;margin:0 auto;font-weight:300}

/* contact (email-only card) */
.contact-card{text-align:center;border:1px solid var(--line);border-radius:6px;
  padding:clamp(2.5rem,6vw,4.5rem) clamp(1.5rem,5vw,3.5rem);
  background:linear-gradient(160deg,var(--forest),var(--ink));box-shadow:var(--shadow)}
.contact-email{display:inline-block;font-family:var(--display);
  font-size:clamp(1.7rem,6vw,3rem);color:var(--gold-soft);margin:1rem 0 2rem;
  letter-spacing:.01em;word-break:break-word;border-bottom:1px solid transparent;transition:.3s}
.contact-email:hover{color:var(--gold);border-bottom-color:var(--gold)}
.contact-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.contact-foot{margin-top:2rem;color:var(--stone);font-size:.88rem;font-weight:300}
@media(max-width:480px){ .contact-actions .btn{width:100%;justify-content:center} }

/* contact (legacy two-column, kept for compatibility) */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.contact-info .row{padding:1.4rem 0;border-bottom:1px solid var(--line)}
.contact-info .row .k{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.contact-info .row .v{color:var(--ivory);font-size:1.05rem;font-weight:300}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Rich content components ---------- */
.pullquote{font-family:var(--display);font-size:clamp(1.6rem,3.6vw,2.6rem);line-height:1.3;
  color:var(--ivory);max-width:24ch;margin:0;font-style:italic}
.section.light .pullquote{color:var(--paper-ink)}
.pullquote cite{display:block;font-family:var(--body);font-style:normal;font-size:.8rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);margin-top:1.4rem}

.timeline{position:relative;margin:0;padding:0 0 0 1.5rem;list-style:none;border-left:1px solid var(--line)}
.timeline li{position:relative;padding:0 0 2.4rem 1.8rem}
.timeline li:last-child{padding-bottom:0}
.timeline li::before{content:"";position:absolute;left:-1.55rem;top:.35rem;width:9px;height:9px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 4px rgba(198,160,83,.15)}
.timeline .yr{font-family:var(--display);font-size:1.3rem;color:var(--gold-soft);line-height:1}
.timeline h4{font-size:1.15rem;margin:.5rem 0 .4rem}
.timeline p{color:var(--ivory-dim);font-weight:300;margin:0;font-size:.96rem}
.section.light .timeline p{color:#5d6356}
.section.light .timeline .yr{color:var(--gold-deep)}

.factlist{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.factlist div{background:var(--forest);padding:1.4rem 1.5rem}
.section.light .factlist div{background:#fff}
.factlist .k{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.factlist .v{color:var(--ivory);font-weight:300}
.section.light .factlist .v{color:var(--paper-ink)}

.twocol{columns:2;column-gap:3rem}
.twocol p{break-inside:avoid;color:var(--ivory-dim);font-weight:300}
.section.light .twocol p{color:#4f5549}

.editable{border:1px dashed var(--line);border-radius:4px;padding:1.4rem 1.6rem;background:rgba(198,160,83,.04)}
.editable .tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700;display:block;margin-bottom:.6rem}
.editable p{margin:0;color:var(--ivory-dim);font-weight:300}
.section.light .editable p{color:#5d6356}

.divider{height:1px;background:var(--line);border:none;margin:0}

@media(max-width:760px){
  .factlist{grid-template-columns:1fr}
  .twocol{columns:1}
}


/* ---------- Responsive ---------- */
@media(max-width:980px){
  .split,.contact-grid{grid-template-columns:1fr}
  .split.flip .media{order:0}
  .grid-3{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .auth-shell{grid-template-columns:1fr}
  .auth-aside{display:none}
}
@media(max-width:680px){
  .nav-links,.nav-cta .btn{display:none}
  .burger{display:inline-flex}
  .nav-links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:2rem;
    background:rgba(10,18,13,.97);backdrop-filter:blur(8px);transform:translateY(-100%);
    transition:transform .5s cubic-bezier(.2,.7,.2,1);z-index:40;
  }
  body.menu-open .nav-links{display:flex;transform:none}
  .nav-links a{font-size:1.4rem;font-family:var(--display)}
  .nav-auth{display:block}
  .nav-auth a{color:var(--gold-soft)}
  .grid-3,.stats,.foot-grid{grid-template-columns:1fr}
  .doc-row{grid-template-columns:auto 1fr;row-gap:.5rem}
  .doc-size{grid-column:2;justify-self:start}
  .doc-actions{grid-column:1/-1;width:100%}
  .doc-actions .dl{flex:1;justify-content:center;margin-top:.3rem}
  .press li{flex-direction:column;gap:.4rem}
  .press .src{flex-basis:auto}
  .foot-bottom{flex-direction:column;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
