/* ============================================
   Affreso Default Theme
   ============================================ */
:root{
  --ink:#1b1e28; --ink-2:#3d4252; --mut:#6e7383; --faint:#9b9fae;
  --line:#e8e9ef; --bg:#ffffff; --bg-2:#f6f7fb;
  --acc:#5b5bd6; --acc-2:#4848c4; --acc-soft:#eeeefb;
  --ok:#1a9d6c; --ok-soft:#e3f6ee; --warn:#b97a12; --warn-soft:#fdf3e0; --bad:#d6455b;
  --r:14px;
  --shadow:0 1px 3px rgba(20,22,40,.06),0 10px 32px rgba(20,22,40,.07);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,"Helvetica Neue",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font:16px/1.65 var(--font);color:var(--ink);background:var(--bg)}
a{color:var(--acc);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.container{max-width:1080px;margin:0 auto;padding:0 22px}
.narrow{max-width:760px}

/* Header */
.site-header{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:50}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 22px;max-width:1080px;margin:0 auto}
.site-logo{display:flex;align-items:center;gap:10px;color:var(--ink);font-weight:800;font-size:19px;letter-spacing:-.3px}
.site-logo:hover{text-decoration:none}
.logo-mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#6e6ee8,#4848c4);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:16px}
.site-nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.site-nav a{padding:7px 13px;border-radius:9px;color:var(--ink-2);font-weight:500;font-size:14.5px}
.site-nav a:hover{background:var(--bg-2);text-decoration:none}
.site-nav a.cta{background:var(--acc);color:#fff;font-weight:600;margin-left:6px}
.site-nav a.cta:hover{background:var(--acc-2)}

/* Hero */
.hero{background:linear-gradient(180deg,#f4f5fc 0%,#fff 100%);padding:72px 0 56px;text-align:center}
.hero h1{font-size:clamp(30px,5vw,46px);letter-spacing:-1px;line-height:1.15;max-width:760px;margin:0 auto 16px}
.hero p{font-size:18px;color:var(--mut);max-width:560px;margin:0 auto 28px}
.btn{display:inline-block;background:var(--acc);color:#fff;padding:13px 26px;border-radius:11px;font-weight:600;font-size:15.5px;border:0;cursor:pointer;font-family:var(--font)}
.btn:hover{background:var(--acc-2);text-decoration:none}
.btn.ghost{background:#fff;color:var(--ink-2);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--bg-2)}
.btn.sm{padding:8px 16px;font-size:14px;border-radius:9px}

/* Cards / grids */
.grid{display:grid;gap:24px}
.grid.cols-3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card .thumb{height:180px;background:linear-gradient(135deg,#e8e8fb,#d4d4f5);display:flex;align-items:center;justify-content:center;font-size:40px;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .pad{padding:20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.card h3{font-size:17.5px;letter-spacing:-.2px;line-height:1.35}
.card h3 a{color:var(--ink)}
.card p{font-size:14px;color:var(--mut);flex:1}
.card .meta{font-size:12.5px;color:var(--faint);display:flex;justify-content:space-between;align-items:center;gap:8px}

/* Sections */
.section{padding:56px 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:26px}
.section-head h2{font-size:26px;letter-spacing:-.5px}
.page-content{padding:52px 0 64px}
.page-content h1,.prose-title{font-size:clamp(28px,4vw,38px);letter-spacing:-.8px;margin-bottom:10px;line-height:1.2}
.prose{font-size:16.5px}
.prose p{margin:0 0 18px}
.prose h2{font-size:24px;margin:30px 0 12px;letter-spacing:-.4px}
.prose h3{font-size:19px;margin:24px 0 10px}
.prose ul,.prose ol{padding-left:26px;margin:0 0 18px}
.prose li{margin-bottom:6px}
.prose blockquote{border-left:3px solid var(--acc);padding:6px 20px;color:var(--mut);margin:20px 0;background:var(--bg-2);border-radius:0 10px 10px 0}
.prose img{border-radius:12px;margin:10px 0}
.prose code{background:var(--bg-2);padding:2px 7px;border-radius:6px;font-size:14px}
.post-meta{color:var(--faint);font-size:14px;margin-bottom:28px}

/* Badges */
.badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 11px;border-radius:99px}
.badge.free{background:var(--ok-soft);color:var(--ok)}
.badge.paid{background:var(--warn-soft);color:var(--warn)}
.badge.acc{background:var(--acc-soft);color:var(--acc-2)}

/* Forms */
.form-card{max-width:420px;margin:60px auto;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:36px}
.form-card h1{font-size:24px;letter-spacing:-.4px;margin-bottom:6px}
.form-card .sub{color:var(--mut);font-size:14px;margin-bottom:22px}
label.f{display:block;font-size:13.5px;font-weight:600;margin:14px 0 6px}
.input{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;font-size:15px;font-family:var(--font);background:#fbfbfd}
.input:focus{outline:2px solid #c9c9f4;border-color:var(--acc)}
textarea.input{resize:vertical}
.alert{padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:16px}
.alert.error{background:#fdebee;color:#a32940;border:1px solid #f6c6cf}
.alert.success{background:var(--ok-soft);color:#0e7a52;border:1px solid #bfe9d6}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:var(--bg-2);margin-top:60px}
.site-footer .inner{max-width:1080px;margin:0 auto;padding:32px 22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--mut);font-size:14px}

/* Pagination */
.pagination{display:flex;gap:8px;margin-top:34px;justify-content:center}
.pagination a,.pagination span{padding:8px 15px;border:1px solid var(--line);border-radius:10px;font-size:14px}
.pagination span.cur{background:var(--acc);color:#fff;border-color:var(--acc)}

/* Community (forum + messages + profiles) — core features */
.forum-topic-row{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#fff;
  border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:10px;color:var(--ink)}
.forum-topic-row:hover{text-decoration:none;border-color:var(--acc);box-shadow:var(--shadow)}
.ft-title{font-weight:600;font-size:15px}
.forum-post{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin-bottom:12px}
.forum-post.op{border-left:3px solid var(--acc)}
.fp-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.fp-body{font-size:15px;line-height:1.65}
.msg-thread{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;max-height:520px;overflow-y:auto;margin-bottom:14px}
.msg{margin-bottom:14px;max-width:78%}
.msg.mine{margin-left:auto;text-align:right}
.msg-bubble{display:inline-block;background:var(--bg-2);border-radius:14px 14px 14px 4px;padding:10px 15px;font-size:14.5px;text-align:left}
.msg.mine .msg-bubble{background:var(--acc);color:#fff;border-radius:14px 14px 4px 14px}
.msg-time{font-size:11px;color:var(--faint);margin-top:3px}
.msg-compose{display:flex;gap:10px;align-items:flex-end}
.msg-compose textarea{flex:1}
.profile-head{display:flex;align-items:center;gap:20px;margin-bottom:24px;flex-wrap:wrap}
img.avatar{border-radius:50%;object-fit:cover}
div.avatar{border-radius:50%;background:var(--acc-soft);color:var(--acc-2);display:inline-flex;align-items:center;justify-content:center;font-weight:700}
.meeting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:13px 17px;margin-bottom:9px;flex-wrap:wrap}
.meeting-row .mt-when{font-weight:700;color:var(--acc-2);font-size:13px}

/* Volunteer module */
.avail-grid{border-collapse:collapse;width:100%}
.avail-grid th,.avail-grid td{border:1px solid var(--line);padding:10px;text-align:center;font-size:14px}
.avail-grid th{background:var(--bg-2);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--mut)}
.avail-grid input{width:18px;height:18px}
.cal-grid{width:100%;border-collapse:collapse;table-layout:fixed}
.cal-grid th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:8px;text-align:left}
.cal-grid td{border:1px solid var(--line);vertical-align:top;height:92px;padding:6px}
.cal-ev{display:block;font-size:11px;background:var(--acc-soft);color:var(--acc-2);border-radius:5px;padding:2px 6px;margin-top:3px;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis}

@media(max-width:720px){
  .site-header .inner{flex-direction:column;align-items:flex-start}
  .hero{padding:48px 0 40px}
}
