:root{--bg: #f7f8fb;--text: #0f172a;--muted: #6b7280}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text)}.app-root{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;background:#1f2937;color:#fff;padding:16px;border-bottom:1px solid rgba(255,255,255,.06)}.app-header h1{font-size:1.125rem;margin:0;font-weight:600}.header-left{display:flex;align-items:center;gap:12px}.brand-logo{width:40px;height:40px;object-fit:cover;border-radius:6px}.brand-link{display:inline-flex;align-items:center;text-decoration:none;color:inherit}.brand-link:focus-visible{outline:2px solid rgba(255,255,255,.8);outline-offset:2px;border-radius:6px}.header-right{display:flex;align-items:center;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#02061780;display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}.modal-panel{width:100%;max-width:900px;max-height:90vh;background:#fff;border-radius:10px;box-shadow:0 12px 40px #02061766;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:16px 20px;border-bottom:1px solid #eef2f7}.modal-header h3{margin:0}.modal-body{padding:12px 16px;display:flex;flex-direction:column;gap:12px;overflow:auto}.modal-field{display:flex;flex-direction:column}.modal-label{font-size:.85rem;color:var(--muted);margin-bottom:6px}.modal-field input,.modal-field textarea,.modal-field select{padding:8px 10px;border:1px solid #e6eef7;border-radius:8px;font-size:.95rem;width:100%;background:#f0f2f5}.modal-field input:focus,.modal-field textarea:focus,.modal-field select:focus{background:#fff;outline:2px solid rgba(37,99,235,.15);border-color:#2563eb}.modal-row{display:flex;gap:12px}.modal-row .modal-field{flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid #eef2f7}.btn{background:transparent;border:1px solid rgba(15,23,42,.08);padding:8px 12px;border-radius:8px;cursor:pointer}.btn[disabled]{opacity:.5;cursor:not-allowed}.btn-primary{background:#2563eb;color:#fff;border-color:transparent}.events-section h3{margin-top:0}.event-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}@media (min-width:1000px){.event-list .event-card{max-width:900px;margin-left:auto;margin-right:auto;width:100%}}.event-card{display:flex;align-items:stretch;background:#fff;padding:0;border-radius:10px;box-shadow:0 4px 8px #0f172a0f;border:1px solid #eef2f7;overflow:hidden;margin-bottom:10px}.event-card{position:relative}.type-stripe{width:0;flex:0 0 0;display:none}.event-card-content{display:flex;flex-direction:column;padding:0;flex:1;gap:12px}.event-inner{display:flex;gap:12px;align-items:stretch}.date-column{width:clamp(120px,12ch,180px);min-width:calc(12ch + 24px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px}.date-column{border-radius:10px 0 0 10px}.date-day{font-size:1rem;font-weight:700;color:#000;line-height:1}.date-month-day{font-size:.85rem;color:#000;margin-top:6px}.content-column{flex:1;display:flex;flex-direction:column;gap:12px;padding-left:16px}.event-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.event-card-left{flex:1;min-width:0}.event-card-left h4{margin:8px 0 6px;font-size:1rem}.event-link{color:inherit;text-decoration:none;transition:color .12s ease}.event-link:visited{color:inherit}.event-link:hover{text-decoration:none;color:#0b3d91}.date-time{color:var(--text);font-weight:400;font-size:.85rem;margin-top:6px}.event-meta{font-size:.9rem;color:var(--muted)}.event-type-badge{display:inline-flex;align-items:center;margin-top:0;padding:6px 10px;border-radius:999px;background:#0f172a0f;color:var(--muted);font-size:.9rem;font-weight:600}.event-location-inline{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#0f172a08;color:var(--muted);font-size:.9rem;font-weight:500}.required-bubble{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#fff4e6;color:#92400e;font-size:.78rem;font-weight:600;margin-left:6px;text-transform:lowercase}.required-bubble:empty{display:none}.event-attendee-summary{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#0f172a08;color:var(--muted);font-size:.9rem;font-weight:600}.event-attendee-summary svg{width:16px;height:16px;display:block}.event-attendee-summary .attendee-count{font-weight:600}.event-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid #f1f5f9;padding-top:12px}.footer-left{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.95rem;flex-wrap:wrap}.footer-right{display:flex;align-items:center;gap:12px}.attendance-btn{border:1px solid rgba(15,23,42,.06);background:transparent;padding:6px 10px;border-radius:8px;cursor:pointer;font-weight:600;color:var(--muted);min-width:48px}.attendance-btn.skeleton{background:linear-gradient(90deg,#0f172a08,#0f172a03);color:#0f172a80}.attendance-icons{display:flex;align-items:center;gap:8px;margin-left:12px;padding:6px 8px;margin-right:8px;border-radius:8px}.attendance-icon-btn{width:28px;height:28px;border-radius:6px;border:none;background:#0206170a;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:all .15s ease}.attendance-icon-btn:hover{background:#0206170f;opacity:.95}.attendance-icon-btn:disabled{opacity:.4;cursor:not-allowed}.attendance-icon-btn svg{display:block;width:20px;height:20px}.attendance-icons.full{display:flex}.attendance-icons-compact{display:none;position:relative}.attendance-icon-btn.small{width:28px;height:28px;padding:4px}.attendance-icon-btn.small svg{width:20px;height:20px}.overflow-menu{position:absolute;right:0;top:40px;background:#fff;border:1px solid #eef2f7;box-shadow:0 8px 24px #02061714;border-radius:8px;padding:6px;z-index:40}.overflow-items{display:flex;gap:6px;align-items:center}.overflow-menu .attendance-icon-btn{width:34px;height:34px;border-radius:6px}.attendance-icons-compact .overflow-btn.attendance-yes{border:2.5px solid rgba(22,163,74,.5);color:#16a34a;background:#16a34a14}.attendance-icons-compact .overflow-btn.attendance-yes svg{stroke:currentColor}.attendance-icons-compact .overflow-btn.attendance-maybe{border:2.5px solid rgba(17,24,39,.35);color:#111827;background:#1118270d}.attendance-icons-compact .overflow-btn.attendance-maybe svg{stroke:currentColor}.attendance-icons-compact .overflow-btn.attendance-no{border:2.5px solid rgba(239,68,68,.5);color:#ef4444;background:#ef44440f}.attendance-icons-compact .overflow-btn.attendance-no svg{stroke:currentColor}.attendance-icons-compact .overflow-btn{box-sizing:border-box;padding:0}.attendance-icons-compact .overflow-btn svg{width:18px;height:18px}.attendance-yes{color:#16a34a}.attendance-maybe{color:#111827}.attendance-no{color:#ef4444}.edit-btn{color:#2563eb}.share-btn{color:#8b5cf6}.title-share-btn{background:transparent;border:none;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:6px;cursor:pointer}.title-share-btn svg{width:16px;height:16px}.title-share-btn:hover{color:var(--text)}.title-cal-btn{background:transparent;border:none;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:6px;cursor:pointer;margin-left:0}.title-cal-btn svg{width:16px;height:16px}.title-cal-btn:hover{background:transparent;color:var(--text)}.gcal-btn{color:#ea4335}.gcal-btn:hover{background:#ea433514;color:#c5221f}.attendance-icon-btn.active{background:currentColor;border:2px solid currentColor}.attendance-icon-btn.active svg{stroke:#fff}.attendance-icon-btn.active svg path{stroke:#fff}.attendance-icon-btn:focus-visible{outline:2px solid rgba(37,99,235,.15);outline-offset:2px}.event-card-right{margin-left:16px;display:flex;align-items:center}.attendance-buttons{display:flex;gap:8px}.attendance-btn{border:1px solid rgba(15,23,42,.08);background:transparent;padding:8px 10px;border-radius:8px;cursor:pointer;font-weight:600;color:var(--muted);min-width:56px}.attendance-btn:hover{opacity:.95}.attendee-note{font-size:.85em;color:#6b7280;margin-left:4px}.attendance-btn.skeleton{background:linear-gradient(90deg,#0f172a0a,#0f172a05);color:#0f172a66}@media (max-width:900px){.date-column{width:clamp(110px,12ch,160px)}}@media (max-width:600px){.event-card{flex-direction:column;align-items:stretch;padding:0;margin-bottom:10px}.event-card-content{flex-direction:column;align-items:stretch;padding:0}.event-inner{flex-direction:column;gap:0}.date-column{width:100%;flex-direction:row;align-items:center;justify-content:flex-start;padding:6px 8px;border-radius:10px 10px 0 0}.date-day{font-size:.9rem;font-weight:700}.date-month-day{font-size:.85rem;margin-left:8px;margin-top:0}.date-column .date-time{margin-left:8px;margin-top:0;font-size:.85rem;font-weight:400}.content-column{padding-left:8px;padding-right:8px;padding-top:6px;gap:8px}.event-card-left h4{margin:4px 0;font-size:.95rem}.event-card-right{margin-left:0;margin-top:8px;display:flex;justify-content:flex-end}.event-footer{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding-top:8px;padding-bottom:8px}.footer-left{order:1;flex:1;display:flex;align-items:center;gap:8px;min-width:0}.footer-right{order:2;display:flex;align-items:center;gap:8px}.event-list{gap:8px}.attendance-icons{margin-left:8px;gap:6px;padding:4px 6px;margin-right:6px;border-radius:6px}.attendance-icons.full{display:none}.attendance-icons-compact{display:flex}.event-details.open{padding:8px}}@media (max-width:480px){.app-header{flex-direction:column;align-items:flex-start;gap:8px;padding:12px}.header-left{gap:8px}.brand-logo{width:36px;height:36px}.app-header h1{font-size:1rem}.header-right{align-self:flex-end;gap:6px}}@media (max-width:700px){.modal-panel{max-width:100%;border-radius:8px}.modal-body{padding:12px}.modal-row{flex-direction:column}}@media (max-width:420px){.modal-panel{height:100%;max-height:100%;border-radius:0}.modal-header{padding:12px}.modal-footer{padding:10px}}.expand-btn{display:inline-flex;align-items:center;justify-content:center;border:none;background:#0206170a;padding:0;border-radius:6px;cursor:pointer;color:var(--muted);margin-left:8px;margin-right:8px;width:28px;height:28px}.expand-btn:hover{background:#0206170f;opacity:.98}.expand-btn:focus-visible{outline:2px solid rgba(37,99,235,.15);outline-offset:2px}.expand-btn svg{transition:transform .18s ease;width:20px;height:20px}.expand-btn.open svg{transform:rotate(180deg)}.event-details{max-height:0;overflow:hidden;transition:max-height .2s ease;padding:0 16px}.event-details.open{max-height:none;overflow:visible;padding:12px 16px 16px;background:#fafafa;border-top:1px solid #f1f5f9}.attendee-table{width:100%;border-collapse:collapse}.attendee-table td{padding:8px 12px;border-bottom:1px solid rgba(15,23,42,.03);font-size:.95rem}.attendee-table tr:last-child td{border-bottom:none}.attendee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin-top:8px}.attendee-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#0f172a05;border-radius:6px;font-size:.9rem}.attendee-icon{font-weight:700;font-size:1rem;flex-shrink:0}.attendee-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:600px){.attendee-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}.attendee-item{padding:5px 8px;font-size:.85rem}}.event-details .event-desc{margin:0 0 10px;color:var(--muted);font-size:.95rem}.event-card,.event-desc,.markdown-preview{overflow-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.event-desc img,.markdown-preview img{max-width:100%;height:auto;display:block}.markdown-preview{font-size:.95rem}.markdown-preview p,.event-desc p{margin:0 0 8px;color:var(--text)}.markdown-preview code,.event-desc code{background:#0f172a0a;padding:2px 6px;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Roboto Mono,Courier New,monospace}.markdown-preview pre,.event-desc pre{background:#0f172a10;padding:8px;border-radius:8px;overflow:auto}.markdown-preview a,.event-desc a{color:#2563eb}.md-toggle{display:inline-flex;border:1px solid #e6eef7;border-radius:8px;overflow:hidden;margin:6px 0 8px}.md-btn{background:transparent;border:0;padding:6px 10px;font-size:.9rem;cursor:pointer;color:var(--muted)}.md-btn.active{background:#2563eb;color:#fff}.md-btn:focus{outline:2px solid rgba(37,99,235,.2);outline-offset:2px}.app-main{flex:1;padding:12px 24px;max-width:100%;width:100%;margin:0 auto}.app-footer{padding:12px;text-align:center;color:var(--muted);font-size:.9rem}.hello{background:#fff;padding:12px;border-radius:8px;border:1px solid #eef2f7}.event-page-container{max-width:900px;margin:0 auto;padding:2rem 1rem}@media (max-width:700px){.event-page-container{max-width:100%;padding:1rem}}@media (max-width:600px){.event-page-container{padding:0 8px}.event-page-container .event-card{border-radius:10px;margin:0 0 10px;width:100%;box-shadow:0 4px 8px #0f172a0f}.event-page-container .event-card .date-column{border-radius:10px 10px 0 0}.event-page-container .event-card .event-card-content{padding:0}}.home-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.events-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.events-controls .search-input{flex:1;min-width:200px}.group-by-control{display:flex;align-items:center;gap:6px;white-space:nowrap}.group-by-control label{font-size:.82rem;color:var(--muted);margin:0}.group-by-control select{padding:6px 8px;border:1px solid #e6eef7;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}.group-by-control select:focus{outline:2px solid rgba(37,99,235,.12)}.group-by-control input{padding:6px 8px;border:1px solid #e6eef7;border-radius:6px;font-size:.9rem;background:#fff}.group-by-control input:focus{outline:2px solid rgba(37,99,235,.12);background:#fff}.group-by-control input{padding:8px 10px;border:1px solid #e6eef7;border-radius:8px;font-size:.95rem;background:#fff}.group-by-control input:focus{outline:2px solid rgba(37,99,235,.15);background:#fff}.group-label{margin:8px 0 6px;font-size:.95rem;color:var(--muted);font-weight:600}.event-section-group{display:flex;flex-direction:column;gap:8px}.group-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 4px}.group-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:none;background:transparent;color:var(--muted);cursor:pointer}.group-toggle svg{transition:transform .18s ease}.group-header.collapsed .group-toggle svg{transform:rotate(-90deg)}.group-header .group-label{margin:0;font-size:.95rem;color:var(--muted);font-weight:600}.search-input{padding:8px 10px;border:1px solid #e6eef7;border-radius:8px;font-size:.95rem;min-width:0;width:auto;max-width:100%}.search-input:focus{outline:2px solid rgba(37,99,235,.15)}.icon-button{display:inline-flex;align-items:center;justify-content:center;background:var(--text);color:var(--bg);border:none;padding:8px;border-radius:8px;cursor:pointer;width:40px;height:40px}.icon-button:hover{opacity:.9}.icon-button:active{transform:scale(.98)}.icon-button svg{display:block}.app-header .icon-button{width:36px;height:36px;border-radius:6px}.icon-button.filter-btn{background:transparent;color:#0f172a73;border:1px solid rgba(15,23,42,.04)}.icon-button.filter-btn:hover{color:#0f172aa6;background:#0f172a05}.icon-button.filter-btn.active{background:transparent;color:#2563ebd9;border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb0f}.icon-button.filter-btn.active svg{stroke:currentColor;fill:transparent}.icon-button.filter-btn.active:hover{opacity:.98}.user-indicator{background:#f7f8fb;border-bottom:1px solid #e6eef7;padding:8px 16px;display:flex;justify-content:flex-end;align-items:center;gap:8px}.user-indicator-label{font-size:.85rem;color:var(--muted);font-weight:500}.user-indicator-name{font-size:.85rem;color:var(--text);font-weight:600}.section-header{font-weight:600;font-size:.92rem;color:#111827;margin-top:12px;margin-bottom:8px;font-style:normal;border-bottom:1px solid #eef2f7;padding-bottom:8px}.subsection-header{display:none}
