:root{--bg: #faf7ff;--surface: #ffffff;--ink: #1f1633;--ink-soft: #6b6485;--brand: #7c3aed;--brand-2: #ec4899;--brand-grad: linear-gradient(135deg, #7c3aed 0%, #ec4899 100%);--success: #16a34a;--danger: #dc2626;--warn: #d97706;--border: #ece6f6;--shadow-sm: 0 2px 6px rgba(31, 22, 51, .06);--shadow-md: 0 8px 24px rgba(31, 22, 51, .1);--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}.app{min-height:100%;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-weight:700;font-size:20px}.brand-icon{font-size:26px}.brand-text{background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}.app-nav{display:flex;gap:12px;align-items:center}.nav-link{color:var(--ink);text-decoration:none;font-weight:600;padding:6px 10px;border-radius:8px}.nav-link:hover{background:var(--border)}.nav-link.subtle{color:var(--ink-soft);font-weight:500;font-size:14px}.nav-link-btn{background:none;border:none;cursor:pointer;font-size:16px}.app-main{flex:1;max-width:980px;width:100%;margin:0 auto;padding:24px 20px 60px}.app-footer{padding:18px 20px;border-top:1px solid var(--border);color:var(--ink-soft);font-size:13px;text-align:center;background:var(--surface)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:12px;font-weight:600;border:1px solid transparent;cursor:pointer;background:var(--surface);color:var(--ink);font-size:15px;text-decoration:none;transition:transform .05s ease,box-shadow .15s ease,background .15s ease}.btn:hover{box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--brand-grad);color:#fff;border:none}.btn-primary:hover{box-shadow:var(--shadow-md)}.btn-secondary{background:var(--surface);border:1px solid var(--border)}.btn-danger{background:var(--surface);color:var(--danger);border:1px solid var(--border)}.btn-danger:hover{background:#fef2f2}.btn-tiny{padding:4px 10px;font-size:13px;border:1px solid var(--border)}.btn-big{padding:14px 22px;font-size:17px;width:100%;max-width:320px}.btn[disabled]{opacity:.6;cursor:wait}.hero{text-align:center;padding:16px 0 24px}.hero-title{font-size:42px;margin:0 0 6px;background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{color:var(--ink-soft);margin:0;font-size:17px}.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.event-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:18px;text-decoration:none;color:var(--ink);display:flex;gap:14px;transition:transform .1s ease,box-shadow .15s ease;position:relative;overflow:hidden}.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.event-card.funded{border-color:var(--success)}.event-card-icon{font-size:38px;flex-shrink:0;line-height:1}.event-card-body{flex:1;min-width:0}.event-card-name{margin:0 0 4px;font-size:18px}.event-card-desc{color:var(--ink-soft);margin:0 0 10px;font-size:14px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.due-chip{display:inline-block;margin:0 0 10px;font-size:12px;font-weight:600;color:var(--ink-soft);background:#f1eaff;padding:3px 9px;border-radius:999px}.due-chip.urgent{background:#fef3c7;color:#92400e}.due-chip.overdue{background:#fee2e2;color:var(--danger)}.event-hero-due{margin:6px 0 0;color:var(--ink-soft);font-size:14px;font-weight:600}.event-hero-due.urgent{color:var(--warn)}.event-hero-due.overdue{color:var(--danger)}.event-hero-due .due-days{font-weight:500;opacity:.85}.funded-badge{position:absolute;top:10px;right:10px;background:var(--success);color:#fff;padding:3px 8px;font-size:12px;border-radius:999px;font-weight:700}.thermometer-track{height:14px;background:#f1eaff;border-radius:999px;overflow:hidden}.thermometer-fill{height:100%;background:var(--brand-grad);transition:width .6s cubic-bezier(.32,.72,.4,1);border-radius:999px;min-width:4px}.thermometer.big .thermometer-track{height:22px}.thermometer-caption{display:flex;gap:6px;align-items:baseline;margin-top:6px;font-size:13px;color:var(--ink-soft)}.thermometer-caption strong{color:var(--ink);font-size:15px}.thermometer-caption.big{font-size:16px}.thermometer-caption.big .raised{font-size:28px;font-weight:800;color:var(--brand)}.thermometer-caption.big .of{font-size:16px}.thermometer-percent{margin-left:auto;background:#f1eaff;color:var(--brand);padding:2px 8px;border-radius:999px;font-weight:700;font-size:12px}.event-detail{position:relative}.back-link{display:inline-block;color:var(--ink-soft);text-decoration:none;margin-bottom:12px;font-size:14px}.back-link:hover{color:var(--brand)}.event-hero{display:flex;gap:18px;align-items:center;margin-bottom:18px}.event-hero-icon{font-size:64px;background:var(--surface);border-radius:24px;padding:12px 16px;box-shadow:var(--shadow-sm)}.event-hero-title{margin:0;font-size:30px}.event-hero-desc{margin:4px 0 0;color:var(--ink-soft)}.thermometer.big{background:var(--surface);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);margin-bottom:22px}.funded-banner{background:#dcfce7;color:#166534;padding:18px 22px;border-radius:var(--radius);font-size:18px;font-weight:700;text-align:center;margin-bottom:22px}.donate-section{background:var(--surface);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);margin-bottom:22px;text-align:center}.section-title{margin:0 0 14px;font-size:20px}.donate-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;text-align:center;margin-bottom:18px}.venmo-card,.check-card{border:1px dashed var(--border);border-radius:var(--radius);padding:16px}.venmo-qr{width:180px;height:180px;object-fit:contain;border-radius:12px;background:#fff}.venmo-handle{color:var(--brand);font-weight:700;margin:8px 0 4px}.venmo-tip,.check-card p{color:var(--ink-soft);margin:6px 0 0;font-size:14px}.donor-list{background:var(--surface);border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow-sm)}.donor-list.empty{text-align:center}.donor-list ul{list-style:none;padding:0;margin:0}.donor-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}.donor-row:last-child{border-bottom:none}.donor-info{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.donor-name{font-weight:600}.donor-method{background:#f1eaff;color:var(--brand);padding:1px 8px;border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.donor-verified{color:var(--success);font-size:13px;font-weight:600}.donor-pending{color:var(--ink-soft);font-size:13px}.donor-actions{display:flex;gap:10px;align-items:center}.donor-amount{font-weight:700;font-size:16px}.donor-mod{display:flex;gap:6px}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:100}.confetti-piece{position:absolute;top:-20px;display:block;border-radius:2px;animation:confetti-fall linear forwards}@keyframes confetti-fall{to{transform:translateY(110vh) rotate(720deg);opacity:.5}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f163373;display:flex;align-items:center;justify-content:center;padding:16px;z-index:200}.modal{background:var(--surface);border-radius:var(--radius);padding:22px;max-width:420px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md)}.modal h3{margin:0 0 4px}.modal-sub{color:var(--ink-soft);margin:0 0 16px;font-size:14px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.field{display:block;margin-bottom:14px}.field>span{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:4px}.field input,.field select,.field textarea,.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:15px;color:var(--ink);font-family:inherit}.field input:focus,.field select:focus,.field textarea:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #7c3aed2e}.amount-input{display:flex;align-items:center;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff}.amount-prefix{padding:0 10px;color:var(--ink-soft);background:#fbf8ff;align-self:stretch;display:flex;align-items:center;font-weight:600}.amount-input input{border:none!important;box-shadow:none!important}.check-field{display:flex!important;align-items:center;gap:8px}.check-field input{width:auto}.check-field>span{margin:0}.error-banner{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;padding:10px 12px;border-radius:10px;font-size:14px;margin:6px 0 10px}.chairman-login{display:flex;justify-content:center;padding-top:24px}.auth-card{background:var(--surface);border-radius:var(--radius);padding:28px;width:100%;max-width:380px;box-shadow:var(--shadow-sm)}.auth-card h1{margin:0 0 6px;font-size:22px}.auth-card .muted{color:var(--ink-soft);margin:0 0 18px;font-size:14px}.chairman-dashboard{display:flex;flex-direction:column;gap:20px}.page-header{display:flex;justify-content:space-between;align-items:center}.page-header h1{margin:0;font-size:26px}.card{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}.card h2{margin:0 0 14px;font-size:18px}.card h3{margin:14px 0 6px;font-size:16px}.form-card{padding:20px}.form-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin-bottom:10px}.form-group{display:flex;flex-direction:column;gap:4px;min-width:160px}.form-group label{font-size:13px;font-weight:600;color:var(--ink-soft)}.form-group.grow{flex:1;min-width:200px}.form-group.icon-col{min-width:0}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.event-table{width:100%;border-collapse:collapse}.event-table th,.event-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--border);font-size:14px}.event-table th{color:var(--ink-soft);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.event-table tr:last-child td{border-bottom:none}.event-table .td-icon{font-size:22px;width:40px}.event-table .td-due{white-space:nowrap;color:var(--ink-soft)}.event-table .td-due.urgent{color:var(--warn);font-weight:600}.event-table .td-due.overdue{color:var(--danger);font-weight:700}.event-table .td-actions{display:flex;gap:6px;justify-content:flex-end}.event-table a{color:var(--brand);font-weight:600;text-decoration:none}.event-table a:hover{text-decoration:underline}.status-pill{padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize}.status-pill.open{background:#dcfce7;color:#166534}.status-pill.closed{background:#f1eaff;color:var(--brand)}.icon-picker{position:relative}.icon-picker-current{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:#fbf8ff;border:1px solid var(--border);border-radius:10px;cursor:pointer}.icon-display{font-size:28px;line-height:1}.icon-picker-hint{font-size:12px;color:var(--ink-soft)}.icon-picker-grid{position:absolute;top:calc(100% + 6px);left:0;z-index:60;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px;display:grid;grid-template-columns:repeat(8,1fr);gap:4px;box-shadow:var(--shadow-md);width:min(360px,90vw);max-height:280px;overflow-y:auto}.icon-picker-cell{background:none;border:none;font-size:22px;width:36px;height:36px;border-radius:8px;cursor:pointer;line-height:1}.icon-picker-cell:hover{background:#fbf8ff}.icon-picker-cell.active{background:#f1eaff;outline:2px solid var(--brand)}.pending-panel{border-left:4px solid var(--warn)}.pending-header h2{display:flex;align-items:center;gap:10px;margin:0}.pending-count{background:var(--warn);color:#fff;font-size:12px;font-weight:700;padding:2px 9px;border-radius:999px;letter-spacing:.5px}.pending-header .muted{margin:4px 0 14px;font-size:14px}.pending-list{list-style:none;padding:0;margin:0}.pending-row{display:grid;grid-template-columns:minmax(160px,1.4fr) minmax(140px,1fr) auto auto auto;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.pending-row:last-child{border-bottom:none}.pending-event{display:flex;align-items:center;gap:8px;min-width:0}.pending-icon{font-size:22px}.pending-event-name{color:var(--ink);text-decoration:none;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pending-event-name:hover{color:var(--brand)}.pending-donor{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}.pending-name{font-weight:600}.pending-amount{font-weight:700;font-size:16px;text-align:right}.pending-when{color:var(--ink-soft);font-size:13px;text-align:right}.pending-actions{display:flex;gap:6px}@media (max-width: 720px){.pending-row{grid-template-columns:1fr auto;grid-template-areas:"event amount" "donor when" "actions actions"}.pending-event{grid-area:event}.pending-donor{grid-area:donor}.pending-amount{grid-area:amount}.pending-when{grid-area:when}.pending-actions{grid-area:actions;justify-content:flex-end}}.qr-preview{display:flex;gap:16px;align-items:center;margin-top:8px;flex-wrap:wrap}.qr-preview img{width:160px;height:160px;border-radius:12px;border:1px solid var(--border);object-fit:contain;background:#fff}.qr-actions{display:flex;flex-direction:column;gap:8px}.qr-section .btn input[type=file]{display:none}.muted{color:var(--ink-soft)}.page-loading{text-align:center;padding:60px 0;color:var(--ink-soft)}.empty-state{text-align:center;padding:60px 20px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.empty-state .empty-icon{font-size:48px}.empty-state h2{margin:12px 0 4px}.empty-state p{color:var(--ink-soft);margin:0}
