/* Allen's Automotive — "Honest workshop"
   Warm cream, deep ink navy, safety-orange accent used semantically. */

:root {
  --paper: #faf6ef;
  --surface: #fffdf8;
  --ink: #1b2a41;
  --ink-soft: #44506a;
  --line: #e3dccd;
  --accent: #c2410c;        /* safety orange, AA on cream for large/bold */
  --accent-bright: #e8590c; /* decorative only (stars, dot, rules) */
  --open-green: #2f7d32;

  --font-display: "Zilla Slab", "Georgia", serif;
  --font-body: "Inter", system-ui, sans-serif;

  --text-base: clamp(1rem, 0.95rem + 0.3vw, 1.125rem);
  --text-hero: clamp(3rem, 1.4rem + 7vw, 6.5rem);
  --text-h2: clamp(1.75rem, 1.3rem + 1.6vw, 2.5rem);

  --space-section: clamp(4rem, 2.5rem + 5vw, 8rem);
  --duration: 180ms;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; margin: 0; }

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
}

.wrap { max-width: 62rem; margin-inline: auto; padding-inline: clamp(1.25rem, 4vw, 2.5rem); }

h1, h2, h3 { font-family: var(--font-display); line-height: 1.05; }
h2 { font-size: var(--text-h2); }
a { color: var(--accent); }
a:focus-visible { outline: 3px solid var(--accent); outline-offset: 3px; border-radius: 2px; }

.visually-hidden {
  position: absolute; width: 1px; height: 1px; overflow: hidden;
  clip-path: inset(50%); white-space: nowrap;
}

/* ---- Hero ---- */
.hero {
  padding-block: var(--space-section);
  border-bottom: 4px solid var(--ink);
  /* subtle grain */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}

.hero-badge {
  display: inline-flex; align-items: center; gap: 0.5em;
  font-size: 0.85rem; font-weight: 600; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--ink-soft);
  border: 1px solid var(--line); background: var(--surface);
  padding: 0.4em 0.9em; border-radius: 999px;
}
.dot { width: 0.6em; height: 0.6em; border-radius: 50%; background: var(--open-green); }

.hero h1 {
  font-size: var(--text-hero);
  font-weight: 700;
  margin-block: 0.35em 0.2em;
  letter-spacing: -0.01em;
}

.hero-sub { max-width: 34ch; font-size: clamp(1.1rem, 1rem + 0.6vw, 1.35rem); color: var(--ink-soft); }

.hero-cta { margin-top: 2.25rem; display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }

.btn-call {
  display: inline-block; background: var(--accent); color: #fff;
  font-weight: 600; font-size: 1.15rem; text-decoration: none;
  padding: 0.9em 1.6em; border-radius: 6px;
  box-shadow: 0 3px 0 #7c2d12;
  transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}
.btn-call:hover { transform: translateY(-2px); box-shadow: 0 5px 0 #7c2d12; }
.btn-call:active { transform: translateY(1px); box-shadow: 0 2px 0 #7c2d12; }

.hero-addr { color: var(--ink-soft); font-weight: 600; }

/* ---- Services ---- */
.services { padding-block: var(--space-section); }
.section-lede { color: var(--ink-soft); margin-block: 0.5rem 2.5rem; max-width: 45ch; }

.services-grid {
  list-style: none; padding: 0;
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
}

.svc {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 8px; padding: 1.25rem 1.4rem;
  transition: border-color var(--duration) var(--ease), transform var(--duration) var(--ease);
}
.svc:hover { border-color: var(--accent-bright); transform: translateY(-2px); }
.svc h3 { font-size: 1.2rem; margin-bottom: 0.35rem; }
.svc p { color: var(--ink-soft); font-size: 0.95rem; }

.svc-featured {
  grid-column: 1 / -1;
  border-left: 6px solid var(--accent-bright);
}
.svc-featured h3 { font-size: 1.5rem; }
.svc-featured p { max-width: 60ch; }

/* ---- Quote ---- */
.quote { background: var(--ink); color: var(--paper); padding-block: var(--space-section); }
.quote blockquote { max-width: 42ch; margin-inline: auto; text-align: center; }
.quote blockquote p {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1.1rem + 1.6vw, 2.1rem);
  font-weight: 600; line-height: 1.3;
}
.quote cite { display: block; margin-top: 1.25rem; font-style: normal; color: #b9c3d6; }
.quote .rating { text-align: center; margin-top: 2.5rem; color: #b9c3d6; }
.quote .rating a { color: var(--paper); }
.stars { color: var(--accent-bright); letter-spacing: 0.15em; }

/* ---- Find us ---- */
.findus { padding-block: var(--space-section); }
.findus-cols { display: grid; gap: 3rem; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); }
.findus address { font-style: normal; margin-block: 1rem 1.5rem; line-height: 1.7; }

.btn-directions {
  display: inline-block; border: 2px solid var(--ink); color: var(--ink);
  font-weight: 600; text-decoration: none;
  padding: 0.7em 1.4em; border-radius: 6px;
  transition: background var(--duration) var(--ease), color var(--duration) var(--ease);
}
.btn-directions:hover { background: var(--ink); color: var(--paper); }
.findus-phone { margin-top: 1.25rem; color: var(--ink-soft); }

.hours { border-collapse: collapse; margin-top: 1rem; width: 100%; max-width: 24rem; }
.hours th, .hours td { text-align: left; padding: 0.6em 0; border-bottom: 1px solid var(--line); }
.hours th { font-weight: 600; }
.hours td { color: var(--ink-soft); }

/* ---- Footer ---- */
footer {
  border-top: 4px solid var(--ink);
  padding-block: 2rem;
  font-size: 0.9rem; color: var(--ink-soft);
}

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