:root{--color-primary: #FF6B35;--color-primary-hover: #E55A2B;--color-primary-light: #FFF0EB;--color-primary-dark: #CC4A1F;--color-white: #FFFFFF;--color-bg: #F8F9FA;--color-surface: #FFFFFF;--color-border: #E5E7EB;--color-border-hover: #D1D5DB;--color-text-primary: #1A1A2E;--color-text-secondary: #6B7280;--color-text-tertiary: #9CA3AF;--color-text-inverse: #FFFFFF;--color-error: #EF4444;--color-error-bg: #FEF2F2;--color-success: #10B981;--color-success-bg: #F0FDF4;--color-telegram: #039BE5;--color-telegram-hover: #0288D1;--color-telegram-bg: #E1F5FE;--color-absent: #EF4444;--color-absent-bg: #FEF2F2;--color-registered: #9CA3AF;--color-registered-bg: #F3F4F6;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 28px;--font-size-4xl: 32px;--line-height-tight: 1.25;--line-height-base: 1.5;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--color-info: #039BE5;--color-info-bg: #E1F5FE;--color-bg-card: #FFFFFF;--color-warning: #d97706;--color-warning-bg: #fef3c7;--color-hover: rgba(0,0,0,.04);--color-input-bg: #FFFFFF;--color-primary-text: #FFFFFF;--transition-fast: .15s ease;--transition-base: .2s ease}[data-theme=dark]{--color-primary: #FF6B35;--color-primary-hover: #E55A2B;--color-primary-light: #2d1f1a;--color-primary-dark: #CC4A1F;--color-white: #16213e;--color-bg: #0f1629;--color-surface: #16213e;--color-border: #2a2a4a;--color-border-hover: #3a3a5a;--color-text-primary: #e8e8e8;--color-text-secondary: #a0a0b0;--color-text-tertiary: #6b7280;--color-text-inverse: #1a1a2e;--color-error: #EF4444;--color-error-bg: #3b1a1a;--color-success: #10B981;--color-success-bg: #1a3b2e;--color-warning: #f59e0b;--color-warning-bg: #3b2e1a;--color-hover: rgba(255,255,255,.06);--color-input-bg: #1e2a45;--color-primary-text: #FFFFFF;--color-telegram: #039BE5;--color-telegram-hover: #0288D1;--color-telegram-bg: #1a2a3b;--color-info: #60a5fa;--color-info-bg: #1a2a4a;--color-bg-card: #1a2440;--color-absent: #EF4444;--color-absent-bg: #3b1a1a;--color-registered: #6b7280;--color-registered-bg: #1f1f30;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .3)}[data-theme=dark] .chat-item:hover{background:var(--color-surface)}[data-theme=dark] .chat-item.active{background:var(--color-primary-light)}[data-theme=dark] .chat-item.unread{background:var(--color-surface)}[data-theme=dark] .chat-item.unread:hover{background:var(--color-border)}[data-theme=dark] .msg-other{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .msg-own{color:#fff}[data-theme=dark] .chat-sidebar{background:var(--color-surface)}[data-theme=dark] .chat-window{background:var(--color-bg)}[data-theme=dark] .chat-window-header,[data-theme=dark] .mermaid-wrapper,[data-theme=dark] .chat-input-area{background:var(--color-surface)}[data-theme=dark] .chat-input-field{background:var(--color-bg)}[data-theme=dark] .chat-input-field textarea{color:var(--color-text-primary)}[data-theme=dark] .chat-input-send.disabled{background:var(--color-border);color:var(--color-text-tertiary)}[data-theme=dark] .chats-placeholder{background:var(--color-bg)}[data-theme=dark] .chat-info-panel{background:var(--color-surface)}[data-theme=dark] .msg-date-separator span,[data-theme=dark] .chat-info-avatar,[data-theme=dark] .chat-member-avatar{background:var(--color-bg)}[data-theme=dark] .invite-link-input{background:var(--color-bg);color:var(--color-text-primary)}[data-theme=dark] .new-personal-user-avatar{background:var(--color-bg)}[data-theme=dark] .new-personal-user:hover,[data-theme=dark] .create-group-user:hover{background:var(--color-border)}[data-theme=dark] .chat-file-item:hover{background:var(--color-surface)}[data-theme=dark] .chat-messages-empty{color:var(--color-text-secondary)}[data-theme=dark] .msg-own .msg-text a{color:#fff}[data-theme=dark] .app-nav{background:var(--color-surface)}[data-theme=dark] .period-chip{background:var(--color-surface);color:var(--color-text-secondary)}[data-theme=dark] .period-chip:hover{border-color:var(--color-primary)}[data-theme=dark] .chip{background:var(--color-surface);color:var(--color-text-secondary)}[data-theme=dark] .chip.type-training.active{background:var(--color-primary-light)}[data-theme=dark] .chip.type-meeting.active{background:var(--color-success-bg)}[data-theme=dark] .chip-group .chip{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text-secondary)}[data-theme=dark] .chip-group .chip.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}[data-theme=dark] .ev-filters{background:transparent}[data-theme=dark] .event-card{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .card.event-card{background:var(--color-surface)}[data-theme=dark] .ev-date-block{color:var(--color-text-primary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--font-size-base);-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-primary);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;font-family:inherit}input,button,textarea,select{font:inherit}a{color:inherit;text-decoration:none}.heading-1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}.heading-2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}.subtitle{font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-base);color:var(--color-text-secondary)}.body-small{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);line-height:var(--line-height-base);color:var(--color-text-secondary)}.caption{font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);line-height:var(--line-height-base);color:var(--color-text-tertiary)}.link{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:color var(--transition-fast)}.link:hover{color:var(--color-primary-hover);text-decoration:underline}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.screen-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.screen-content{width:100%;max-width:480px;margin:0 auto}@media (min-width: 768px){.screen-content{max-width:720px;padding:0 var(--space-6)}}@media (min-width: 1024px){.screen-content{max-width:960px}}@media (min-width: 1440px){.screen-content{max-width:1200px}}.screen-content-wide{max-width:1400px}.mermaid-wrapper{display:flex;justify-content:center;padding:var(--space-4);background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-border);margin:var(--space-4) 0;overflow-x:auto}.screen-centered{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-8)}.screen-page{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-6) 0}.screen-header{display:flex;flex-direction:column;gap:var(--space-2)}.logo-area{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.app-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.divider{width:100%;height:1px;background:var(--color-border);margin:var(--space-2) 0}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--space-6);box-shadow:var(--shadow-sm)}.detail-list{display:flex;flex-direction:column}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) 0}.detail-item+.detail-item{border-top:1px solid var(--color-border)}.detail-item .detail-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.detail-item .detail-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-align:right}.detail-item .detail-value.placeholder{color:var(--color-text-tertiary);font-style:italic}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:var(--radius-md);font-size:13px;font-weight:500;z-index:9999;animation:toast-in .2s ease;box-shadow:var(--shadow-lg)}.toast-success{background:var(--color-success);color:#fff}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.chats-page{display:flex;height:calc(100vh - 56px);max-height:calc(100vh - 56px);overflow:hidden}.chats-sidebar{width:340px;flex-shrink:0;border-right:1px solid var(--color-border);display:flex;flex-direction:column}.chats-main{flex:1;display:flex;flex-direction:column;min-width:0}.chats-info-panel{width:320px;flex-shrink:0;border-left:1px solid var(--color-border);overflow-y:auto}.chats-placeholder{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.chat-detail-page{height:calc(100vh - 56px);display:flex;flex-direction:column}.chat-sidebar{display:flex;flex-direction:column;height:100%;background:var(--color-surface)}.chat-sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0}.chat-sidebar-top{display:flex;align-items:center;justify-content:space-between}.chat-sidebar-title{font-size:18px;font-weight:700}.chat-sidebar-actions{display:flex;gap:var(--space-2)}.chat-sidebar-list{flex:1;overflow-y:auto}.chat-list-section{margin-top:var(--space-1)}.chat-section-title{font-size:11px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;padding:var(--space-2) var(--space-4) var(--space-1)}.chat-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);text-decoration:none;color:inherit;border-bottom:1px solid var(--color-border)}.chat-item:hover{background:var(--color-bg)}.chat-item.active{background:var(--color-primary-light)}.chat-item.unread{background:var(--color-bg)}.chat-item.unread:hover{background:var(--color-border)}.chat-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;color:#fff;font-weight:700}.chat-info{flex:1;min-width:0}.chat-name{font-size:14px;font-weight:500;display:flex;align-items:center;gap:var(--space-2)}.chat-preview{font-size:12px;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.chat-time{font-size:11px;color:var(--color-text-tertiary);white-space:nowrap;flex-shrink:0}.chat-unread{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;font-size:10px;font-weight:700}.chat-muted{opacity:.5}.chat-muted-icon{font-size:11px}.chat-window{display:flex;flex-direction:column;height:100%;background:var(--color-bg)}.chat-window-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0}.chat-back-btn{background:none;border:none;font-size:20px;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary)}.chat-window-title{flex:1;min-width:0;cursor:pointer}.chat-window-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-window-meta{font-size:11px;color:var(--color-text-tertiary)}.chat-info-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-3);display:flex;flex-direction:column;gap:2px}.chat-messages-loading,.chat-messages-error,.chat-messages-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8)}.chat-window-input{flex-shrink:0}.chat-archived-notice,.chat-muted-notice{padding:var(--space-3) var(--space-4);text-align:center;font-size:13px;color:var(--color-text-tertiary);background:var(--color-surface);border-top:1px solid var(--color-border)}.chat-uploading-indicator{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:12px;color:var(--color-text-secondary);background:var(--color-surface);border-top:1px solid var(--color-border)}.chat-upload-error{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);font-size:12px;color:var(--color-error);background:var(--color-error-bg);border-top:1px solid var(--color-border);cursor:pointer}.chat-upload-error-close{background:none;border:none;font-size:16px;color:var(--color-error);cursor:pointer;padding:0 4px}.msg{max-width:75%;padding:8px 12px;border-radius:var(--radius-md);position:relative;word-wrap:break-word;margin-bottom:2px}.msg-own{align-self:flex-end;background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.msg-other{align-self:flex-start;background:var(--color-surface);border:1px solid var(--color-border);border-bottom-left-radius:4px;display:flex;flex-direction:column;gap:2px}.msg-own,.msg-other{max-width:70%}.msg-other.msg-grouped{border-top-left-radius:4px;margin-top:1px}.msg-own.msg-grouped{border-top-right-radius:4px;margin-top:1px}.msg-grouped .msg-other-header{display:none}.msg-system-wrapper{align-self:center;max-width:90%;background:transparent;border:none;padding:4px 12px}.msg-other-header{display:flex;align-items:center;gap:var(--space-2)}.msg-avatar-link{text-decoration:none;flex-shrink:0}.msg-other-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.msg-other-info{display:flex;align-items:baseline;gap:6px;min-width:0}.msg-sender-name{font-size:13px;font-weight:600;color:var(--color-text-primary);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-sender-name:hover{text-decoration:underline;color:var(--color-primary)}.msg-sender-call{font-size:12px;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-text{font-size:14px;line-height:1.4}.msg-text a{color:inherit;text-decoration:underline}.msg-own .msg-text a{color:#fff}.msg-image{cursor:pointer}.msg-img{max-width:240px;max-height:240px;border-radius:var(--radius-sm);display:block}.msg-file{display:flex;align-items:center;gap:var(--space-2)}.msg-file-icon{font-size:24px}.msg-file-info{flex:1;min-width:0}.msg-file-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-file-size{font-size:11px;opacity:.7}.msg-file-download{font-size:12px;padding:4px 8px;border-radius:var(--radius-sm);background:#fff3;color:inherit;text-decoration:none;white-space:nowrap}.msg-location{display:block;text-decoration:none;color:inherit}.msg-location-label{font-weight:500;margin-bottom:2px}.msg-location-coords{font-size:12px;opacity:.7}.msg-system{font-size:12px;color:var(--color-text-tertiary);font-style:italic;text-align:center}.msg-deleted{font-size:12px;font-style:italic;opacity:.6}.msg-meta{display:flex;align-items:center;gap:4px;margin-top:2px}.msg-own .msg-meta{justify-content:flex-end}.msg-time{font-size:10px;opacity:.7}.msg-edited{font-size:10px;opacity:.6}.msg-status-icon{font-size:10px;margin-left:2px}.msg-status-read{color:var(--color-info)}.msg-actions{position:relative;cursor:pointer}.msg-actions-btn{font-size:14px;opacity:.7;padding:0 4px}.msg-menu{position:absolute;bottom:100%;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;min-width:140px;overflow:hidden}.msg-menu button{display:block;width:100%;padding:8px 12px;border:none;background:none;text-align:left;font-size:13px;cursor:pointer;color:var(--color-text-primary)}.msg-menu button:hover{background:var(--color-bg)}.msg-menu-danger{color:var(--color-error)}.msg-date-separator{display:flex;align-items:center;justify-content:center;padding:var(--space-3) 0}.msg-date-separator span{font-size:11px;color:var(--color-text-tertiary);background:var(--color-bg);padding:2px 12px;border-radius:var(--radius-full);border:1px solid var(--color-border)}.msg-link{color:var(--color-primary);text-decoration:underline}.msg-reply{font-size:11px;opacity:.7;border-left:2px solid currentColor;padding-left:6px;margin-bottom:4px}.chat-input-area{background:var(--color-surface);border-top:1px solid var(--color-border);position:relative}.chat-input-row{display:flex;align-items:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4)}.chat-input-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-input-field{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:4px 8px;background:var(--color-bg)}.chat-input-field textarea{width:100%;border:none;outline:none;resize:none;background:transparent;font-size:14px;line-height:1.4;min-height:24px;max-height:120px;padding:4px 0}.chat-input-send{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;border:none;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-input-send.disabled{background:var(--color-border);color:var(--color-text-tertiary);cursor:not-allowed}.chat-location-form{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-2)}.location-row{display:flex;gap:var(--space-2);align-items:center}.location-input{flex:1;padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px}.emoji-picker{position:absolute;bottom:100%;left:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:20;width:260px}.emoji-picker-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.emoji-picker-title{font-size:13px;font-weight:600}.emoji-picker-close{background:none;border:none;font-size:14px;cursor:pointer;color:var(--color-text-tertiary)}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:var(--space-2);max-height:180px;overflow-y:auto}.emoji-item{background:none;border:none;font-size:22px;cursor:pointer;padding:4px;border-radius:var(--radius-sm);text-align:center}.emoji-item:hover{background:var(--color-bg)}.attach-menu{position:absolute;bottom:100%;left:36px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:20;display:flex;gap:4px;padding:var(--space-2)}.attach-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-3);border:none;background:none;cursor:pointer;border-radius:var(--radius-md);min-width:64px}.attach-item:hover{background:var(--color-bg)}.attach-icon{font-size:24px}.attach-label{font-size:11px;color:var(--color-text-secondary)}.chat-info-panel{display:flex;flex-direction:column;height:100%;background:var(--color-surface)}.chat-info-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border)}.chat-info-title{font-size:15px;font-weight:600}.chat-info-close{background:none;border:none;font-size:16px;cursor:pointer;color:var(--color-text-tertiary)}.chat-info-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--color-bg);margin:var(--space-4) auto 0;color:var(--color-text-secondary)}.chat-info-details{text-align:center;padding:var(--space-3) var(--space-4)}.chat-info-name{font-size:16px;font-weight:600}.chat-info-type{font-size:12px;color:var(--color-text-tertiary);margin-top:2px}.chat-info-created{font-size:11px;color:var(--color-text-tertiary);margin-top:4px}.chat-info-invite{padding:0 var(--space-4) var(--space-3)}.chat-info-tabs{display:flex;border-bottom:1px solid var(--color-border);overflow-x:auto}.chat-info-tab{padding:var(--space-2) var(--space-3);border:none;background:none;font-size:12px;cursor:pointer;color:var(--color-text-secondary);white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.chat-info-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.chat-info-content{flex:1;overflow-y:auto}.chat-info-leave{padding:var(--space-4);border-top:1px solid var(--color-border)}.chat-members{padding:var(--space-2) 0}.chat-members-header{padding:var(--space-2) var(--space-4);font-size:12px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase}.chat-member-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4)}.chat-member-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--color-text-secondary);flex-shrink:0}.chat-member-info{flex:1;min-width:0}.chat-member-name{font-size:13px;font-weight:500}.chat-member-self{color:var(--color-text-tertiary);font-weight:400}.chat-member-meta{display:flex;gap:var(--space-2);font-size:11px;color:var(--color-text-tertiary)}.chat-member-role{text-transform:capitalize}.member-action-select{padding:4px 6px;font-size:11px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer}.chat-media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:var(--space-2)}.chat-media-item{aspect-ratio:1;overflow:hidden;border-radius:var(--radius-sm);cursor:pointer}.chat-media-thumb{width:100%;height:100%;object-fit:cover}.chat-files-list{padding:var(--space-2)}.chat-file-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-sm);text-decoration:none;color:inherit}.chat-file-item:hover{background:var(--color-bg)}.chat-file-icon{font-size:20px}.chat-file-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-modal-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.invite-link-display{display:flex}.invite-link-input{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;background:var(--color-bg)}.invite-link-actions{display:flex;gap:var(--space-2)}.invite-link-empty{display:flex;flex-direction:column;gap:var(--space-3);text-align:center}.create-group-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);max-height:400px;overflow-y:auto}.create-group-users{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto}.create-group-user{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);cursor:pointer;border-radius:var(--radius-sm)}.create-group-user:hover{background:var(--color-bg)}.create-group-user input[type=checkbox]{width:16px;height:16px}.create-group-user-name{font-size:13px;flex:1}.create-group-user-call{font-size:11px;color:var(--color-text-tertiary)}.create-group-footer{padding-top:var(--space-2)}.new-personal-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);max-height:400px;overflow-y:auto}.new-personal-users{display:flex;flex-direction:column;gap:2px}.new-personal-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);cursor:pointer;border:none;background:none;border-radius:var(--radius-sm);text-align:left;width:100%}.new-personal-user:hover{background:var(--color-bg)}.new-personal-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--color-text-secondary);flex-shrink:0}.new-personal-user-info{flex:1;min-width:0}.new-personal-user-name{font-size:14px;font-weight:500}.new-personal-user-call{font-size:12px;color:var(--color-text-tertiary)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:pointer}.lightbox-close{position:absolute;top:16px;right:16px;background:#fff3;border:none;color:#fff;font-size:24px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-image{max-width:90vw;max-height:90vh;border-radius:var(--radius-md);cursor:default}.location-map{margin:var(--space-2) 0}.location-map-label{font-size:12px;color:var(--color-text-tertiary);margin-top:4px;text-align:center}.tab-bar{display:flex;gap:var(--space-1);overflow-x:auto;flex-wrap:nowrap}.tab-btn{padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);font-size:12px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab-btn:hover{border-color:var(--color-primary)}.tab-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.chat-tab-bar{display:flex;gap:2px;overflow-x:hidden;margin-top:var(--space-2)}.chat-tab{flex-shrink:0;display:flex;align-items:center;gap:4px;padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);cursor:pointer;transition:all var(--transition-fast);font-size:12px;color:var(--color-text-secondary);line-height:1}.chat-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.chat-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.chat-tab-icon{font-size:14px;line-height:1}.chat-tab-label{font-size:11px;font-weight:500;white-space:nowrap}@media (max-width: 1024px){.chat-info-panel{display:none}}@media (max-width: 768px){.chats-page{flex-direction:column}.chats-sidebar{width:100%;border-right:none;height:100%}.chats-sidebar-hidden{display:none}.chats-main{display:none;height:100%}.chats-main-visible{display:flex}.chats-placeholder{display:none}.msg{max-width:85%}.attach-menu{left:0;right:0;bottom:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:row;justify-content:center}.emoji-picker{left:0;right:0;width:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.emoji-grid{grid-template-columns:repeat(7,1fr)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:var(--line-height-base);transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){background:var(--color-primary-dark)}.btn-telegram{background:var(--color-telegram);color:var(--color-text-inverse);padding:var(--space-4) var(--space-8);border-radius:var(--radius-lg);font-size:var(--font-size-lg);box-shadow:var(--shadow-md);gap:var(--space-3)}.btn-telegram:hover:not(:disabled){background:var(--color-telegram-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-telegram:active:not(:disabled){transform:translateY(0)}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:var(--space-2) var(--space-3)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text-primary)}.btn-danger{background:transparent;color:var(--color-error);border:1px solid var(--color-error)}.btn-danger:hover:not(:disabled){background:var(--color-error-bg)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.btn-full{width:100%}.btn-success{background:var(--color-success);color:var(--color-text-inverse)}.btn-success:disabled{background:var(--color-success);opacity:.7}.btn-outline{background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-outline:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border-hover)}.btn .spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.input-group{display:flex;flex-direction:column;gap:var(--space-1)}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.input-field{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);transition:border-color var(--transition-fast)}.input-field:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input-field input{flex:1;border:none;outline:none;background:transparent;font-size:var(--font-size-base);color:var(--color-text-primary)}.input-field input::placeholder{color:var(--color-text-tertiary)}.input-search{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);display:flex;align-items:center;gap:var(--space-3);transition:border-color var(--transition-fast)}.input-search:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input-search input{flex:1;border:none;outline:none;background:transparent;font-size:var(--font-size-base);color:var(--color-text-primary)}.input-search input::placeholder{color:var(--color-text-tertiary)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:var(--line-height-base)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.alert-error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.alert-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning)}.alert-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.avatar{border-radius:var(--radius-full);object-fit:cover;flex-shrink:0}.list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.list-item:hover{background:var(--color-bg)}.list-item.selected{background:var(--color-primary-light);border:1px solid var(--color-primary)}.list-item-title{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-12) var(--space-6);text-align:center}.empty-icon{width:64px;height:64px;opacity:.3}.empty-title{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.skeleton{background:linear-gradient(90deg,var(--color-border) 25%,var(--color-bg) 50%,var(--color-border) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:16px;width:100%}.skeleton-text-sm{height:14px;width:60%}.skeleton-avatar{width:56px;height:56px;border-radius:var(--radius-full)}.skeleton-button{height:48px;border-radius:var(--radius-md)}.skeleton-card{height:200px;border-radius:var(--radius-lg)}.region-list{display:flex;flex-direction:column;gap:var(--space-1);max-height:360px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.region-list::-webkit-scrollbar{width:4px}.region-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.bottom-fixed{padding-top:var(--space-4);border-top:1px solid var(--color-border);background:var(--color-white)}.card-success{border-color:var(--color-success);background:var(--color-success-bg)}.section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-4) 0 var(--space-2) 0}.placeholder-block{border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3)}.placeholder-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:14px;opacity:.5}.placeholder-text{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.status-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 12px;border-radius:999px}.status-badge.planned{background:var(--color-info-bg);color:var(--color-info)}.status-badge.completed{background:var(--color-bg);color:var(--color-text-tertiary)}.status-badge.cancelled{background:var(--color-error-bg);color:var(--color-error)}.status-badge.confirmed{background:var(--color-success-bg);color:var(--color-success)}.onboarding-card{display:flex;flex-direction:column;gap:16px}.onboarding-card .card-row{display:flex;align-items:flex-start;gap:12px}.onboarding-card .card-row .card-icon{width:40px;height:40px;border-radius:10px;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.onboarding-card .card-row .card-icon.icon-success{background:var(--color-success-bg)}.onboarding-card .card-row .card-text{flex:1}.onboarding-card .card-row .card-text .label{font-size:12px;color:var(--color-text-tertiary)}.onboarding-card .card-row .card-text .value{font-size:15px;font-weight:500;color:var(--color-text-primary)}.spots-bar{display:flex;gap:4px;margin-top:6px}.spots-bar .spot{width:10px;height:10px;border-radius:50%;background:var(--color-border)}.spots-bar .spot.filled{background:var(--color-primary)}.spots-bar .spot.free{background:var(--color-border)}.congrats-block{text-align:center;padding:24px 16px}.congrats-block .congrats-icon{font-size:48px;margin-bottom:12px}.congrats-block .congrats-title{font-size:20px;font-weight:700;margin-bottom:4px}.congrats-block .congrats-text{font-size:14px;color:var(--color-text-secondary);margin-bottom:20px}.action-bar{display:flex;flex-direction:column;gap:8px;width:100%}.call-sign-section{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:16px 20px;display:flex;flex-direction:column;gap:12px}.call-sign-section .section-label{font-size:12px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.call-sign-input-row{display:flex;gap:8px;align-items:center}.call-sign-input-row .input-field{flex:1}.call-sign-input-row .input-field.small-input{padding:8px 12px}.call-sign-display{display:flex;align-items:center;justify-content:space-between}.call-sign-display .call-sign-value{font-size:18px;font-weight:700;color:var(--color-primary);letter-spacing:.02em}.call-sign-display .call-sign-meta{font-size:12px;color:var(--color-text-tertiary)}.availability-check{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500}.availability-check.available{color:var(--color-success)}.availability-check.taken{color:var(--color-error)}.qr-section{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background var(--transition-fast)}.qr-section:hover{background:var(--color-bg)}.qr-section .qr-info{display:flex;align-items:center;gap:12px}.qr-section .qr-text{font-size:14px;font-weight:500;color:var(--color-text-primary)}.qr-section .qr-subtext{font-size:12px;color:var(--color-text-tertiary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.modal{background:var(--color-white);border-radius:var(--radius-xl);width:100%;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);padding:var(--space-6)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal-close{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--color-bg);border:none;cursor:pointer;transition:background var(--transition-fast)}.modal-close:hover{background:var(--color-border)}.qr-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-4) 0}.qr-image{width:200px;height:200px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.qr-url{font-size:var(--font-size-xs);color:var(--color-text-tertiary);word-break:break-all;text-align:center;max-width:280px}.profile-header{display:flex;align-items:center;gap:16px;padding:8px 0 20px}.profile-header .profile-name-block{display:flex;flex-direction:column;gap:2px}.profile-header .profile-name-block .name{font-size:20px;font-weight:600;color:var(--color-text-primary)}.profile-header .profile-name-block .username{font-size:14px;color:var(--color-text-secondary)}.app-nav{background:var(--color-white);border-bottom:1px solid var(--color-border);padding:0 var(--space-4);display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100;gap:var(--space-2)}.app-nav .nav-links{display:flex;align-items:center;gap:var(--space-1);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;flex:1;min-width:0}.app-nav .nav-links::-webkit-scrollbar{display:none}.app-nav .nav-link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;flex-shrink:0}.app-nav .nav-link:hover{background:var(--color-bg);color:var(--color-text-primary)}.app-nav .nav-link.active{color:var(--color-primary);background:var(--color-primary-light)}.app-nav .nav-user{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);flex-shrink:0}.user-menu{position:relative}.user-menu-trigger{all:unset;cursor:pointer;display:flex;align-items:center;gap:4px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:background var(--transition-fast)}.user-menu-trigger:hover{background:var(--color-bg)}.user-menu-name-desktop{display:none}.user-menu-initials-mobile{display:flex;width:32px;height:32px;align-items:center;justify-content:center;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:700}@media (min-width: 768px){.user-menu-name-desktop{display:inline}.user-menu-initials-mobile{display:none}}.user-menu-dropdown{position:absolute;top:100%;right:0;min-width:180px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;padding:var(--space-1)}.user-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:none;border:none;text-align:left;cursor:pointer;text-decoration:none;transition:background var(--transition-fast)}.user-menu-item:hover{background:var(--color-bg);color:var(--color-text-primary)}.event-card{display:flex;flex-direction:column;gap:10px;padding:16px}.event-card .event-top{display:flex;justify-content:space-between;align-items:flex-start}.event-card .event-meta{display:flex;flex-direction:column;gap:4px}.event-card .event-meta .meta-row{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary)}.event-card .event-meta .meta-row svg{flex-shrink:0}.state-block{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-8) var(--space-6);text-align:center}.welcome-avatar{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#ff6b35,#e55a2b);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700;flex-shrink:0}.info-card{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);width:100%}.info-row{display:flex;justify-content:space-between;align-items:center}.info-row .label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.info-row .value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.cta-block{background:var(--color-primary-light);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);text-align:center}.cta-block .cta-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.cta-block .cta-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.progress-bar .progress-fill{height:100%;border-radius:var(--radius-full);background:var(--color-primary);transition:width var(--transition-base)}.progress-bar .progress-fill.warning{background:var(--color-warning)}.progress-bar .progress-fill.success{background:var(--color-success)}.progress-bar .progress-fill.danger{background:var(--color-error)}.progress-info{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:1px solid var(--color-border);background:var(--color-white);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.chip:hover{border-color:var(--color-border-hover);background:var(--color-bg)}.chip.active,.chip.type-training.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.chip.type-search.active{background:var(--color-info-bg);border-color:var(--color-info);color:var(--color-info)}.chip.type-meeting.active{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.period-chip{font-size:13px;padding:4px 14px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast)}.period-chip:hover{border-color:var(--color-border-hover)}.period-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.calendar-grid{width:100%}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:var(--space-2)}.calendar-header .day-name{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);padding:var(--space-2) 0;text-transform:uppercase}.calendar-body{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;position:relative;transition:background var(--transition-fast);min-height:44px}.calendar-cell:hover{background:var(--color-bg)}.calendar-cell.other-month{opacity:.3}.calendar-cell.today{background:var(--color-primary-light);font-weight:var(--font-weight-bold)}.calendar-cell.today .day-number{color:var(--color-primary)}.calendar-cell.selected{background:var(--color-primary)}.calendar-cell.selected .day-number{color:#fff;font-weight:var(--font-weight-bold)}.calendar-cell .day-number{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.calendar-cell .day-dot{width:5px;height:5px;border-radius:50%;background:var(--color-primary);margin-top:2px}.calendar-cell .day-count{font-size:9px;font-weight:var(--font-weight-bold);color:#fff;background:var(--color-primary);border-radius:8px;padding:0 4px;min-width:16px;text-align:center;position:absolute;top:2px;right:2px;line-height:14px}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.calendar-nav .nav-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.calendar-nav .nav-arrows{display:flex;gap:var(--space-2)}.calendar-nav .nav-arrows button{width:36px;height:36px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-white);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.calendar-nav .nav-arrows button:hover{background:var(--color-bg);border-color:var(--color-border-hover)}.calendar-nav .btn-today{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-white);cursor:pointer;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.calendar-nav .btn-today:hover{background:var(--color-bg);border-color:var(--color-border-hover)}.day-events{margin-top:var(--space-4);border-top:1px solid var(--color-border);padding-top:var(--space-4)}.day-events .day-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.day-event-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.day-event-item:hover{background:var(--color-bg)}.day-event-item .event-info{flex:1}.day-event-item .event-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.day-event-item .event-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.day-event-item .event-type-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.day-event-item .event-type-icon svg{width:18px;height:18px}.event-card .card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-2)}.event-card .event-title{font-size:16px;font-weight:600;color:var(--color-text-primary)}.event-card .event-row{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-text-secondary)}.event-card .event-row svg{flex-shrink:0}.ev-date-block{display:flex;align-items:center;gap:12px}.ev-date-block .ev-date-num{font-size:28px;font-weight:700;color:var(--color-primary);line-height:1}.ev-date-block .ev-date-text{font-size:13px;color:var(--color-text-secondary);line-height:1.3}.event-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 10px;border-radius:999px;background:var(--color-primary-light);color:var(--color-primary-dark)}.type-training svg{stroke:var(--color-primary)}.type-search svg{stroke:var(--color-info)}.type-meeting svg{stroke:var(--color-success)}.ev-header{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.ev-header .ev-title{font-size:22px;font-weight:700;color:var(--color-text-primary)}.ev-header .ev-type-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ev-section{margin-bottom:16px}.ev-section .ev-section-title{font-size:12px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.ev-detail-row{display:flex;align-items:center;gap:10px;padding:8px 0}.ev-detail-row .ev-icon{width:36px;height:36px;border-radius:8px;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ev-detail-row .ev-icon svg{width:18px;height:18px}.ev-detail-row .ev-text{flex:1}.ev-detail-row .ev-text .ev-label{font-size:12px;color:var(--color-text-tertiary)}.ev-detail-row .ev-text .ev-value{font-size:15px;font-weight:500;color:var(--color-text-primary)}.deadline-note{font-size:13px;color:var(--color-text-secondary);margin-bottom:16px;padding:10px 14px;background:var(--color-bg);border-radius:var(--radius-md)}.participant-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md)}.participant-item:hover{background:var(--color-bg)}.participant-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#ff6b35,#e55a2b);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0}.participant-info{flex:1}.participant-name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.participant-callsign{font-size:12px;color:var(--color-text-tertiary)}.participant-status{width:80px;text-align:center}.attendance-toggle{display:flex;gap:4px}.attendance-toggle button{padding:4px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-white);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.attendance-toggle button:hover{border-color:var(--color-border-hover)}.attendance-toggle button.selected-present{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.attendance-toggle button.selected-absent{background:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.attendance-toggle button:disabled{opacity:.5;cursor:not-allowed}.fixed-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 10px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.fixed-badge.attended{background:var(--color-success-bg);color:var(--color-success)}.fixed-badge.absent{background:var(--color-error-bg);color:var(--color-error)}.fixed-badge.registered{background:var(--color-info-bg);color:var(--color-info)}.fixed-badge.cancelled{background:var(--color-bg);color:var(--color-text-tertiary);text-decoration:line-through}.part-summary{display:flex;gap:12px;margin-bottom:16px}.part-summary .stat{flex:1;text-align:center;padding:10px;border-radius:var(--radius-md);background:var(--color-bg)}.part-summary .stat .num{font-size:20px;font-weight:700;color:var(--color-text-primary)}.part-summary .stat .label{font-size:11px;color:var(--color-text-tertiary);margin-top:2px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field .field-label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.form-field .field-label .required{color:var(--color-error);margin-left:2px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.textarea-field{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);transition:border-color var(--transition-fast)}.textarea-field:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.textarea-field textarea{flex:1;border:none;outline:none;background:transparent;font-size:var(--font-size-base);color:var(--color-text-primary);resize:vertical;min-height:80px;padding:var(--space-3) var(--space-4);font-family:inherit}.textarea-field textarea::placeholder{color:var(--color-text-tertiary)}.input-field select{flex:1;border:none;outline:none;background:transparent;font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input-field:has(select){padding-right:var(--space-3)}.modal-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6)}.modal-actions .btn{flex:1}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.text-center{text-align:center}.w-full{width:100%}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.avatar-initials{border-radius:50%;background:linear-gradient(135deg,#ff6b35,#e55a2b);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0}.badge-ghost{background:var(--color-bg);color:var(--color-text-secondary)}.ev-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.profile-avatar-initials{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#ff6b35,#e55a2b);display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:700;flex-shrink:0}.stat-card{text-align:center;padding:var(--space-4);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border)}.stat-card .stat-number{font-size:28px;font-weight:700;line-height:1.2}.stat-card .stat-label{font-size:12px;color:var(--color-text-tertiary);margin-top:4px}.stat-card .stat-sub{font-size:11px;color:var(--color-text-tertiary);margin-top:2px}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;font-size:11px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.03em;padding:var(--space-3) var(--space-3);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.admin-table td{padding:var(--space-3) var(--space-3);border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);vertical-align:middle}.admin-table .user-cell{display:flex;align-items:center;gap:var(--space-2)}.user-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}.user-card:last-child{border-bottom:none}.user-card .user-info{flex:1}.user-card .user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.user-card .user-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.avatar-xs{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-sm{width:40px;height:40px;border-radius:50%;flex-shrink:0}.avatar-md{width:56px;height:56px;border-radius:50%;flex-shrink:0}.badge-newbie{background:var(--color-bg);color:var(--color-text-tertiary);border:1px solid var(--color-border)}.badge-member{background:var(--color-success-bg);color:var(--color-success)}.badge-instructor{background:var(--color-info-bg);color:var(--color-info)}.badge-region-admin{background:var(--color-warning-bg);color:var(--color-warning)}.badge-sys-admin,.badge-danger{background:var(--color-error-bg);color:var(--color-error)}.filter-bar{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:center;margin-bottom:var(--space-4)}.filter-bar .input-field{min-width:180px;flex:1;max-width:300px}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-1);margin-top:var(--space-4);flex-wrap:wrap}.pagination .page-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer}.pagination .page-btn:hover{background:var(--color-bg);border-color:var(--color-border-hover)}.pagination .page-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination .page-btn:disabled{opacity:.3;cursor:not-allowed}.pagination .page-info{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0 var(--space-2);display:flex;align-items:center}.admin-nav{display:flex;gap:var(--space-1);margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);overflow-x:auto}.admin-nav a{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);border-bottom:2px solid transparent;white-space:nowrap;transition:all var(--transition-fast);text-decoration:none}.admin-nav a:hover{color:var(--color-text-primary)}.admin-nav a.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:220px;background:var(--color-white);border-right:1px solid var(--color-border);padding:var(--space-5);flex-shrink:0;display:flex;flex-direction:column}.admin-sidebar .sidebar-logo{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);font-size:var(--font-size-base);font-weight:700;color:var(--color-primary)}.admin-sidebar .sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.admin-sidebar .sidebar-nav a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none}.admin-sidebar .sidebar-nav a:hover{background:var(--color-bg);color:var(--color-text-primary)}.admin-sidebar .sidebar-nav a.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.admin-sidebar .sidebar-nav hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-3) 0}.admin-main{flex:1;padding:var(--space-6);min-width:0}@media (max-width: 767px){.admin-sidebar{display:none}.admin-main{padding:var(--space-4)}.desktop-only{display:none!important}.calendar-cell{aspect-ratio:auto;min-height:36px}}@media (min-width: 768px){.mobile-only{display:none!important}}.checkbox-list{display:flex;flex-direction:column;gap:var(--space-1)}.checkbox-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer}.checkbox-item:hover{background:var(--color-bg)}.checkbox-item .ach-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.checkbox-item .ach-info{flex:1}.checkbox-item .ach-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.checkbox-item .ach-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.checkbox-item .ach-checkbox{width:20px;height:20px;border-radius:4px;border:2px solid var(--color-border);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.checkbox-item .ach-checkbox.checked{background:var(--color-primary);border-color:var(--color-primary)}.checkbox-item .ach-checkbox.checked:after{content:"✓";color:#fff;font-size:13px;font-weight:700}.block-info{background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-md);padding:var(--space-4)}.block-info .block-date{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-error)}.block-info .block-reason{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.mini-bar{display:flex;align-items:flex-end;gap:4px;height:40px;padding-top:8px}.mini-bar .bar{width:100%;border-radius:3px 3px 0 0;min-height:4px}.action-menu{position:relative;display:inline-block}.action-menu-btn{border:none;background:none;cursor:pointer;font-size:18px;color:var(--color-text-tertiary);padding:4px;border-radius:var(--radius-sm)}.action-menu-btn:hover{background:var(--color-bg)}.action-dropdown{position:absolute;right:0;top:100%;min-width:180px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;padding:var(--space-1);display:none}.action-dropdown.show{display:block}.action-dropdown button,.action-dropdown a{display:flex;width:100%;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:none;border:none;text-align:left;cursor:pointer;text-decoration:none}.action-dropdown button:hover,.action-dropdown a:hover{background:var(--color-bg);color:var(--color-text-primary)}.action-icons{display:flex;gap:var(--space-1);align-items:center;justify-content:flex-end}.btn-icon{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;cursor:pointer;font-size:16px;text-decoration:none;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--color-bg);border-color:var(--color-border)}.role-selector{display:flex;gap:var(--space-2);flex-wrap:wrap}.role-option{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;cursor:pointer;background:var(--color-white);transition:all var(--transition-fast)}.role-option:hover{border-color:var(--color-primary)}.role-option.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.role-option.disabled{opacity:.4;cursor:not-allowed}.char-counter{position:absolute;right:var(--space-3);bottom:var(--space-3);font-size:11px;color:var(--color-text-tertiary)}.achievement-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border)}.achievement-card .ach-main-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.achievement-card .ach-body{flex:1}.achievement-card .ach-title{font-size:var(--font-size-base);font-weight:600}.achievement-card .ach-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.achievement-card .ach-stats{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:4px}.achievement-card .ach-actions{flex-shrink:0;display:flex;gap:var(--space-2)}.audit-entry{display:flex;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.audit-entry:last-child{border-bottom:none}.audit-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.audit-body{flex:1;min-width:0}.audit-action{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.audit-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.audit-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap}.region-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-white);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.region-btn:hover{border-color:var(--color-primary)}.region-btn.active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3);margin-bottom:var(--space-5)}@media (min-width: 768px){.dashboard-grid{grid-template-columns:repeat(4,1fr)}}.chart-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--space-4);margin-bottom:var(--space-4)}.chart-card .chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.chart-card .chart-title{font-size:var(--font-size-sm);font-weight:600}.quick-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast)}.quick-link:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.quick-link .ql-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px}.quick-link .ql-label{font-size:var(--font-size-sm);font-weight:500}.quick-link .ql-count{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.filter-date{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.filter-date .input-field{min-width:130px;flex:0 1 auto}.field-group{display:flex;flex-direction:column;gap:var(--space-1)}.field-group>.field-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.field-group>.field-label .required{color:var(--color-error);margin-left:2px}.mobile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}@media (min-width: 768px){.mobile-header{display:none}.admin-table{table-layout:auto;width:100%}.admin-table td,.admin-table th{white-space:nowrap}.admin-table .action-icons{white-space:nowrap;min-width:140px}.admin-table .user-cell{min-width:180px}.admin-table td:first-child,.admin-table th:first-child{padding-left:var(--space-4)}.admin-table td:last-child,.admin-table th:last-child{padding-right:var(--space-4)}}.input-field .search-icon{flex-shrink:0;font-size:16px}.achievement-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}@media (min-width: 480px){.achievement-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.achievement-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.achievement-grid{grid-template-columns:repeat(4,1fr)}}.ach-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);transition:all var(--transition-base);position:relative}.ach-card.earned{border-color:var(--color-success);background:var(--color-success-bg)}.ach-card.unearned{opacity:.6}.ach-card .ach-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px}.ach-card.earned .ach-icon{background:var(--color-primary-light)}.ach-card.unearned .ach-icon{background:var(--color-bg);filter:grayscale(1)}.ach-card .ach-name{font-size:var(--font-size-sm);font-weight:600}.ach-card .ach-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:1.3}.ach-card .ach-badge{font-size:10px;padding:1px 8px;border-radius:var(--radius-full);font-weight:600}.ach-card .ach-date{font-size:10px;color:var(--color-text-tertiary);margin-top:auto}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.ach-card:nth-child(1){animation:fadeSlideUp .3s ease .05s both}.ach-card:nth-child(2){animation:fadeSlideUp .3s ease .1s both}.ach-card:nth-child(3){animation:fadeSlideUp .3s ease .15s both}.ach-card:nth-child(4){animation:fadeSlideUp .3s ease .2s both}.ach-card:nth-child(5){animation:fadeSlideUp .3s ease .25s both}.ach-card:nth-child(6){animation:fadeSlideUp .3s ease .3s both}.ach-card:nth-child(7){animation:fadeSlideUp .3s ease .35s both}.ach-card:nth-child(8){animation:fadeSlideUp .3s ease .4s both}.counter-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);background:var(--color-primary-light);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:var(--space-3);padding:var(--space-3) 0;position:relative}.timeline-left{display:flex;flex-direction:column;align-items:center;width:48px;flex-shrink:0;padding-top:4px}.timeline-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;z-index:1}.timeline-dot.attended{background:var(--color-success);box-shadow:0 0 0 3px var(--color-success-bg)}.timeline-dot.absent{background:var(--color-absent);box-shadow:0 0 0 3px var(--color-absent-bg)}.timeline-dot.registered{background:var(--color-registered);box-shadow:0 0 0 3px var(--color-registered-bg)}.timeline-line{width:2px;flex:1;background:var(--color-border);min-height:24px}.timeline-item:last-child .timeline-line{display:none}.timeline-date{font-size:11px;color:var(--color-text-tertiary);white-space:nowrap;text-align:center;margin-top:2px}.timeline-body{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.timeline-title{font-size:var(--font-size-sm);font-weight:600}.timeline-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.timeline-footer{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap}.timeline-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.chip-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.chip{padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);background:var(--color-white);cursor:pointer;transition:all var(--transition-fast)}.chip:hover{border-color:var(--color-primary)}.chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.user-id-short{font-family:monospace;font-size:11px;color:var(--color-text-tertiary);margin-left:6px}.mini-achievements{display:flex;gap:var(--space-2)}.mini-ach{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);font-size:18px;flex-shrink:0}.mini-ach.unearned-mini{background:var(--color-bg);filter:grayscale(1);opacity:.4}.mini-event{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.mini-event:last-child{border-bottom:none}.mini-event .me-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);min-width:60px}.mini-event .me-name{font-size:var(--font-size-sm);font-weight:500;flex:1}.section-link{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:500;display:inline-flex;align-items:center;gap:var(--space-1)}.section-link:hover{text-decoration:underline}.load-more{text-align:center;padding:var(--space-4) 0}.markdown-content{line-height:1.7;color:var(--color-text-primary);overflow-wrap:break-word}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin-top:1.5em;margin-bottom:.5em;font-weight:600}.markdown-content h1{font-size:1.75em}.markdown-content h2{font-size:1.4em}.markdown-content h3{font-size:1.15em}.markdown-content p{margin-bottom:1em}.markdown-content ul,.markdown-content ol{margin-bottom:1em;padding-left:1.5em}.markdown-content li{margin-bottom:.25em}.markdown-content a{color:var(--color-primary);text-decoration:underline}.markdown-content blockquote{border-left:4px solid var(--color-border);padding-left:16px;margin:1em 0;color:var(--color-text-secondary)}.markdown-content code{background:var(--color-bg);border-radius:6px;padding:2px 6px;font-size:.9em;font-family:monospace}.markdown-content pre{background:var(--color-bg);border-radius:8px;padding:16px;overflow-x:auto;margin-bottom:1em;border:1px solid var(--color-border)}.markdown-content pre code{background:none;padding:0}.markdown-content table{border-collapse:collapse;width:100%;margin-bottom:1em;display:block;overflow-x:auto}.markdown-content th,.markdown-content td{border:1px solid var(--color-border);padding:8px 12px;text-align:left;font-size:14px}.markdown-content th{background:var(--color-bg);font-weight:600}.markdown-content img{max-width:100%;height:auto;border-radius:8px}.markdown-content hr{border:none;border-top:1px solid var(--color-border);margin:1.5em 0}.bot-section{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);margin-top:var(--space-4)}.bot-section .bot-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-telegram-bg);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.bot-section .bot-info{flex:1}.bot-section .bot-title{font-size:var(--font-size-sm);font-weight:600}.bot-section .bot-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.bot-section .bot-status{font-size:var(--font-size-sm);color:var(--color-success);font-weight:500}.region-dropdown{position:absolute;top:100%;left:0;z-index:50;width:280px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-top:4px;overflow:hidden}.region-dropdown-search{padding:var(--space-2);border-bottom:1px solid var(--color-border)}.region-dropdown-search input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);outline:none}.region-dropdown-search input:focus{border-color:var(--color-primary)}.region-dropdown-list{max-height:200px;overflow-y:auto}.region-dropdown-item{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast)}.region-dropdown-item:hover{background:var(--color-bg)}.region-dropdown-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.region-dropdown-loading{padding:var(--space-4);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.region-dropdown-error{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs);color:var(--color-error);background:var(--color-error-bg)}.call-sign-disabled{padding:var(--space-3) 0;display:flex;flex-direction:column;gap:var(--space-3)}.toggle{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer}.toggle input[type=checkbox]{display:none}.toggle-slider{width:36px;height:20px;background:var(--color-border);border-radius:10px;position:relative;transition:background var(--transition-fast)}.toggle-slider:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:var(--color-surface);top:2px;left:2px;transition:transform var(--transition-fast)}.toggle input:checked+.toggle-slider{background:var(--color-success)}.toggle input:checked+.toggle-slider:after{transform:translate(16px)}.toggle-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media (min-width: 768px){.app-nav .nav-links{overflow-x:visible}}@media (min-width: 1024px){.login-page .btn-full{width:auto;min-width:280px}.screen-content:has(.region-list){max-width:600px}.region-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);max-height:none;overflow-y:visible}.screen-content:has(.onboarding-card){max-width:600px}.screen-content:has(.profile-header){max-width:960px}.profile-layout{display:grid;grid-template-columns:1fr 300px;gap:var(--space-6);align-items:start}.profile-side{position:sticky;top:80px}.event-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media (min-width: 1400px){.event-grid{grid-template-columns:repeat(3,1fr)}}.ev-filters{flex-wrap:nowrap}.calendar-grid{max-width:800px;margin:0 auto}.timeline-layout{display:grid;grid-template-columns:1fr 280px;gap:var(--space-6);align-items:start}.timeline-main{order:1}.timeline-side{order:2;position:sticky;top:80px}.ev-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--space-6);align-items:start}.ev-detail-main{order:1}.ev-detail-side{order:2;position:sticky;top:80px}.admin-main{max-width:1400px}.modal{max-width:640px}.modal:has(.achievement-card){max-width:680px}.modal:has(.checkbox-list){max-width:680px}.modal:has(textarea){max-width:800px}.modal:has(.onboarding-card){max-width:720px}.participant-item{display:grid;grid-template-columns:40px 1fr 180px;align-items:center;gap:var(--space-3)}.participant-item .participant-avatar{width:36px;height:36px}.onboarding-participant-item{display:grid;grid-template-columns:40px 1fr 160px;align-items:center;gap:var(--space-3)}.wiki-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}body{overflow-x:hidden}}select,.filter-select,.sidebar-region-select select{background:var(--color-input-bg);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:8px;padding:8px 32px 8px 12px;font:inherit;-moz-appearance:none;-webkit-appearance:none;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='%23999' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer}select:hover,.filter-select:hover{border-color:var(--color-border-hover)}select:focus,.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}button.link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:0;font:inherit;text-decoration:underline;text-underline-offset:2px}button.link:hover{color:var(--color-primary-hover, #e55a2b)}.admin-table tr:hover td{background:var(--color-hover, rgba(0,0,0,.02))}.period-chip{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:20px;padding:6px 16px;font-size:14px;cursor:pointer;transition:background .2s}.period-chip.active,.period-chip:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.chip.create-btn{background:var(--color-primary);color:var(--color-primary-text, #fff);border:none;border-radius:20px;padding:8px 20px;font-weight:600;cursor:pointer}.sidebar-region-select select{width:100%;font-size:13px}.badge-warning{background:var(--color-warning-bg, #fef3c7);color:var(--color-warning, #d97706)}.resp-person-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.audit-filter-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;z-index:100;padding:8px;max-height:300px;overflow-y:auto;box-shadow:0 4px 12px #00000026}
