/* ───────────────── Freeopoly shared chrome (header, footer, base tokens) ───────────────── */
:root {
  --green:#1C8442; --green-mid:#1E6B38; --green-dark:#145C2D; --green-light:#EAF6EE; --green-border:#B6DEC4; --green-glow:rgba(28,132,66,0.12);
  --free:#1C8442; --free-bg:#EAF6EE; --free-border:#B6DEC4;
  --fwp:#1558A8; --fwp-bg:#E8F0FB; --fwp-border:#A3C0E8;
  --win:#F4690E; --win-bg:#FDEEE1; --win-border:#F6CCA1;
  --urgent:#B84A00; --urgent-bg:#FDF0E8; --red:#C0392B;
  --bg:#FAFAF8; --surface:#FFFFFF; --surface2:#F2F2F7; --surface3:#E5E5EA;
  --text1:#1C1C1E; --text2:#3C3C43; --text3:#636366; --text4:#8E8E93; --divl:#E5E5EA; --div:#C6C6C8;
  --sh-sm:0 1px 3px rgba(0,0,0,0.07),0 1px 2px rgba(0,0,0,0.04);
  --sh-md:0 4px 14px rgba(0,0,0,0.08),0 2px 5px rgba(0,0,0,0.04);
  --sh-lg:0 10px 32px rgba(0,0,0,0.10),0 4px 10px rgba(0,0,0,0.05);
  --r:14px; --r-lg:20px; --r-xl:28px; --pill:999px;
}
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Lato',sans-serif; background:var(--bg); color:var(--text1); }
a { color:inherit; text-decoration:none; }
.sr-only { position:absolute!important; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

/* HEADER */
header { background:linear-gradient(45deg,#1C8442 0%,#2EA85C 100%); height:52px; display:flex; align-items:center; justify-content:center; position:sticky; top:0; z-index:50; }
.header-inner { max-width:1180px; width:100%; display:flex; align-items:center; gap:14px; padding:0 20px; }
.logo { font-family:'Outfit',sans-serif; font-weight:900; font-size:22px; letter-spacing:-0.6px; color:#fff; flex-shrink:0; }
.logo sup { font-size:0.5em; font-weight:600; }
.header-search { flex:1; max-width:440px; display:flex; align-items:center; gap:9px; background:rgba(255,255,255,0.15); border:1.5px solid rgba(255,255,255,0.25); border-radius:var(--pill); padding:0 15px; height:36px; }
.header-search i { color:rgba(255,255,255,0.7); font-size:14px; }
.header-search input { flex:1; border:none; outline:none; background:transparent; color:#fff; font-family:'Lato',sans-serif; font-size:14px; }
.header-search input::placeholder { color:rgba(255,255,255,0.6); }
.header-spacer { flex:1; }
.h-link { color:rgba(255,255,255,0.85); font-family:'Outfit',sans-serif; font-weight:600; font-size:14px; padding:8px 12px; border-radius:var(--pill); white-space:nowrap; }
.h-link:hover { background:rgba(255,255,255,0.12); color:#fff; }
.btn-join { padding:7px 18px; border-radius:var(--pill); font-family:'Outfit',sans-serif; font-weight:700; font-size:14px; color:#fff; border:1.5px solid rgba(255,255,255,0.5); background:transparent; cursor:pointer; white-space:nowrap; }
.btn-join:hover { background:rgba(255,255,255,0.15); border-color:#fff; }
/* auth-aware nav: hidden by default; site.js reveals based on sign-in state */
.auth-in { display:none; }
.nav-avatar { width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,#2DA05A,#145C2D); display:flex; align-items:center; justify-content:center; font-family:'Outfit',sans-serif; font-weight:800; font-size:14px; color:#fff; flex-shrink:0; text-decoration:none; }

/* Shared primary button */
.btn-primary { display:inline-flex; align-items:center; gap:9px; padding:13px 26px; border-radius:var(--pill); background:var(--green); color:#fff; font-family:'Outfit',sans-serif; font-weight:700; font-size:15px; border:none; cursor:pointer; transition:background 0.15s; }
.btn-primary:hover { background:var(--green-mid); }

/* Breadcrumb */
.breadcrumb { max-width:860px; margin:0 auto; padding:22px 20px 0; display:flex; align-items:center; gap:8px; font-family:'Outfit',sans-serif; font-size:13px; color:var(--text4); }
.breadcrumb a { color:var(--text4); font-weight:600; }
.breadcrumb a:hover { color:var(--green); }
.breadcrumb .sep { color:var(--div); }
.breadcrumb .cur { color:var(--text2); font-weight:700; }

/* ───────────────── FOOTER w/ SITEMAP ───────────────── */
footer { background:#23282A; color:rgba(255,255,255,0.7); margin-top:64px; }
.footer-inner { max-width:1100px; margin:0 auto; padding:46px 20px 32px; display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr 1fr; gap:30px; }
.footer-logo { font-family:'Outfit',sans-serif; font-weight:900; font-size:21px; color:#fff; margin-bottom:10px; }
.footer-logo sup { font-size:0.5em; font-weight:600; }
.footer-tag { font-family:'Lato',sans-serif; font-size:13px; line-height:1.55; max-width:250px; margin-bottom:16px; }
.footer-social { display:flex; gap:9px; }
.footer-social a { width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,0.08); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.85); font-size:15px; transition:all 0.15s; }
.footer-social a:hover { background:var(--green); color:#fff; transform:translateY(-2px); }
.footer-cols { display:contents; }
.footer-col h4 { font-family:'Outfit',sans-serif; font-weight:700; font-size:12px; text-transform:uppercase; letter-spacing:0.5px; color:rgba(255,255,255,0.5); margin-bottom:13px; }
.footer-col a { display:block; font-family:'Lato',sans-serif; font-size:14px; color:rgba(255,255,255,0.8); margin-bottom:10px; }
.footer-col a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.12); text-align:center; padding:18px; font-family:'Lato',sans-serif; font-size:12px; color:rgba(255,255,255,0.55); }

@media (max-width:860px){ .footer-inner{ grid-template-columns:1fr 1fr; } .footer-cols{ display:contents; } }
@media (max-width:520px){ .footer-inner{ grid-template-columns:1fr 1fr; } .footer-brand{ grid-column:1 / -1; } }

/* ───────────────── No-orphan / wrap hygiene ───────────────── */
h1,h2,h3,h4,p { text-wrap:pretty; }
.breadcrumb a, .breadcrumb .cur, .pill { white-space:nowrap; }

/* ───────────────── Conversion nudges (shared) ───────────────── */
.fp-toast { position:fixed; left:50%; bottom:24px; transform:translateX(-50%) translateY(16px); background:rgba(28,28,30,0.94); color:#fff; font-family:'Outfit',sans-serif; font-weight:600; font-size:14px; padding:13px 22px; border-radius:var(--pill); box-shadow:var(--sh-lg); opacity:0; pointer-events:none; transition:all .28s; z-index:9000; max-width:90vw; text-align:center; }
.fp-toast.show { opacity:1; transform:translateX(-50%) translateY(0); pointer-events:auto; }
.fp-toast a { color:#9FE3B6; }

.fp-modal-overlay { position:fixed; inset:0; z-index:9500; background:rgba(20,30,24,0.55); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; padding:20px; }
.fp-modal-overlay.show { display:flex; animation:fpFade .2s ease; }
@keyframes fpFade { from{opacity:0} to{opacity:1} }
.fp-modal { position:relative; background:#fff; border-radius:var(--r-xl); padding:34px 32px 28px; max-width:420px; width:100%; text-align:center; box-shadow:0 30px 70px rgba(0,0,0,0.3); animation:fpPop .26s cubic-bezier(.34,1.2,.64,1); }
@keyframes fpPop { from{opacity:0;transform:scale(.94) translateY(10px)} to{opacity:1;transform:none} }
.fp-modal-x { position:absolute; top:14px; right:14px; width:32px; height:32px; border-radius:50%; border:none; background:var(--bg); color:var(--text3); font-size:15px; cursor:pointer; }
.fp-modal-x:hover { background:var(--surface3); }
.fp-modal-ic { width:62px; height:62px; border-radius:18px; background:var(--green-light); color:var(--green); display:flex; align-items:center; justify-content:center; font-size:26px; margin:0 auto 16px; }
.fp-modal h3 { font-family:'Outfit',sans-serif; font-weight:800; font-size:22px; color:var(--text1); margin-bottom:10px; letter-spacing:-0.4px; }
.fp-modal p { font-family:'Lato',sans-serif; font-size:15px; line-height:1.55; color:var(--text3); margin-bottom:22px; }
.fp-btn-primary { display:inline-flex; align-items:center; justify-content:center; gap:9px; width:100%; padding:14px; border-radius:var(--pill); background:var(--green); color:#fff; font-family:'Outfit',sans-serif; font-weight:800; font-size:15px; border:none; cursor:pointer; text-decoration:none; transition:background .15s; }
.fp-btn-primary:hover { background:var(--green-mid); }
.fp-btn-primary.sm { width:auto; padding:10px 20px; font-size:14px; }
.fp-btn-text { display:block; width:100%; margin-top:10px; background:none; border:none; color:var(--text4); font-family:'Outfit',sans-serif; font-weight:600; font-size:13.5px; cursor:pointer; padding:8px; }
.fp-btn-text:hover { color:var(--text2); }
.fp-exit-form { display:flex; gap:8px; }
.fp-exit-form input { flex:1; min-width:0; height:48px; border:1.5px solid var(--div); border-radius:var(--r); padding:0 14px; font-family:'Lato',sans-serif; font-size:15px; outline:none; }
.fp-exit-form input:focus { border-color:var(--green); box-shadow:0 0 0 3px var(--green-glow); }
.fp-exit-form button { border:none; background:var(--green); color:#fff; font-family:'Outfit',sans-serif; font-weight:800; font-size:14px; padding:0 20px; border-radius:var(--r); cursor:pointer; white-space:nowrap; }
.fp-exit-form button:hover { background:var(--green-mid); }

.fp-bar { position:fixed; left:0; right:0; bottom:0; z-index:8000; background:#1C1C1E; color:#fff; display:flex; align-items:center; justify-content:center; gap:18px; padding:13px 20px; transform:translateY(110%); transition:transform .3s ease; flex-wrap:wrap; }
.fp-bar.show { transform:translateY(0); }
.fp-bar-txt { font-family:'Outfit',sans-serif; font-weight:600; font-size:14px; display:inline-flex; align-items:center; gap:9px; }
.fp-bar-txt i { color:#9FE3B6; }
.fp-bar-cta { display:inline-flex; align-items:center; gap:10px; }
.fp-bar-x { width:32px; height:32px; border-radius:50%; border:none; background:rgba(255,255,255,0.12); color:#fff; font-size:14px; cursor:pointer; }
.fp-bar-x:hover { background:rgba(255,255,255,0.22); }

.fp-grid-promo { background:linear-gradient(150deg,var(--green-light) 0%,#DCEFE3 100%); border:1.5px dashed var(--green-border); border-radius:var(--r-lg); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:22px 18px; min-height:200px; cursor:pointer; transition:transform .18s; text-decoration:none; }
.fp-grid-promo:hover { transform:translateY(-3px); }
.fp-gp-ic { width:46px; height:46px; border-radius:14px; background:#fff; color:var(--green); display:flex; align-items:center; justify-content:center; font-size:20px; box-shadow:var(--sh-sm); margin-bottom:12px; }
.fp-gp-t { font-family:'Outfit',sans-serif; font-weight:800; font-size:16px; color:var(--text1); margin-bottom:6px; }
.fp-gp-s { font-family:'Lato',sans-serif; font-size:13px; color:var(--green-mid); line-height:1.45; margin-bottom:14px; }
.fp-gp-btn { font-family:'Outfit',sans-serif; font-weight:800; font-size:13px; color:#fff; background:var(--green); padding:9px 18px; border-radius:var(--pill); }
.fp-signup-form { display:flex; flex-direction:column; gap:10px; margin-bottom:6px; text-align:left; }
.fp-signup-form input { height:48px; border:1.5px solid var(--div); border-radius:var(--r); padding:0 14px; font-family:'Lato',sans-serif; font-size:15px; outline:none; transition:all .14s; width:100%; }
.fp-signup-form input:focus { border-color:var(--green); box-shadow:0 0 0 3px var(--green-glow); }
.fp-signup-form .fp-btn-primary { margin-top:4px; }
@media(max-width:560px){ .fp-bar{ gap:10px; padding:11px 14px; } .fp-bar-txt{ font-size:12.5px; } }

/* card freshness */
.fcard-verified{display:flex;align-items:center;gap:6px;margin-top:10px;font-family:'Lato',sans-serif;font-size:11px;color:var(--text4)}
.fp-dot{width:7px;height:7px;border-radius:50%;background:#1C8442;flex-shrink:0;box-shadow:0 0 0 3px rgba(28,132,66,0.16)}
