/* PDF Church — Member Portal UI. Uses theme variables from inc/theme.php */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:560;letter-spacing:-.01em}
input,select,textarea,button{font-family:inherit}
.pav{border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;flex:none;object-fit:cover;overflow:hidden}

.app{display:grid;grid-template-columns:268px 1fr;min-height:100vh}
.side{background:var(--surface);border-right:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.side .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.side .brand .badge{width:40px;height:40px;border-radius:11px;overflow:hidden;flex:none;background:#7C1A2E}
.side .brand b{font-family:var(--font-display);font-size:16px;line-height:1.1}
.side .brand small{display:block;color:var(--muted);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;margin-top:3px}
.side .grp{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:14px 10px 7px}
.side nav a{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:11px;color:var(--ink-soft);font-size:14px;font-weight:500;transition:.18s;margin-bottom:2px}
.side nav a svg{width:18px;height:18px;flex:none}
.side nav a:hover{background:var(--surface-2);color:var(--ink)}
.side nav a.active{background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#fff;box-shadow:0 8px 18px -8px var(--halo)}
:root[data-theme="dark"] .side nav a.active{color:#231521}
.side nav a .badge-n{margin-left:auto;background:var(--wine);color:var(--on-wine);font-size:11px;font-weight:700;border-radius:100px;padding:1px 8px}
.side .foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.side .who{display:flex;align-items:center;gap:11px;padding:8px 6px}
.side .who b{font-size:13.5px;display:block}.side .who span{font-size:11.5px;color:var(--muted)}

.main{padding:0 clamp(20px,3vw,40px) 64px;overflow-x:hidden}
.topbar{display:flex;align-items:center;gap:14px;padding:22px 0;position:sticky;top:0;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);z-index:20;border-bottom:1px solid var(--line);margin-bottom:26px}
.icon-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--surface);display:grid;place-items:center;cursor:pointer;color:var(--ink-soft);transition:.2s}
.icon-btn:hover{color:var(--ink);border-color:var(--gold)}
.theme-toggle .sun{display:none}.theme-toggle .moon{display:block}
:root[data-theme="dark"] .theme-toggle .sun{display:block}:root[data-theme="dark"] .theme-toggle .moon{display:none}
.topbar h1{font-size:24px}.topbar .sub{color:var(--muted);font-size:13px;margin-top:2px}.topbar .sp{margin-left:auto}

.btn{font-weight:650;font-size:14px;border:0;cursor:pointer;border-radius:11px;padding:11px 17px;display:inline-flex;align-items:center;gap:8px;transition:transform .18s,box-shadow .25s}
.btn svg{width:16px;height:16px}
.btn-primary{background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#fff;box-shadow:0 8px 20px -8px var(--halo)}
:root[data-theme="dark"] .btn-primary{color:#231521}
.btn-primary:hover{transform:translateY(-1px)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}.btn-ghost:hover{border-color:var(--gold)}
.btn-wine{background:var(--wine);color:var(--on-wine)}:root[data-theme="dark"] .btn-wine{background:var(--surface-2);color:var(--ink)}
.btn-sm{padding:8px 13px;font-size:13px;border-radius:9px}
.btn-danger{background:transparent;color:#C8403A;border:1px solid color-mix(in srgb,#C8403A 40%,var(--line))}

/* greeting hero */
.greet{position:relative;overflow:hidden;border-radius:22px;padding:30px clamp(22px,4vw,40px);margin-bottom:24px;
  background:linear-gradient(135deg,var(--wine),#3a1420);color:var(--on-wine);box-shadow:var(--shadow-lg)}
:root[data-theme="dark"] .greet{background:linear-gradient(135deg,color-mix(in srgb,var(--wine) 42%,#180e13),#160d12);border:1px solid var(--line)}
.greet::after{content:"";position:absolute;width:46vw;height:46vw;top:-22vw;right:-12vw;border-radius:50%;background:radial-gradient(circle,var(--halo),transparent 62%)}
.greet .in{position:relative;z-index:1;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.greet .pav{box-shadow:0 0 0 3px rgba(255,255,255,.25)}
.greet h1{font-size:clamp(24px,3.4vw,32px);color:var(--on-wine)}
.greet p{opacity:.86;font-size:14.5px;margin-top:4px}
.greet .pill{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:5px 12px;border-radius:100px;font-size:12px;font-weight:600;margin-top:10px}
.greet .next{margin-left:auto;text-align:right;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:16px 20px;backdrop-filter:blur(6px)}
.greet .next span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;opacity:.8}
.greet .next b{font-family:var(--font-display);font-size:22px;display:block;margin-top:3px}

.grid{display:grid;gap:18px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.col-2{grid-column:span 2}

.card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:22px;position:relative}
.card h2,.card h3{font-size:17px;margin-bottom:2px}
.card .cap{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.card .more{position:absolute;top:20px;right:20px;font-size:13px;color:var(--gold);font-weight:600;display:inline-flex;align-items:center;gap:5px}
.card .more svg{width:14px;height:14px}
.muted{color:var(--muted)}.small{font-size:13px}

.stat{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px}
.stat .ic{width:40px;height:40px;border-radius:11px;background:var(--surface-2);display:grid;place-items:center;color:var(--gold);margin-bottom:12px}
.stat b{font-family:var(--font-display);font-size:30px;font-weight:600;line-height:1;display:block}
.stat span{color:var(--muted);font-size:12.5px}
.stat.wine .ic{color:var(--wine)}

/* ring + figure */
.ringrow{display:flex;align-items:center;gap:20px}
.ringrow .meta b{font-family:var(--font-display);font-size:26px;display:block;line-height:1}
.ringrow .meta span{color:var(--muted);font-size:13px}

/* list rows */
.lrow{display:flex;align-items:center;gap:13px;padding:12px 0;border-top:1px solid var(--line)}
.lrow:first-of-type{border-top:0}
.lrow .ic{width:38px;height:38px;border-radius:11px;background:var(--surface-2);display:grid;place-items:center;color:var(--gold);flex:none}
.lrow b{font-size:14.5px;display:block}.lrow .sub{color:var(--muted);font-size:12.5px}
.lrow .end{margin-left:auto;text-align:right;font-size:13px;color:var(--ink-soft);white-space:nowrap}

.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.03em;padding:4px 10px;border-radius:100px;background:var(--surface-2);color:var(--ink-soft)}
.pill.ok{background:color-mix(in srgb,#5BA24F 16%,transparent);color:#3c7a36}
.pill.gold{background:var(--halo);color:var(--gold)}
.pill.wine{background:color-mix(in srgb,var(--wine) 14%,transparent);color:var(--wine)}
.pill.warn{background:color-mix(in srgb,#E0A53D 18%,transparent);color:#a06e12}

/* progress bar */
.bar{height:9px;border-radius:6px;background:var(--line);overflow:hidden;margin:8px 0}
.bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gold-bright),var(--gold))}

/* table */
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:0 12px 11px;font-weight:700}
.table td{padding:12px;border-top:1px solid var(--line);vertical-align:middle}
.table tr:hover td{background:var(--surface-2)}
.tright{text-align:right}

/* announcement */
.ann{border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:12px;background:var(--bg)}
.ann.pin{border-color:color-mix(in srgb,var(--gold) 45%,var(--line));background:color-mix(in srgb,var(--gold) 6%,var(--surface))}
.ann h4{font-size:15.5px;margin-bottom:5px;display:flex;align-items:center;gap:8px}
.ann p{color:var(--ink-soft);font-size:13.5px}
.ann .by{color:var(--muted);font-size:11.5px;margin-top:8px}

/* fields */
.field{margin-bottom:15px}.field label{display:block;font-size:12.5px;font-weight:650;color:var(--ink-soft);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);background:var(--bg);border-radius:10px;padding:11px 13px;font-size:14px;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--halo)}
.row{display:grid;gap:14px}.row.c2{grid-template-columns:1fr 1fr}.row.c3{grid-template-columns:1fr 1fr 1fr}
.switch{position:relative;display:inline-block;width:42px;height:24px;flex:none}
.switch input{opacity:0;width:0;height:0}.switch .sl{position:absolute;inset:0;background:var(--line);border-radius:24px;cursor:pointer;transition:.2s}
.switch .sl::before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked+.sl{background:var(--gold)}.switch input:checked+.sl::before{transform:translateX(18px)}

.flash{padding:13px 18px;border-radius:12px;background:color-mix(in srgb,#5BA24F 14%,var(--surface));border:1px solid color-mix(in srgb,#5BA24F 30%,var(--line));margin-bottom:18px;font-size:14px}
.flash.err{background:color-mix(in srgb,#C8403A 12%,var(--surface));border-color:color-mix(in srgb,#C8403A 30%,var(--line))}
.sec-title{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--muted);margin:26px 0 14px;text-transform:uppercase}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative}
.login-wrap::before{content:"";position:fixed;width:60vw;height:60vw;top:-25vw;right:-15vw;border-radius:50%;background:radial-gradient(circle,var(--halo),transparent 65%)}
.login-card{width:100%;max-width:410px;background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:38px;box-shadow:var(--shadow-lg);position:relative;z-index:1}
.login-card .badge{width:62px;height:62px;border-radius:17px;overflow:hidden;margin:0 auto 18px;background:#7C1A2E}
.login-card h1{font-size:24px;text-align:center}.login-card .sub{text-align:center;color:var(--muted);font-size:14px;margin:4px 0 24px}
.demo-accts{margin-top:20px;border-top:1px solid var(--line);padding-top:16px}
.demo-accts .d{display:flex;align-items:center;gap:8px;justify-content:space-between;font-size:12.5px;padding:5px 0;color:var(--ink-soft)}
.demo-accts code{font-family:ui-monospace,monospace;background:var(--surface-2);padding:2px 7px;border-radius:6px;cursor:pointer}

@media(max-width:880px){
  .app{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:60;transform:translateX(-100%);transition:transform .3s;width:268px}
  .side.open{transform:none}
  .g2,.g3,.g4,.row.c2,.row.c3{grid-template-columns:1fr}.col-2{grid-column:span 1}
  .greet .next{margin-left:0;width:100%;text-align:left}
  .mobnav{display:grid!important}
}
.mobnav{display:none}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
