/* BookPressed — front-end, built on the existing chapters/races/challenges design system.
   Fonts: Playfair Display (editorial headlines), Source Serif 4 (body), Barlow Condensed (labels), Barlow (UI).
   Brand: red #dd012c, yellow #fcef1d, blue #2c45fe — used as sharp accents on white/off-white. */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=Source+Serif+4:ital,wght@0,400;0,600;1,400&family=Barlow+Condensed:wght@600;700;800;900&family=Barlow:wght@400;500;600;700&display=swap');

:root{
  --red:#dd012c; --red-dk:#b8001f; --yellow:#fcef1d; --blue:#2c45fe; --blue-dk:#1d2fb0;
  --ink:#0a0d1a; --body:#33384a; --muted:#7b8194; --line:#e3e7f5;
  --paper:#fafbff; --shelf:#f0f4ff;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Source Serif 4',Georgia,serif;color:var(--body);background:#fff;font-size:17px;line-height:1.65}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 22px}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;color:var(--ink);letter-spacing:-.01em;line-height:1.15}
h1{font-size:40px;font-weight:900;margin:.1em 0 .35em}
h2{font-size:28px;font-weight:900;margin:0 0 .5em}
h3{font-size:21px;font-weight:700;margin:0 0 .4em}

/* labels / kickers */
.kicker{font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.18em;font-size:13px;color:var(--blue)}

/* ── buttons: pill shape with colored shadow, from the race button system ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;font-size:16px;padding:13px 30px;border:none;border-radius:50px;
  cursor:pointer;transition:transform .18s,box-shadow .18s,background .18s;text-decoration:none;white-space:nowrap}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 4px 14px rgba(221,1,44,.35)}
.btn-red:hover{background:var(--red-dk);box-shadow:0 6px 20px rgba(221,1,44,.5)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 4px 14px rgba(44,69,254,.32)}
.btn-blue:hover{background:var(--blue-dk);box-shadow:0 6px 20px rgba(44,69,254,.5)}
.btn-yellow{background:var(--yellow);color:#1a1a1a;box-shadow:0 4px 14px rgba(252,239,29,.45)}
.btn-yellow:hover{background:#ffe620;box-shadow:0 6px 20px rgba(252,239,29,.6)}
.btn-ghost{background:#fff;color:var(--ink);border:2px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-lg{font-size:18px;padding:15px 36px}

/* form fields */
input,textarea,select{width:100%;font-family:'Barlow',sans-serif;font-size:16px;padding:12px 14px;
  border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(44,69,254,.12)}
label{font-family:'Barlow',sans-serif;font-weight:600;color:var(--ink);display:block;margin:14px 0 5px;font-size:15px}

/* cards */
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;
  box-shadow:0 2px 12px rgba(44,69,254,.06),0 1px 3px rgba(0,0,0,.04)}

.flash{font-family:'Barlow',sans-serif;font-weight:600;padding:13px 18px;border-radius:10px;margin:16px 0}
.flash.error{background:#fdeaec;color:var(--red-dk)}
.flash.success{background:#eef8e8;color:#2f6b12}
.muted{color:var(--muted)}

/* ═══ top utility bar (logged in) ═══ */
.util{background:var(--ink);color:#aeb4c8}
.util .container{display:flex;align-items:center;gap:16px;height:56px}
.util .search{flex:1;max-width:460px}
.util .search input{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:14px;border-radius:50px;padding:9px 16px}
.util .search input::placeholder{color:#8b91a8}
.util .ic{color:#aeb4c8;position:relative;display:inline-flex;font-size:18px;width:22px;justify-content:center}
.util .ic:hover{color:#fff;text-decoration:none}
.util .badge{position:absolute;top:-7px;right:-9px;background:var(--red);color:#fff;font-family:'Barlow',sans-serif;font-size:11px;font-weight:700;border-radius:10px;padding:1px 5px;line-height:1.3}
.util .me{display:flex;align-items:center;gap:9px;color:#fff;font-family:'Barlow',sans-serif;font-weight:600;font-size:14px}
.util .me:hover{text-decoration:none}
.avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#3a4156;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-family:'Barlow',sans-serif;font-weight:700;font-size:13px}

/* ═══ main nav ═══ */
.nav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav .container{display:flex;align-items:center;gap:26px;height:78px}
.nav .brand img{height:46px;width:auto}
.nav .tagline{font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.14em;font-size:12px;color:var(--muted);text-transform:uppercase;border-left:1px solid var(--line);padding-left:16px}
.nav .links{margin-left:auto;display:flex;gap:26px;align-items:center}
.nav .links a{font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:16px;color:var(--ink);display:inline-flex;align-items:center;gap:7px}
.nav .links a:hover,.nav .links a.active{color:var(--blue);text-decoration:none}
.nav .links a svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}

/* ═══ landing hero ═══ */
.hero{background:var(--red);color:#fff;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(circle at 20% 30%, rgba(255,255,255,.06) 0 8px, transparent 9px),
  radial-gradient(circle at 70% 60%, rgba(255,255,255,.05) 0 6px, transparent 7px);
  background-size:90px 90px;opacity:.6}
.hero .container{position:relative;display:grid;grid-template-columns:1.25fr .9fr;gap:48px;padding:60px 22px 70px;align-items:start}
.hero h1{color:#fff;font-size:46px;line-height:1.08;margin:0 0 18px}
.hero .lede{font-family:'Source Serif 4',serif;font-size:20px;line-height:1.55;color:rgba(255,255,255,.95);max-width:520px;margin:0 0 30px}
.hero .plans{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* pricing cards */
.price{background:#fff;border-radius:14px;padding:24px;color:var(--ink);box-shadow:0 10px 30px rgba(0,0,0,.18);position:relative;display:flex;flex-direction:column}
.price.featured{border:3px solid var(--yellow)}
.price .pname{font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:16px;color:var(--muted)}
.price .pcost{font-family:'Playfair Display',serif;font-weight:900;font-size:34px;color:var(--ink);margin:4px 0 2px;line-height:1.05}
.price .pcost small{font-family:'Barlow',sans-serif;font-weight:600;font-size:15px;color:var(--muted);display:block;margin-top:4px}
.price ul{list-style:none;padding:0;margin:16px 0 20px;font-family:'Barlow',sans-serif;font-size:15px}
.price li{padding:5px 0;display:flex;gap:9px;align-items:flex-start;color:var(--body)}
.price li svg{width:17px;height:17px;flex-shrink:0;margin-top:3px;stroke:var(--red);fill:none;stroke-width:3}
.price .btn{margin-top:auto}

/* login box */
.loginbox{background:#fff;border-radius:14px;padding:28px;color:var(--ink);box-shadow:0 10px 30px rgba(0,0,0,.18)}
.loginbox h2{font-size:23px;margin-bottom:14px}
.loginbox .alt{font-family:'Barlow',sans-serif;font-size:14px;text-align:right;margin:8px 0 0}
.loginbox hr{border:none;border-top:1px solid var(--line);margin:20px 0}

/* ═══ logged-in home ═══ */
.welcome{background:var(--shelf);border-bottom:1px solid var(--line)}
.welcome .container{padding:30px 22px}
.welcome h1{margin:0}
.welcome .pts{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:7px;font-family:'Barlow Condensed',sans-serif;font-weight:800;
  letter-spacing:.04em;font-size:15px;padding:7px 16px;border-radius:50px;text-transform:uppercase}
.pill.w{background:#e6e9ff;color:var(--blue-dk)}
.pill.f{background:#fff7cc;color:#6b5d00}

/* section tiles — clean, not cartoonish: editorial cards with a colored top rule */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:28px 0}
.tile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0;overflow:hidden;
  box-shadow:0 2px 12px rgba(44,69,254,.06);transition:transform .2s,box-shadow .2s;display:block}
.tile:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(44,69,254,.14);text-decoration:none}
.tile .top{height:6px}
.tile.t-red .top{background:var(--red)} .tile.t-blue .top{background:var(--blue)} .tile.t-yellow .top{background:var(--yellow)}
.tile .in{padding:20px 22px}
.tile h3{margin:0 0 6px;color:var(--ink)}
.tile p{font-family:'Barlow',sans-serif;font-size:14px;color:var(--muted);margin:0;line-height:1.55}

.layout{display:grid;grid-template-columns:1fr 360px;gap:34px;padding:34px 0}
@media(max-width:900px){.layout{grid-template-columns:1fr}}

/* ═══ activity feed (read-only) ═══ */
.feed{display:flex;flex-direction:column}
.feed-row{display:flex;gap:13px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line)}
.feed-row:last-child{border-bottom:none}
.feed-row .fava{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:#e6e9ff;display:flex;align-items:center;justify-content:center;font-family:'Barlow',sans-serif;font-weight:700;color:var(--blue-dk);font-size:14px}
.feed-row .txt{flex:1;font-family:'Barlow',sans-serif;font-size:15px;color:var(--body)}
.feed-row .txt b{color:var(--ink);font-weight:700}
.tag{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;border-radius:50px;padding:3px 10px;margin-left:7px;white-space:nowrap}
.tag.race{background:#ffe5e9;color:var(--red-dk)} .tag.chapter{background:#e6e9ff;color:var(--blue-dk)}
.tag.challenge{background:#fff0f5;color:#c01f5b} .tag.member,.tag.friend{background:#eef8e8;color:#2f6b12} .tag.feedback{background:#fff8e1;color:#8a6d00}

/* generic list + table */
.list{list-style:none;padding:0;margin:0}
.list li{padding:15px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px}
.list li:last-child{border-bottom:none}
.list .ti{font-family:'Playfair Display',serif;font-weight:700;font-size:18px;color:var(--ink)}
.table{width:100%;border-collapse:collapse;font-family:'Barlow',sans-serif}
.table th{font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--muted);text-align:left;padding:11px 14px;border-bottom:2px solid var(--line)}
.table td{padding:13px 14px;border-bottom:1px solid var(--line);font-size:15px}

/* chat */
.chat{display:flex;flex-direction:column;height:460px;border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden}
.chat .msgs{flex:1;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:9px}
.chat .msg{max-width:74%;padding:9px 14px;border-radius:14px;background:var(--shelf);font-family:'Barlow',sans-serif;font-size:15px}
.chat .msg.me{align-self:flex-end;background:var(--blue);color:#fff}
.chat .msg .who{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.75;margin-bottom:2px}
.chat .chat-form{display:flex;gap:9px;padding:12px;border-top:1px solid var(--line)}
.chat .chat-form input{border-radius:50px}

footer{background:var(--ink);color:#8b91a8;font-family:'Barlow',sans-serif;font-size:14px;padding:30px 0;margin-top:50px}
footer a{color:#c4c8dc}

@media(max-width:860px){
  h1{font-size:32px} .hero h1{font-size:34px}
  .hero .container{grid-template-columns:1fr;gap:30px;padding:40px 22px 50px}
  .hero .plans{grid-template-columns:1fr 1fr}
  .nav .container{height:auto;flex-wrap:wrap;padding-top:12px;padding-bottom:12px;gap:14px}
  .nav .links{gap:16px;width:100%;flex-wrap:wrap}
  .nav .tagline{display:none}
}
@media(max-width:520px){.hero .plans{grid-template-columns:1fr}}

/* admin shell keeps its own structural styles; inherits brand tokens */
.admin-wrap{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.admin-side{background:var(--ink);color:#aeb4c8;padding:20px 0}
.admin-side .brand{padding:0 22px 18px}.admin-side .brand img{height:34px}
.admin-side a{display:flex;gap:11px;align-items:center;color:#aeb4c8;padding:12px 22px;font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:15px}
.admin-side a:hover,.admin-side a.active{background:rgba(0,0,0,.25);color:#fff;text-decoration:none;border-left:3px solid var(--yellow)}
.admin-main{padding:28px 32px;background:var(--paper)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin:18px 0}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px}
.stat .n{font-family:'Playfair Display',serif;font-weight:900;font-size:30px;color:var(--ink)}
.stat .l{font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:var(--muted)}
@media(max-width:860px){.admin-wrap{grid-template-columns:1fr}}
