/* freeholdip.css — shared design system (mirrors the homepage look).
   Linked by every non-landing page: <link rel="stylesheet" href="/freeholdip.css">
   Icons come from the external sprite: <svg class="ic"><use href="/icons.svg#i-id"/></svg>
   The homepage (index.html) stays self-contained for robustness; keep tokens here in sync with it. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,500;1,9..144,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --bg:#08111f;--bg2:#0c1c33;
  --card:#0f223d;--card2:#0c1a30;--line:rgba(158,203,255,.14);--line2:rgba(158,203,255,.28);
  --ink:#eaf1fb;--mut:#9fb4d6;--soft:#c6d6ee;
  --accent:#8fc0ff;--accent2:#bcd8ff;--gold:#e9c573;--gold2:#f3d99a;--ok:#6fe39a;--warn:#f4c264;--bad:#ff8a8a;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
strong,b{color:#fff}

/* ---- atmospheric background (add <div class="fbg"><div class="glow g1"></div><div class="glow g2"></div><div class="grid"></div></div>) ---- */
.fbg{position:fixed;inset:0;z-index:-1;overflow:hidden;background:
  radial-gradient(1100px 620px at 78% -8%,#15315a 0%,transparent 60%),
  radial-gradient(900px 600px at 8% 8%,#102744 0%,transparent 55%),
  linear-gradient(180deg,#08111f,#070e1a)}
.fbg .glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.4}
.fbg .g1{width:480px;height:480px;left:-120px;top:-80px;background:radial-gradient(circle,#caa24a4d,transparent 70%)}
.fbg .g2{width:520px;height:520px;right:-160px;top:300px;background:radial-gradient(circle,#2f6bbf3d,transparent 70%)}
.fbg .grid{position:absolute;inset:0;background-image:radial-gradient(rgba(158,203,255,.06) 1px,transparent 1px);
  background-size:30px 30px;-webkit-mask:radial-gradient(circle at 50% 18%,#000,transparent 76%);mask:radial-gradient(circle at 50% 18%,#000,transparent 76%)}

/* ---- layout ---- */
.wrap{max-width:980px;margin:0 auto;padding:1.4rem 1.3rem 4rem;position:relative}
.wrap.narrow{max-width:820px}

/* ---- icons ---- */
.ic{width:1.5rem;height:1.5rem;display:inline-block;vertical-align:middle;fill:none;
  stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ic.sm{width:1.05rem;height:1.05rem}

/* ---- header ---- */
.site-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.4rem 0}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:700;font-size:1.16rem;letter-spacing:-.01em;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .logo{width:32px;height:32px;flex:0 0 32px;filter:drop-shadow(0 4px 12px #caa24a40)}
.nav{display:flex;align-items:center;gap:1.3rem;font-size:.92rem;font-weight:600}
.nav a{color:var(--soft)}.nav a:hover{color:#fff;text-decoration:none}
.preview{font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold2);
  border:1px solid #6a5526;background:linear-gradient(180deg,#2a2110,#1c1709);border-radius:99px;padding:.32rem .8rem;white-space:nowrap}

/* ---- headings / hero ---- */
.eyebrow{font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.9rem}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,4.4vw,3.1rem);line-height:1.08;letter-spacing:-.018em;margin:0 0 1rem}
.hl{font-style:italic;font-weight:500;background:linear-gradient(180deg,#f3d99a,#dca94e);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
h2{font-family:var(--serif);font-weight:600;font-size:1.65rem;letter-spacing:-.01em;margin:2.6rem 0 .8rem;color:#fff}
h3{font-size:1.08rem;margin:.1rem 0 .4rem;color:#fff}
.lead{font-size:1.12rem;line-height:1.75;color:var(--soft)}
p{color:var(--soft)}
.shead{display:flex;align-items:baseline;gap:.8rem;margin:3rem 0 1.4rem;flex-wrap:wrap}
.shead h2{margin:0}
.shead .num{font-size:.72rem;font-weight:700;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}
.hero{text-align:center;padding:2rem 0 1rem}
.hero h1{margin-left:auto;margin-right:auto}
.hero .lead{max-width:42rem;margin:0 auto 1.4rem}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;border-radius:11px;padding:.72rem 1.25rem;
  font-weight:700;font-size:.96rem;border:1px solid transparent;cursor:pointer;
  transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn .ic{width:1.05rem;height:1.05rem}
.btn.gold{background:linear-gradient(180deg,#f3d99a,#e0b45c);color:#1d1606;box-shadow:0 10px 26px -12px #e9c57380}
.btn.ghost{background:#0e1f3880;color:var(--accent2);border-color:var(--line2)}
.btn.ghost:hover{border-color:var(--accent);color:#fff}
.btnrow{display:flex;gap:.7rem;flex-wrap:wrap}
.btnrow.center{justify-content:center}

/* ---- cards / grid ---- */
.card{background:linear-gradient(165deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:16px;
  padding:1.25rem 1.35rem;transition:border-color .22s,transform .22s,box-shadow .22s}
.card.lift:hover{transform:translateY(-4px);border-color:var(--line2);box-shadow:0 22px 46px -28px #000d}
.grid{display:grid;gap:1.1rem}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.chip{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;flex:0 0 44px;
  background:linear-gradient(160deg,#9ec6ff1a,#9ec6ff08);border:1px solid var(--line);color:var(--gold2)}
.who{color:var(--gold);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.frow{display:flex;gap:1rem;align-items:flex-start}
ul.clean{margin:.5rem 0 0;padding-left:1.15rem}
ul.clean li{margin:.4rem 0;font-size:.95rem;color:#dbe6f7}
ul.check{list-style:none;margin:.6rem 0 0;padding:0}
ul.check li{position:relative;padding-left:1.7rem;margin:.5rem 0;font-size:.95rem;color:#dbe6f7}
ul.check li::before{content:"";position:absolute;left:0;top:.36em;width:1.05rem;height:1.05rem;
  background:no-repeat center/contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236fe39a' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.6l4.4 4.4L19 7.2'/%3E%3C/svg%3E")}

/* ---- highlight panel ---- */
.panel{background:linear-gradient(160deg,#15294a,#0d1f38);border:1px solid #6a5526;border-radius:18px;padding:1.7rem;margin:2rem 0}
.panel h2{margin-top:0}
.panel .big{font-family:var(--serif);font-size:1.35rem;color:#fff;font-weight:600;margin:1rem 0 .3rem}

/* ---- prose (legal / guide bodies) ---- */
.prose{max-width:46rem}
.prose h2{font-size:1.4rem}
.prose h3{font-size:1.08rem;margin-top:1.6rem;color:var(--gold2)}
.prose p,.prose li{color:var(--soft)}
.prose ul{padding-left:1.2rem}.prose li{margin:.4rem 0}
.meta{color:var(--mut);font-size:.88rem}

/* ---- trust bar ---- */
.trustbar{margin-top:3rem;border:1px solid var(--line);border-radius:18px;padding:1.6rem;
  background:linear-gradient(165deg,#0e1f38,#0a162a);text-align:center}
.trustbar .tlabel{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--mut);margin-bottom:1.1rem}
.badges{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem 1.1rem}
.tbadge{display:inline-flex;align-items:center;gap:.6rem;padding:.55rem 1rem;border-radius:12px;
  background:#0a142680;border:1px solid var(--line);font-weight:600;font-size:.9rem;color:#dce7f8}
.tbadge .ic{width:1.3rem;height:1.3rem;color:var(--gold2)}
.tbadge.chain .ic{color:var(--accent2)}

/* ---- footer ---- */
.site-foot{margin-top:3.4rem;padding-top:1.5rem;border-top:1px solid var(--line);color:var(--mut);font-size:.9rem}
.site-foot .tag{font-family:var(--serif);font-style:italic;color:var(--soft)}
.site-foot .about{display:inline-flex;align-items:center;gap:.4rem;color:var(--gold2);margin-top:.7rem;font-weight:600}
.site-foot .links{margin-top:.8rem;display:flex;flex-wrap:wrap;gap:.4rem .9rem}
.site-foot .links a{color:var(--accent)}

/* ---- motion ---- */
@keyframes frise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.reveal{opacity:0;animation:frise .8s cubic-bezier(.2,.7,.3,1) forwards;animation-delay:var(--d,0s)}

@media(max-width:760px){.grid.c2,.grid.c3{grid-template-columns:1fr}.nav{display:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto}.reveal{opacity:1}}
