/* ============ STONECRAFT RENOVATIONS ============ */
:root{
  --bg:#fefdfb;
  --beige:#f5f1ea;
  --beige-deep:#ede6d9;
  --charcoal:#1f2421;
  --charcoal-soft:#2d332f;
  --text:#4b5249;
  --muted:#8a9088;
  --gold:#b08d4e;
  --gold-soft:#c9a96a;
  --line:#e7e0d3;
  --white:#fff;
  --shadow-sm:0 6px 22px rgba(31,36,33,.06);
  --shadow-md:0 18px 48px rgba(31,36,33,.10);
  --shadow-lg:0 34px 80px rgba(31,36,33,.16);
  --radius:16px;
  --radius-lg:24px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --max:1200px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 30px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:.95rem;padding:14px 28px;border-radius:10px;cursor:pointer;border:none;transition:all .25s ease;white-space:nowrap}
.btn--lg{padding:16px 34px;font-size:1rem}
.btn--primary{background:var(--charcoal);color:#fff;box-shadow:0 10px 26px rgba(31,36,33,.22)}
.btn--primary:hover{background:#11150f;transform:translateY(-2px);box-shadow:0 16px 34px rgba(31,36,33,.30)}
.btn--outline{background:transparent;color:var(--charcoal);border:1.5px solid var(--line)}
.btn--outline:hover{border-color:var(--charcoal);background:var(--charcoal);color:#fff}
.btn--block{width:100%}

/* Eyebrow / headings */
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.section{padding:108px 0}
.section--alt{background:var(--beige)}
.section__head{max-width:660px;margin:0 auto 64px;text-align:center}
.section__title{font-family:var(--serif);font-weight:600;font-size:2.9rem;line-height:1.1;color:var(--charcoal);letter-spacing:-.01em}
.section__title--left{text-align:left}
.section__lead{margin-top:18px;font-size:1.08rem;color:var(--muted)}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;transition:all .3s ease}
.nav.scrolled{background:rgba(254,253,251,.94);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);padding:12px 0}
.nav__inner{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-size:1.45rem;font-weight:600;color:var(--charcoal)}
.brand__mark{color:var(--gold);font-size:1.3rem}
.brand__name strong{color:var(--gold)}
.nav__links{display:flex;gap:32px}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--text);transition:color .2s}
.nav__links a:hover{color:var(--gold)}

/* Hero */
.hero{padding:160px 0 90px;background:linear-gradient(180deg,var(--beige) 0%,var(--bg) 100%);position:relative;overflow:hidden}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero__badge{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:50px;padding:8px 18px;font-size:.83rem;font-weight:600;color:var(--charcoal);box-shadow:var(--shadow-sm);margin-bottom:26px}
.hero__badge .dot{width:8px;height:8px;border-radius:50%;background:#4caf50;box-shadow:0 0 0 4px rgba(76,175,80,.18)}
.hero__title{font-family:var(--serif);font-weight:600;font-size:4.1rem;line-height:1.04;color:var(--charcoal);letter-spacing:-.02em;margin-bottom:22px}
.hero__title .accent{color:var(--gold);font-style:italic}
.hero__sub{font-size:1.18rem;color:var(--text);max-width:520px;margin-bottom:34px;font-weight:300}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:46px}
.hero__trust{display:flex;gap:40px}
.hero__stat{display:flex;flex-direction:column}
.hero__stat strong{font-family:var(--serif);font-size:2rem;color:var(--charcoal);line-height:1}
.hero__stat span{font-size:.85rem;color:var(--muted);margin-top:4px}

.hero__visual{position:relative}
.hero__img{height:520px;border-radius:var(--radius-lg);background-size:cover;background-position:center;box-shadow:var(--shadow-lg)}
.hero__card{position:absolute;background:#fff;border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px}
.hero__card strong{display:block;font-size:.92rem;color:var(--charcoal)}
.hero__card small{font-size:.78rem;color:var(--muted)}
.hero__card--top{top:32px;left:-28px}
.hero__card-icon{width:36px;height:36px;border-radius:50%;background:#eaf5ea;color:#3d9140;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.hero__card--bottom{bottom:36px;right:-24px}
.hero__card-stars{color:var(--gold);letter-spacing:1px;font-size:.85rem}

/* Trust strip */
.strip{background:var(--charcoal);color:#d8d2c4}
.strip__inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;padding:22px 0;font-size:.92rem;font-weight:500}
.strip__inner span{display:flex;align-items:center;gap:8px}

/* Services */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.service{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .35s ease,box-shadow .35s ease}
.service:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.service__img{height:180px;background-size:cover;background-position:center}
.service__body{padding:26px 24px 28px}
.service__body h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--charcoal);margin-bottom:10px}
.service__body p{font-size:.93rem;color:var(--muted);margin-bottom:16px}
.service__link{font-size:.88rem;font-weight:600;color:var(--gold);transition:gap .2s}
.service__link:hover{color:#8f6f37}

/* Why */
.why{display:grid;grid-template-columns:.85fr 1.15fr;gap:72px;align-items:center}
.why__media{position:relative}
.why__img{height:540px;border-radius:var(--radius-lg);background-size:cover;background-position:center;box-shadow:var(--shadow-md)}
.why__badge{position:absolute;bottom:-26px;right:-22px;background:var(--gold);color:#fff;border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-md);max-width:180px}
.why__badge strong{font-family:var(--serif);font-size:2.6rem;line-height:1;display:block}
.why__badge span{font-size:.84rem;display:block;margin-top:8px;color:rgba(255,255,255,.92)}
.why__content .section__title{margin-bottom:18px}
.why__lead{font-size:1.05rem;color:var(--text);margin-bottom:32px}
.why__list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:26px}
.why__list li{display:flex;gap:14px}
.why__icon{font-size:1.5rem;flex-shrink:0;width:48px;height:48px;background:#fff;border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.why__list strong{display:block;font-size:1.05rem;color:var(--charcoal);margin-bottom:4px}
.why__list p{font-size:.9rem;color:var(--muted);line-height:1.55}

/* Projects */
.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.project{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);min-height:300px;display:flex;align-items:flex-end;transition:transform .35s ease,box-shadow .35s ease}
.project:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.project--wide{grid-column:span 3;min-height:420px}
.project__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
.project:hover .project__img{transform:scale(1.05)}
.project::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,24,21,0) 35%,rgba(20,24,21,.82) 100%)}
.project__info{position:relative;z-index:2;padding:28px;color:#fff}
.project--wide .project__info{padding:38px;max-width:560px}
.project__tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:8px}
.project__info h3{font-family:var(--serif);font-size:1.55rem;font-weight:600;margin-bottom:6px}
.project--wide .project__info h3{font-size:2rem}
.project__info p{font-size:.92rem;color:rgba(255,255,255,.82)}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.review{background:#fff;border-radius:var(--radius-lg);padding:32px 30px;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .3s ease,box-shadow .3s ease}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.review__stars{color:var(--gold);letter-spacing:3px;font-size:1.05rem;margin-bottom:18px}
.review blockquote{font-size:1.02rem;line-height:1.7;color:var(--text);margin-bottom:24px}
.review figcaption{display:flex;align-items:center;gap:13px;border-top:1px solid var(--line);padding-top:18px}
.review__avatar{width:48px;height:48px;border-radius:50%;background-size:cover;background-position:center;flex-shrink:0}
.review__person{display:flex;flex-direction:column}
.review__person strong{color:var(--charcoal);font-size:.96rem}
.review__person small{color:var(--muted);font-size:.82rem}

/* Process */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.step{position:relative;background:var(--beige);border-radius:var(--radius-lg);padding:38px 28px;border:1px solid var(--line);transition:transform .3s ease,box-shadow .3s ease}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);background:#fff}
.step__num{font-family:var(--serif);font-size:2.6rem;font-weight:600;color:var(--gold-soft);display:block;margin-bottom:14px}
.step h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--charcoal);margin-bottom:10px}
.step p{font-size:.93rem;color:var(--muted)}

/* CTA */
.cta{background:var(--charcoal);color:#e6e0d4;padding:100px 0}
.cta__inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.cta__title{font-family:var(--serif);font-size:3rem;font-weight:600;color:#fff;line-height:1.08;margin-bottom:18px}
.cta__text{font-size:1.12rem;color:#b3ab9b;margin-bottom:28px;max-width:480px}
.cta__points{list-style:none;display:flex;flex-direction:column;gap:12px}
.cta__points li{font-size:1.02rem;color:#d8d2c4}
.cta__form{background:#fff;border-radius:var(--radius-lg);padding:38px;box-shadow:var(--shadow-lg)}
.cta__form-title{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--charcoal);margin-bottom:22px}
.field{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:.95rem;color:var(--charcoal);background:#fdfcf9;transition:border-color .2s;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.cta__form-note{text-align:center;font-size:.83rem;color:var(--muted);margin-top:14px}
.cta__form-note.success{color:#3d9140;font-weight:600}

/* Footer */
.footer{background:#171b16;color:#a7a293;padding:72px 0 0}
.footer__inner{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:50px}
.brand--light{color:#fff;font-size:1.5rem;margin-bottom:16px}
.footer__tagline{font-size:.93rem;color:#8a8576;max-width:330px;line-height:1.7;margin-bottom:20px}
.footer__social{display:flex;gap:18px}
.footer__social a{font-size:.88rem;color:#a7a293;transition:color .2s}
.footer__social a:hover{color:var(--gold-soft)}
.footer__col h4{font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:16px}
.footer__col a{display:block;font-size:.93rem;color:#8a8576;margin-bottom:10px;transition:color .2s}
.footer__col a:hover{color:#fff}
.footer__col p{font-size:.93rem;color:#8a8576;line-height:1.8}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0}
.footer__bottom .container{display:flex;justify-content:space-between;font-size:.82rem;color:#6f6a5d}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media(max-width:1000px){
  .hero__inner,.why,.cta__inner{grid-template-columns:1fr;gap:48px}
  .services,.projects,.reviews,.process{grid-template-columns:1fr 1fr}
  .project--wide{grid-column:span 2}
  .hero__title{font-size:3.2rem}
  .section__title{font-size:2.3rem}
  .nav__links{display:none}
  .hero__card--bottom{right:0}
  .why__badge{right:0}
}
@media(max-width:600px){
  .services,.projects,.reviews,.process,.why__list{grid-template-columns:1fr}
  .project--wide{grid-column:span 1}
  .hero__title{font-size:2.5rem}
  .hero__trust{gap:24px}
  .strip__inner{justify-content:flex-start;gap:14px}
  .field-row{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__bottom .container{flex-direction:column;gap:8px;text-align:center}
}
