/* ============================================================
 * shared.css — public-site palette tokens (Trydent painting)
 * ============================================================
 * Imports the canonical component library, then provides public-
 * site-only overrides. The canonical components.css is copy-deployed
 * from trydent-painting-admin/assets/components.css at build (see
 * tools/sync-components.ps1 — TBD).
 *
 * Per-tenant brand overrides are applied at runtime by theme-loader.js
 * after _middleware.ts attaches tenant config to the page.
 * ============================================================ */

@import './components.css';

/* Public-site default palette (overridden per tenant). */
:root {
  --paper: var(--neutral-bg);
  --ink:   var(--neutral-fg);
  --shadow: var(--neutral-shadow);
}

/* Public-site default typography pair is Pair 1 (Playfair + Inter).
 * Tenant config can swap to any of pair-2..pair-8 via the typography
 * pair link element injected by _middleware.ts. */

/* Off-canvas / scroll behavior tweaks specific to public pages */
html { scroll-behavior: smooth; }
body { padding-bottom: 80px; } /* room for mobile-sticky-cta */

/* Skip-to-content link — required for WCAG AA */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--brand-secondary);
  color: white;
  padding: var(--sp-8) var(--sp-16);
  z-index: 100;
  text-decoration: none;
}
.skip-link:focus { top: 0; }

/* ============================================================
 * INSTANT QUOTE WIDGET — tint-specific
 * ============================================================ */
.instant-quote-section { padding: var(--sp-48) 0; }
.instant-quote-section.alt { background: var(--neutral-bg-alt); }

.iq-card {
  background: white;
  border: 1px solid var(--neutral-border);
  border-radius: var(--r-lg);
  padding: var(--sp-24);
  box-shadow: var(--neutral-shadow);
  max-width: 720px;
  margin: 0 auto;
}

.iq-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-12);
  margin-bottom: var(--sp-20);
}
@media (max-width: 600px) { .iq-row { grid-template-columns: 1fr; } }

.iq-label {
  display: block;
  font-size: var(--fs-12);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--neutral-muted);
  margin-bottom: var(--sp-6);
}
.iq-row select, .iq-row input[type="text"] {
  width: 100%;
  padding: var(--sp-12);
  border: 1px solid var(--neutral-border);
  border-radius: var(--r-sm);
  font: inherit;
  background: white;
}
.iq-row select:focus, .iq-row input:focus {
  outline: 2px solid var(--brand-primary);
  outline-offset: -1px;
}

.iq-packages {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-8);
  margin-bottom: var(--sp-20);
}
@media (max-width: 600px) { .iq-packages { grid-template-columns: 1fr 1fr; } }

.iq-pkg {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--sp-12) var(--sp-8);
  border: 2px solid var(--neutral-border);
  border-radius: var(--r-sm);
  cursor: pointer;
  background: white;
  transition: border-color 0.15s, background 0.15s;
}
.iq-pkg:hover { border-color: var(--brand-secondary); }
.iq-pkg input { position: absolute; opacity: 0; pointer-events: none; }
.iq-pkg--active { border-color: var(--brand-primary); background: var(--neutral-bg-alt); }
.iq-pkg__label { font-weight: 700; font-size: var(--fs-14); }
.iq-pkg__blurb { font-size: var(--fs-12); color: var(--neutral-muted); margin-top: 2px; }

.iq-result { text-align: center; }
.iq-result .muted { color: var(--neutral-muted); font-size: var(--fs-14); }

.iq-quote { display: flex; flex-direction: column; gap: var(--sp-12); align-items: center; padding: var(--sp-12) 0; }
.iq-quote__price {
  font-family: var(--font-display, var(--font-body));
  font-size: 3rem;
  font-weight: 800;
  line-height: 1;
  color: var(--brand-primary);
}
.iq-quote__note { font-size: var(--fs-14); color: var(--neutral-muted); max-width: 480px; }
.iq-quote--contact .iq-quote__note { font-size: var(--fs-16); color: var(--neutral-fg); }

/* ============================================================
 * SPEC TABLE — tint-specific (spec-sheet layout)
 * ============================================================ */
.spec-table-wrap { overflow-x: auto; margin-top: var(--sp-24); }
.spec-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-14);
  background: white;
  border: 1px solid var(--neutral-border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.spec-table th, .spec-table td {
  padding: var(--sp-12) var(--sp-16);
  text-align: left;
  border-bottom: 1px solid var(--neutral-border);
}
.spec-table thead { background: var(--neutral-bg-alt); }
.spec-table th {
  font-size: var(--fs-12);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--neutral-muted);
}
.spec-table tr.highlight { background: var(--neutral-bg-alt); }
.spec-table tr:last-child td { border-bottom: 0; }
.spec-table .muted { color: var(--neutral-muted); font-size: var(--fs-12); font-weight: normal; }
