

/* ============================================
   La Bella Madera — shared site styles
   ============================================ */

:root{
  --paper:#FAF9F6;
  --card:#FFFFFF;
  --ink:#2B2521;
  --ink-soft:#6B5B4D;
  --espresso:#1F1B17;
  --line:#E4DFD5;
  --line-strong:#C4BBAC;

  --display: 'Fraunces', serif;
  --body: 'Work Sans', sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  line-height:1.6;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

:focus-visible{
  outline: 2px solid var(--espresso);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}

.wrap{ max-width:1200px; margin:0 auto; padding:0 32px; }

/* ---------- joinery rule (section divider) ---------- */
.joint-rule{
  width:100%;
  height:18px;
  display:block;
  color:var(--line-strong);
}

/* ---------- header ---------- */
header{
  position:sticky; top:0; left:0; right:0;
  z-index:50;
  background:rgba(250,249,246,0.92);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 32px;
  max-width:1200px; margin:0 auto;
}
.logo{
  font-family:var(--display);
  font-weight:600;
  font-size:1.25rem;
  letter-spacing:0.005em;
  white-space:nowrap;
  color:var(--espresso);
}
.logo span{ color:var(--ink-soft); font-style:italic; }
.nav-links{ display:flex; gap:36px; align-items:center; }
.nav-links a{
  font-size:0.92rem;
  color:var(--ink-soft);
  transition:color 0.2s ease;
  position:relative;
  padding-bottom:4px;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.current{ color:var(--espresso); border-bottom:1px solid var(--espresso); }
.nav-cta{
  background:var(--espresso);
  color:var(--paper) !important;
  padding:10px 20px;
  border-radius:2px;
  font-weight:600;
  font-size:0.88rem;
  border-bottom:none !important;
}
.nav-cta:hover{ background:#3A332C; color:var(--paper) !important; }
.nav-toggle{ display:none; background:none; border:none; color:var(--ink); font-size:1.6rem; cursor:pointer; }

@media (max-width:860px){
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    background:var(--card);
    flex-direction:column; align-items:flex-start;
    padding:24px 32px; gap:20px;
    border-bottom:1px solid var(--line);
    display:none;
  }
  .nav-links.open{ display:flex; }
  .nav-toggle{ display:block; }
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:15px 28px;
  border-radius:2px;
  font-weight:600;
  font-size:0.92rem;
  cursor:pointer;
  border:1px solid transparent;
  transition: all 0.22s ease;
  font-family:var(--body);
}
.btn-primary{ background:var(--espresso); color:var(--paper); }
.btn-primary:hover{ background:#3A332C; transform:translateY(-1px); }
.btn-ghost{ border-color:var(--line-strong); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--espresso); background:rgba(31,27,23,0.03); }

/* ---------- page header (non-home pages) ---------- */
.page-header{
  padding:64px 0 56px;
  border-bottom:1px solid var(--line);
}
.page-header .eyebrow{ margin-bottom:16px; }
.page-header h1{
  font-family:var(--display);
  font-weight:380;
  font-size:clamp(2.2rem, 4vw, 3.4rem);
  line-height:1.06;
  letter-spacing:-0.01em;
}
.page-header p{
  margin-top:18px;
  color:var(--ink-soft);
  font-size:1.05rem;
  max-width:560px;
}

.eyebrow{
  font-size:0.78rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:600;
  display:flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:"";
  width:24px; height:1px;
  background:var(--espresso);
}

/* ---------- section base ---------- */
section{ padding:96px 0; position:relative; }
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head .eyebrow{ margin-bottom:16px; }
h2{
  font-family:var(--display);
  font-weight:380;
  font-size:clamp(2rem, 3.4vw, 2.9rem);
  line-height:1.1;
}
.section-head p{
  margin-top:18px;
  color:var(--ink-soft);
  font-size:1.04rem;
  max-width:520px;
}

/* ---------- marquee strip ---------- */
.marquee-strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:22px 0;
  overflow:hidden;
  background:var(--card);
}
.marquee-track{
  display:flex; gap:64px;
  white-space:nowrap;
  animation: scroll-left 28s linear infinite;
  width:max-content;
}
.marquee-track span{
  font-family:var(--display);
  font-style:italic;
  font-size:1rem;
  color:var(--ink-soft);
  letter-spacing:0.03em;
}
@keyframes scroll-left{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* ---------- process ---------- */
.process-list{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.process-step{
  background:var(--card);
  padding:36px 28px;
  position:relative;
}
.process-step .stage-name{
  font-family:var(--display);
  font-size:1.3rem;
  font-weight:500;
  margin-bottom:12px;
}
.process-step p{
  color:var(--ink-soft);
  font-size:0.92rem;
}
.process-step .stage-mark{
  font-family:var(--display);
  font-style:italic;
  color:var(--ink-soft);
  font-size:0.85rem;
  margin-bottom:18px;
  display:block;
}
@media (max-width:920px){ .process-list{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .process-list{ grid-template-columns:1fr; } }

/* ---------- gallery ---------- */
.gallery-head-row{
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:56px; flex-wrap:wrap; gap:24px;
}
.filter-row{ display:flex; gap:10px; flex-wrap:wrap; }
.filter-btn{
  padding:9px 18px;
  border:1px solid var(--line-strong);
  border-radius:2px;
  font-size:0.85rem;
  color:var(--ink-soft);
  background:transparent;
  cursor:pointer;
  transition: all 0.2s ease;
  font-family:var(--body);
}
.filter-btn:hover{ border-color:var(--espresso); color:var(--ink); }
.filter-btn.active{ background:var(--espresso); border-color:var(--espresso); color:var(--paper); }

.gallery-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:28px;
}
.gallery-item{
  position:relative;
  border-radius:3px;
  overflow:hidden;
  cursor:pointer;
  background:var(--card);
  border:1px solid var(--line);
}
.gallery-item .ph-img{
  aspect-ratio: 4/5;
  background:
    linear-gradient(135deg, rgba(196,187,172,0.45), rgba(228,223,213,0.65)),
    repeating-linear-gradient(100deg, rgba(43,37,33,0.04) 0px, rgba(43,37,33,0.04) 2px, transparent 2px, transparent 22px);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-soft);
  font-size:0.78rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  text-align:center;
  padding:24px;
  transition: transform 0.5s ease;
}
.gallery-item:hover .ph-img{ transform:scale(1.04); }
.gallery-caption{
  padding:18px 20px;
  border-top:1px solid var(--line);
}
.gallery-caption .piece-name{
  font-family:var(--display);
  font-size:1.1rem;
}
.gallery-caption .piece-meta{
  font-size:0.82rem;
  color:var(--ink-soft);
  margin-top:4px;
}
.gallery-item.hidden{ display:none; }

@media (max-width:920px){ .gallery-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .gallery-grid{ grid-template-columns:1fr; } }

/* ---------- materials strip ---------- */
.materials{ background:var(--card); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.materials-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:32px;
}
.material-card{
  border:1px solid var(--line);
  border-radius:3px;
  overflow:hidden;
  background:var(--paper);
}
.material-swatch{ height:140px; }
.material-card .info{ padding:20px; }
.material-card h3{
  font-family:var(--display);
  font-size:1.15rem;
  font-weight:500;
  margin-bottom:6px;
}
.material-card p{ font-size:0.85rem; color:var(--ink-soft); }
@media (max-width:920px){ .materials-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .materials-grid{ grid-template-columns:1fr; } }

/* ---------- testimonial ---------- */
.testimonial{ text-align:center; max-width:760px; margin:0 auto; }
.testimonial blockquote{
  font-family:var(--display);
  font-size:clamp(1.5rem, 2.6vw, 2.1rem);
  font-weight:380;
  line-height:1.35;
  font-style:italic;
}
.testimonial cite{
  display:block;
  margin-top:28px;
  font-style:normal;
  font-size:0.88rem;
  color:var(--ink-soft);
  letter-spacing:0.02em;
}

/* ---------- two-col content blocks (about page) ---------- */
.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:64px;
  align-items:center;
}
.split.reverse .split-media{ order:2; }
.split-media .ph-img{
  aspect-ratio: 4/3;
  background:
    linear-gradient(135deg, rgba(196,187,172,0.45), rgba(228,223,213,0.65)),
    repeating-linear-gradient(100deg, rgba(43,37,33,0.04) 0px, rgba(43,37,33,0.04) 2px, transparent 2px, transparent 22px);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-soft);
  font-size:0.78rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  text-align:center;
  padding:24px;
  border-radius:3px;
  border:1px solid var(--line);
}
.split-text h2{ margin-bottom:20px; }
.split-text p{ color:var(--ink-soft); margin-bottom:16px; }
.split-text p:last-child{ margin-bottom:0; }
@media (max-width:860px){
  .split, .split.reverse{ grid-template-columns:1fr; gap:32px; }
  .split.reverse .split-media{ order:0; }
}

/* ---------- values grid (about page) ---------- */
.values-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:40px;
}
.value-item .value-mark{
  font-family:var(--display);
  font-style:italic;
  font-size:0.85rem;
  color:var(--ink-soft);
  margin-bottom:14px;
  display:block;
}
.value-item h3{
  font-family:var(--display);
  font-size:1.3rem;
  font-weight:500;
  margin-bottom:10px;
}
.value-item p{ color:var(--ink-soft); font-size:0.94rem; }
@media (max-width:860px){ .values-grid{ grid-template-columns:1fr; gap:32px; } }

/* ---------- team strip (about page) ---------- */
.team-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:32px;
}
.team-card .ph-img{
  aspect-ratio:1;
  border-radius:3px;
  margin-bottom:16px;
}
.team-card h3{ font-family:var(--display); font-size:1.1rem; margin-bottom:4px; }
.team-card .role{ font-size:0.85rem; color:var(--ink-soft); }
@media (max-width:860px){ .team-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .team-grid{ grid-template-columns:1fr; } }

/* ---------- quote form ---------- */
.quote-section{ background:var(--card); border-top:1px solid var(--line); }
.quote-grid{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap:64px;
  align-items:start;
}
.quote-info h2{ margin-bottom:20px; }
.quote-info p{ color:var(--ink-soft); margin-bottom:28px; max-width:420px; }
.quote-points{ list-style:none; display:flex; flex-direction:column; gap:14px; }
.quote-points li{
  display:flex; gap:12px; align-items:flex-start;
  font-size:0.92rem; color:var(--ink-soft);
}
.quote-points li::before{
  content:"";
  width:6px; height:6px;
  margin-top:8px;
  background:var(--espresso);
  flex-shrink:0;
  transform:rotate(45deg);
}

form{ display:flex; flex-direction:column; gap:20px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
label{
  font-size:0.82rem;
  color:var(--ink-soft);
  margin-bottom:8px;
  display:block;
  letter-spacing:0.02em;
}
input, select, textarea{
  width:100%;
  background:var(--paper);
  border:1px solid var(--line-strong);
  color:var(--ink);
  padding:13px 14px;
  border-radius:2px;
  font-family:var(--body);
  font-size:0.94rem;
  transition: border-color 0.2s ease;
}
input::placeholder, textarea::placeholder{ color:#9C8F80; }
input:focus, select:focus, textarea:focus{
  outline:none;
  border-color:var(--espresso);
}
textarea{ resize:vertical; min-height:110px; }
.field{ display:flex; flex-direction:column; }
.submit-row{ margin-top:8px; }
.form-note{ font-size:0.78rem; color:var(--ink-soft); margin-top:6px; }
.form-success{
  display:none;
  background:#F1EEE7;
  border:1px solid var(--line-strong);
  padding:18px 20px;
  border-radius:2px;
  font-size:0.92rem;
  color:var(--ink);
}
.form-success.show{ display:block; }

@media (max-width:920px){
  .quote-grid{ grid-template-columns:1fr; gap:48px; }
  .form-row{ grid-template-columns:1fr; }
}

/* ---------- contact info cards ---------- */
.contact-info-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:24px;
  margin-bottom:72px;
}
.contact-info-card{
  border:1px solid var(--line);
  border-radius:3px;
  padding:28px;
  background:var(--paper);
}
.contact-info-card .eyebrow{ margin-bottom:14px; }
.contact-info-card p, .contact-info-card a{
  display:block;
  font-size:0.95rem;
  color:var(--ink);
  margin-bottom:4px;
}
.contact-info-card a:hover{ color:var(--ink-soft); }
@media (max-width:860px){ .contact-info-grid{ grid-template-columns:1fr; } }

/* ---------- footer ---------- */
footer{
  border-top:1px solid var(--line);
  padding:64px 0 32px;
  background:var(--card);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:56px;
}
.footer-brand .logo{ margin-bottom:16px; display:inline-block; }
.footer-brand p{ color:var(--ink-soft); font-size:0.9rem; max-width:280px; }
.footer-col h4{
  font-size:0.8rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:18px;
}
.footer-col a{
  display:block;
  color:var(--ink);
  font-size:0.92rem;
  margin-bottom:12px;
  transition:color 0.2s ease;
}
.footer-col a:hover{ color:var(--ink-soft); }
.footer-bottom{
  display:flex; justify-content:space-between;
  border-top:1px solid var(--line);
  padding-top:28px;
  font-size:0.8rem;
  color:var(--ink-soft);
  flex-wrap:wrap; gap:12px;
}
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }

/* reveal on scroll */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal.in{ opacity:1; transform:translateY(0); }