/* =====================================================================
   Relocation Roadmap — shared.css
   Consolidated shared components linked from every page.
   Covers: brand color tokens, fluid typography, top navigation,
   breadcrumbs, disclaimer banner, and link-vote chips.
   Page-specific CSS (city office modal, state grid, guide cards,
   admin dashboard) remains inline in each page.
   ===================================================================== */

/* ---- Brand color tokens (Brazil / Germany / Canada) ---- */
:root{
  --br-green:#009C3B; --br-yellow:#FFDF00; --br-blue:#002776;
  --de-red:#DD0000;   --de-gold:#FFCE00;   --de-black:#0a0a0a;
  --ca-red:#FF0000;   --ca-white:#ffffff;
  --ink:#1a1a1a; --paper:#ffffff; --line:#e5e5e5; --muted:#6b6560;
}

/* ---- Fluid base type (scales text with viewport) ---- */
html{font-size:clamp(16px,0.6vw + 14.5px,21px)}

/* =========================== ABSTRACT TRICOLOR DECOR =========================== */
/* Brazil (green/yellow/blue) + Germany (black/red/gold) + Canada (red/white)
   rendered as soft, low-opacity background accents so they add atmosphere
   without hurting text contrast (WCAG AA preserved). */

/* Page-wide soft blobs anchored to the body, fixed so they drift behind content */
body{position:relative}
body::before{
  content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(40vw 40vw at 8% 12%, rgba(0,156,59,0.06) 0%, transparent 60%),
    radial-gradient(38vw 38vw at 92% 22%, rgba(221,0,0,0.05) 0%, transparent 60%),
    radial-gradient(46vw 46vw at 78% 88%, rgba(0,39,118,0.05) 0%, transparent 62%),
    radial-gradient(34vw 34vw at 15% 92%, rgba(255,206,0,0.06) 0%, transparent 60%);
}

/* Tricolor edge stripe — reusable divider between sections */
.tri-stripe{height:3px;border:0;background:linear-gradient(90deg,var(--br-green) 0% 33%,var(--de-gold) 33% 66%,var(--de-red) 66% 100%)}

/* Diagonal geometric corner accent — add via class="has-accent" on a section */
.has-accent{position:relative;overflow:hidden}
.has-accent::after{
  content:'';position:absolute;top:-30px;right:-30px;width:140px;height:140px;
  pointer-events:none;opacity:.5;
  background:conic-gradient(from 45deg,
      var(--br-green) 0deg 60deg,
      var(--de-gold) 60deg 120deg,
      var(--de-red) 120deg 180deg,
      var(--br-blue) 180deg 240deg,
      transparent 240deg 360deg);
  -webkit-mask:radial-gradient(circle at 100% 0,#000 0,#000 60%,transparent 62%);
  mask:radial-gradient(circle at 100% 0,#000 0,#000 60%,transparent 62%);
  border-radius:0 0 0 100%;
}
@media (prefers-reduced-motion:no-preference){
  .has-accent::after{transition:transform .4s ease}
  .has-accent:hover::after{transform:rotate(20deg) scale(1.08)}
}

/* =========================== TOP NAV =========================== */
.topnav{position:relative;background:rgba(255,255,255,0.92);backdrop-filter:saturate(180%) blur(8px);-webkit-backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);z-index:50;display:block;height:auto;padding:0}
.topnav-inner{max-width:100%;margin:0;padding:14px clamp(16px,3vw,40px);display:flex;align-items:center;justify-content:flex-end;gap:clamp(20px,3vw,48px)}
.brand{order:3;font-weight:800;font-size:17px;color:var(--ink);text-decoration:none;letter-spacing:-.01em;display:flex;align-items:center;gap:10px;margin-left:auto}
.brand-logo,.topnav-brand-logo,.nav-logo-img{display:block !important;width:40px;height:40px;border-radius:8px;object-fit:contain;flex-shrink:0;transition:width .2s ease,height .2s ease}
@media (min-width:640px){.brand-logo,.topnav-brand-logo,.nav-logo-img{width:52px;height:52px;border-radius:10px}}
@media (min-width:1024px){.brand-logo,.topnav-brand-logo,.nav-logo-img{width:64px;height:64px;border-radius:12px}}
@media (min-width:1440px){.brand-logo,.topnav-brand-logo,.nav-logo-img{width:76px;height:76px;border-radius:14px}}
.brand-text{display:inline-block;font-weight:800;font-size:1rem;letter-spacing:-.01em;color:var(--ink)}
@media (max-width:680px){.brand-text{display:none}}
.nav-links{order:2;display:flex;gap:clamp(16px,2vw,32px);align-items:center}
.nav-links a{color:#444;text-decoration:none;font-size:14px;font-weight:500;transition:.15s;position:relative;white-space:nowrap}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--de-red);transition:.2s}
.nav-links a:hover{color:var(--de-red)}
.nav-links a:hover::after{width:100%}
.nav-toggle{order:1;display:none;background:none;border:0;cursor:pointer;width:40px;height:40px;padding:8px;flex-direction:column;justify-content:space-around;margin-right:auto}
.nav-toggle span{display:block;width:100%;height:2px;background:#1a1a1a;border-radius:2px;transition:.2s}
.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:780px){
  .topnav-inner{padding:10px 16px;justify-content:space-between}
  .brand{margin-left:0}
  .nav-toggle{display:flex;margin-left:0;margin-right:auto}
  .nav-links{order:4;display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:8px 0;border-bottom:1px solid var(--line);box-shadow:0 4px 12px rgba(0,0,0,.08)}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 20px;font-size:15px;font-weight:600;border-bottom:1px solid rgba(0,0,0,.04)}
  .nav-links a::after{display:none}
  .nav-links a:last-child{border-bottom:0}
}

/* =========================== BREADCRUMBS =========================== */
.breadcrumbs-below{display:flex;align-items:center;gap:6px;font-size:13px;margin:0;padding:14px clamp(16px,3vw,40px) 6px;text-align:left;justify-content:flex-start;color:var(--muted);width:100%;box-sizing:border-box}
.breadcrumbs-below a{color:var(--de-red);text-decoration:none;font-weight:600}
.breadcrumbs-below a:hover{text-decoration:underline}
.breadcrumbs-below .sep{color:#9ca3af}
.breadcrumbs-below .current{color:var(--muted);font-weight:600}

/* =========================== DISCLAIMER BANNER =========================== */
/* Canonical visual: red attention-band, white text, full-width. */
/* Applied identically to all 3 markup variants used across the site. */
.disclaimer-bar,
.disclaimer-banner,
.disclaimer-aside{background:#DD0000;border-top:3px solid #000000;border-bottom:1px solid #000000;padding:18px clamp(16px,3vw,40px);font-size:13px;color:#ffffff;text-align:left}
.disclaimer-bar{display:flex;gap:14px;align-items:flex-start}
.disclaimer-bar p,
.disclaimer-banner p,
.disclaimer-aside p{margin:0;color:#ffffff}
.disclaimer-bar strong,
.disclaimer-banner strong,
.disclaimer-aside strong{font-weight:700;color:#ffffff}
.disclaimer-bar .disclaimer-inner,
.disclaimer-banner .disclaimer-inner,
.disclaimer-aside .disclaimer-aside-inner{display:flex;gap:14px;align-items:flex-start;color:#ffffff;max-width:100%;margin:0;width:100%;padding:0;box-sizing:border-box}
.disclaimer-banner .container-narrow{max-width:100%;margin:0;padding:0}
.disclaimer-icon{flex-shrink:0;color:#ffffff}

/* =========================== LINK-VOTE CHIPS =========================== */
.housing-links{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 4px}
.housing-chip{display:inline-flex;align-items:center;font-size:14px;font-weight:600;padding:8px 14px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:var(--ink);background:#fafafa;transition:transform .12s ease,background .15s ease,border-color .15s ease,color .15s ease}
.housing-chip:hover{transform:translateY(-1px);background:var(--br-green);border-color:var(--br-green);color:#fff}
.housing-chip:nth-child(2):hover{background:var(--de-red);border-color:var(--de-red)}
.housing-chip:nth-child(3):hover{background:var(--br-blue);border-color:var(--br-blue)}
.housing-chip:nth-child(4):hover{background:var(--de-gold);border-color:var(--de-gold);color:#1a1a1a}
