:root{--text: #6b6375;--text-h: #08060d;--bg: #fff;--border: #e5e4e7;--code-bg: #f4f3ec;--accent: #aa3bff;--accent-bg: rgba(170, 59, 255, .1);--accent-border: rgba(170, 59, 255, .5);--social-bg: rgba(244, 243, 236, .5);--shadow: rgba(0, 0, 0, .1) 0 10px 15px -3px, rgba(0, 0, 0, .05) 0 4px 6px -2px;--sans: system-ui, "Segoe UI", Roboto, sans-serif;--heading: system-ui, "Segoe UI", Roboto, sans-serif;--mono: ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 1024px){:root{font-size:16px}}@media (prefers-color-scheme: dark){:root{--text: #9ca3af;--text-h: #f3f4f6;--bg: #16171d;--border: #2e303a;--code-bg: #1f2028;--accent: #c084fc;--accent-bg: rgba(192, 132, 252, .15);--accent-border: rgba(192, 132, 252, .5);--social-bg: rgba(47, 48, 58, .5);--shadow: rgba(0, 0, 0, .4) 0 10px 15px -3px, rgba(0, 0, 0, .25) 0 4px 6px -2px}#social .button-icon{filter:invert(1) brightness(2)}}body{margin:0}#root{width:1126px;max-width:100%;margin:0 auto;text-align:center;border-inline:1px solid var(--border);min-height:100svh;display:flex;flex-direction:column;box-sizing:border-box}h1,h2{font-family:var(--heading);font-weight:500;color:var(--text-h)}h1{font-size:56px;letter-spacing:-1.68px;margin:32px 0}@media (max-width: 1024px){h1{font-size:36px;margin:20px 0}}h2{font-size:24px;line-height:118%;letter-spacing:-.24px;margin:0 0 8px}@media (max-width: 1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);display:inline-flex;border-radius:4px;color:var(--text-h)}code{font-size:15px;line-height:135%;padding:4px 8px;background:var(--code-bg)}.app-container{max-width:900px;margin:0 auto;padding:2.5rem 1.5rem}.nav-modern{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(13,148,136,.2)}.nav-brand{font-weight:700;font-size:1.25rem;color:#0f766e;text-decoration:none}.nav-right{display:flex;align-items:center;gap:.5rem}.btn-modern{border-radius:8px;font-weight:500}.page-title{font-size:1.5rem;font-weight:700;color:#0f766e;margin-bottom:1.5rem}.card-modern{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0d948812;border:1px solid rgba(13,148,136,.15);overflow:hidden}.card-modern .card-body{padding:1.25rem}.table-modern{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0d948812;overflow:hidden}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(180deg,#e0f2f1,#f0fdfa,#fffbeb)}.auth-card{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 40px #0d94881f;width:100%;max-width:360px}.auth-card h1{font-size:1.5rem;color:#0f766e;margin-bottom:.25rem}.auth-card .text-muted{color:#64748b;font-size:.9rem;margin-bottom:1.5rem}.auth-card input,.auth-card select{width:100%;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;font-size:1rem}.auth-card .btn{padding:.75rem;font-size:1rem;border-radius:8px}.w-100{width:100%}.flex-wrap{flex-wrap:wrap}.mb-0{margin-bottom:0}.mb-3{margin-bottom:1rem}.fw-semibold{font-weight:600}.table-responsive{overflow-x:auto}.table th,.table td{padding:.75rem}.btn-outline-primary{border:1px solid #0d9488;color:#0d9488;text-decoration:none;padding:.5rem 1rem;border-radius:8px;display:inline-block}.btn-outline-primary:hover{background:#0d9488;color:#fff}.qr-scanner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.qr-scanner-modal{background:#fff;border-radius:16px;padding:1.5rem;max-width:400px;width:100%}.admin-links{display:flex;flex-wrap:wrap;gap:.5rem}.admin-links .btn{text-decoration:none}.list-group{list-style:none;padding:0;margin:0}.list-group-item{padding:.75rem 1rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.me-1{margin-right:.25rem}.stat-today-cards{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.stat-today-card{flex:1;min-width:140px;color:#fff;border-radius:16px;padding:1rem 1.25rem;text-align:center;box-shadow:0 4px 12px #0000001a}.stat-today-worship{background:linear-gradient(135deg,#0d9488,#0f766e);box-shadow:0 4px 12px #0d948840}.stat-today-meeting{background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 4px 12px #6366f140}.stat-type-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem}.stat-type-tab{flex:1;padding:.6rem 1rem;border:1px solid #e2e8f0;border-radius:10px;background:#fff;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.stat-type-tab:hover{border-color:#0d9488;color:#0f766e}.stat-type-tab.active{background:#0d9488;border-color:#0d9488;color:#fff}.stat-today-label{font-size:.9rem;font-weight:500;opacity:.95;margin-bottom:.25rem}.stat-today-value{font-size:2rem;font-weight:700;line-height:1.2}.stat-today-unit{font-size:1rem;font-weight:500;margin-left:.15rem;opacity:.9}.stat-date-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.stat-date-row{flex:1 1 140px;min-width:0}.stat-submit-btn{flex-shrink:0}.stat-section-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:#134e4a}.stat-chart-wrap{height:260px;min-height:200px}.stat-table-wrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}.stat-table{min-width:max-content}.stat-table .stat-sticky-col{position:sticky;left:0;background:#fff;z-index:2;box-shadow:2px 0 4px -2px #0000001a;min-width:100px;white-space:nowrap}.stat-table thead .stat-sticky-col{z-index:3;background:#f8fafc}.stat-table .stat-sticky-total{position:sticky;right:0;background:#fff;z-index:2;box-shadow:-2px 0 4px -2px #0000001a;min-width:60px;font-weight:600}.stat-table thead .stat-sticky-total{z-index:3;background:#f8fafc}@media (max-width: 576px){.stat-today-cards{flex-direction:column}.stat-today-card{padding:1.25rem 1rem;min-width:0}.stat-today-value{font-size:2.25rem}.stat-type-tabs{flex-wrap:wrap}.stat-date-form{flex-direction:column;align-items:stretch}.stat-date-row{flex:none}.stat-submit-btn{width:100%}.stat-chart-wrap{height:220px}.stat-section-title{font-size:.95rem}.stat-table .stat-sticky-col{min-width:80px;font-size:.9rem}.stat-table td,.stat-table th{padding:.5rem .4rem;font-size:.85rem}}.qr-display{padding:1rem}.qr-checkin-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(180deg,#e0f2f1,#f0fdfa,#fffbeb)}.qr-checkin-card{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 40px #0d94881f;width:100%;max-width:400px}.qr-checkin-card h2{font-size:1.5rem;color:#0f766e;margin-bottom:.5rem}#qr-reader video{border-radius:8px}.qr-checkin-card .alert-success{font-size:1.1rem;font-weight:500}*{box-sizing:border-box}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(180deg,#e0f2f1,#f0fdfa 30%,#fffbeb);color:#134e4a;line-height:1.65;min-height:100vh;margin:0}.form-control,.form-select{display:block;width:100%;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem}.form-label{display:block;margin-bottom:.25rem;font-weight:500}.btn{display:inline-block;padding:.5rem 1rem;border-radius:8px;font-weight:500;cursor:pointer;border:1px solid transparent;text-decoration:none}.btn-primary{background:#0d9488;color:#fff;border-color:#0d9488}.btn-primary:hover{background:#0f766e}.btn-success{background:#059669;color:#fff}.btn-danger{background:#dc2626;color:#fff}.btn-outline-secondary{background:transparent;border-color:#94a3b8;color:#64748b}.btn-outline-danger{background:transparent;border-color:#dc2626;color:#dc2626}.btn-sm{padding:.25rem .5rem;font-size:.875rem}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.alert-success{background:#d1fae5;color:#065f46}.alert-danger{background:#fee2e2;color:#991b1b}.alert-info{background:#e0f2fe;color:#0369a1}.text-muted{color:#64748b}.text-decoration-none{text-decoration:none}.fs-3{font-size:1.75rem}.fw-bold{font-weight:700}.stat-link{text-decoration:none;color:inherit;padding:.25rem .5rem;border-radius:6px;display:inline-block}.stat-link:hover{background:#0d94881f;color:#0f766e}.d-flex{display:flex}.gap-2{gap:.5rem}.mb-4{margin-bottom:1.5rem}
