:root{
            --black:   #0d0d0d;
      --dark:    #141414;
      --dark2:   #1a1a1a;
      --gold:    #c9a84c;
      --gold-lt: #d4b06a;
      --white:   #f5f0e8;
      --muted:   #8a8070;
      --border:  rgba(201,168,76,0.25);
  --sj-black:#121110;
  --sj-black-2:#1a1816;
  --sj-panel:#1e1c19;
  --sj-gold:#c9974a;
  --sj-gold-light:#e0b876;
  --sj-cream:#f4efe7;
  --sj-text-muted:#cfc8bd;
  --sj-border:rgba(201,151,74,0.35);
  --font-display:'Cormorant Garamond', serif;
  --font-body:'Jost', sans-serif;
}

*{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  background-color:var(--sj-cream);
  font-family:var(--font-body);
  color:#2a2622;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:0.5px;
}

.sj-gold{color:var(--sj-gold);}
.sj-gold-text{color:var(--sj-gold-light);}

a{text-decoration:none;}


    /* ─── HERO ─── */
    .hero {
      background: var(--black);
      min-height: 88vh;
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: center;
    }
    .hero-image {
      position: absolute;
      inset: 0;
      right: 0;
      left: 35%;
      background: url('https://images.unsplash.com/photo-1618221195710-dd6b41faaea6?w=1200&q=80') center/cover no-repeat;
    }
    .hero-image::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to right, var(--black) 0%, rgba(13,13,13,0.65) 60%, rgba(13,13,13,0.3) 100%);
    }
    .hero-content {
      position: relative;
      z-index: 2;
      padding: 5rem 0 5rem;
    }
    .hero-eyebrow {
      width: 40px;
      height: 2px;
      background: var(--gold);
      margin-bottom: 1.5rem;
    }
    .hero h1 {
      font-size: clamp(2.8rem, 6vw, 5.5rem);
      font-weight: 700;
      line-height: 1.0;
      letter-spacing: -0.5px;
      margin-bottom: 0.2rem;
color: var(--white); 
    }
    .hero h1 .gold { color: var(--gold); }
    .hero-desc {
      font-size: 0.88rem;
      color: rgba(245,240,232,0.75);
      max-width: 340px;
      margin-top: 1.5rem;
      margin-bottom: 0.75rem;
    }
    .hero-sub {
      font-size: 0.85rem;
      color: var(--gold);
      margin-bottom: 2.2rem;
    }
    .btn-gold {
      background: var(--gold);
      color: var(--black);
      font-size: 0.68rem;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      padding: 0.85rem 1.8rem;
      border: 1.5px solid var(--gold);
      transition: background .2s, color .2s;
      display: inline-block;
    }
    .btn-gold:hover { background: transparent; color: var(--gold); }
    .btn-outline-gold {
      background: transparent;
      color: var(--white);
      font-size: 0.68rem;
      font-weight: 600;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      padding: 0.85rem 1.8rem;
      border: 1.5px solid rgba(245,240,232,0.45);
      transition: border-color .2s, color .2s;
      display: inline-block;
    }
    .btn-outline-gold:hover { border-color: var(--gold); color: var(--gold); }

/* ================= NAVBAR ================= */
.sj-navbar{
  background-color:rgba(18,17,16,0.92);
  backdrop-filter:blur(6px);
  padding-top:14px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(201,151,74,0.15);
  transition:padding .3s ease;
}

.sj-brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.sj-logo-mark{
  width:48px;
  height:48px;
  border:1px solid var(--sj-gold);
  transform:rotate(45deg);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-weight:700;
  font-size:0.85rem;
  color:var(--sj-cream);
  flex-shrink:0;
}
.sj-logo-mark span{transform:rotate(-45deg);}

.sj-brand-text{display:flex;flex-direction:column;line-height:1.1;}
.sj-brand-name{
  font-family:var(--font-display);
  font-size:1.5rem;
  color:var(--sj-cream);
  font-weight:600;
}
.sj-brand-name em{color:var(--sj-gold);font-style:normal;font-weight:400;}
.sj-brand-sub{
  font-size:0.62rem;
  letter-spacing:3px;
  color:var(--sj-gold);
  font-weight:400;
  text-transform:uppercase;
}

.navbar-nav .nav-link{
  color:var(--sj-cream);
  font-size:0.85rem;
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-weight:400;
  padding:0.6rem 1rem;
  position:relative;
}
.navbar-nav .nav-link.active,
.navbar-nav .nav-link:hover{color:var(--sj-gold);}
.navbar-nav .nav-link.active::after{
  content:"";
  position:absolute;
  left:1rem;right:1rem;bottom:0.2rem;
  height:1px;
  background:var(--sj-gold);
}

.sj-btn-outline-gold{
  border:1px solid var(--sj-gold);
  color:var(--sj-gold);
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-size:0.78rem;
  border-radius:0;
  transition:all .25s ease;
}
.sj-btn-outline-gold:hover{background:var(--sj-gold);color:var(--sj-black);}

/* ================= HERO ================= */
.sj-hero{
  background-color:var(--sj-black);
  background-image:radial-gradient(circle at 80% 20%, rgba(201,151,74,0.08), transparent 50%);
  min-height:100vh;
  padding-top:140px;
  padding-bottom:80px;
}

.sj-hero-heading{
  color:var(--sj-cream);
  font-size:clamp(2.6rem, 5vw, 4.2rem);
  line-height:1.05;
  font-weight:600;
  margin-bottom:1.5rem;
}

.sj-rule{
  width:70px;
  height:2px;
  background:var(--sj-gold);
  margin:1.5rem 0;
}
.sj-rule-center{margin-left:auto;margin-right:auto;}

.sj-hero-text{
  color:var(--sj-text-muted);
  font-size:1.05rem;
  max-width:480px;
  margin-bottom:0.5rem;
}

.sj-hero-img-wrap{
  position:relative;
  border:1px solid var(--sj-border);
  padding:14px;
}
.sj-hero-img{
  width:100%;
  height:560px;
  object-fit:cover;
  display:block;
}

.sj-btn-gold{
  background:var(--sj-gold);
  color:var(--sj-black);
  border:1px solid var(--sj-gold);
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-size:0.82rem;
  font-weight:500;
  border-radius:0;
  transition:all .25s ease;
}
.sj-btn-gold:hover{background:transparent;color:var(--sj-gold);}

.sj-btn-outline-light{
  background:transparent;
  color:var(--sj-cream);
  border:1px solid rgba(244,239,231,0.5);
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-size:0.82rem;
  border-radius:0;
  transition:all .25s ease;
}
.sj-btn-outline-light:hover{border-color:var(--sj-gold);color:var(--sj-gold);}

/* ================= FEATURE STRIP ================= */
.sj-feature-strip{
  background-color:var(--sj-black-2);
  border-top:1px solid rgba(201,151,74,0.15);
}
.sj-feature-icon{
  font-size:2.1rem;
  color:var(--sj-gold);
  display:block;
  margin-bottom:1rem;
}
.sj-feature-title{
  color:var(--sj-cream);
  font-size:0.95rem;
  letter-spacing:1px;
  text-transform:uppercase;
  font-family:var(--font-body);
  font-weight:500;
  margin-bottom:0.5rem;
}
.sj-feature-text{
  color:var(--sj-text-muted);
  font-size:0.88rem;
  max-width:240px;
  margin:0 auto;
}

.sj-divider-bar{
  background:var(--sj-gold);
  color:var(--sj-black);
  padding:0.9rem 0;
  font-size:0.85rem;
  letter-spacing:2px;
  text-transform:uppercase;
  text-align:center;
  font-weight:500;
}

/* ================= SECTIONS ================= */
.sj-section{background-color:var(--sj-cream);}
.sj-section-dark{
  background-color:var(--sj-black);
}
.sj-section-dark .sj-eyebrow{color:var(--sj-gold);}
.sj-section-dark .sj-section-heading{color:var(--sj-cream);}
.sj-section-dark .sj-body-text{color:var(--sj-text-muted);}

.py-lg-6{padding-top:6rem;padding-bottom:6rem;}

.sj-eyebrow{
  text-transform:uppercase;
  letter-spacing:3px;
  font-size:0.8rem;
  color:var(--sj-gold);
  font-weight:500;
  margin-bottom:0.5rem;
}

.sj-section-heading{
  font-size:clamp(1.9rem, 3vw, 2.6rem);
  color:#1c1a17;
}

.sj-body-text{
  color:#4a4540;
  font-size:1rem;
  line-height:1.75;
  margin-bottom:1.2rem;
}

.sj-about-img{
  width:100%;
  height:480px;
  object-fit:cover;
  border:1px solid var(--sj-border);
  padding:10px;
  background:var(--sj-black);
}

/* ================= SERVICES ================= */
.sj-service-card{
  background:var(--sj-black-2);
  border:1px solid rgba(201,151,74,0.18);
  padding:2.4rem 2rem;
  transition:border-color .25s ease, transform .25s ease;
}
.sj-service-card:hover{
  border-color:var(--sj-gold);
  transform:translateY(-4px);
}
.sj-service-card i{
  font-size:2rem;
  color:var(--sj-gold);
  margin-bottom:1.2rem;
  display:block;
}
.sj-service-card h3{
  color:var(--sj-cream);
  font-size:1.3rem;
  margin-bottom:0.6rem;
}
.sj-service-card p{
  color:var(--sj-text-muted);
  font-size:0.92rem;
  margin:0;
}

/* ================= GALLERY ================= */
.sj-gallery-img{
  width:100%;
  height:260px;
  object-fit:cover;
  filter:grayscale(8%);
  transition:transform .4s ease, filter .4s ease;
}
.sj-gallery-img:hover{transform:scale(1.03);filter:grayscale(0%);}

/* ================= QUOTE FORM ================= */
.sj-contact-list li{
  color:var(--sj-text-muted);
  margin-bottom:0.9rem;
  font-size:0.95rem;
}
.sj-contact-list i{color:var(--sj-gold);margin-right:0.6rem;width:18px;}

.sj-socials a{
  width:40px;height:40px;
  border:1px solid var(--sj-border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--sj-cream);
  transition:all .25s ease;
}
.sj-socials a:hover{background:var(--sj-gold);color:var(--sj-black);border-color:var(--sj-gold);}

.sj-quote-form-wrap{
  background:var(--sj-black-2);
  border:1px solid rgba(201,151,74,0.2);
  padding:2.5rem;
}

.sj-form-heading{
  color:var(--sj-cream);
  font-size:1.6rem;
  margin-bottom:1.5rem;
}

.sj-quote-form-wrap .form-label{
  color:var(--sj-text-muted);
  font-size:0.82rem;
  letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:0.4rem;
}

.sj-input{
  background:var(--sj-black);
  border:1px solid rgba(201,151,74,0.3);
  color:var(--sj-cream);
  border-radius:0;
  padding:0.7rem 0.9rem;
  font-family:var(--font-body);
}
.sj-input:focus{
  background:var(--sj-black);
  color:var(--sj-cream);
  border-color:var(--sj-gold);
  box-shadow:0 0 0 0.2rem rgba(201,151,74,0.2);
}
.sj-input::placeholder{color:#8a8378;}
select.sj-input{color:var(--sj-cream);}
select.sj-input option{background:var(--sj-black);}

.sj-form-success{
  text-align:center;
  padding:2.5rem 1rem;
  color:var(--sj-cream);
}
.sj-form-success i{
  font-size:2.6rem;
  color:var(--sj-gold);
  display:block;
  margin-bottom:1rem;
}

/* ================= FOOTER ================= */
.sj-footer{
  background:var(--sj-black);
  border-top:1px solid rgba(201,151,74,0.15);
}
.sj-footer-copy{
  color:#8a8378;
  font-size:0.85rem;
}

/* ================= RESPONSIVE ================= */
@media (max-width:991.98px){
  .sj-hero{padding-top:120px;text-align:left;}
  .sj-hero-img{height:380px;}
  .sj-about-img{height:320px;}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;}
}

/* Focus visibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:2px solid var(--sj-gold);
  outline-offset:2px;
}
