/* ============================================================================
 * scott_common/public_shell.css  [v0.79.0]
 *
 * Shared PUBLIC marketing chrome — responsive header + footer + family cross-nav.
 * Ported from sr-trucking's marketing/base.html (the best public site) and
 * generalized so every Scott marketing site (recycling / plastics / trucking /
 * superstore) shares ONE responsive frame while keeping its OWN menu + content.
 *
 * Per-site theming flows through two CSS custom properties set inline on the
 * page root from SCOTT_COMMON_BRAND (see context_processors/shell_brand.py):
 *     --public-brand     : the site's primary brand color (header bg, accents)
 *     --public-accent    : the CTA / highlight color (gold-equivalent)
 * Sensible Scott-navy defaults below so the shell renders even unthemed.
 *
 * This file is FRAME-ONLY. It deliberately does NOT style hero/sections/forms
 * (those stay per-site so content density differs). Sites keep their own
 * body/section CSS.
 * ========================================================================== */

:root {
  --public-brand: #1E3A5F;        /* default = Scott navy */
  --public-brand-dark: #15294A;
  --public-accent: #C9941A;       /* default = Scott amber */
  --public-accent-dark: #a87c11;
  --public-bg: #f7f8fb;
  --public-ink: #1c2530;
  --public-container-max: 1180px;
}

.public-shell * { box-sizing: border-box; }
.public-shell { color: var(--public-ink); background: #fff; margin: 0; line-height: 1.55;
  font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased; min-height: 100vh;
  display: flex; flex-direction: column; }
.public-shell a { color: var(--public-brand); }
.public-shell img { max-width: 100%; height: auto; }

.public-container { max-width: var(--public-container-max); margin: 0 auto; padding: 0 20px; width: 100%; }

/* ---- FAMILY-OF-COMPANIES STRIP (top, above the main header) -------------- */
.public-family { background: var(--public-brand-dark); color: rgba(255,255,255,0.85);
  font-size: 0.82rem; }
.public-family .row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  padding: 6px 0; }
.public-family .label { font-weight: 700; letter-spacing: 0.3px; text-transform: uppercase;
  font-size: 0.72rem; opacity: 0.7; }
.public-family a { color: rgba(255,255,255,0.85); text-decoration: none; padding: 2px 0; }
.public-family a:hover { color: #fff; text-decoration: underline; }
.public-family a.current { color: #fff; font-weight: 700; }

/* ---- HEADER ------------------------------------------------------------- */
header.public-nav { background: var(--public-brand); color: #fff; padding: 14px 0;
  position: sticky; top: 0; z-index: 50; box-shadow: 0 1px 0 rgba(0,0,0,0.1); }
header.public-nav .row { display: flex; align-items: center; gap: 20px; }
header.public-nav .brand { font-weight: 800; font-size: 1.15rem; text-decoration: none;
  color: #fff; letter-spacing: 0.3px; white-space: nowrap; }
header.public-nav .brand .lt { color: var(--public-accent); }
header.public-nav nav { display: flex; gap: 6px; flex: 1; flex-wrap: wrap; align-items: center; }
header.public-nav nav a { color: rgba(255,255,255,0.85); text-decoration: none;
  padding: 8px 12px; border-radius: 6px; font-size: 0.95rem; }
header.public-nav nav a:hover, header.public-nav nav a.active { color: #fff;
  background: rgba(255,255,255,0.12); }
header.public-nav .cta { background: var(--public-accent); color: var(--public-brand);
  padding: 9px 16px; border-radius: 6px; font-weight: 700; text-decoration: none;
  font-size: 0.92rem; white-space: nowrap; }
header.public-nav .cta:hover { background: var(--public-accent-dark); }
header.public-nav .phone { color: #fff; text-decoration: none; font-weight: 700;
  font-size: 0.95rem; white-space: nowrap; }
header.public-nav .staff-login { background: transparent; color: #fff; text-decoration: none;
  padding: 8px 14px; border-radius: 6px; font-weight: 700; font-size: 0.92rem;
  white-space: nowrap; border: 1.5px solid var(--public-accent); }
header.public-nav .staff-login:hover { background: var(--public-accent); color: var(--public-brand); }

/* ---- MOBILE NAV (hamburger) -------------------------------------------- */
.public-hamburger { display: none; flex-direction: column; gap: 5px; background: none;
  border: none; cursor: pointer; padding: 6px; }
.public-hamburger span { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; }

@media (max-width: 820px) {
  header.public-nav .row { flex-wrap: wrap; }
  header.public-nav nav { display: none; width: 100%; flex-direction: column;
    gap: 2px; padding: 8px 0; }
  header.public-nav nav.open { display: flex; }
  header.public-nav .phone, header.public-nav .cta { display: none; }
  header.public-nav .staff-login { display: inline-block; margin-left: auto;
    padding: 6px 11px; font-size: 0.85rem; }
  .public-hamburger { display: flex; margin-left: 8px; }
  .public-family .row { font-size: 0.78rem; gap: 10px; }
}

/* ---- MAIN --------------------------------------------------------------- */
.public-main { flex: 1 0 auto; }

/* ---- MESSAGES ----------------------------------------------------------- */
.public-messages { max-width: var(--public-container-max); margin: 16px auto 0; padding: 0 20px; }
.public-messages .msg { padding: 10px 14px; border-radius: 6px; margin-bottom: 10px;
  font-size: 0.95rem; background: #e6f0e8; color: #1d5b2c; border: 1px solid #b9d8c1; }
.public-messages .msg.error { background: #fbe6e6; color: #8a1f1f; border-color: #e3b9b9; }

/* ---- FOOTER ------------------------------------------------------------- */
footer.public-footer { background: #061a2c; color: rgba(255,255,255,0.7); padding: 50px 0 30px;
  font-size: 0.92rem; }
footer.public-footer .grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 30px; }
@media (max-width: 800px) { footer.public-footer .grid { grid-template-columns: 1fr 1fr; } }
footer.public-footer h4 { color: #fff; margin: 0 0 12px; font-size: 0.95rem;
  text-transform: uppercase; letter-spacing: 0.5px; }
footer.public-footer a { color: rgba(255,255,255,0.85); text-decoration: none; display: block; padding: 4px 0; }
footer.public-footer a:hover { color: #fff; }
footer.public-footer .legal { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 20px;
  margin-top: 36px; display: flex; justify-content: space-between; flex-wrap: wrap;
  gap: 14px; font-size: 0.85rem; }
footer.public-footer .fam a { display: inline; }
