/* =====================================================================
   public.css — audience-facing pages (no login). Sage Editorial, themed.
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');
:root{
  --paper:#F0EEE3;--ink:#222A1D;--muted:#7C846E;--faint:#A4AB96;--line:#E3E0D0;--line2:#D6D2C0;
  --card:#FBF9F0;--green:#5E8C4F;--green-deep:#3C5A35;--green-soft:#E2EBD3;
  --serif:'Instrument Serif',Georgia,serif;--sans:'Hanken Grotesk',system-ui,sans-serif;
  --theme:#5E8C4F;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.55;font-size:15px}
.serif{font-family:var(--serif);font-weight:400}
a{color:inherit}
img{max-width:100%;display:block}

/* themed gradient background */
.themed{min-height:100vh;background:linear-gradient(170deg,var(--theme),color-mix(in srgb,var(--theme) 78%,#000) 130%);display:flex;flex-direction:column;align-items:center;padding:32px 18px 48px}
.col-wrap{width:100%;max-width:440px;margin:0 auto}

/* brand bar */
.pub-top{display:flex;align-items:center;justify-content:center;gap:6px;color:#fff;opacity:.9;margin-bottom:24px}
.pub-top .serif{font-size:20px}
.pub-top i{font-family:var(--serif);font-style:italic;color:#fff;margin-left:4px}

/* card */
.pub-card{background:var(--card);border-radius:20px;box-shadow:0 20px 50px rgba(20,28,16,.28);overflow:hidden}
.pub-pad{padding:30px 26px}
.pub-cover{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:#ddd}

/* avatar */
.pub-ava{width:84px;height:84px;border-radius:50%;border:4px solid var(--card);background:linear-gradient(135deg,#C2D6A0,#3C5A35);margin:-50px auto 0;position:relative;display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:30px;box-shadow:0 6px 16px rgba(0,0,0,.15)}

.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.16em;font-weight:700;color:var(--theme)}
h1.pub-title{font-family:var(--serif);font-weight:400;font-size:34px;line-height:1.08;letter-spacing:.3px}
.pub-sub{color:var(--muted);font-size:15px}

/* buttons */
.pub-btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;border:none;cursor:pointer;
  font-family:var(--sans);font-weight:700;font-size:15px;padding:15px;border-radius:13px;background:var(--theme);color:#fff;text-decoration:none;transition:.15s;box-shadow:0 4px 14px color-mix(in srgb,var(--theme) 45%,transparent)}
.pub-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.pub-btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line2);box-shadow:none}
.pub-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}

/* link tiles (bio) */
.tiles{display:flex;flex-direction:column;gap:12px}
.tile{display:flex;align-items:center;gap:13px;background:var(--card);border-radius:14px;padding:15px 17px;text-decoration:none;font-weight:600;font-size:15px;box-shadow:0 6px 16px rgba(20,28,16,.12);transition:.15s}
.tile:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(20,28,16,.18)}
.tile .ti{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex:none;background:var(--green-soft);color:var(--green-deep)}
.tile .ti svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.9}
.tile .tile-ico{width:21px;height:21px;flex:none;fill:currentColor;color:var(--ink)}
.tile .tile-lbl{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tile .arr{margin-left:auto;color:var(--faint)}

/* form fields */
.pub-input{width:100%;font-family:var(--sans);font-size:15px;padding:14px 15px;border-radius:12px;border:1px solid var(--line2);background:#fff;outline:none;margin-bottom:12px}
.pub-input:focus{border-color:var(--theme);box-shadow:0 0 0 3px color-mix(in srgb,var(--theme) 22%,transparent)}

/* badges */
.pub-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:4px 11px;border-radius:20px;background:var(--green-soft);color:var(--green-deep)}
.pub-price{font-family:var(--serif);font-size:40px;line-height:1}

/* highlights */
.hl{display:flex;align-items:center;gap:10px;padding:9px 0;font-size:14.5px;color:var(--ink)}
.hl svg{width:18px;height:18px;color:var(--theme);flex:none;stroke:currentColor;fill:none;stroke-width:2}

/* footer */
.pub-foot{text-align:center;color:#fff;opacity:.7;font-size:12px;margin-top:26px}
.pub-foot a{text-decoration:underline}

/* generic light page (legal, confirm on paper) */
.lite{max-width:560px;margin:0 auto;padding:48px 22px}
.lite-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:34px 30px;box-shadow:0 10px 30px rgba(20,28,16,.08)}
.icon-badge{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px}
.icon-badge svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.7}

/* divider */
.hr{height:1px;background:var(--line);border:0;margin:20px 0}

@media (max-width:520px){h1.pub-title{font-size:28px}}
