/* ============================================================
   Durham Appliance Thrift & Repair — concept site
   Design: "The honest trade" — pine + brass, warm and grounded
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,900;1,9..144,500&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --ink:#1c2b27;
  --paper:#f5f2ea;
  --paper-card:#fbfaf5;
  --pine:#2e5d49;
  --pine-dark:#234a3a;
  --pine-deep:#1b3a2d;
  --brass:#bb8a3d;
  --brass-soft:#cda257;
  --clay:#b0492f;
  --stone:#e7e1d4;
  --line:#d9d3c5;
  --muted:#65695f;
  --radius:14px;
  --radius-lg:22px;
  --maxw:1140px;
  --shadow:0 1px 2px rgba(28,43,39,.04),0 8px 30px rgba(28,43,39,.07);
  --shadow-lg:0 4px 12px rgba(28,43,39,.08),0 24px 60px rgba(28,43,39,.12);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem}

/* ---- Concept banner ---- */
.concept-bar{
  background:var(--pine-deep);
  color:#e8efe9;
  font-size:.78rem;
  letter-spacing:.02em;
  text-align:center;
  padding:.5rem 1rem;
  font-weight:500;
}
.concept-bar strong{color:var(--brass-soft);font-weight:600}

/* ---- Header ---- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,242,234,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:.85rem 1.5rem;max-width:var(--maxw);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand-mark{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  background:var(--pine);display:grid;place-items:center;
  box-shadow:0 2px 6px rgba(35,74,58,.35);
}
.brand-mark svg{width:24px;height:24px}
.brand-text{line-height:1.15}
.brand-name{
  font-family:'Fraunces',serif;font-weight:600;font-size:1.08rem;
  color:var(--pine-dark);letter-spacing:-.01em;
}
.brand-sub{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600}

.nav{display:flex;align-items:center;gap:.3rem}
.nav a{
  padding:.5rem .85rem;border-radius:8px;font-size:.93rem;font-weight:500;
  color:var(--ink);transition:background .15s,color .15s;
}
.nav a:hover{background:var(--stone)}
.nav a.active{color:var(--pine);font-weight:600}

.header-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--pine);color:#fff;font-weight:600;font-size:.95rem;
  padding:.62rem 1.15rem;border-radius:10px;white-space:nowrap;
  transition:background .15s,transform .1s;box-shadow:0 2px 8px rgba(35,74,58,.3);
}
.header-cta:hover{background:var(--pine-dark);transform:translateY(-1px)}
.header-cta svg{width:16px;height:16px}

.hamburger{display:none;background:none;border:1.5px solid var(--line);border-radius:9px;padding:.5rem;cursor:pointer}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);margin:4px 0;border-radius:2px;transition:.2s}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;justify-content:center;
  font-weight:600;font-size:1rem;padding:.85rem 1.6rem;border-radius:11px;
  cursor:pointer;border:none;transition:background .15s,transform .1s,box-shadow .15s;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--pine);color:#fff;box-shadow:0 3px 12px rgba(35,74,58,.32)}
.btn-primary:hover{background:var(--pine-dark);transform:translateY(-1px)}
.btn-brass{background:var(--brass);color:#241a06;box-shadow:0 3px 12px rgba(187,138,61,.32)}
.btn-brass:hover{background:var(--brass-soft);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--pine-dark);border:1.5px solid var(--pine);}
.btn-ghost:hover{background:var(--pine);color:#fff}
.btn-lg{font-size:1.08rem;padding:1rem 1.9rem}

/* ---- Eyebrow / section heads ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.74rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:var(--pine);margin-bottom:1rem;
}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--brass);border-radius:2px}
.section-title{
  font-family:'Fraunces',serif;font-weight:600;line-height:1.08;
  font-size:clamp(1.8rem,4vw,2.7rem);letter-spacing:-.015em;color:var(--ink);
}
.section-lead{font-size:1.08rem;color:var(--muted);max-width:560px;margin-top:1rem;line-height:1.7}

section{padding:5rem 0}

/* ---- HERO ---- */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 90% at 85% -10%,rgba(187,138,61,.10),transparent 55%),
    linear-gradient(180deg,#f7f4ec 0%,#f1ede3 100%);
  border-bottom:1px solid var(--line);
}
.hero-grid{
  display:grid;grid-template-columns:1.15fr .85fr;gap:3.5rem;align-items:center;
  padding:4.5rem 0 4rem;
}
.hero h1{
  font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(2.3rem,5.2vw,3.7rem);line-height:1.04;letter-spacing:-.02em;
  margin-bottom:1.25rem;
}
.hero h1 em{font-style:italic;color:var(--pine);font-weight:600}
.hero-sub{font-size:1.15rem;color:var(--muted);line-height:1.65;margin-bottom:2rem;max-width:520px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-bottom:2rem}
.hero-microtrust{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;font-size:.86rem;color:var(--muted);font-weight:500}
.hero-microtrust .dot{display:inline-flex;align-items:center;gap:.4rem}
.hero-microtrust svg{width:15px;height:15px;color:var(--pine)}

/* Trust seal card */
.seal{
  background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);padding:2rem 1.9rem;position:relative;
}
.seal::before{
  content:'';position:absolute;inset:0;border-radius:var(--radius-lg);
  border:1px solid rgba(187,138,61,.25);pointer-events:none;margin:5px;
}
.seal-top{display:flex;align-items:center;gap:1rem;padding-bottom:1.3rem;border-bottom:1px dashed var(--line);margin-bottom:1.3rem}
.seal-score{font-family:'Fraunces',serif;font-weight:700;font-size:3rem;line-height:1;color:var(--pine-dark)}
.seal-stars{color:var(--brass);font-size:1.05rem;letter-spacing:.1em}
.seal-reviews{font-size:.84rem;color:var(--muted);font-weight:500;margin-top:.15rem}
.seal-list{display:flex;flex-direction:column;gap:.95rem}
.seal-item{display:flex;gap:.75rem;align-items:flex-start}
.seal-check{
  width:24px;height:24px;border-radius:50%;background:rgba(46,93,73,.1);
  display:grid;place-items:center;flex-shrink:0;margin-top:.1rem;
}
.seal-check svg{width:14px;height:14px;color:var(--pine)}
.seal-item b{font-weight:600;font-size:.96rem;display:block}
.seal-item span{font-size:.84rem;color:var(--muted);line-height:1.45}

/* ---- Dual path ---- */
.dual{background:var(--pine-deep);color:#eef3ee}
.dual-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.dual-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);padding:2.3rem;transition:transform .2s,border-color .2s,background .2s;
}
.dual-card:hover{transform:translateY(-3px);border-color:rgba(187,138,61,.5);background:rgba(255,255,255,.06)}
.dual-icon{
  width:54px;height:54px;border-radius:14px;background:var(--brass);
  display:grid;place-items:center;margin-bottom:1.3rem;
}
.dual-icon svg{width:28px;height:28px;color:#241a06}
.dual-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.45rem;margin-bottom:.6rem;color:#fff}
.dual-card p{color:#c4d1c8;font-size:.98rem;line-height:1.6;margin-bottom:1.4rem}
.dual-link{display:inline-flex;align-items:center;gap:.45rem;color:var(--brass-soft);font-weight:600;font-size:.95rem}
.dual-link svg{width:16px;height:16px;transition:transform .15s}
.dual-card:hover .dual-link svg{transform:translateX(4px)}

/* ---- Services grid ---- */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:3rem}
.svc-card{
  background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.4rem;transition:transform .18s,box-shadow .18s,border-color .18s;
}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(46,93,73,.3)}
.svc-ic{
  width:46px;height:46px;border-radius:12px;background:var(--stone);
  display:grid;place-items:center;margin-bottom:1rem;
}
.svc-ic svg{width:24px;height:24px;color:var(--pine)}
.svc-card h3{font-weight:600;font-size:1.05rem;margin-bottom:.35rem}
.svc-card p{font-size:.88rem;color:var(--muted);line-height:1.5}

/* ---- Why / promise band ---- */
.why{background:linear-gradient(180deg,#f1ede3,#efe9dd)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.why-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow)}
.why-num{font-family:'Fraunces',serif;font-weight:700;font-size:1.05rem;color:var(--brass);margin-bottom:.8rem}
.why-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.3rem;margin-bottom:.55rem}
.why-card p{font-size:.95rem;color:var(--muted);line-height:1.6}

/* ---- Reviews ---- */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:3rem}
.rev-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;display:flex;flex-direction:column;gap:1rem}
.rev-stars{color:var(--brass);font-size:.95rem;letter-spacing:.12em}
.rev-text{font-size:.98rem;line-height:1.65;color:var(--ink);flex:1}
.rev-by{display:flex;align-items:center;gap:.7rem;border-top:1px solid var(--line);padding-top:1rem}
.rev-av{width:38px;height:38px;border-radius:50%;background:var(--pine);color:#fff;display:grid;place-items:center;font-weight:600;font-size:.95rem;flex-shrink:0}
.rev-name{font-weight:600;font-size:.9rem}
.rev-meta{font-size:.78rem;color:var(--muted)}

/* ---- Service area ---- */
.area{background:var(--pine);color:#eef3ee}
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.area h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(1.8rem,4vw,2.5rem);line-height:1.1;margin-bottom:1rem;color:#fff}
.area p{color:#c4d1c8;font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}
.area-chips{display:flex;flex-wrap:wrap;gap:.55rem}
.area-chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:100px;padding:.4rem .95rem;font-size:.86rem;font-weight:500}

/* ---- CTA band ---- */
.cta-band{background:var(--paper-card);border-top:1px solid var(--line)}
.cta-inner{text-align:center;max-width:640px;margin:0 auto}
.cta-inner h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(1.9rem,4.2vw,2.8rem);line-height:1.1;margin-bottom:1rem}
.cta-inner h2 em{font-style:italic;color:var(--pine)}
.cta-inner p{font-size:1.1rem;color:var(--muted);margin-bottom:2rem}
.cta-actions{display:flex;gap:.85rem;justify-content:center;flex-wrap:wrap}

/* ---- Footer ---- */
.site-footer{background:var(--pine-deep);color:#c4d1c8;padding:3.5rem 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .brand-name{color:#fff}
.foot-brand p{font-size:.9rem;line-height:1.6;margin-top:1rem;max-width:280px}
.foot-col h4{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:1rem;font-weight:700}
.foot-col a,.foot-col p{display:block;font-size:.92rem;color:#c4d1c8;padding:.28rem 0;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-bottom{padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:#8ba093}
.foot-bottom .concept-note{color:var(--brass-soft)}

/* ---- Page hero (interior) ---- */
.page-hero{background:linear-gradient(180deg,#f7f4ec,#f1ede3);border-bottom:1px solid var(--line);padding:3.5rem 0}
.page-hero h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(2rem,4.5vw,3rem);line-height:1.06;letter-spacing:-.02em;margin-bottom:.8rem}
.page-hero p{font-size:1.1rem;color:var(--muted);max-width:620px}
.crumb{font-size:.82rem;color:var(--muted);margin-bottom:1rem}
.crumb a:hover{color:var(--pine)}

/* ---- Services page detail ---- */
.svc-detail{display:flex;flex-direction:column;gap:1.2rem;margin-top:2.5rem}
.svc-row{display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:center;background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem 1.8rem;transition:border-color .18s,box-shadow .18s}
.svc-row:hover{border-color:rgba(46,93,73,.3);box-shadow:var(--shadow)}
.svc-row-ic{width:56px;height:56px;border-radius:14px;background:var(--stone);display:grid;place-items:center;flex-shrink:0}
.svc-row-ic svg{width:28px;height:28px;color:var(--pine)}
.svc-row h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.25rem;margin-bottom:.3rem}
.svc-row p{font-size:.94rem;color:var(--muted);line-height:1.55}
.svc-row .btn{flex-shrink:0}

/* ---- About ---- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.about-body p{margin-bottom:1.2rem;font-size:1.05rem;line-height:1.75;color:var(--ink)}
.about-body p.lead{font-family:'Fraunces',serif;font-size:1.35rem;line-height:1.5;color:var(--pine-dark);font-weight:500}
.about-card{background:var(--pine-deep);color:#eef3ee;border-radius:var(--radius-lg);padding:2.2rem;position:sticky;top:90px}
.about-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.3rem;color:#fff;margin-bottom:1.3rem}
.about-stat{display:flex;align-items:baseline;gap:.6rem;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.1)}
.about-stat:last-of-type{border-bottom:none}
.about-stat .n{font-family:'Fraunces',serif;font-weight:700;font-size:1.8rem;color:var(--brass-soft)}
.about-stat .l{font-size:.92rem;color:#c4d1c8}
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:3rem}
.value{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.value .vic{width:42px;height:42px;border-radius:11px;background:rgba(46,93,73,.1);display:grid;place-items:center;margin-bottom:.9rem}
.value .vic svg{width:22px;height:22px;color:var(--pine)}
.value h3{font-weight:600;font-size:1.05rem;margin-bottom:.35rem}
.value p{font-size:.9rem;color:var(--muted);line-height:1.55}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.3rem}
.ci-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;display:flex;gap:1rem;align-items:flex-start}
.ci-ic{width:46px;height:46px;border-radius:12px;background:rgba(46,93,73,.1);display:grid;place-items:center;flex-shrink:0}
.ci-ic svg{width:22px;height:22px;color:var(--pine)}
.ci-card h3{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem;font-weight:700}
.ci-card p,.ci-card a{font-size:1.02rem;font-weight:500;line-height:1.5}
.ci-card a:hover{color:var(--pine)}
.ci-hours{font-size:.92rem !important;font-weight:400 !important;color:var(--muted)}

.form-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.2rem;box-shadow:var(--shadow)}
.form-card h2{font-family:'Fraunces',serif;font-weight:600;font-size:1.5rem;margin-bottom:.4rem}
.form-card .fc-sub{font-size:.95rem;color:var(--muted);margin-bottom:1.6rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.4rem}
.field label .req{color:var(--clay)}
.field input,.field select,.field textarea{
  width:100%;border:1.5px solid var(--line);border-radius:10px;
  padding:.7rem .9rem;font-size:.98rem;font-family:inherit;color:var(--ink);
  background:#fff;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--pine);box-shadow:0 0 0 3px rgba(46,93,73,.12);
}
.field textarea{resize:vertical;min-height:110px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-note{font-size:.82rem;color:var(--muted);margin-top:.6rem;text-align:center}

/* ---- Responsive ---- */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .seal{max-width:460px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .why-grid,.rev-grid{grid-template-columns:1fr}
  .dual-grid,.area-grid,.about-grid,.contact-grid,.values{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .about-card{position:static}
  .nav,.header-cta{display:none}
  .hamburger{display:block}
  .nav.open{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:1rem 1.5rem;gap:.2rem;
  }
  .nav.open a{padding:.7rem .5rem}
}
@media(max-width:560px){
  body{font-size:16px}
  section{padding:3.5rem 0}
  .svc-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .svc-row{grid-template-columns:auto 1fr;gap:1rem}
  .svc-row .btn{grid-column:1/-1}
  .hero h1{font-size:2.1rem}
}

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

/* reveal — only hides when JS is active (progressive enhancement, never blank) */
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none}}
