:root{--bg: #f5f5f7;--surface: #ffffff;--border: #d1d1d6;--text: #1c1c1e;--text-muted: #6e6e73;--accent: #0071e3;--accent-hover: #0077ed;--danger: #ff3b30;--warn-bg: #fff3cd;--warn-border: #ffc107;--info-bg: #d1ecf1;--info-border: #17a2b8;--radius: 8px;--shadow: 0 1px 4px rgba(0,0,0,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:15px}a{color:var(--accent);text-decoration:none}button{cursor:pointer;font:inherit}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius);font-size:14px;font-weight:500;transition:background .15s}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-hover)}.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn--ghost:hover{background:var(--border)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover{opacity:.9}.btn--sm{padding:4px 10px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}.hub-page{min-height:100vh;display:flex;flex-direction:column}.hub-header{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.hub-logo{font-size:18px;font-weight:700;flex:1}.hub-header__title{flex:1;font-weight:600}.hub-main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:24px 16px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-size:22px;font-weight:600}.hub-input{display:block;width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font:inherit;background:var(--surface);color:var(--text);margin-top:4px}.hub-input:focus{outline:2px solid var(--accent);outline-offset:1px}.hub-input--sm{width:auto}.hub-input:disabled{background:var(--bg);color:var(--text-muted)}.field-label{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:12px}.field-label--inline{display:inline-block;margin-right:16px}.form-title{font-size:16px;font-weight:600;margin-bottom:12px}.form-actions{display:flex;gap:8px;margin-top:12px}.create-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.meta-form{display:flex;flex-direction:column;gap:4px}.hub-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.hub-table th{text-align:left;font-size:13px;font-weight:600;color:var(--text-muted);padding:10px 14px;border-bottom:1px solid var(--border)}.hub-table td{padding:12px 14px;border-bottom:1px solid var(--border)}.hub-table tr:last-child td{border-bottom:none}.hub-table__row--clickable{cursor:pointer}.hub-table__row--clickable:hover{background:var(--bg)}.status-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:500}.status-badge--draft{background:#e5e5ea;color:#3a3a3c}.status-badge--preview{background:#ede9fe;color:#6d28d9}.status-badge--ready{background:#d1f0d1;color:#1a7f37}.status-badge--loaded{background:#cce5ff;color:#004085}.status-badge--live{background:#fff3cd;color:#856404}.status-badge--closed{background:#f8d7da;color:#842029}.status-badge--pushed{background:#d4edda;color:#155724}.status-badge--processed{background:#cce5ff;color:#004085}.status-badge--waiting{background:#e5e5ea;color:#6e6e73}.banner{padding:10px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:14px}.banner--warn{background:var(--warn-bg);border:1px solid var(--warn-border)}.banner--info{background:var(--info-bg);border:1px solid var(--info-border)}.hub-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px}.hub-tab{background:none;border:none;padding:10px 18px;font-size:14px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;cursor:pointer}.hub-tab:hover{color:var(--text)}.hub-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.event-meta-section{margin-bottom:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.event-meta-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.event-meta-row:last-child{margin-bottom:0}.panel-section{margin-bottom:28px}.panel-section__title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text)}.question-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.question-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.question-row[draggable=true]{cursor:grab}.question-row__content{display:flex;align-items:flex-start;gap:10px}.question-row__drag{color:var(--text-muted);font-size:18px;padding-top:2px}.question-row__text{flex:1}.question-row__text p{margin-bottom:4px}.question-row__actions{display:flex;gap:6px;flex-shrink:0}.question-editor__add{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.question-form__row{display:flex;gap:16px;margin:8px 0}.sync-info{display:grid;grid-template-columns:140px 1fr;gap:6px 16px;margin-top:12px}.sync-info dt{font-weight:500;color:var(--text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px 32px;width:100%;max-width:380px;box-shadow:var(--shadow)}.login-title{font-size:24px;font-weight:700;margin-bottom:24px;text-align:center}.login-form{display:flex;flex-direction:column;gap:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:12px;padding:28px;max-width:400px;width:90%;box-shadow:0 8px 32px #0003}.text--muted{color:var(--text-muted);font-size:14px}.error-msg{color:var(--danger);font-size:13px;margin-top:6px}.sync-status{display:flex;flex-direction:column;gap:1.5rem}.sync-timeline{display:flex;gap:0;flex-wrap:wrap;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.timeline-step{flex:1 1 auto;padding:8px 10px;border-right:1px solid var(--border);background:var(--bg);text-align:center;font-size:12px;color:var(--text-muted);min-width:70px}.timeline-step:last-child{border-right:none}.timeline-step--done{background:var(--primary, #2563eb);color:#fff}.timeline-step__label{display:block;font-weight:600}.timeline-step__date{display:block;font-size:10px;margin-top:2px;opacity:.85}.sync-jobs-table,.sync-log-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}.sync-jobs-table th,.sync-jobs-table td,.sync-log-table th,.sync-log-table td{text-align:left;padding:6px 8px;border-bottom:1px solid var(--border)}.sync-jobs-table th,.sync-log-table th{font-weight:600;color:var(--text-muted)}.badge{padding:1px 6px;border-radius:999px;font-size:11px;font-weight:700}.badge--error{background:var(--danger, #c0392b);color:#fff}.gallery{display:flex;flex-direction:column;gap:24px}.gallery-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.gallery-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.gallery-thumb-btn{width:100%;border:none;background:none;padding:0;cursor:pointer}.gallery-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:#000}.gallery-thumb--placeholder{display:flex;align-items:center;justify-content:center;background:#1c1c1e;color:#fff;font-size:28px}.gallery-card-body{padding:10px 12px;flex:1}.gallery-card-name{font-weight:600;margin-bottom:2px}.gallery-card-question{font-size:13px;margin-bottom:4px}.gallery-card-meta{font-size:12px}.gallery-card-actions{display:flex;gap:6px;flex-wrap:wrap;padding:8px 12px;border-top:1px solid var(--border)}.gallery-modal-video{width:100%;max-height:70vh;background:#000}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--surface);border-radius:var(--radius);box-shadow:0 8px 32px #0000004d;padding:24px;max-width:480px;width:90%}.modal-box--video{max-width:800px;padding:0;overflow:hidden}.modal-box--video .modal-header{padding:12px 16px}.modal-box--video .modal-footer{padding:8px 16px;border-top:1px solid var(--border)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-title{font-weight:600;font-size:16px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.modal-form{display:flex;flex-direction:column;gap:12px}.panel-section--danger{border:1px solid var(--danger);background:#fff5f5}.purge-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px}.admin-table{width:100%;border-collapse:collapse;font-size:14px;margin-top:8px}.admin-table th,.admin-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}.admin-table th{font-weight:600;color:var(--text-muted)}.panel-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.disk-bar-wrap{background:var(--border);border-radius:4px;height:10px;overflow:hidden;margin-bottom:8px}.disk-bar{height:100%;background:var(--accent);transition:width .3s}.disk-bar-wrap--low .disk-bar{background:var(--danger)}.disk-warn{color:var(--danger)}.token-display{background:#f0f0f0;padding:8px 12px;border-radius:4px;font-family:monospace;word-break:break-all}.admin-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px;flex-wrap:wrap}.admin-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:500;cursor:pointer;color:var(--text-muted);white-space:nowrap}.admin-tab:hover{color:var(--text)}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:8px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:var(--shadow)}.dash-card--alert{border-color:var(--danger);background:#fff5f5}.dash-card__value{font-size:28px;font-weight:700;color:var(--text)}.dash-card--alert .dash-card__value{color:var(--danger)}.dash-card__label{font-size:12px;color:var(--text-muted);text-align:center}.ev-list{display:flex;flex-direction:column;gap:8px}.ev-row{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}.ev-row__header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer}.ev-row__header:hover{background:var(--bg)}.ev-row__info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ev-row__toggle{font-size:12px;flex-shrink:0}.event-panel{border-top:1px solid var(--border)}.event-panel__section{padding:14px 16px;border-bottom:1px solid var(--border)}.event-panel__section:last-child{border-bottom:none}.event-panel__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.event-panel__owner{font-size:14px;margin-bottom:8px}.owner-form{display:flex;gap:6px;align-items:center;margin-top:6px}.reg-link-box{margin-top:8px;background:#f0fdf4;border:1px solid #86efac;border-radius:6px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.reg-link-code{font-family:monospace;font-size:11px;word-break:break-all;background:#e8f5e9;padding:4px 6px;border-radius:4px}.token-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.token-item{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px}.token-item__top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.token-item__label{font-weight:500;font-size:13px}.token-item__row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.token-code{font-family:monospace;font-size:11px;word-break:break-all;background:#fff;border:1px solid var(--border);padding:3px 6px;border-radius:4px;flex:1;min-width:0}.token-gen-form{display:flex;flex-direction:column;gap:6px;max-width:380px;margin-top:8px}.create-event-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.create-user-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:8px}.placeholder-box{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);padding:24px;max-width:560px}.events-token-list{display:flex;flex-direction:column;gap:8px}.event-token-row{border:1px solid var(--border);border-radius:6px;overflow:hidden}.event-token-row__header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#fafafa}.event-token-row__body{padding:12px 16px;border-top:1px solid var(--border)}.admin-table--sm{font-size:13px}.admin-table--sm th,.admin-table--sm td{padding:6px 8px}.token-form{display:flex;flex-direction:column;gap:8px;max-width:420px;margin-top:8px}.hub-input--sm{font-size:13px;padding:6px 8px}.token-reveal{background:#f0fdf4;border:1px solid #86efac;border-radius:6px;padding:12px;margin-top:8px}.theme-picker{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:4px}.theme-option{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 16px;border:2px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;transition:border-color .15s;min-width:140px}.theme-option:hover:not(:disabled){border-color:var(--accent)}.theme-option--active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.theme-option:disabled{opacity:.6;cursor:not-allowed}.theme-option__label{font-size:14px;font-weight:600}.theme-option__hint{font-size:12px;color:var(--text-muted)}.preview-token-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px}.modal__title{font-size:16px;font-weight:600;margin-bottom:16px}.modal__body{font-size:14px}
