﻿:root{--space-xs: 0.25rem;--space-sm: 0.5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--font-heading: 'Space Grotesk', ui-sans-serif, system-ui, sans-serif;--font-body: system-ui, -apple-system, 'Segoe UI', sans-serif;--radius: 8px;--border-w-thin: 1px;--border-w-thick: 1px;--border-w-accent: 2px;--shadow-sm: 0 1px 3px;--shadow-md: 0 4px 12px;--shadow-lg: 0 8px 24px;--hover-x: 0;--hover-y: -2px;--press-x: 0;--press-y: 0;--text-transform-ui: none;--ls-display: -0.02em;--ls-heading: -0.01em;--ls-label: 0.02em;--ls-button: 0.02em;--accent: light-dark(#059669, #10b981);--accent-hover: light-dark(#047857, #34d399);--accent-muted: light-dark(#d1fae5, #064e3b);--accent-contrast: light-dark(#ffffff, #021a0f);--color-text-primary: light-dark(#1a1a1a, #efefef);--color-text-secondary: light-dark(#555, #aaa);--color-text-muted: light-dark(#888, #666);--color-bg: light-dark(#f5f0eb, #0a0a0a);--color-bg-panel: light-dark(#ffffff, #141414);--color-bg-raised: light-dark(#ececec, #1e1e1e);--color-border: light-dark(#e0e0e0, #2e2e2e);--color-border-subtle: light-dark(#f0f0f0, #222);--shadow-color: light-dark(rgba(0,0,0,0.1), rgba(0,0,0,0.3));--color-success: light-dark(#16a34a, #4ade80);--color-warning: light-dark(#d97706, #fbbf24);--color-danger: light-dark(#dc2626, #f87171)}[data-theme=retro]{--border-w-thin: 2px;--border-w-thick: 3px;--border-w-accent: 4px;--radius: 0;--shadow-sm: 3px 3px 0;--shadow-md: 5px 5px 0;--shadow-lg: 8px 8px 0;--shadow-color: light-dark(#0a0a0a, #888888);--hover-x: -2px;--hover-y: -2px;--press-x: 2px;--press-y: 2px;--text-transform-ui: uppercase;--ls-display: -0.04em;--ls-heading: -0.02em;--ls-label: 0.1em;--ls-button: 0.05em;--color-border: light-dark(#1a1a1a, #2e2e2e);--color-border-subtle: light-dark(#d5d0cb, #222)}[data-accent=emerald]{--accent: light-dark(#059669, #10b981);--accent-hover: light-dark(#047857, #34d399);--accent-muted: light-dark(#d1fae5, #064e3b);--accent-contrast: light-dark(#ffffff, #021a0f)}[data-accent=grey]{--accent: light-dark(#6b7280, #9ca3af);--accent-hover: light-dark(#4b5563, #b0b7c3);--accent-muted: light-dark(#f3f4f6, #1f2937);--accent-contrast: light-dark(#ffffff, #0f1623)}[data-accent=blue]{--accent: light-dark(#2563eb, #60a5fa);--accent-hover: light-dark(#1d4ed8, #93bbfd);--accent-muted: light-dark(#dbeafe, #1e3a5f);--accent-contrast: light-dark(#ffffff, #0a1628)}[data-accent=violet]{--accent: light-dark(#7c3aed, #a78bfa);--accent-hover: light-dark(#6d28d9, #c4b5fd);--accent-muted: light-dark(#ede9fe, #2e1065);--accent-contrast: light-dark(#ffffff, #120a2e)}[data-accent=rose]{--accent: light-dark(#e11d48, #fb7185);--accent-hover: light-dark(#be123c, #fda4af);--accent-muted: light-dark(#ffe4e6, #4c0519);--accent-contrast: light-dark(#ffffff, #1a0008)}[data-accent=amber]{--accent: light-dark(#d97706, #fbbf24);--accent-hover: light-dark(#b45309, #fcd34d);--accent-muted: light-dark(#fef3c7, #451a03);--accent-contrast: light-dark(#ffffff, #1a0e00)}[data-accent=slate]{--accent: light-dark(#475569, #94a3b8);--accent-hover: light-dark(#334155, #b0bec5);--accent-muted: light-dark(#e2e8f0, #1e293b);--accent-contrast: light-dark(#ffffff, #0f172a)}/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:rgba(0,0,0,0)}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}*,*::before,*::after{box-sizing:border-box}*:not(dialog){margin:0}@media(prefers-reduced-motion: no-preference){html{interpolate-size:allow-keywords}}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}p{text-wrap:pretty}h1,h2,h3,h4,h5,h6{text-wrap:balance}#root,#__next{isolation:isolate}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.1;letter-spacing:var(--ls-heading)}.heading-display{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.05;letter-spacing:var(--ls-display)}.heading-1{font-family:var(--font-heading);font-size:clamp(1.8rem,3vw,2.369rem);font-weight:700;letter-spacing:-0.03em}.label-text{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label)}:root{color-scheme:light dark}html{font-family:var(--font-body)}body{color:var(--color-text-primary);background:var(--color-bg)}::selection{background:var(--accent);color:var(--accent-contrast)}a{color:inherit}.flex-row{display:flex;flex-direction:row;flex-wrap:wrap}.btn{font-family:var(--font-heading);font-size:.875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-button);padding:var(--space-sm) var(--space-lg);border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-sm);text-decoration:none;transition:transform .1s ease,box-shadow .1s ease}.btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.btn--primary{background:var(--accent);color:var(--accent-contrast);box-shadow:var(--shadow-sm) var(--shadow-color)}.btn--primary:hover{background:var(--accent-hover);transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-md) var(--shadow-color)}.btn--primary:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.btn--secondary{background:var(--color-bg-panel);color:var(--color-text-primary);box-shadow:var(--shadow-sm) var(--shadow-color)}.btn--secondary:hover{transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-md) var(--shadow-color)}.btn--secondary:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.btn--danger{background:var(--color-danger);color:#fff;box-shadow:var(--shadow-sm) var(--shadow-color)}.btn--danger:hover{transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-md) var(--shadow-color)}.btn--danger:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.btn--ghost{background:rgba(0,0,0,0);border-color:rgba(0,0,0,0);color:var(--color-text-primary)}.btn--ghost:hover{border-color:var(--color-border)}.btn--ghost-danger,.btn--ghost-warning,.btn--ghost-success{background:rgba(0,0,0,0);border-color:rgba(0,0,0,0);color:var(--color-text-primary)}.btn--ghost-success:hover{border-color:var(--color-success);color:var(--color-success)}.btn--ghost-warning:hover{border-color:var(--color-warning);color:var(--color-warning)}.btn--ghost-danger:hover{border-color:var(--color-danger);color:var(--color-danger)}.btn--sm{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}.form-label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-secondary);display:block;margin-bottom:var(--space-xs)}input[type=text],input[type=email],input[type=password],input[type=url],input[type=date],input[type=time],input[type=datetime-local],input[type=number],textarea,select{font-family:var(--font-body);font-size:1rem;color:var(--color-text-primary);background:var(--color-bg-panel);border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);padding:var(--space-sm) var(--space-md);width:100%;transition:box-shadow .15s ease}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=url]:focus,input[type=date]:focus,input[type=time]:focus,input[type=datetime-local]:focus,input[type=number]:focus,textarea:focus,select:focus{outline:none;box-shadow:var(--shadow-sm) var(--accent)}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=url]::placeholder,input[type=date]::placeholder,input[type=time]::placeholder,input[type=datetime-local]::placeholder,input[type=number]::placeholder,textarea::placeholder,select::placeholder{color:var(--color-text-muted)}textarea{min-height:6rem;resize:vertical}select{appearance:none;background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:var(--space-2xl)}input[type=checkbox]{accent-color:var(--accent)}.card{border:var(--border-w-thin) solid var(--color-border);box-shadow:var(--shadow-md) var(--shadow-color);border-radius:var(--radius);background:var(--color-bg-panel);padding:var(--space-lg)}.card--interactive{border:var(--border-w-thin) solid var(--color-border);box-shadow:var(--shadow-md) var(--shadow-color);border-radius:var(--radius);background:var(--color-bg-panel);padding:var(--space-lg);transition:transform .1s ease,box-shadow .1s ease}.card--interactive:hover{transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-lg) var(--shadow-color)}.card--interactive:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.badge--muted,.badge--danger,.badge--warning,.badge--success,.badge--accent{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-button);padding:var(--space-xs) var(--space-sm);border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);display:inline-block}.badge--accent{background:var(--accent-muted);color:var(--accent)}.badge--success{background:light-dark(#dcfce7, #052e16);color:var(--color-success);border-color:var(--color-success)}.badge--warning{background:light-dark(#fef3c7, #451a03);color:var(--color-warning);border-color:var(--color-warning)}.badge--danger{background:light-dark(#fee2e2, #450a0a);color:var(--color-danger);border-color:var(--color-danger)}.badge--muted{background:var(--color-bg-raised);color:var(--color-text-muted)}.pagination{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-lg)}.pagination__info{font-size:.875rem;color:var(--color-text-muted);flex:1;text-align:center}.pagination__btn--disabled{opacity:.35;pointer-events:none;cursor:default}body{margin:0 auto;max-width:1280px;width:auto;padding:0 var(--space-sm)}@media(min-width: 768px){body{padding:0 var(--space-lg)}}header{background:var(--color-bg-panel);border:var(--border-w-thin) solid var(--color-border);border-top:none;border-bottom:var(--border-w-accent) solid var(--accent);padding:var(--space-md) var(--space-lg);border-radius:var(--radius);border-top-left-radius:0;border-top-right-radius:0}.site-name{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-heading)}.site-name a{text-decoration:none;color:var(--color-text-primary)}.nav--authenticated .nav__links{display:none}@media(min-width: 768px){.nav--authenticated .nav__links{display:flex}}.nav-hamburger{display:block;position:relative}@media(min-width: 768px){.nav-hamburger{display:none}}.nav-hamburger__toggle{background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--color-text-primary);padding:var(--space-xs);line-height:1;list-style:none}.nav-hamburger__toggle::-webkit-details-marker{display:none}.nav-hamburger__menu{position:absolute;right:0;top:100%;background:var(--color-bg-panel);border:var(--border-w-thin) solid var(--color-border);display:flex;flex-direction:column;min-width:160px;padding:var(--space-sm);gap:var(--space-sm);z-index:100}.nav-hamburger__menu a{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);text-decoration:none;color:var(--color-text-secondary);padding:var(--space-xs) 0}.nav-hamburger__menu a:hover{color:var(--accent)}.nav-hamburger__menu button{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);padding:var(--space-xs) 0;text-align:left}.nav-hamburger__menu button:hover{color:var(--accent)}.nav__links{display:flex;align-items:center;gap:var(--space-lg)}.nav__links a{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);text-decoration:none;color:var(--color-text-secondary)}.nav__links a:hover{color:var(--accent)}.nav__links a.btn--primary{color:var(--accent-contrast)}.nav__links a.btn--danger{color:#fff}.nav__user{font-size:.75rem;color:var(--color-text-muted);border-left:var(--border-w-thin) solid var(--color-border);padding-left:var(--space-lg)}nav.flex-row{justify-content:space-between;align-items:center}main{background:var(--color-bg-panel);border:var(--border-w-thin) solid var(--color-border);border-top:none;padding:var(--space-md);margin-top:0;border-radius:var(--radius);border-top-left-radius:0;border-top-right-radius:0}@media(min-width: 768px){main{padding:var(--space-xl)}}.page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-lg);margin-bottom:var(--space-xl);border-bottom:var(--border-w-thick) solid var(--color-border)}#logout-form{display:inline}#logout-button{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label)}#logout-button:hover{color:var(--accent)}p.error{margin-top:var(--space-sm);color:var(--color-danger);font-weight:500;border-left:var(--border-w-accent) solid var(--color-danger);padding-left:var(--space-md)}.field{margin-bottom:1.25rem}.home{display:flex;flex-direction:column;gap:var(--space-2xl)}.home-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.home-section__heading{font-family:var(--font-heading);font-size:.75rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-muted);display:flex;align-items:center;gap:var(--space-sm);margin:0 0 var(--space-lg)}.home-section__header .home-section__heading{margin-bottom:0}.home-section__count{font-family:var(--font-body);font-size:.75rem;font-weight:600;background:var(--accent);color:var(--accent-contrast);border-radius:99px;padding:1px 7px}.home-empty{text-align:center;color:var(--color-text-muted);padding:var(--space-2xl) 0}.home-empty p{margin-bottom:var(--space-lg)}.home-empty__sub{color:var(--color-text-muted);font-size:.875rem;margin:0}.home-see-all{display:inline-block;margin-top:var(--space-lg);font-size:.875rem;color:var(--accent);text-decoration:none}.home-see-all:hover{text-decoration:underline}.login-container{width:100%;max-width:500px;margin:0 auto;border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);padding:var(--space-3xl) var(--space-2xl) var(--space-2xl);box-shadow:var(--shadow-md) var(--shadow-color)}.login-container label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-secondary);display:block;margin-bottom:var(--space-xs)}.login-container input[type=username],.login-container input[type=email],.login-container input[type=password]{width:100%;padding:.8rem 1rem;border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);font-size:.95rem;color:var(--color-text-primary);outline:none;margin-bottom:1rem}.login-container input:focus{border-color:var(--accent);box-shadow:var(--shadow-sm) var(--accent);background:var(--color-bg)}.login-container button[type=submit]{font-family:var(--font-heading);font-size:.875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-button);padding:var(--space-sm) var(--space-lg);border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-sm);text-decoration:none;transition:transform .1s ease,box-shadow .1s ease;background:var(--accent);color:var(--accent-contrast);box-shadow:var(--shadow-md) var(--shadow-color);width:100%;justify-content:center}.login-container button[type=submit]:hover{background:var(--accent-hover);transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-lg) var(--shadow-color)}.login-container button[type=submit]:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.login-container button[type=submit]:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.event-card-list{display:grid;grid-template-columns:1fr;gap:var(--space-lg);list-style:none;padding:0;margin:0}.event-card-list>li{min-width:0}@media(min-width: 768px){.event-card-list{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1024px){.event-card-list{grid-template-columns:repeat(3, 1fr)}}.event-card-link-wrapper{text-decoration:none;color:inherit;display:block;height:100%}.event-card{border:var(--border-w-thin) solid var(--color-border);box-shadow:var(--shadow-md) var(--shadow-color);border-radius:var(--radius);background:var(--color-bg-panel);padding:0;overflow:hidden;position:relative;transition:transform .1s ease,box-shadow .1s ease;height:100%;display:flex;flex-direction:column}.event-card::before{content:"";display:block;height:var(--border-w-accent);background:var(--accent);flex-shrink:0}.event-card:hover{transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-lg) var(--shadow-color)}.event-card:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.event-card__body{display:flex;flex:1;gap:var(--space-md);padding:var(--space-md)}@media(min-width: 768px){.event-card__body{padding:var(--space-lg)}}.event-card__date{flex-shrink:0;text-align:center;min-width:3.5rem}.event-card__month{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--accent)}.event-card__day{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;line-height:1;color:var(--color-text-primary)}@media(min-width: 768px){.event-card__day{font-size:2rem}}.event-card__start-time{font-family:var(--font-heading);font-size:.75rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-muted);margin-top:3px}.event-card__content{flex:1;min-width:0;display:flex;flex-direction:column}.event-card__title{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;line-height:1.2;margin:0 0 var(--space-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-card__description{font-size:.875rem;color:var(--color-text-muted);line-height:1.4;margin:0 0 var(--space-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-card__meta{display:flex;flex-direction:column;gap:var(--space-xs)}.event-card__time{font-size:.75rem;color:var(--color-text-muted)}.event-card__host{font-size:.75rem;display:flex;gap:var(--space-xs);align-items:center}.event-card__host-label{color:var(--color-text-muted);font-weight:600}.event-card__host-name{color:var(--color-text-secondary)}.event-card__rsvp{font-family:var(--font-heading);font-size:.625rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);padding:1px var(--space-xs);border:var(--border-w-thin) solid;align-self:flex-start}.event-card__rsvp--yes{color:var(--color-success);border-color:var(--color-success)}.event-card__rsvp--maybe{color:var(--color-warning);border-color:var(--color-warning)}.event-card__rsvp--no{color:var(--color-danger);border-color:var(--color-danger)}.event-card__group-badge{font-family:var(--font-heading);font-size:.625rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);padding:1px var(--space-xs);border:var(--border-w-thin) solid var(--color-border);color:var(--color-text-muted);background:var(--color-bg-raised);align-self:flex-start}.events-page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-lg);margin-bottom:var(--space-xl);border-bottom:var(--border-w-thick) solid var(--color-border);flex-wrap:wrap;gap:var(--space-sm)}.events-page-header .nav__links{gap:var(--space-sm);flex-wrap:wrap}.pending-invites{margin-bottom:var(--space-xl)}.pending-invites__summary{font-family:var(--font-heading);font-size:.875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-warning);cursor:pointer;user-select:none;margin-bottom:var(--space-md);list-style:none}.pending-invites__summary::-webkit-details-marker{display:none}.pending-invites__summary::before{content:"▶ ";font-size:.625rem}details[open] .pending-invites__summary::before{content:"▼ "}.pending-invite-card{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border:var(--border-w-thin) solid var(--color-border);border-left:var(--border-w-accent) solid var(--color-warning);border-radius:var(--radius);margin-bottom:var(--space-sm);background:var(--color-bg-panel)}.pending-invite-card__info{display:flex;flex-direction:column;gap:var(--space-xs)}.pending-invite-card__title{font-family:var(--font-heading);font-weight:700;font-size:1rem;text-decoration:none;color:var(--color-text-primary)}.pending-invite-card__title:hover{color:var(--accent)}.pending-invite-card__time{font-size:.75rem;color:var(--color-text-muted)}.pending-invite-card__actions{display:flex;gap:var(--space-xs)}.pending-invite-card__actions form{display:inline}.single-event__rsvp{margin-bottom:var(--space-xl);padding:var(--space-lg);border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-raised)}.single-event__rsvp-buttons{display:flex;gap:var(--space-sm);margin-top:var(--space-sm)}.single-event__rsvp-buttons form{display:inline}.event-list--hide-no [data-rsvp=no]{display:none}#filter-not-going[aria-pressed=true]{border-color:var(--color-border);background:var(--color-bg-raised)}.past-events{margin-top:var(--space-2xl)}.past-events__summary{font-family:var(--font-heading);font-size:.875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-muted);cursor:pointer;user-select:none;margin-bottom:var(--space-lg);list-style:none}.past-events__summary::-webkit-details-marker{display:none}.past-events__summary::before{content:"▶ ";font-size:.625rem}details[open] .past-events__summary::before{content:"▼ "}.past-events__list{opacity:.6}.past-events__show-all{display:inline-block;margin-top:var(--space-md);font-size:.875rem;color:var(--accent);text-decoration:none}.past-events__show-all:hover{text-decoration:underline}.past-events-filter{margin-bottom:var(--space-xl)}.past-events-filter__row{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-xs)}.past-events-filter__row select{flex:0 1 240px;cursor:pointer}.past-events-filter__row select:hover{border-color:var(--accent)}.events-empty{border:var(--border-w-thin) dashed var(--color-border);border-radius:var(--radius);padding:var(--space-3xl) var(--space-xl);text-align:center;color:var(--color-text-muted)}.events-empty p{margin-bottom:var(--space-lg)}.single-event{max-width:900px;margin:0 auto}.single-event__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-xl)}.single-event__title{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.05;letter-spacing:var(--ls-display);margin:0}.single-event__meta{display:flex;flex-wrap:wrap;gap:var(--space-2xl);margin-bottom:var(--space-xl)}.single-event__meta-block label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);display:block;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.single-event__meta-block span{font-size:1.125rem;color:var(--color-text-primary)}.single-event__description{line-height:1.7;margin-bottom:var(--space-xl)}.single-event__organizers{margin-bottom:var(--space-xl)}.single-event__organizers .label-text{display:block;margin-bottom:var(--space-sm)}.organizer-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.organizer-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border:var(--border-w-thin) solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-raised);font-size:.875rem;font-weight:600;text-decoration:none;color:var(--color-text-primary);transition:background .1s ease,border-color .1s ease}.organizer-badge:hover{background:var(--color-bg-panel);border-color:var(--accent);color:var(--accent)}.organizer-badge__creator-tag{font-size:.75rem;font-weight:400;color:var(--color-text-muted)}.single-event__attendees{margin-bottom:var(--space-xl);padding-top:var(--space-lg);border-top:var(--border-w-thin) solid var(--color-border)}.attendee-invite-form{margin-bottom:var(--space-lg)}.attendee-invite-form .label-text{margin-bottom:var(--space-sm)}.attendee-invite-form__row{display:flex;gap:var(--space-sm)}.attendee-invite-form__row input{flex:1}.attendee-invite-form__row .btn{flex-shrink:0}.attendee-group{margin-bottom:var(--space-lg)}.attendee-group__label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);display:block;margin-bottom:var(--space-sm)}.attendee-group__label--success{color:var(--color-success)}.attendee-group__label--warning{color:var(--color-warning)}.attendee-group__label--danger{color:var(--color-danger)}.attendee-group__label--muted{color:var(--color-text-muted)}.attendee-group__list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.attendee-group__list a{text-decoration:none}.attendee-empty{color:var(--color-text-muted);font-size:.875rem}.single-event__actions{display:flex;gap:var(--space-md);padding-top:var(--space-lg);border-top:var(--border-w-thin) solid var(--color-border)}.event-form-container{width:100%;max-width:640px;margin:0 auto}.event-form-container__heading{font-family:var(--font-heading);font-weight:700;padding-bottom:var(--space-md);margin-bottom:var(--space-xl);border-bottom:var(--border-w-thick) solid var(--color-border)}.event-form label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-secondary);display:block;margin-bottom:var(--space-xs)}.form-time-row{display:grid;grid-template-columns:1fr;gap:var(--space-md)}.form-time-row>.field{min-width:0}@media(min-width: 768px){.form-time-row{grid-template-columns:1fr 1fr}}.single-group{max-width:1100px;margin:0 auto}.single-group__title{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.05;letter-spacing:var(--ls-display);margin:0 0 var(--space-xl)}.single-group__layout{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-2xl);align-items:start}@media(max-width: 768px){.single-group__layout{grid-template-columns:1fr}}.single-group__section-heading{font-size:1.125rem;font-weight:700;margin:0 0 var(--space-lg)}.single-group__sidebar{border-left:var(--border-w-thin) solid var(--color-border);padding-left:var(--space-xl)}@media(max-width: 768px){.single-group__sidebar{border-left:none;border-top:var(--border-w-thin) solid var(--color-border);padding-left:0;padding-top:var(--space-lg)}}.group-past-events{margin-top:var(--space-2xl)}.group-past-events__heading{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.group-events-empty{color:var(--color-text-muted);font-size:.875rem}.member-section{margin-bottom:var(--space-lg)}.member-section__label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);display:block;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.member-list{display:flex;flex-direction:column;gap:var(--space-xs)}.member-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border:var(--border-w-thin) solid var(--color-border);background:var(--color-bg-raised)}.member-row__info{display:flex;align-items:center;gap:var(--space-sm)}.member-row__name{font-weight:600;font-size:.9375rem;text-decoration:none;color:var(--color-text-primary)}.member-row__name:hover{color:var(--accent)}.member-row__badge--admin{font-family:var(--font-heading);font-size:.625rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--accent);border:var(--border-w-thin) solid var(--accent);padding:1px var(--space-xs)}.member-row__actions{display:flex;align-items:center;gap:var(--space-xs)}.member-row__actions form{display:inline}.member-empty{color:var(--color-text-muted);font-size:.875rem}.member-invite-form{margin-bottom:var(--space-lg)}.member-invite-form .label-text{margin-bottom:var(--space-sm)}.member-invite-form__row{display:flex;gap:var(--space-sm)}.member-invite-form__row input{flex:1}.member-invite-form__row .btn{flex-shrink:0}.groups-page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-lg);margin-bottom:var(--space-xl);border-bottom:var(--border-w-thick) solid var(--color-border)}.group-list{display:flex;flex-direction:column;gap:var(--space-sm);list-style:none;padding:0;margin:0}.group-list__item{display:block;padding:var(--space-md) var(--space-lg);border:var(--border-w-thin) solid var(--color-border);background:var(--color-bg-raised);text-decoration:none;font-weight:600;color:var(--color-text-primary);transition:border-color .1s ease,color .1s ease}.group-list__item:hover{border-color:var(--accent);color:var(--accent)}.group-color-picker{display:flex;gap:var(--space-sm);margin:var(--space-xs) 0 var(--space-md)}.group-color-swatch{width:1.5rem;height:1.5rem;border:var(--border-w-thin) solid rgba(0,0,0,0);cursor:pointer;flex-shrink:0}.group-color-swatch.active,.group-color-swatch:hover{border-color:var(--color-text-primary);box-shadow:var(--shadow-sm) var(--shadow-color)}.group-settings{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:var(--border-w-thin) solid var(--color-border)}.group-form-container{width:100%;max-width:480px;margin:0 auto}.group-form-container__heading{font-family:var(--font-heading);font-weight:700;padding-bottom:var(--space-md);margin-bottom:var(--space-xl);border-bottom:var(--border-w-thick) solid var(--color-border)}.group-form label{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-secondary);display:block;margin-bottom:var(--space-xs)}.flatpickr-calendar{border-radius:var(--radius);border:var(--border-w-thin) solid var(--color-border);box-shadow:var(--shadow-md) var(--shadow-color);background:var(--color-bg-panel)}.flatpickr-calendar .flatpickr-months{border-bottom:var(--border-w-thin) solid var(--color-border)}.flatpickr-calendar .flatpickr-day{border-radius:var(--radius)}.flatpickr-calendar .flatpickr-day.selected,.flatpickr-calendar .flatpickr-day.startRange,.flatpickr-calendar .flatpickr-day.endRange{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast)}.flatpickr-calendar .flatpickr-day:hover{background:var(--accent-muted);border-color:var(--color-border)}.flatpickr-calendar .flatpickr-day.today:not(.selected){border-color:var(--accent)}.flatpickr-calendar .flatpickr-prev-month:hover svg,.flatpickr-calendar .flatpickr-next-month:hover svg{fill:var(--accent)}.settings-page{max-width:640px;margin:0 auto;padding:var(--space-lg)}.settings-section{margin-bottom:var(--space-2xl)}.settings-section h2{margin-bottom:var(--space-md);letter-spacing:var(--ls-heading)}.settings-section p{color:var(--color-text-secondary);margin-bottom:var(--space-md);font-size:.9rem}.theme-options{display:flex;gap:var(--space-md)}.theme-option{flex:1;border:var(--border-w-thin) solid var(--color-border);box-shadow:var(--shadow-md) var(--shadow-color);border-radius:var(--radius);background:var(--color-bg-panel);padding:var(--space-lg);cursor:pointer;text-align:center;transition:transform .1s ease,box-shadow .1s ease}.theme-option:hover{transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-lg) var(--shadow-color)}.theme-option:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-sm) var(--shadow-color)}.theme-option.active{border-color:var(--accent);box-shadow:var(--shadow-md) var(--accent)}.theme-option .theme-option__label{font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-button);margin-bottom:var(--space-xs)}.theme-option .theme-option__desc{font-size:.85rem;color:var(--color-text-secondary)}.accent-options{display:flex;gap:var(--space-sm);flex-wrap:wrap}.accent-swatch{width:48px;height:48px;border-radius:var(--radius);border:var(--border-w-thin) solid var(--color-border);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;position:relative}.accent-swatch:hover{transform:translate(var(--hover-x), var(--hover-y));box-shadow:var(--shadow-md) var(--shadow-color)}.accent-swatch.active{border-color:var(--color-text-primary);box-shadow:var(--shadow-md) var(--shadow-color)}.accent-swatch.active::after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}.friends-section{margin-bottom:var(--space-2xl)}.friends-section__heading{font-family:var(--font-heading);font-size:.6875rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--color-text-muted);margin-bottom:var(--space-md)}.friend-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-xs)}.friend-list__item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border:var(--border-w-thin) solid var(--color-border);background:var(--color-bg-raised)}.friend-list__name{display:flex;align-items:baseline;gap:var(--space-sm);font-weight:600;font-size:.9375rem;text-decoration:none;color:var(--color-text-primary)}.friend-list__name:hover{color:var(--accent)}.friend-list__username{font-size:.8125rem;font-weight:400;color:var(--color-text-muted)}.friend-list__actions{display:flex;gap:var(--space-sm)}.friend-list__actions form{display:inline}.friends-empty{color:var(--color-text-muted);font-size:.875rem}.friends-add-form{margin-bottom:var(--space-2xl);padding-bottom:var(--space-2xl);border-bottom:var(--border-w-thin) solid var(--color-border)}.friends-add-form__row{display:flex;gap:var(--space-sm);margin-top:var(--space-sm)}.friends-add-form__row input{flex:1;max-width:320px}.friends-add-form__row .btn{flex-shrink:0}.friends-add-form__success{margin-top:var(--space-sm);color:var(--color-success);font-weight:500;border-left:var(--border-w-accent) solid var(--color-success);padding-left:var(--space-md)}.friend-status-badge{font-family:var(--font-heading);font-size:.75rem;font-weight:700;text-transform:var(--text-transform-ui);letter-spacing:var(--ls-label);color:var(--accent);border:var(--border-w-thin) solid var(--accent);padding:2px var(--space-sm);border-radius:var(--radius)}
