:root{
  /* Base */
  --bg: #f7f6f2;             /* slightly warmer background */
  --panel: #ffffff;
  --text: #1f2937;
  --muted: #4b5563;
  --border: #e8e5de;

  /* Brand accents */
  --gold: #c6a75e;
  --gold-2: #b8923a;
  --sage: #7a8f7b;
  --sage-2: #5f7762;

  /* Main accent now GOLD */
  --accent: var(--gold);
  --accent-2: var(--gold-2);

  /* Typography */
  --serif: "Cormorant Garamond", serif;
  --sans: "Jost", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --serif: "Libre Baskerville", serif;

  --text-strong: #111827;
  --text-soft: #374151;
}
    
*{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  margin:0;
  background:var(--bg);
  color:var(--text-strong);
  font-family:var(--sans);
  font-weight:400;
  font-size:18px;        /* was 17px */
  line-height:1.75;      /* was 1.65 */
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Slightly stronger paragraph legibility */
p, li{
  color: var(--text-soft);
}

/* Make small uppercase labels easier to read */
.kicker,
.section-label,
.nav-link,
.contact-label{
  letter-spacing:.16em;  /* reduce a bit from very wide */
}

/* Improve general heading contrast */
.hero-title,
.section-title,
.card-lite h3{
  color: var(--text-strong);
}

a{color:inherit}
a:hover{opacity:.95}

/* NAV */
.site-nav{
  background:var(--bg);
  border-bottom:1px solid var(--border);
  padding:1.4rem 0;
}

.brand{
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  text-decoration: none;
}

/* Main business name */
.brand-line{
  font-family: var(--serif);
  font-size: 1.8rem;          /* bigger */
  font-weight: 600;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
  letter-spacing: .02em;
  color: #2d2a22;             /* warm deep tone */
}

/* Gold emphasis */
.brand-gold{
  color: var(--gold);
}

/* Subline */
.brand-sub{
  font-family: var(--sans);
  font-size: .82rem;          /* larger for legibility */
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--sage);
  margin-top: 6px;
}

/* Hover */
.brand:hover .brand-gold{
  color: var(--gold-2);
}
@media (max-width:768px){
  .brand-line{
    font-size: 1.5rem;
  }
  .brand-sub{
    font-size: .72rem;
  }
}

.nav-link{
  color: var(--muted) !important;
  font-weight: 600;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.86rem;
  padding:.6rem 0 !important;
}
.nav-link:hover{
  color: var(--gold) !important;
}

.navbar-toggler{border:none}
.navbar-toggler:focus{box-shadow:none}

/* Dark hamburger for light theme */
.navbar-toggler{
  border-color: rgba(0,0,0,.25);
}
.navbar-toggler-icon{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(0,0,0,0.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* BUTTONS */
.btn{
  border-radius:16px;
  font-weight:700;
  padding:.85rem 1.1rem;
  border:1px solid transparent;
}

.btn-cta{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff !important;
}
.btn-cta:hover{background:var(--accent-2); border-color:var(--accent-2)}

.btn-ghost{
  background: transparent;
  border-color: var(--sage);
  color: var(--sage) !important;
}
.btn-ghost:hover{
  background: rgba(122,143,123,0.10);
  border-color: var(--sage-2);
  color: var(--sage-2) !important;
}

.btn-gold{
  background: var(--gold);
  border-color: var(--gold);
  color: #1f2937 !important;
}
.btn-gold:hover{
  background: var(--gold-2);
  border-color: var(--gold-2);
  color: #111827 !important;
}

/* HERO */
.hero{
  padding:4.8rem 0 3.8rem;
}

.kicker{
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.74rem;
  margin-bottom:1.5rem;
}

.hero-title{
  font-family: var(--serif);
  font-weight: 400;                 /* slightly stronger */
  font-size: clamp(2.8rem, 6vw, 4.8rem);  /* bigger */
  line-height: 1.08;
  margin: 0 0 1.2rem;
  color: #2d2a22;                   /* warm deep tone */
  text-shadow: none;
}

/* Make the emphasized line gold instead of muted */
.hero-title em{
  color: var(--gold);
  font-style: normal;
  font-weight: 500;
}

.hero-lead{
  color: var(--muted);
  text-shadow: 0 1px 0 rgba(255,255,255,0.55);
  max-width: 54ch;
  font-size:1.05rem;
}

.hero-actions{
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
  margin-top:1.7rem
}

.trustline{
  margin-top:1.6rem;
  color:var(--muted);
  font-size:.95rem;
}
.trustline .dot{margin:0 .5rem}

/* HERO BG */
.hero.hero--bg{
  position: relative;
  padding: 6.2rem 0 5.3rem;
  background-image: url("../img/hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Lighter overlay so the image shows more */
.hero.hero--bg::before{
  background: linear-gradient(
    90deg,
    rgba(247,246,242,0.80) 0%,
    rgba(247,246,242,0.55) 45%,
    rgba(247,246,242,0.30) 100%
  );
}
/* Hero text panel: keeps text readable over bright/dark areas */
.hero.hero--bg .col-lg-7{
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(198,167,94,0.35);
  border-radius: 18px;
  padding: 1.25rem 1.25rem;
  backdrop-filter: blur(2px);
}
/* Make ghost button visible on top of hero image */
.hero.hero--bg .btn-ghost{
  background: rgba(255,255,255,0.68);
  border-color: rgba(138,111,90,0.35);
}
.hero.hero--bg .btn-ghost:hover{
  background: rgba(255,255,255,0.82);
  border-color: var(--accent);
}

.hero.hero--bg .container{
  position: relative;
  z-index: 1;
}

/* DIVIDER */
.divider{
  border:none;
  border-top:1px solid var(--border);
  opacity:.7;
  margin:0;
}

/* SECTIONS */
.section{padding:4.2rem 0}
.section.alt{background:rgba(255,255,255,0.18)}

.section-label{
  color: var(--gold);   /* was --accent */
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;     /* slightly bigger */
  font-weight:800;
  margin-bottom:1rem;
}
.section-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.75rem, 2.8vw, 2.45rem);
  margin:0 0 .8rem;
}
.section-text{
  color:var(--muted);
  max-width:100ch
}

/* CARDS */
.card-lite{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:18px;
  padding:1.2rem 1.2rem;
  height:100%;
}

.card-lite h3{
  font-family:var(--serif);
  font-weight:500;
  font-size:1.28rem;
  margin:0 0 .55rem;
}

.card-lite p{margin:0; color:var(--muted)}

.card-lite:hover{
  border-color: rgba(122, 143, 123, 0.55); /* sage */
  box-shadow: 0 10px 26px rgba(17, 24, 39, 0.06);
  transition: box-shadow .2s ease, border-color .2s ease;
}

/* Service cards with small image */
.card-service{
  padding:1.0rem 1.0rem 1.15rem;
  display:flex;
  flex-direction:column;
}
.card-service .card-img-top{ 
  width:100%;
  height:132px;
  object-fit:cover;
  object-position: center top;
  border-radius:14px;
  border:1px solid var(--border);
}
.card-service .card-body{
  flex:1;
}

/* Notes */
.note-box{
  padding:1rem 1.1rem;
  border-radius:18px;
}
.note-box--neutral{
  background: rgba(138,111,90,0.08);
  border: 1px solid rgba(138,111,90,0.22);
  color: var(--text);
}

/* ABOUT portrait */
.about-portrait{
  width: 100%;
  max-width: 190px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--panel);
  display:block;
}

/* BULLETS */
.bullets{
  margin:1.1rem 0 0;
  color:var(--muted);
}
.bullets li{margin:.35rem 0}

/* CONTACT */
.contact-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.contact-item{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:18px;
  padding:1rem 1.1rem;
}

.contact-label{
  color: var(--gold);   /* was --accent */
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.74rem;     /* slightly bigger */
  font-weight:800;
  margin-bottom:.35rem;
}

.contact-value{color:var(--text)}
.contact-value a{
  color:var(--text);
  text-decoration:none;
  border-bottom:1px solid transparent
}
.contact-value a:hover{border-color:var(--accent)}

.map-wrap{
  height:320px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
}
.map-wrap iframe{
  width:100%;
  height:100%;
  border:0;
  filter:grayscale(55%) contrast(.98) brightness(1.05)
}
/* FOOTER */
.footer{
  padding:2.2rem 0;
  border-top:1px solid var(--border);
}
.footer .muted{color:var(--muted)}

/* RESPONSIVE */
@media (max-width: 768px){
  body{font-size:17px}
  .hero{padding:3.3rem 0 2.7rem}
  .contact-grid{grid-template-columns:1fr}
  /* Service cards: show full image nicely on mobile (no cropping) */
  .card-service .card-img-top{
    height:170px;
    object-fit:contain;
    object-position:center;
    background:#fff;
    padding:10px;
  }
  /* Give the card enough height for title + text */
  .card-service{min-height:340px}
  .about-portrait{max-width:160px}
}
/* Rolling text banner */
.rolling-banner {
  width: 100%;
  overflow: hidden;
  border-radius: 0px;
  padding: 1rem 1.2rem;
  margin-top: 1rem;
  margin-bottom: 1rem;

  background: linear-gradient(
    90deg,
    rgba(198, 167, 94, 0.10),
    rgba(122, 143, 123, 0.10)
  );

  border: 1px solid rgba(198, 167, 94, 0.40);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.04);
}

/* Wrapper */
.rolling-marquee {
  display: flex;
  width: 100%;
  overflow: hidden;
}

/* Track */
.rolling-track {
  display: inline-flex;
  align-items: center;
  gap: 1.4rem;
  white-space: nowrap;
  flex-shrink: 0;
  padding-right: 1.4rem;

  will-change: transform;
  animation: rolling-marquee 24s linear infinite;
}

/* MAIN TEXT — stronger */
.rolling-item {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.35rem;          /* bigger */
  font-weight: 600;            /* stronger */
  letter-spacing: 0.3px;
  color: #3F3A2F;              /* warm deep brown-gray (better contrast) */
}

/* Separator */
.rolling-sep {
  color: #7A8F7B;               /* sage */
  font-size: 1.3rem;
  font-weight: 700;
  opacity: 0.9;
}

/* Animation */
@keyframes rolling-marquee {
  0%   { transform: translate3d(0,0,0); }
  100% { transform: translate3d(-100%,0,0); }
}


/* Pause on hover (feels interactive and calm) */
.rolling-banner:hover .rolling-track {
  animation-play-state: paused;
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
  .rolling-track { animation: none; }
}