/* ===== Gudino & Sons — site styles ===== */
:root{
  --ink:#130C08;        /* warm near-black (logo) */
  --ink-2:#241812;      /* raised dark surface */
  --gold:#B87522;       /* ochre gold (logo) */
  --gold-hi:#D89B4C;    /* lifted gold for dark bg / hover */
  --gold-deep:#8F5A17;
  --cream:#F4ECDE;      /* warm field */
  --paper:#FBF7EF;      /* lightest warm white */
  --stone:#7C6E5D;      /* muted taupe text */
  --stone-2:#9C8E7C;
  --line:#E4D8C4;       /* warm hairline */
  --line-dk:rgba(244,236,222,.16);
  --white:#fff;
  --shadow:0 18px 50px -22px rgba(19,12,8,.45);
  --shadow-sm:0 8px 24px -14px rgba(19,12,8,.4);
  --wrap:1200px;
  --r:10px;
  --font-d:"Archivo",system-ui,sans-serif;
  --font-b:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-b);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-d);font-weight:800;line-height:1.06;letter-spacing:-.02em;margin:0}
h1{font-size:clamp(2.5rem,6vw,4.4rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:1.3rem;letter-spacing:-.01em}
p{margin:0 0 1rem}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,5vw,44px)}
section{padding:clamp(64px,8vw,110px) 0}
.eyebrow{
  display:inline-block;font-family:var(--font-d);font-weight:700;
  text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;color:var(--gold-deep);
  margin-bottom:16px;
}
.dark .eyebrow{color:var(--gold-hi)}
.lead{font-size:clamp(1.05rem,1.6vw,1.24rem);color:var(--stone);line-height:1.6}
.dark, .dark p, .dark .lead{color:#E9DECD}
.dark h1,.dark h2,.dark h3{color:var(--paper)}
em{font-style:normal;color:var(--gold)}
.dark em{color:var(--gold-hi)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;cursor:pointer;
  font-family:var(--font-d);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:15px 28px;border-radius:8px;border:2px solid transparent;transition:.2s;white-space:nowrap;
}
.btn-gold{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-hi);border-color:var(--gold-hi);transform:translateY(-2px)}
.btn-ink{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-ink:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--paper);border-color:rgba(244,236,222,.4)}
.btn-ghost:hover{border-color:var(--gold-hi);color:var(--gold-hi)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper)}

/* ---- header ---- */
header#site-header{position:sticky;top:0;z-index:50}
.nav{
  position:absolute;top:0;left:0;right:0;z-index:50;transition:.28s;
}
.nav-in{max-width:var(--wrap);margin:0 auto;padding:16px clamp(20px,5vw,44px);
  display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav .brand{display:flex;align-items:center;gap:12px}
.nav .brand .markimg{height:42px;width:auto;transition:.28s}
.nav .brand .lt{display:block}
.nav .brand .dk{display:none}
.wordmark{font-family:var(--font-d);font-weight:900;font-size:1.05rem;line-height:.92;letter-spacing:-.01em;
  text-transform:uppercase;color:var(--paper);transition:.28s;white-space:nowrap}
.wordmark small{display:block;font-size:.46rem;font-weight:700;letter-spacing:.34em;color:var(--gold-hi);margin-top:3px}
.nav.solid .wordmark{color:var(--ink)}
body[data-hero="light"] .wordmark{color:var(--ink)}
.nav-links{display:flex;align-items:center;gap:22px}
.navcta{display:none}
.nav-links a{font-family:var(--font-d);font-weight:600;font-size:.92rem;color:var(--paper);opacity:.92;transition:.18s;white-space:nowrap}
.nav-links a:hover{color:var(--gold-hi);opacity:1}
.nav .call{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);font-weight:700;color:var(--paper)}
.nav .call .btn{padding:11px 20px;font-size:.9rem}
/* scrolled / solid state */
.nav.solid{position:fixed;background:var(--paper);box-shadow:0 6px 30px -18px rgba(19,12,8,.5);border-bottom:1px solid var(--line)}
.nav.solid .nav-links a,.nav.solid .call{color:var(--ink)}
.nav.solid .brand .lt{display:none}
.nav.solid .brand .dk{display:block}
.nav.solid .btn-ghost{color:var(--ink);border-color:var(--ink)}
/* pages with light hero use solid-on-light from the start */
body[data-hero="light"] .nav{position:absolute}
body[data-hero="light"] .nav-links a,body[data-hero="light"] .call{color:var(--ink)}
body[data-hero="light"] .brand .lt{display:none}
body[data-hero="light"] .brand .dk{display:block}
body[data-hero="light"] .btn-ghost{color:var(--ink);border-color:var(--ink)}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:8px}
.menu-btn span{display:block;width:26px;height:2px;background:currentColor;margin:5px 0}
.nav .call, .nav-links{color:var(--paper)}

/* ---- hero (dark editorial) ---- */
.hero{position:relative;background:var(--ink);color:var(--paper);overflow:hidden;
  padding-top:clamp(120px,15vh,180px);padding-bottom:clamp(70px,9vw,120px)}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 82% 15%,rgba(184,117,34,.22),transparent 55%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,64px);align-items:center;position:relative}
.hero h1{margin-bottom:22px}
.hero .lead{max-width:34ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0 30px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:.85rem;color:#E9DECD;
  background:rgba(244,236,222,.07);border:1px solid var(--line-dk);border-radius:100px;padding:8px 15px}
.chip b{color:var(--gold-hi);font-family:var(--font-d)}
.hero-media{position:relative}
.hero-media .frame{border-radius:14px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(244,236,222,.12);
  aspect-ratio:4/3.4}
.hero-media .frame img{width:100%;height:100%;object-fit:cover}
.hero-media .tag{position:absolute;left:-14px;bottom:26px;background:var(--gold);color:var(--ink);
  font-family:var(--font-d);font-weight:800;font-size:.8rem;letter-spacing:.02em;padding:11px 18px;border-radius:8px;box-shadow:var(--shadow-sm)}
.hero-media .tag small{display:block;font-weight:600;font-size:.72rem;opacity:.8;letter-spacing:0}

/* ---- stats band ---- */
.stats{background:var(--gold);color:var(--ink)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-top:34px;padding-bottom:34px}
.stat{ text-align:center;padding:6px}
.stat .n{font-family:var(--font-d);font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1}
.stat .l{font-size:.82rem;font-weight:600;letter-spacing:.02em;margin-top:7px;color:#3c2a12}
.stat+.stat{border-left:1px solid rgba(19,12,8,.16)}

/* ---- section heads ---- */
.sec-head{max-width:640px;margin-bottom:44px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head p{color:var(--stone);margin-top:10px}

/* ---- value strip ---- */
.value{background:var(--cream)}
.value .wrap{max-width:840px;text-align:center}
.value h2{margin-bottom:16px}
.value p{color:var(--stone);font-size:1.1rem}
.rule{width:54px;height:3px;background:var(--gold);border:0;margin:0 auto 26px}

/* ---- services ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px 26px;
  transition:.22s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.svc:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#d8c39d}
.svc .ic{width:52px;height:52px;border-radius:11px;background:var(--cream);display:grid;place-items:center;margin-bottom:18px}
.svc .ic svg{width:26px;height:26px;fill:none;stroke:var(--gold-deep);stroke-width:1.7}
.svc h3{margin-bottom:9px}
.svc p{color:var(--stone);font-size:.96rem;margin-bottom:16px}
.svc .more{margin-top:auto;font-family:var(--font-d);font-weight:700;font-size:.9rem;color:var(--gold-deep)}
.svc.feature{grid-column:span 3;flex-direction:row;align-items:stretch;padding:0}
.svc.feature .txt{padding:38px 34px;flex:1;display:flex;flex-direction:column;justify-content:center}
.svc.feature .pic{flex:1.1;min-height:300px;position:relative}
.svc.feature .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.svc.feature .badge{align-self:flex-start;background:var(--gold);color:var(--ink);font-family:var(--font-d);
  font-weight:800;font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;padding:6px 12px;border-radius:6px;margin-bottom:16px}
.svc.feature h3{font-size:1.7rem}

/* ---- gallery ---- */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.frame{position:relative;border-radius:var(--r);overflow:hidden;background:var(--ink)}
.frame img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.frame:hover img{transform:scale(1.05)}
.gal .frame{aspect-ratio:1}
.gal .frame.wide{grid-column:span 2;aspect-ratio:2/1}
.cap{position:absolute;left:0;right:0;bottom:0;padding:26px 18px 14px;color:#fff;font-size:.85rem;font-weight:500;
  background:linear-gradient(transparent,rgba(19,12,8,.82));opacity:0;transform:translateY(8px);transition:.25s}
.frame:hover .cap{opacity:1;transform:none}

/* ---- process ---- */
.process{background:var(--ink);color:var(--paper)}
.psteps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:10px}
.pstep{background:var(--ink-2);border:1px solid var(--line-dk);border-radius:var(--r);padding:30px 26px}
.pstep .knum{font-family:var(--font-d);font-weight:800;color:var(--gold-hi);font-size:.8rem;letter-spacing:.14em;margin-bottom:14px}
.pstep h3{color:var(--paper);margin-bottom:8px}
.pstep p{color:#CDBFAC;font-size:.95rem;margin:0}

/* ---- review ---- */
.review{background:var(--cream);text-align:center}
.review .wrap{max-width:760px}
.stars{color:var(--gold);font-size:1.3rem;letter-spacing:3px;margin-bottom:18px}
.review blockquote{font-family:var(--font-d);font-weight:700;font-size:clamp(1.4rem,2.6vw,2rem);
  line-height:1.28;letter-spacing:-.01em;margin:0 0 20px}
.review .who{color:var(--stone);font-weight:600}
.review .rec{margin-top:8px;font-size:.86rem;color:var(--gold-deep);font-family:var(--font-d);font-weight:700;letter-spacing:.03em}

/* ---- about split ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.about .media .frame{aspect-ratio:4/4.4;box-shadow:var(--shadow)}
.about h2{margin-bottom:16px}
.about p{color:var(--stone)}
.sign{font-family:var(--font-d);font-weight:800;color:var(--ink);margin-top:18px}
.badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.badges .b{display:flex;align-items:center;gap:9px;font-size:.82rem;font-weight:600;color:var(--stone);
  border:1px solid var(--line);border-radius:8px;padding:9px 13px;background:var(--white)}
.badges .b svg{width:17px;height:17px;stroke:var(--gold-deep);fill:none;stroke-width:1.8}

/* ---- cta band ---- */
.cta-band{background:linear-gradient(120deg,var(--ink),#2a1c12);color:var(--paper);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 50% -10%,rgba(184,117,34,.25),transparent 60%)}
.cta-band .wrap{position:relative;max-width:680px}
.cta-band h2{color:var(--paper);margin-bottom:12px}
.cta-band p{color:#E4D7C4;margin-bottom:26px}

/* ---- inner page hero (light) ---- */
.page-hero{background:var(--cream);padding-top:clamp(130px,16vh,180px);padding-bottom:clamp(46px,6vw,72px);border-bottom:1px solid var(--line)}
.page-hero .crumb{font-size:.8rem;color:var(--stone-2);font-weight:600;margin-bottom:14px}
.page-hero .crumb a:hover{color:var(--gold-deep)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem)}
.page-hero p{color:var(--stone);max-width:56ch;margin-top:14px;font-size:1.1rem}

/* ---- content blocks ---- */
.prose{max-width:760px}
.prose h2{margin:0 0 14px}
.prose p{color:var(--stone)}
.two-col{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(34px,5vw,60px);align-items:start}
.checks{list-style:none;padding:0;margin:20px 0 0;display:grid;gap:12px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-size:.98rem}
.checks li::before{content:"";flex:0 0 22px;height:22px;margin-top:1px;border-radius:6px;background:var(--cream);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238F5A17' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:15px;background-repeat:no-repeat;background-position:center}
.aside-card{background:var(--ink);color:var(--paper);border-radius:var(--r);padding:30px 28px;position:sticky;top:100px}
.aside-card h3{color:var(--paper);margin-bottom:6px}
.aside-card p{color:#CDBFAC;font-size:.92rem}
.aside-card .btn{width:100%;justify-content:center;margin-top:8px}
.aside-card .ph{font-family:var(--font-d);font-weight:800;font-size:1.5rem;color:var(--gold-hi);margin:10px 0 4px}

.svc-list{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,60px);align-items:start}
.field{margin-bottom:16px}
.field label{display:block;font-size:.82rem;font-weight:600;font-family:var(--font-d);margin-bottom:6px;color:var(--ink)}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:8px;
  font-family:inherit;font-size:1rem;background:var(--white);color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.info-row .ic{flex:0 0 42px;height:42px;border-radius:10px;background:var(--cream);display:grid;place-items:center}
.info-row .ic svg{width:20px;height:20px;stroke:var(--gold-deep);fill:none;stroke-width:1.8}
.info-row .k{font-family:var(--font-d);font-weight:700;font-size:.95rem}
.info-row .v{color:var(--stone);font-size:.95rem}
.info-row .v a:hover{color:var(--gold-deep)}
.note{font-size:.82rem;color:var(--stone-2);margin-top:8px}

/* ---- footer ---- */
footer#site-footer{background:var(--ink);color:#CDBFAC}
.foot{max-width:var(--wrap);margin:0 auto;padding:clamp(56px,7vw,80px) clamp(20px,5vw,44px) 34px;
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px}
.foot .brand img{height:52px;margin-bottom:16px}
.foot p{font-size:.92rem;line-height:1.6;color:#B7A88F}
.foot h4{font-family:var(--font-d);font-weight:700;color:var(--paper);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px}
.foot a{display:block;color:#CDBFAC;font-size:.93rem;padding:5px 0;transition:.15s}
.foot a:hover{color:var(--gold-hi)}
.foot .ph{font-family:var(--font-d);font-weight:800;font-size:1.35rem;color:var(--paper);margin-bottom:6px}
.foot-bot{border-top:1px solid var(--line-dk);margin-top:20px}
.foot-bot .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;padding-bottom:30px;
  font-size:.8rem;color:#8f8471}

/* ---- brands ---- */
.brands{background:var(--paper)}
.brand-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.brand-card{flex:1 1 158px;max-width:212px;border:1px solid var(--line);border-radius:var(--r);padding:26px 16px;text-align:center;background:var(--white);
  transition:.2s;display:flex;flex-direction:column;justify-content:center;min-height:120px}
.brand-card:hover{border-color:#d8c39d;transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.brand-card .lg{height:50px;display:flex;align-items:center;justify-content:center;margin-bottom:13px}
.brand-card .lg img{max-height:50px;max-width:150px;width:auto;object-fit:contain}
.brand-card .lg img.mono{filter:brightness(0)}
.brand-card .bn{font-family:var(--font-d);font-weight:800;font-size:1.12rem;letter-spacing:-.01em;line-height:1.05;color:var(--ink)}
.brand-card .bt{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-deep);margin-top:0}
.brand-note{text-align:center;color:var(--stone);font-size:.92rem;margin:26px 0 0}

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

/* ---- responsive ---- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-media{max-width:460px}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:0}
  .stat{padding:18px}.stat:nth-child(3){border-left:0}
  .stat+.stat{border-left:1px solid rgba(19,12,8,.16)}
  .stat:nth-child(odd){border-left:0}
  .svc-grid,.svc-list,.psteps,.gal{grid-template-columns:repeat(2,1fr)}
  .svc.feature{flex-direction:column}.svc.feature .pic{min-height:240px}
  .svc.feature{grid-column:span 2}
  .split,.two-col,.contact-grid{grid-template-columns:1fr}
  .aside-card{position:static}
  .gal .frame.wide{grid-column:span 2}
  .foot{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  body{font-size:16px}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--ink);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;padding:40px;
    transform:translateX(100%);transition:.3s;box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .nav-links a{color:var(--paper)!important;font-size:1.2rem;padding:8px 0}
  .navcta{display:inline-flex!important;margin-top:16px;color:var(--ink)!important;font-size:1rem!important}
  .menu-btn{display:block;color:var(--paper);z-index:60}
  body[data-hero="light"] .menu-btn,.nav.solid .menu-btn{color:var(--ink)}
  .nav .call{display:none}
  .svc-grid,.svc-list,.psteps,.gal,.foot{grid-template-columns:1fr}
  .svc.feature{grid-column:span 1}
  .gal .frame.wide{grid-column:span 1;aspect-ratio:3/2}
  .stats .wrap{grid-template-columns:1fr 1fr}
}
