/* Alfred Concierge Reviews — light theme matching alfredconcierge.app
 * Palette mirrors the app: zinc gray scale + electric-yellow #FFD60A accent
 * + Apple system green #34C759, flipped to light surfaces.
 */
:root {
  /* brand accent */
  --yellow: #FFD60A;
  --yellow-deep: #EAC400;
  --green: #34C759;
  /* ink (on yellow / headings) */
  --ink: #0A0A0B;
  /* zinc scale */
  --zinc-900: #18181B;
  --zinc-700: #3F3F46;
  --zinc-600: #52525B;
  --zinc-500: #71717A;
  --zinc-400: #A1A1AA;
  --zinc-300: #D4D4D8;
  --zinc-200: #E4E4E7;
  --zinc-100: #F4F4F5;
  --zinc-50:  #FAFAFA;
  /* roles */
  --bg: var(--zinc-50);
  --card: #ffffff;
  --body: var(--zinc-700);
  --muted: var(--zinc-500);
  --line: var(--zinc-200);
  --radius: 18px;
  --radius-sm: 12px;
  --shadow: 0 1px 2px rgba(10,10,11,.04), 0 10px 30px rgba(10,10,11,.06);
  --shadow-sm: 0 1px 2px rgba(10,10,11,.05);
  --max: 1080px;
  --font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --serif: "Times New Roman", Didot, "Bodoni 72", "Playfair Display", Georgia, serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--body);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3 { color: var(--ink); letter-spacing: -.02em; line-height: 1.15; }
.hero h1, .reviews > h2, .faq > h2, .answer-block h2 { font-family: var(--serif); letter-spacing: -.01em; font-weight: 600; }
a { color: var(--zinc-900); text-decoration: none; }
a:hover { text-decoration: underline; }
.muted { color: var(--muted); }

/* header */
.site-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 1.1rem clamp(1rem, 4vw, 2.5rem);
  max-width: var(--max); margin: 0 auto;
}
.brand { display: inline-flex; align-items: center; gap: .6rem; font-weight: 700; font-size: 1.05rem; color: var(--ink); }
.brand:hover { text-decoration: none; }
.brand .logo-mark { width: 30px; height: 30px; border-radius: 8px; display: block; }
.brand .wordmark { font-family: var(--serif); font-style: italic; font-weight: 600; font-size: 1.2rem; }
.brand .sub { font-family: var(--font); font-style: normal; font-weight: 600; color: var(--muted); font-size: .95rem; letter-spacing: 0; }
.site-header nav { display: flex; align-items: center; gap: clamp(.75rem, 2vw, 1.5rem); }
.site-header nav a:not(.btn) { color: var(--zinc-700); font-weight: 600; font-size: .95rem; }

/* buttons */
.btn {
  display: inline-block; background: var(--yellow); color: var(--ink);
  padding: .72rem 1.3rem; border-radius: 999px; font-weight: 700;
  border: 0; cursor: pointer; font-size: 1rem; line-height: 1.2;
  transition: transform .08s ease, box-shadow .15s ease, background .15s ease;
  box-shadow: 0 1px 2px rgba(10,10,11,.08);
}
.btn:hover { background: var(--yellow-deep); text-decoration: none; transform: translateY(-1px); box-shadow: 0 6px 18px rgba(234,196,0,.35); }
.btn-ghost { background: #fff; color: var(--ink); border: 1.5px solid var(--line); box-shadow: var(--shadow-sm); }
.btn-ghost:hover { background: #fff; border-color: var(--zinc-300); box-shadow: var(--shadow); }
.btn-sm { padding: .5rem 1rem; font-size: .9rem; }
.btn-lg { padding: .95rem 1.7rem; font-size: 1.05rem; }

main { max-width: var(--max); margin: 0 auto; padding: 0 clamp(1rem, 4vw, 2.5rem) 4rem; }
main.narrow { max-width: 680px; }

/* hero */
.hero { text-align: center; padding: clamp(2rem, 6vw, 4.5rem) 0 2.5rem; }
.hero.compact { padding: 2rem 0 1rem; text-align: left; }
.eyebrow { text-transform: uppercase; letter-spacing: .14em; font-size: .78rem; font-weight: 700; color: var(--zinc-600); margin: 0 0 1rem; display: inline-flex; align-items: center; gap: .5rem; }
.eyebrow::before { content: ""; width: 22px; height: 3px; border-radius: 2px; background: var(--yellow); display: inline-block; }
.hero h1 { font-size: clamp(2.2rem, 5.5vw, 3.6rem); margin: 0 0 1rem; }
.lede { font-size: 1.18rem; color: var(--zinc-600); max-width: 60ch; margin: 0 auto 1.6rem; }
.hero.compact .lede { margin-left: 0; }
.rating-summary { display: inline-flex; align-items: center; gap: .65rem; margin-bottom: 1.6rem; flex-wrap: wrap; justify-content: center; }
.big-rating { font-family: var(--serif); font-size: 2.8rem; font-weight: 600; color: var(--ink); line-height: 1; }
.rating-count { color: var(--muted); font-weight: 600; }
.hero-cta { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }

.stars { color: var(--yellow); letter-spacing: 2px; font-size: 1.2rem; }

/* answer block (light, premium card) */
.answer-block {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: clamp(1.5rem, 4vw, 2.25rem); margin: 1rem 0 3rem; box-shadow: var(--shadow);
  position: relative; overflow: hidden;
}
.answer-block::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px; background: var(--yellow); }
.answer-block h2 { margin: 0 0 1.25rem; font-size: 1.35rem; }
.facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.1rem 2rem; margin: 0; }
.facts div { border-top: 1px solid var(--line); padding-top: .8rem; }
.facts dt { font-size: .74rem; text-transform: uppercase; letter-spacing: .1em; color: var(--zinc-500); font-weight: 700; }
.facts dd { margin: .3rem 0 0; color: var(--zinc-700); }

/* reviews */
.reviews, .faq { padding-top: 1rem; }
.reviews > h2, .faq > h2 { font-size: 1.8rem; margin-bottom: 1.25rem; }
.sample-banner {
  background: #fffbea; border: 1px solid var(--yellow); color: #6b5210;
  padding: .85rem 1rem; border-radius: var(--radius-sm); margin-bottom: 1.5rem; font-size: .92rem;
}
.sample-banner code { background: rgba(10,10,11,.06); padding: .1rem .35rem; border-radius: 4px; }
.review-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; }
.review {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.5rem; box-shadow: var(--shadow-sm); display: flex; flex-direction: column;
  transition: box-shadow .15s ease, transform .08s ease;
}
.review:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.review-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .5rem; }
.source { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--zinc-600); background: var(--zinc-100); padding: .25rem .6rem; border-radius: 999px; }
.review-title { font-size: 1.12rem; margin: .25rem 0 .5rem; }
.review-body { margin: 0 0 1rem; color: var(--zinc-700); }
.review-meta { margin: auto 0 0; font-size: .85rem; color: var(--muted); }
.review-meta .author { font-weight: 700; color: var(--ink); }
.reviews-cta { text-align: center; margin: 2.5rem 0 0; }
.reviews-cta p { color: var(--muted); margin-bottom: .85rem; }

/* faq */
.faq { margin-top: 3rem; }
.faq-item { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-sm); margin-bottom: .6rem; box-shadow: var(--shadow-sm); }
.faq-item summary { cursor: pointer; font-weight: 700; padding: 1rem 1.2rem; list-style: none; color: var(--ink); font-size: 1.02rem; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; float: right; color: var(--yellow-deep); font-weight: 800; font-size: 1.2rem; line-height: 1.3; }
.faq-item[open] summary::after { content: "–"; }
.faq-answer { padding: 0 1.2rem 1.1rem; color: var(--zinc-700); }
.faq-answer p { margin: 0; }

/* about */
.about { margin-top: 3rem; padding-top: 1rem; }
.about h2 { font-family: var(--serif); font-weight: 600; font-size: 1.8rem; margin-bottom: 1rem; }
.about p { color: var(--zinc-700); max-width: 70ch; }
.about .updated { font-size: .85rem; color: var(--muted); margin-top: 1rem; }

/* ===== Discover (programmatic SEO) ===== */
.crumbs { font-size: .85rem; color: var(--muted); margin: 0 0 .5rem; }
.crumbs a { color: var(--zinc-600); }
.crumbs span { color: var(--ink); font-weight: 600; }

.vgrid-wrap { margin-top: 1rem; }
.vgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.25rem; }
.vcard { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: box-shadow .15s ease, transform .08s ease; }
.vcard:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.vcard-img { width: 100%; height: 180px; object-fit: cover; display: block; background: var(--zinc-100); }
.vcard-img--ph { background: linear-gradient(135deg, var(--zinc-100), var(--zinc-200)); }
.vcard-body { padding: 1.1rem 1.2rem 1.3rem; }
.vcard-name { font-size: 1.1rem; margin: 0 0 .3rem; }
.vcard-meta { font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; color: var(--zinc-500); font-weight: 700; margin: 0 0 .5rem; }
.vcard-desc { font-size: .92rem; color: var(--zinc-700); margin: 0; }

.hub-grid-wrap { margin-top: 1rem; }
.hub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.1rem; }
.hub-card { display: block; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; box-shadow: var(--shadow-sm); color: var(--ink); transition: box-shadow .15s ease, transform .08s ease; }
.hub-card:hover { text-decoration: none; box-shadow: var(--shadow); transform: translateY(-2px); border-color: var(--zinc-300); }
.hub-card h3 { margin: 0 0 .4rem; font-size: 1.2rem; }
.hub-card p { margin: 0 0 .9rem; color: var(--muted); font-size: .92rem; }
.hub-go { color: var(--yellow-deep); font-weight: 700; font-size: .9rem; }

.cities h2 { font-size: 1.8rem; }
.city-grid { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1rem; }
.city-chip { display: inline-flex; align-items: center; gap: .5rem; background: var(--card); border: 1px solid var(--line); border-radius: 999px; padding: .55rem 1rem; font-weight: 600; color: var(--ink); box-shadow: var(--shadow-sm); }
.city-chip:hover { text-decoration: none; border-color: var(--yellow); }
.city-chip span { background: var(--zinc-100); color: var(--zinc-600); border-radius: 999px; font-size: .72rem; padding: .1rem .45rem; font-weight: 700; }

.table-wrap { overflow-x: auto; margin: 1.5rem 0; }
.cmp { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.cmp th, .cmp td { text-align: left; padding: .85rem 1rem; border-bottom: 1px solid var(--line); vertical-align: top; font-size: .95rem; }
.cmp thead th { background: var(--zinc-900); color: #fff; font-family: var(--serif); }
.cmp tbody th { color: var(--zinc-500); text-transform: uppercase; font-size: .74rem; letter-spacing: .08em; width: 22%; }

.prose { max-width: 72ch; }
.prose h2 { font-family: var(--serif); font-weight: 600; font-size: 1.4rem; margin: 1.6rem 0 .6rem; }
.prose p { color: var(--zinc-700); }
.link-list { list-style: none; padding: 0; display: grid; gap: .6rem; }
.link-list a { display: block; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: .9rem 1.1rem; font-weight: 600; color: var(--ink); box-shadow: var(--shadow-sm); }
.link-list a:hover { text-decoration: none; border-color: var(--yellow); }

/* form */
.review-form { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1.25rem, 4vw, 2rem); box-shadow: var(--shadow); display: grid; gap: 1.1rem; }
.review-form label { font-weight: 600; display: grid; gap: .4rem; font-size: .95rem; color: var(--ink); }
.review-form input[type=text], .review-form input[type=email], .review-form textarea {
  font: inherit; padding: .72rem .9rem; border: 1px solid var(--line); border-radius: 10px; background: #fff; width: 100%; color: var(--ink);
}
.review-form textarea { resize: vertical; }
.review-form input:focus, .review-form textarea:focus { outline: 2px solid var(--yellow); border-color: var(--yellow); }
.review-form fieldset { border: 0; padding: 0; margin: 0; }
.review-form legend { font-weight: 700; margin-bottom: .4rem; color: var(--ink); }
.row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.checkbox { grid-template-columns: auto 1fr; align-items: start; gap: .6rem; font-weight: 400; color: var(--zinc-700); }
.checkbox input { margin-top: .3rem; accent-color: var(--green); }
.form-status { font-weight: 600; margin: 0; }
.form-status.ok { color: #1d7a46; }
.form-status.err { color: #b3261e; }
.fine-print { font-size: .85rem; color: var(--muted); margin-top: 1.25rem; }

/* star input */
.star-input { display: inline-flex; flex-direction: row-reverse; gap: .15rem; }
.star-input input { position: absolute; opacity: 0; width: 0; }
.star-input label { font-size: 2.1rem; color: var(--zinc-300); cursor: pointer; transition: color .1s; }
.star-input label:hover, .star-input label:hover ~ label,
.star-input input:checked ~ label { color: var(--yellow); }
.star-input input:focus-visible + label { outline: 2px solid var(--ink); border-radius: 4px; }

/* footer */
.site-footer { border-top: 1px solid var(--line); background: #fff; padding: 2.25rem clamp(1rem, 4vw, 2.5rem); text-align: center; }
.site-footer p { margin: .35rem 0; color: var(--muted); font-size: .9rem; }
.site-footer strong { color: var(--ink); }

@media (max-width: 560px) {
  .row { grid-template-columns: 1fr; }
  .site-header nav a:not(.btn) { display: none; }
  .brand .sub { display: none; }
}
