/* PDF Church admin — reuses theme variables injected by 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}

.app{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
/* sidebar */
.side{background:var(--surface);border-right:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px}
.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:17px;line-height:1.1}
.side .brand small{display:block;color:var(--muted);font-size:10px;letter-spacing:.18em;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 .foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.side .who{display:flex;align-items:center;gap:11px;padding:8px 10px}
.side .who .av{width:36px;height:36px;border-radius:50%;background:var(--wine);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}
.side .who b{font-size:13.5px;display:block} .side .who span{font-size:11.5px;color:var(--muted);text-transform:capitalize}

/* main */
.main{padding:0 clamp(20px,3vw,40px) 60px;overflow-x:hidden}
.topbar{display:flex;align-items:center;gap:16px;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:28px}
.topbar h1{font-size:26px;font-weight:560}
.topbar .sub{color:var(--muted);font-size:13.5px;margin-top:2px}
.topbar .sp{margin-left:auto}
.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}

.btn{font-weight:650;font-size:14px;border:0;cursor:pointer;border-radius:11px;padding:11px 18px;display:inline-flex;align-items:center;gap:8px;transition:transform .18s,box-shadow .25s,background .2s}
.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-danger{background:transparent;color:#C8403A;border:1px solid color-mix(in srgb,#C8403A 40%,var(--line))}
.btn-danger:hover{background:color-mix(in srgb,#C8403A 12%,transparent)}
.btn-sm{padding:8px 13px;font-size:13px;border-radius:9px}

/* cards / panels */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:24px;margin-bottom:22px}
.panel h2{font-size:19px;margin-bottom:4px}
.panel .hint{color:var(--muted);font-size:13px;margin-bottom:18px}
.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)}

/* stat tiles */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:20px;position:relative;overflow:hidden}
.stat .ic{width:42px;height:42px;border-radius:11px;background:var(--surface-2);display:grid;place-items:center;color:var(--gold);margin-bottom:14px}
.stat b{font-family:var(--font-display);font-size:34px;font-weight:600;line-height:1;display:block}
.stat span{color:var(--muted);font-size:13px}
.stat .ico-bg{position:absolute;right:-10px;top:-10px;color:var(--line);opacity:.5}

/* fields */
.field{margin-bottom:16px}
.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);transition:border-color .18s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--halo)}
.field textarea{min-height:96px;resize:vertical}
.field .help{font-size:11.5px;color:var(--muted);margin-top:5px}
.row{display:grid;gap:14px}.row.c2{grid-template-columns:1fr 1fr}.row.c3{grid-template-columns:1fr 1fr 1fr}

/* color token grid */
.tokens{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.token{border:1px solid var(--line);border-radius:11px;padding:10px;background:var(--bg)}
.token label{font-size:11px;color:var(--muted);display:block;margin-bottom:6px;text-transform:capitalize}
.token .pick{display:flex;align-items:center;gap:8px}
.token input[type=color]{width:34px;height:34px;border:1px solid var(--line);border-radius:8px;padding:0;background:none;cursor:pointer;flex:none}
.token input[type=text]{flex:1;border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:7px 9px;font-size:12px;color:var(--ink);font-family:ui-monospace,monospace}

/* table */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:0 14px 12px;font-weight:700}
.table td{padding:14px;border-top:1px solid var(--line);vertical-align:middle}
.table tr:hover td{background:var(--surface-2)}
.table .thumb{width:54px;height:40px;border-radius:8px;object-fit:cover;background:var(--surface-2)}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.04em;padding:4px 10px;border-radius:100px;background:var(--surface-2);color:var(--ink-soft)}
.tag.ok{background:color-mix(in srgb,#5BA24F 16%,transparent);color:#3c7a36}
.tag.warn{background:color-mix(in srgb,#E0A53D 18%,transparent);color:#a06e12}
.tag.gold{background:var(--halo);color:var(--gold)}
.actions{display:flex;gap:8px;justify-content:flex-end}

/* toggle switch */
.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)}

/* block editor list */
.blocks{display:flex;flex-direction:column;gap:12px}
.blk{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.blk .drag{color:var(--muted);cursor:grab}
.blk .ico{width:40px;height:40px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center;color:var(--gold);flex:none}
.blk b{font-size:15px}.blk span{color:var(--muted);font-size:12.5px;text-transform:capitalize}
.blk .right{margin-left:auto;display:flex;align-items:center;gap:12px}

/* flash */
.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))}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative}
.login-card{width:100%;max-width:400px;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:64px;height:64px;border-radius:18px;overflow:hidden;margin:0 auto 20px;background:#7C1A2E;box-shadow:var(--shadow)}
.login-card h1{font-size:25px;text-align:center;margin-bottom:6px}
.login-card p.sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:26px}

@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:60;transform:translateX(-100%);transition:transform .3s;width:264px}
  .side.open{transform:none}
  .g2,.g3,.g4,.row.c2,.row.c3{grid-template-columns:1fr}
  .mobnav{display:grid!important}
}
.mobnav{display:none}
