/* ============================================================
   Post-Your-Horse — shared tokens & app-chrome styles
   Used by checkout.html and dashboard.html
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --orange-h: 55;
  --orange-c: 0.17;
  --accent-green-enabled: 1;

  --c-orange:     oklch(0.72 var(--orange-c) var(--orange-h));
  --c-orange-2:   oklch(0.64 calc(var(--orange-c) * 1.05) calc(var(--orange-h) - 8));
  --c-orange-soft:oklch(0.94 calc(var(--orange-c) * 0.35) var(--orange-h));
  --c-green:      oklch(0.78 calc(0.17 * var(--accent-green-enabled)) 140);
  --c-green-soft: oklch(0.94 calc(0.07 * var(--accent-green-enabled)) 140);

  --bg:       oklch(0.985 0.006 80);
  --bg-2:     oklch(0.965 0.008 80);
  --surface:  oklch(1 0 0);
  --ink:      oklch(0.20 0.01 60);
  --ink-2:    oklch(0.38 0.01 60);
  --ink-3:    oklch(0.55 0.01 60);
  --line:     oklch(0.90 0.01 80);
  --line-2:   oklch(0.82 0.01 80);

  --radius: 14px;
  --radius-lg: 22px;
  --shadow-sm: 0 1px 2px rgba(50,30,10,.05), 0 2px 6px rgba(50,30,10,.04);
  --shadow-md: 0 10px 30px -12px rgba(50,30,10,.18);
  --shadow-lg: 0 30px 60px -24px rgba(50,30,10,.25);

  --maxw: 1240px;

  --font-display: "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --font-body:    "Inter", ui-sans-serif, system-ui, sans-serif;
}

*{box-sizing:border-box}
html, body{margin:0;padding:0}
body{
  background: var(--bg); color: var(--ink);
  font-family: var(--font-body); line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img{max-width:100%;display:block}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin:0;color:var(--ink)}
h1{font-size: clamp(28px, 3.4vw, 42px)}
h2{font-size: clamp(22px, 2.2vw, 28px)}
h3{font-size: 18px}
p{margin:0;color:var(--ink-2)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ------------ App chrome: top bar ------------ */
.appbar{
  position:sticky; top:0; z-index:30; background:rgba(255,255,255,.86);
  backdrop-filter: blur(14px); border-bottom:1px solid var(--line);
}
.appbar-row{display:flex;align-items:center;justify-content:space-between;height:68px;gap:24px}
.appbar-logo{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.01em}
.appbar-logo img{height:30px;width:auto}
.appbar-right{display:flex;align-items:center;gap:16px;font-size:14px}
.appbar-right a{color:var(--ink-2)}
.appbar-right a:hover{color:var(--ink)}
.user-chip{
  display:flex;align-items:center;gap:10px;padding:6px 10px 6px 6px;
  background:var(--bg-2); border:1px solid var(--line); border-radius:999px;
  font-weight:600; font-size:13px;
}
.user-chip .avatar{
  width:28px;height:28px;border-radius:50%;
  background: linear-gradient(135deg, var(--c-orange), var(--c-orange-2));
  color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;
}

/* ------------ Buttons ------------ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:999px; padding:12px 20px; font-weight:600; font-size:14px;
  border:1px solid transparent; background:transparent; color:var(--ink);
  transition: all .18s ease; cursor:pointer;
}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:oklch(0.28 0.02 55)}
.btn-accent{background:var(--c-orange);color:#fff;box-shadow: 0 10px 20px -8px color-mix(in oklab, var(--c-orange) 60%, transparent)}
.btn-accent:hover{background:var(--c-orange-2)}
.btn-ghost{background:var(--bg-2);border-color:var(--line)}
.btn-ghost:hover{background:var(--surface);border-color:var(--line-2)}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ------------ Cards ------------ */
.card{
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm);
}
.card-lg{padding:32px;border-radius:var(--radius-lg)}

/* ------------ Form primitives ------------ */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:12px;font-weight:600;color:var(--ink-2);letter-spacing:.02em;text-transform:uppercase}
.field input,.field select,.field textarea{
  border:1px solid var(--line); background:var(--surface); color:var(--ink);
  padding:12px 14px; border-radius:10px; font-size:15px; font-family:inherit;
  transition: border-color .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none; border-color: var(--c-orange);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--c-orange) 25%, transparent);
}
.field-hint{font-size:12px;color:var(--ink-3);margin-top:2px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:620px){.field-row{grid-template-columns:1fr}}

/* ------------ Badges, dots ------------ */
.badge{
  display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  background:var(--bg-2); color:var(--ink-2); border:1px solid var(--line);
}
.badge-green{background: color-mix(in oklab, var(--c-green) 30%, var(--bg)); color: oklch(0.30 0.08 145); border-color: color-mix(in oklab, var(--c-green) 50%, var(--line))}
.badge-orange{background: var(--c-orange-soft); color: oklch(0.32 0.12 55); border-color: color-mix(in oklab, var(--c-orange) 40%, var(--line))}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block;background:var(--ink-3)}
.dot.green{background:var(--c-green);animation: dot-pulse 1.8s ease-in-out infinite}
.dot.orange{background:var(--c-orange)}
@keyframes dot-pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ------------ Footer ------------ */
.app-footer{padding:40px 0;margin-top:60px;border-top:1px solid var(--line);color:var(--ink-3);font-size:13px}
.app-footer-row{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.app-footer a{color:var(--ink-3)}
.app-footer a:hover{color:var(--ink)}
