*,:before,:after{box-sizing:border-box}body{color:#1a1a1a;background:#f5f5f5;margin:0;font-family:system-ui,-apple-system,sans-serif;line-height:1.5}a{color:#06c}input,button{font:inherit}.app-with-sidebar{min-height:100vh;display:flex}.sidebar{color:#fff;background:#1a1a1a;flex-direction:column;width:220px;min-width:220px;padding:1.25rem 0;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.sidebar-link{color:#ccc;padding:.5rem 1.25rem;font-size:.95rem;text-decoration:none;display:block}.sidebar-link:hover{color:#fff;background:#ffffff14}.sidebar-link.active{color:#fff;background:#ffffff1f;font-weight:500}.sidebar-logout{color:#ccc;cursor:pointer;background:0 0;border:1px solid #555;border-radius:6px;margin:.75rem 1rem 0;padding:.5rem 1rem;font-size:.9rem}.sidebar-logout:hover{color:#fff;background:#ffffff0d;border-color:#888}.app-main{flex:1;padding:1.5rem;overflow:auto}.container{max-width:720px;margin:0 auto;padding:1.5rem}.card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.muted{color:#666;margin:0 0 1rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.35rem;font-size:.9rem;font-weight:500;display:block}.form-group input{border:1px solid #ccc;border-radius:6px;width:100%;padding:.5rem .75rem}.form-group input:focus{border-color:#06c;outline:none}.btn{cursor:pointer;border:none;border-radius:6px;padding:.6rem 1.2rem;font-weight:500;display:inline-block}.btn-primary{color:#fff;background:#06c;width:100%;margin-top:.5rem}.btn-primary:hover{background:#0052a3}.btn-sm{width:auto;margin-top:0;padding:.35rem .6rem;font-size:.85rem}.btn-sm+.btn-sm{margin-left:.35rem}.input-sm{border:1px solid #ccc;border-radius:4px;width:120px;padding:.35rem .5rem;font-size:.9rem}.wing-edit-password{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.success-msg{color:#0a6b0a;margin:0 0 .5rem;font-size:.9rem}.error-msg{color:#c00;margin-top:.5rem;font-size:.9rem}.error-msg .error-hint{color:#666;margin-top:.5rem;font-size:.85rem;display:block}.error-msg code{background:#f0f0f0;border-radius:4px;padding:.1rem .35rem;font-size:.8rem}.page-title{margin:0 0 1rem;font-size:1.25rem}.coming-soon{color:#555;margin:1.5rem 0 0;font-size:1.1rem}.wing-list{border-top:1px solid #eee;margin-top:1.5rem;padding-top:1.5rem}.wing-list h2{margin:0 0 .75rem;font-size:1.1rem}.wing-table{border-collapse:collapse;width:100%;font-size:.9rem}.wing-table th,.wing-table td{text-align:left;border-bottom:1px solid #eee;padding:.5rem .75rem}.wing-table th{color:#555;font-weight:600}.wing-table tr:last-child td{border-bottom:none}.wing-list-empty{color:#666;font-size:.9rem}.wing-dashboard-page{background:#fff;min-height:calc(100vh + 3rem);margin:-1.5rem}.wing-dashboard{flex-direction:column;min-height:100%;display:flex}.wing-dashboard-top{background:linear-gradient(#fff 0%,#f8fafc 100%);border-bottom:1px solid #e2e8f0;flex-shrink:0;box-shadow:inset 0 1px #fffc,0 2px 8px #0000000a}.wing-dashboard-tabs{justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.wing-dashboard-tabs-left{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;gap:.5rem;padding:4px;display:flex}.wing-dashboard-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500;transition:background .2s,color .2s,box-shadow .2s}.wing-dashboard-tab:hover{color:#334155;background:#ffffffb3}.wing-dashboard-tab.active{color:#0f172a;background:#fff;font-weight:600;box-shadow:0 1px 3px #00000014}.wing-dashboard-logout{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background .2s,border-color .2s,color .2s}.wing-dashboard-logout:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.wing-dashboard-save-btn{color:#fff;cursor:pointer;background:linear-gradient(#2563eb 0%,#1d4ed8 100%);border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;transition:transform .15s,box-shadow .2s,opacity .2s;box-shadow:0 1px 3px #2563eb59}.wing-dashboard-save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.wing-dashboard-save-btn:disabled{opacity:.7;cursor:not-allowed;box-shadow:none;transform:none}.wing-roster{flex-direction:column;flex:1;min-height:0;margin:0;display:flex}.wing-roster-scroll{overflow:hidden}.wing-roster-table-wrap{flex-direction:column;flex:1;min-height:0;display:flex;overflow:auto}.wing-roster-header{background:linear-gradient(#f1f5f9 0%,#e2e8f0 100%);border-bottom:1px solid #cbd5e1;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex;box-shadow:0 2px 4px #0000000f}.wing-roster-title{color:#0f172a;letter-spacing:-.02em;margin:0;font-size:1.2rem;font-weight:700}.wing-roster-table-scroll{padding:0 1.25rem 1.25rem}.wing-roster-table tbody tr:nth-child(odd){background:#fff}.wing-roster-table tbody tr:nth-child(2n){background:#f1f1f1}.wing-roster-table tbody tr:hover{background:#e8e8e8!important}.wing-roster-table thead{z-index:1;position:sticky;top:0}.wing-roster-table thead th{color:#f8fafc;text-transform:uppercase;letter-spacing:.04em;background:#1e293b;font-size:.75rem;font-weight:600;box-shadow:0 1px #00000026}.wing-roster-cards{flex-direction:column;gap:.75rem;padding:0 1rem 1.5rem;display:none}.wing-member-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;box-shadow:0 2px 8px #0000000f}.wing-member-card-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.wing-member-card-sr{color:#f8fafc;background:#1e293b;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;font-size:.8rem;font-weight:600;display:inline-flex}.wing-member-card-name{color:#0f172a;font-size:1rem;font-weight:600}.wing-member-card-meta{color:#475569;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.wing-member-card-meta span{white-space:nowrap}.wing-member-card-meetings{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.wing-meeting-check{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:.35rem;padding:.35rem .6rem;font-size:.8rem;display:inline-flex}.wing-meeting-check input{accent-color:#2563eb;margin:0}.wing-member-card-meetings-view{gap:.5rem}.wing-member-card-meetings-view .met{color:#166534;background:#dcfce7;border-radius:8px;padding:.35rem .6rem;font-size:.8rem;font-weight:500}.wing-member-card-meetings-view .missed{color:#64748b;background:#f1f5f9;border-radius:8px;padding:.35rem .6rem;font-size:.8rem}@media (max-width:768px){.wing-dashboard-page{min-height:calc(100vh + 1rem);margin:-.5rem}.wing-dashboard-tabs{flex-direction:column;align-items:stretch;gap:.75rem;padding:.75rem 1rem}.wing-dashboard-tabs-left{justify-content:stretch;width:100%}.wing-dashboard-tab{text-align:center;flex:1;padding:.6rem .75rem;font-size:.85rem}.wing-dashboard-logout{width:100%;padding:.6rem 1rem}.wing-roster-header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.wing-roster-title{flex:1;min-width:0;font-size:1rem}.wing-dashboard-save-btn{width:100%}.wing-roster-desktop{display:none!important}.wing-roster-cards,.wing-roster-mobile{display:flex!important}}@media (min-width:769px){.wing-roster-mobile{display:none!important}}.roster-form{margin-bottom:1.5rem}.form-row{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-bottom:.5rem;display:grid}.form-group select{background:#fff;border:1px solid #ccc;border-radius:6px;width:100%;padding:.5rem .75rem}.form-group select:focus{border-color:#06c;outline:none}.table-wrap{overflow-x:auto}.roster-full{background:#fff;flex-direction:column;min-height:calc(100vh + 3rem);margin:-1.5rem;display:flex}.roster-header{background:#fafafa;border-bottom:1px solid #e5e7eb;flex-shrink:0;padding:1.25rem 1.5rem}.roster-title{color:#111;margin:0 0 .25rem;font-size:1.35rem;font-weight:600}.roster-subtitle{color:#6b7280;margin:0;font-size:.9rem}.roster-filters{flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.75rem;display:flex}.roster-filter-label{color:#374151;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:inline-flex}.roster-filter-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:7rem;padding:.4rem .6rem;font-size:.9rem}.roster-filter-select:focus{border-color:#06c;outline:none}.roster-loading,.roster-empty{color:#6b7280;flex:1;justify-content:center;align-items:center;padding:2rem;font-size:1rem;display:flex}.roster-table-wrap{flex:1;padding:0 1rem 1rem;overflow:auto}.roster-table{border-collapse:collapse;width:100%;min-width:900px;font-size:.9rem}.roster-table thead{z-index:1;color:#fff;background:#1a1a1a;position:sticky;top:0}.roster-table th{text-align:left;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;padding:.75rem .5rem;font-size:.8rem;font-weight:600}.roster-table th:nth-child(n+6){text-align:center;min-width:4rem}.roster-table td{vertical-align:middle;border-bottom:1px solid #eee;padding:.4rem .5rem}.roster-table tbody tr:hover{background:#f9fafb}.roster-cell-sr{text-align:right;color:#6b7280;font-variant-numeric:tabular-nums;width:3rem}.roster-cell-text{color:#374151}.roster-input,.roster-select{background:#fff;border:1px solid #e5e7eb;border-radius:4px;width:100%;min-width:0;padding:.4rem .5rem;font-size:.9rem}.roster-input:focus,.roster-select:focus{border-color:#06c;outline:none;box-shadow:0 0 0 2px #0066cc26}.roster-input-mobile{min-width:8rem}.roster-select{cursor:pointer;min-width:7rem}.roster-cell-check{text-align:center;padding:.5rem}.roster-cell-check input[type=checkbox]{cursor:pointer;accent-color:#06c;width:1.15rem;height:1.15rem}.roster-cell-actions{text-align:center;width:4rem;padding:.35rem!important}.roster-btn-edit{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:6px;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;transition:background .15s,color .15s;display:inline-flex}.roster-btn-edit:hover{color:#fff;background:#06c}.modal-backdrop{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:10px;width:100%;max-width:420px;max-height:calc(100vh - 2rem);overflow:auto;box-shadow:0 20px 50px #0003}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-title{margin:0;font-size:1.15rem;font-weight:600}.modal-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;width:2rem;height:2rem;padding:0;font-size:1.5rem;line-height:1}.modal-close:hover{color:#111;background:#f3f4f6}.modal-form{padding:1.25rem}.modal-form .form-group,.modal-form .form-group:last-of-type{margin-bottom:1rem}.modal-meetings{border-top:1px solid #eee;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem;margin-bottom:1.25rem;padding:.75rem 0;display:flex}.modal-meetings-label{color:#374151;width:100%;font-size:.9rem;font-weight:500}.modal-check-label{cursor:pointer;align-items:center;gap:.4rem;font-size:.9rem;display:inline-flex}.modal-check-label input{accent-color:#06c;width:1.1rem;height:1.1rem}.modal-actions{justify-content:flex-end;gap:.75rem;padding-top:.5rem;display:flex}.modal-actions .btn-primary{width:auto;margin-top:0}.btn-secondary{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:.5rem 1rem;font-weight:500}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}
