*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #2d7a3a;--green-dark: #1e5829;--green-light: #e8f5eb;--red: #c0392b;--red-light: #fdecea;--blue: #2563eb;--text: #1a1a2e;--text-muted: #6b7280;--border: #e5e7eb;--bg: #f9fafb;--white: #ffffff;--radius: 10px;--shadow: 0 2px 12px rgba(0,0,0,.08)}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6}.navbar{display:flex;flex-wrap:wrap;align-items:center;padding:.75rem 2rem;background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 1px 4px #0000000f}.navbar-top{display:flex;align-items:center;flex:1;min-width:0}.navbar-brand{font-size:1.2rem;font-weight:700;color:var(--green)}.navbar-hamburger{display:none;align-items:center;justify-content:center;margin-left:auto;background:none;border:1.5px solid var(--border);border-radius:6px;padding:.3rem .65rem;font-size:1.2rem;line-height:1;cursor:pointer;color:var(--text);transition:background .15s}.navbar-hamburger:hover{background:var(--bg)}.navbar-collapse{display:flex;align-items:center;gap:1.5rem}.navbar-links{display:flex;gap:1rem}.nav-link{text-decoration:none;color:var(--text-muted);font-weight:500;padding:.3rem .7rem;border-radius:6px;transition:color .15s,background .15s}.nav-link:hover{color:var(--green);background:var(--green-light)}.nav-link.active{color:var(--green);font-weight:600}.navbar-user{display:flex;align-items:center;gap:.75rem;margin-left:1rem}.navbar-username{font-size:.875rem;color:var(--text-muted)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d4edda,#f9fafb 60%);padding:2rem}.auth-card{background:var(--white);border-radius:var(--radius);padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:var(--shadow);border:1px solid var(--border)}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon{font-size:2.5rem;display:block;margin-bottom:.5rem}.auth-header h1{font-size:1.6rem;color:var(--green);margin-bottom:.25rem}.auth-header p{color:var(--text-muted);font-size:.9rem}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-muted)}.auth-footer a{color:var(--green);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;color:var(--text)}.page-header p{color:var(--text-muted);margin-top:.25rem}.two-column{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:768px){.navbar{padding:.75rem 1rem;gap:0}.navbar-top{flex:0 0 100%}.navbar-hamburger{display:flex}.navbar-collapse{display:none;flex-direction:column;align-items:stretch;width:100%;border-top:1px solid var(--border);margin-top:.5rem;padding-top:.5rem;gap:.1rem}.navbar-collapse--open{display:flex}.navbar-links{flex-direction:column;gap:.1rem}.nav-link{padding:.75rem .9rem;font-size:1rem;border-radius:7px}.navbar-user{flex-wrap:wrap;margin-left:0;padding:.6rem .5rem .3rem;border-top:1px solid var(--border);margin-top:.25rem;gap:.5rem}.navbar-username{display:block;order:-1;flex:1 1 100%;font-weight:600;color:var(--text)}.two-column{grid-template-columns:1fr}.page{padding:1.25rem 1rem}.card{padding:1.25rem}.page-header h1{font-size:1.4rem}.event-form-card{padding:1.1rem}.form-row--name-date{grid-template-columns:1fr}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{min-width:480px}}.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:1.75rem;box-shadow:var(--shadow)}.card h2{font-size:1.1rem;font-weight:700;margin-bottom:.25rem}.card-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:1.5rem}.form{display:flex;flex-direction:column;gap:1.1rem}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row--name-date{grid-template-columns:2fr 1fr}@media(max-width:480px){.form-row{grid-template-columns:1fr}.auth-card{padding:1.5rem 1.1rem}.events-grid{grid-template-columns:1fr;gap:1rem}.admin-detail-row{flex-wrap:wrap;gap:.2rem}}input,select{padding:.6rem .85rem;border:1.5px solid var(--border);border-radius:7px;font-size:.95rem;background:var(--white);color:var(--text);transition:border-color .15s;width:100%;outline:none}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem;cursor:pointer}input:focus,select:focus{border-color:var(--green);box-shadow:0 0 0 3px #2d7a3a1f}input.input-disabled,input:disabled,select:disabled{background:var(--bg);color:var(--text-muted);cursor:not-allowed}.form-hint{font-size:.78rem;color:var(--text-muted)}.field-error{font-size:.78rem;color:#e53e3e;margin-top:.2rem;display:block}input.input-error,textarea.input-error{border-color:#e53e3e!important;outline-color:#e53e3e}.maps-link{color:var(--color-primary, #2d7a2d);text-decoration:none}.maps-link:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;border:none;border-radius:7px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;text-decoration:none}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover:not(:disabled){background:var(--green-dark)}.btn-outline{background:transparent;color:var(--green);border:1.5px solid var(--green)}.btn-outline:hover:not(:disabled){background:var(--green-light)}.btn-outline-danger{background:transparent;color:var(--red);border:1.5px solid var(--red)}.btn-outline-danger:hover:not(:disabled){background:var(--red-light)}.btn-full{width:100%}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.alert{padding:.6rem .9rem;border-radius:7px;font-size:.875rem;font-weight:500}.alert-error{background:var(--red-light);color:var(--red)}.alert-success{background:var(--green-light);color:var(--green)}.events-past-section{margin-top:2.5rem}.events-past-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;border-top:2px solid var(--border);padding:1rem 0;cursor:pointer;font-size:1rem;font-weight:600;color:var(--text-muted);gap:.5rem;transition:color .15s}.events-past-toggle:hover{color:var(--text)}.events-past-chevron{font-size:1.25rem;line-height:1;transition:transform .2s ease;display:inline-block}.events-past-chevron--open{transform:rotate(180deg)}.events-grid--past{margin-top:1rem;opacity:.8}.events-grid--past .event-card{border-style:dashed}.events-past-sentinel{height:1px}.events-past-loading,.events-past-end{text-align:center;padding:1.25rem 0;color:var(--text-muted);font-size:.9rem}.events-year-divider{grid-column:1 / -1;display:flex;align-items:center;gap:.75rem;margin:.75rem 0 .25rem}.events-year-divider:first-child{margin-top:0}.events-year-divider:before,.events-year-divider:after{content:"";flex:1;height:1px;background:var(--border)}.events-year-divider span{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.event-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .15s,border-color .15s;position:relative;overflow:hidden}.event-card:hover{box-shadow:0 6px 20px #0000001a}.event-card--registered{border-color:var(--green)}.event-badge{background:var(--green);color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.3rem .85rem}.event-card-body{padding:1.25rem 1.25rem .75rem;flex:1}.event-name{font-size:1.05rem;font-weight:700;margin-bottom:.75rem}.event-meta{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem}.event-meta-item{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.meta-icon{flex-shrink:0;width:1.2em}.event-description{font-size:.85rem;color:var(--text-muted);line-height:1.5}.event-card-footer{padding:.75rem 1.25rem 1.25rem}.loading{text-align:center;padding:4rem;color:var(--text-muted);font-size:1rem}.empty-state{text-align:center;padding:5rem 2rem;color:var(--text-muted)}.empty-state span{font-size:3rem;display:block;margin-bottom:1rem}.role-badge{display:inline-block;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.role-badge--admin{background:#fef3c7;color:#92400e}.role-badge--manager{background:#dbeafe;color:#1e40af}.role-badge--user{background:var(--green-light);color:var(--green-dark)}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{text-align:left;padding:.75rem 1.25rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border)}.admin-table td{padding:.85rem 1.25rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table-row{cursor:pointer;transition:background .12s}.admin-table-row:hover{background:var(--green-light)}.admin-table-name{font-weight:600}.admin-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.admin-detail-row:last-child{border-bottom:none}.admin-detail-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.event-card-body--clickable{cursor:pointer}.event-card-body--clickable:hover .event-name{color:var(--green)}.event-form-card{background:var(--white);border:1.5px solid var(--green);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem}.confirm-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200}.confirm-box{background:var(--white);border-radius:var(--radius);padding:2rem;max-width:360px;width:90%;box-shadow:0 8px 32px #0000002e}.confirm-box h3{margin-bottom:.5rem}.confirm-box p{color:var(--text-muted);font-size:.9rem}
