/* ============================================================
   Postpal — shared styles for every page
   Warm, friendly, mobile-first. Edit colours in :root below.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700&family=DM+Sans:wght@400;500;700&display=swap');

:root{
  --cream:#FBF7F0;
  --ink:#2B2722;
  --muted:#8A8178;
  --line:#ECE4D8;
  --card:#FFFFFF;
  --accent:#E07A5F;       /* terracotta */
  --accent-d:#C9614A;
  --green:#3D8361;
  --radius:18px;
  --shadow:0 1px 2px rgba(43,39,34,.05), 0 12px 30px -16px rgba(43,39,34,.22);
  --maxw:1100px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:'DM Sans',system-ui,sans-serif;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:700;line-height:1.12;letter-spacing:-.01em;margin:0 0 .4em}
h1{font-size:clamp(32px,6vw,56px)}
h2{font-size:clamp(26px,4vw,40px)}
h3{font-size:clamp(19px,2.4vw,24px)}
p{margin:0 0 1em}
a{color:inherit}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:560px}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brandmark{font-family:'Fraunces',serif;font-weight:700;font-size:22px;text-decoration:none;color:var(--ink);display:flex;align-items:center;gap:8px}
.brandmark .dot{width:11px;height:11px;border-radius:50%;background:var(--accent)}
.nav__links{display:flex;gap:24px;align-items:center}
.nav__links a{text-decoration:none;color:var(--muted);font-weight:500;font-size:15px}
.nav__links a:hover{color:var(--ink)}
@media(max-width:620px){.nav__links a.hide-sm{display:none}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  font-family:inherit;font-weight:700;font-size:16px;text-decoration:none;
  padding:13px 24px;border-radius:999px;border:2px solid transparent;transition:transform .18s,box-shadow .18s,background .18s}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--accent);color:#fff;box-shadow:0 8px 20px -8px var(--accent)}
.btn--primary:hover{background:var(--accent-d)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink)}
.btn--block{width:100%}
.btn[disabled]{opacity:.55;pointer-events:none}

/* cards / forms */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pad{padding:28px}
@media(max-width:520px){.pad{padding:20px}}
label{display:block;font-weight:500;font-size:14px;margin:0 0 6px}
.req{color:var(--accent)}
input,select,textarea{
  width:100%;font-family:inherit;font-size:16px;color:var(--ink);background:#fff;
  border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;transition:border .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(224,122,95,.15)}
input[readonly]{background:#f6f1e8;color:var(--muted)}
textarea{resize:vertical;min-height:84px}
.field{margin-bottom:18px}
.hint{font-size:13px;color:var(--muted);margin:6px 0 0}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.row2{grid-template-columns:1fr}}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* misc */
.eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700;margin:0 0 12px}
.muted{color:var(--muted)}
.center{text-align:center}
.pill{display:inline-block;background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;margin:3px}
.notice{padding:13px 16px;border-radius:12px;font-size:14px;font-weight:500}
.notice--ok{background:#eaf5ee;color:#236844;border:1px solid #bfe2cc}
.notice--err{background:#fbeae6;color:#a23c25;border:1px solid #f1c7bc}
.footer{border-top:1px solid var(--line);margin-top:80px;padding:36px 0;color:var(--muted);font-size:14px}
.footer a{color:var(--muted);text-decoration:none;margin-right:18px}
.footer a:hover{color:var(--ink)}
.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.hidden{display:none!important}
