:root{color-scheme:dark;--color-primary: #d4af37;--color-primary-dark: #b8962e;--color-primary-light: #e6c85f;--color-bg-dark: #0b0d12;--color-bg-darker: #080a0e;--color-surface: #161921;--color-surface-hover: #2d313f;--color-surface-light: #1e2230;--color-text: #ffffff;--color-text-secondary: #a0a0a0;--color-text-muted: #888888;--color-border: #2d313f;--color-border-light: #404558;--color-success: #4CAF50;--color-error: #f44336;--color-warning: #ff9800;--color-info: #2196F3;--color-solo: #90caf9;--color-normal: #4CAF50;--color-hard: #f39c12;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--font-xs: 11px;--font-sm: 13px;--font-md: 14px;--font-lg: 16px;--font-xl: 18px;--font-2xl: 24px}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-surface)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}::-webkit-scrollbar-thumb:active{background:var(--color-text-muted)}*{box-sizing:border-box}.skip-to-content{position:absolute;top:-40px;left:0;background:var(--color-primary);color:var(--color-bg-dark);padding:var(--spacing-sm) var(--spacing-lg);text-decoration:none;font-weight:600;z-index:10000;transition:top var(--transition-fast);border-radius:0 0 var(--radius-sm) 0}.skip-to-content:focus{top:0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html{overflow-x:hidden;height:100%;background-color:var(--color-bg-dark)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;margin:var(--spacing-xl);background-color:var(--color-bg-dark);color:var(--color-text);-webkit-user-select:none;user-select:none;line-height:1.5;font-size:var(--font-md);overflow-x:hidden;overflow-y:hidden;min-height:calc(100vh - 40px);height:auto}h1{text-align:center;color:var(--color-primary);margin:0 0 var(--spacing-xl) 0}svg,img{pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0b0d12cc;display:none;justify-content:center;align-items:center;flex-direction:column;z-index:10500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.loading-overlay.active{display:flex;pointer-events:all}.loading-spinner{width:50px;height:50px;border:4px solid var(--color-surface);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:var(--spacing-lg);color:var(--color-text);font-size:var(--font-lg)}.skeleton{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-light) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin:var(--spacing-sm) 0}.skeleton-title{height:24px;width:60%;margin:var(--spacing-lg) 0}.progress-bar{width:100%;height:4px;background-color:var(--color-surface);border-radius:var(--radius-full);overflow:hidden;margin:var(--spacing-md) 0}.progress-bar-fill{height:100%;background-color:var(--color-primary);transition:width var(--transition-normal)}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);max-width:1200px;margin-left:auto;margin-right:auto;gap:var(--spacing-md);flex-wrap:wrap;position:relative;z-index:40;overflow:visible}.support-donate-wrapper{position:absolute;top:var(--spacing-xl);left:var(--spacing-xl);z-index:1600;display:inline-block}.support-donate-toggle{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:36px;padding:6px 12px;border:1px solid var(--color-primary);border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-bg-dark);cursor:pointer;font-size:13px;font-weight:700;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-sm);white-space:nowrap}.support-donate-toggle:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.support-donate-toggle:focus-visible{outline:none;box-shadow:0 0 0 2px #d4af3773}.support-donate-menu{position:absolute;left:0;top:calc(100% + 8px);width:224px;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-lg);z-index:1700}.support-donate-link{display:flex;flex-direction:column;gap:2px;border-radius:var(--radius-sm);padding:8px 10px;color:var(--color-text);text-decoration:none;transition:background var(--transition-fast)}.support-donate-link:hover{background:var(--color-surface-hover)}.support-donate-link-title{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--color-text)}.support-donate-link-subtitle{font-size:11px;color:var(--color-text-muted);line-height:1.2}.support-kofi-icon{width:20px;height:20px;flex-shrink:0}.support-external-icon{width:14px;height:14px;color:var(--color-text-muted);flex-shrink:0}@media(max-width:900px){.support-donate-wrapper{top:var(--spacing-md);left:var(--spacing-md)}.support-donate-toggle{min-height:34px;padding:6px 10px}.support-donate-menu{width:210px}}.header-icon-btn{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;border-radius:var(--radius-sm);font-size:var(--font-lg);transition:all var(--transition-fast);flex-shrink:0;min-width:40px;height:46px;display:flex;align-items:center;justify-content:center;font-weight:700}.header-icon-btn:hover,.settings-btn:hover{background-color:var(--color-surface-hover);transform:translateY(-1px)}.header-icon-btn:active{transform:scale(1)}#wizard-btn svg{width:20px;height:20px;display:block}#settings-btn svg{width:20px;height:20px;display:block}.tabs{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tab-button{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);cursor:pointer;border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-weight:700;font-size:var(--font-sm);white-space:nowrap;transition:all var(--transition-fast)}.tab-button:hover{background-color:var(--color-surface-hover)}.tab-button.active{background-color:var(--color-primary);color:var(--color-bg-dark);border-color:var(--color-primary)}.header-help-btn{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;border-radius:var(--radius-sm);font-weight:700;font-size:var(--font-md);white-space:nowrap;transition:all var(--transition-fast);min-height:46px;display:flex;align-items:center;justify-content:center}.header-help-btn:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-light);transform:scale(1.05)}.settings-btn{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;border-radius:var(--radius-sm);font-size:var(--font-lg);transition:all var(--transition-fast);flex-shrink:0;position:relative}.tab-content{padding:var(--spacing-xl);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-width:1200px;margin:0 auto;position:relative;overflow:visible}#friends-tab.tab-content{max-width:1620px;width:min(1620px,100%)}#weekly-tab.tab-content{max-width:none;width:max-content;overflow:visible}#weekly-tab{width:max-content;max-width:none;margin-left:auto;margin-right:auto;overflow:visible}.weekly-cards{display:flex;gap:var(--spacing-xl);padding:12px 0;align-items:flex-start;width:max-content;max-width:none;justify-content:center;box-sizing:border-box;margin:0 auto}#main-content{width:max-content;max-width:100%;margin:0 auto;overflow-x:auto;overflow-y:visible}.weekly-card{padding:14px 16px 16px;background-color:var(--color-surface);border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:relative;overflow:visible;flex:0 0 auto;width:fit-content;max-width:100%}.weekly-card .tracker-table{width:100%}.add-character{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-sm);background-color:var(--color-surface);max-width:fit-content}.add-character input,.add-character select{padding:0 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-dark);color:var(--color-text);min-width:80px;font-size:var(--font-sm);min-height:34px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}#char-name,#char-class{max-width:170px}#char-ilvl{max-width:90px}#char-cp{max-width:170px}.add-character button{background-color:var(--color-primary);color:var(--color-bg-dark);border:1px solid var(--color-border);padding:0 14px;border-radius:var(--radius-md);min-height:34px;cursor:pointer;font-weight:700;font-size:var(--font-sm);transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.add-character button:hover{background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}#roster-list{display:grid;grid-template-columns:repeat(auto-fit,200px);gap:var(--spacing-sm);justify-content:center}.character-card{background-color:var(--color-surface-hover);padding:var(--spacing-lg);border-radius:var(--radius-md);width:200px;min-height:220px;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);cursor:move;border:1px solid transparent;display:flex;flex-direction:column}.character-card h3,.character-card p,.character-card img{pointer-events:none;-webkit-user-select:none;user-select:none}.character-card button{pointer-events:auto}.character-card:hover{border-color:var(--color-border-light)}.character-card.dragging{opacity:.5;transform:scale(.95);cursor:grabbing}.character-card:active{cursor:grabbing;opacity:.8}.character-card h3{margin:0 0 var(--spacing-sm) 0;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;font-size:var(--font-lg)}.character-card p{margin:var(--spacing-xs) 0;font-size:var(--font-sm)}.character-card .card-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:auto;align-items:flex-start}.remove-icon{position:absolute;bottom:var(--spacing-lg);right:var(--spacing-lg);width:35px;height:25px;z-index:1;pointer-events:auto;cursor:pointer}.remove-icon img{width:100%;height:100%;display:block;cursor:pointer;pointer-events:auto;transition:all var(--transition-fast)}.remove-icon:hover{transform:scale(1.2)}.remove-icon:hover img{filter:brightness(1.8)}.character-card button{padding:6px var(--spacing-md);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-xs);font-weight:500;transition:all var(--transition-fast)}.hide-weekly-btn{background-color:#3a3f52;color:var(--color-text);white-space:nowrap}.hide-weekly-btn:hover{background-color:#4a5066}.edit-btn{background-color:var(--color-warning);color:var(--color-bg-dark);padding-right:var(--spacing-2xl)}.edit-btn:hover{background-color:#e68900;transform:translateY(-1px)}.form-row{display:flex;gap:8px}.form-row input{width:180px}.sort-roster-btn{padding:8px 12px;background-color:var(--color-primary);color:var(--color-bg-dark);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-md);cursor:pointer;transition:all var(--transition-fast);position:relative;display:inline-flex;align-items:center;gap:8px;z-index:2}.sort-roster-btn.active{background-color:#d4af3726;border-color:var(--color-primary);color:var(--color-primary)}#refresh-roster-btn{color:var(--color-text)}#refresh-roster-btn:hover{color:var(--color-primary)}.sort-roster-btn .btn-label{font-weight:600}.cooldown-active{opacity:.7;cursor:not-allowed!important}.sort-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:1100;min-width:150px;display:block;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-4px) scale(.98);transform-origin:top left;transition:opacity var(--transition-fast),transform var(--transition-fast),visibility var(--transition-fast)}.sort-dropdown.visible{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0) scale(1)}.sort-dropdown button{width:100%;padding:10px 14px;background:transparent;border:none;color:var(--color-text-secondary);text-align:left;cursor:pointer;transition:all .15s ease;font-size:13px}.sort-dropdown button:hover{background-color:var(--color-surface-hover);color:var(--color-text)}.sort-dropdown button.selected{color:var(--color-primary);background-color:color-mix(in srgb,var(--color-primary) 12%,transparent)}.sort-dropdown button:first-child{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.sort-dropdown button:last-child{border-radius:0 0 var(--radius-sm) var(--radius-sm)}#roster-switcher-container{display:inline-flex;align-items:center;position:relative;max-width:100%;z-index:60}#roster-switcher-container>div{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));border-radius:var(--radius-md);background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 90%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-darker)));box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.roster-switcher{display:flex;align-items:center;gap:6px;margin-right:0;min-width:0}.roster-select{background:color-mix(in srgb,var(--color-surface) 90%,var(--color-bg-dark));color:var(--color-text);border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));border-radius:var(--radius-md);padding:0 10px;font-size:.86rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:164px;height:31px}.roster-select:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.roster-meta-chip{display:inline-flex;align-items:center;justify-content:center;min-width:58px;height:28px;padding:0 7px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));background:color-mix(in srgb,var(--color-surface-light) 88%,var(--color-surface));color:var(--color-text-secondary);font-size:.7rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}.roster-actions{display:flex;gap:5px}.roster-actions .btn-icon{background:color-mix(in srgb,var(--color-surface-light) 88%,var(--color-surface));border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));color:var(--color-text-secondary);width:29px;height:29px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:.84rem;padding:0}.roster-actions .btn-icon:hover:not(:disabled){background:color-mix(in srgb,var(--color-primary) 22%,var(--color-surface));border-color:color-mix(in srgb,var(--color-primary) 52%,var(--color-border));color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.roster-actions .btn-icon.active{background:color-mix(in srgb,var(--color-primary) 24%,var(--color-surface));border-color:color-mix(in srgb,var(--color-primary) 56%,var(--color-border));color:var(--color-primary)}.roster-actions .btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-error{background:var(--color-error);color:#fff;border:none}.btn-error:hover{background:color-mix(in srgb,var(--color-error) 85%,var(--color-bg-dark))}#roster-switcher-container .visible-rosters-popover{top:calc(100% + 8px);right:0;left:auto;width:300px;border-color:color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 90%,var(--color-bg-darker)));z-index:80}#roster-switcher-container .visible-rosters-popover__header{color:var(--color-primary);letter-spacing:.02em;padding:2px 2px 4px}#roster-switcher-container .visible-rosters-list{gap:6px}#roster-switcher-container .visible-rosters-item{min-height:34px;padding:6px 10px;transition:border-color var(--transition-fast),background-color var(--transition-fast)}#roster-switcher-container .visible-rosters-item:hover{border-color:color-mix(in srgb,var(--color-primary) 44%,var(--color-border));background:color-mix(in srgb,var(--color-primary) 10%,var(--color-surface-light))}#roster-switcher-container .roster-switcher-dialog{position:absolute;top:calc(100% + 8px);right:0;z-index:90;width:300px;border:1px solid color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));border-radius:var(--radius-md);background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 90%,var(--color-bg-darker)));box-shadow:var(--shadow-lg);padding:10px;display:grid;gap:8px}#roster-switcher-container .roster-switcher-dialog__title{font-size:.9rem;font-weight:700;color:var(--color-primary)}#roster-switcher-container .roster-switcher-dialog__text{margin:0;font-size:.82rem;color:var(--color-text-secondary);line-height:1.4}#roster-switcher-container .roster-switcher-dialog__label{font-size:.78rem;color:var(--color-text-secondary)}#roster-switcher-container .roster-switcher-dialog input{width:100%;min-height:32px;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));background:var(--color-bg-dark);color:var(--color-text)}#roster-switcher-container .roster-switcher-dialog__actions{display:flex;justify-content:flex-end;gap:6px}#roster-switcher-container .btn-icon-text{min-height:30px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);padding:0 10px;font-size:.78rem;font-weight:600;cursor:pointer}#roster-switcher-container .btn-icon-text.primary{border-color:color-mix(in srgb,var(--color-primary) 46%,var(--color-border));background:color-mix(in srgb,var(--color-primary) 18%,var(--color-surface));color:var(--color-primary)}#roster-switcher-container .btn-icon-text:disabled{opacity:.55;cursor:not-allowed}#roster-tab{--roster-ease-out: cubic-bezier(.2, .8, .2, 1);--roster-ease-snap: cubic-bezier(.18, .9, .28, 1.12);--roster-focus-ring: 0 0 0 2px color-mix(in srgb, var(--color-primary) 40%, transparent);display:grid;gap:var(--spacing-md);width:100%;max-width:640px;margin-inline:auto}#roster-tab .roster-header{display:flex;align-items:center;justify-content:center;position:relative;gap:var(--spacing-sm);padding-bottom:8px;border-bottom:1px solid color-mix(in srgb,var(--color-border-light) 52%,var(--color-border));animation:rosterFadeUp .3s var(--roster-ease-out) both}#roster-tab .roster-heading-group{display:grid;gap:var(--spacing-xs);justify-items:center;text-align:center}#roster-tab .roster-heading-group h1{margin:0}#roster-tab .roster-subtitle{margin:0;color:var(--color-text-secondary);font-size:var(--font-xs)}#roster-tab .roster-header-actions{display:flex;justify-content:flex-end;position:absolute;right:0;top:50%;transform:translateY(-50%)}#roster-tab .roster-summary{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}#roster-tab .roster-summary-chip{display:inline-flex;align-items:center;border:1px solid color-mix(in srgb,var(--color-primary) 28%,var(--color-border));background:color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-dark));color:var(--color-text-secondary);border-radius:var(--radius-full);padding:3px var(--spacing-sm);font-size:var(--font-xs);letter-spacing:.02em;transition:border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}#roster-tab .roster-summary-chip:hover{color:var(--color-text);transform:translateY(-1px);border-color:color-mix(in srgb,var(--color-primary) 44%,var(--color-border));box-shadow:var(--shadow-sm)}#roster-tab .roster-controls{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;justify-items:stretch;gap:var(--spacing-xs);padding:6px;border:1px solid color-mix(in srgb,var(--color-border-light) 50%,var(--color-border));border-radius:var(--radius-lg);background:color-mix(in srgb,var(--color-surface) 92%,var(--color-bg-darker));box-shadow:var(--shadow-sm);position:relative;overflow:visible;z-index:20;isolation:isolate;max-width:620px;width:100%;margin-inline:auto}#roster-tab .roster-controls:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(120deg,color-mix(in srgb,var(--color-primary) 12%,transparent) 0%,transparent 28%,transparent 72%,color-mix(in srgb,var(--color-primary-light) 8%,transparent) 100%);opacity:.6}#roster-tab .roster-form-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:240;display:grid;place-items:center;background:color-mix(in srgb,var(--color-bg-darker) 64%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}#roster-tab .roster-form-panel{width:min(620px,calc(100vw - 24px));max-height:calc(100vh - 36px);overflow:auto;border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));border-radius:var(--radius-lg);background:color-mix(in srgb,var(--color-surface) 94%,var(--color-bg-darker));box-shadow:var(--shadow-lg);padding:var(--spacing-sm)}#roster-tab .roster-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xs)}#roster-tab .roster-form-header h3{margin:0}#roster-tab .roster-form-close{width:30px;height:30px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-size:1rem}#roster-tab .add-character{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:6px;padding:6px;border-color:color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));background:color-mix(in srgb,var(--color-surface-light) 82%,var(--color-surface));max-width:none}#roster-tab .add-character input,#roster-tab .add-character select,#roster-tab .add-character button{width:100%;min-height:31px}#roster-tab .add-character input,#roster-tab .add-character select{background-color:color-mix(in srgb,var(--color-bg-dark) 74%,var(--color-surface));min-width:0;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}#roster-tab .add-character button{border:1px solid color-mix(in srgb,var(--color-primary) 36%,var(--color-border));white-space:nowrap;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast);font-size:var(--font-xs)}#roster-tab .add-character #add-char{min-width:112px}#roster-tab .add-character #char-name,#roster-tab .add-character #char-class,#roster-tab .add-character #char-ilvl,#roster-tab .add-character #char-cp{max-width:100%}#roster-tab .add-character input:hover,#roster-tab .add-character select:hover{border-color:color-mix(in srgb,var(--color-primary) 34%,var(--color-border))}#roster-tab .add-character input:focus-visible,#roster-tab .add-character select:focus-visible,#roster-tab .add-character button:focus-visible,#roster-tab #sort-roster-btn:focus-visible,#roster-tab #refresh-roster-btn:focus-visible,#roster-tab #open-add-char-btn:focus-visible,#roster-tab #import-mathi-btn:focus-visible,#roster-tab .sort-dropdown button:focus-visible,#roster-tab .character-card .card-buttons button:focus-visible,#roster-tab .remove-icon:focus-visible{outline:none;box-shadow:var(--roster-focus-ring)}#roster-tab .add-character button[type=button]:not(#add-char){background:var(--color-surface);color:var(--color-text-secondary);border-color:var(--color-border)}#roster-tab .add-character button[type=button]:not(#add-char):hover{background:var(--color-surface-hover);color:var(--color-text)}#roster-tab #sort-roster-btn,#roster-tab #refresh-roster-btn,#roster-tab #open-add-char-btn,#roster-tab #import-mathi-btn{width:auto;min-width:92px;justify-content:center;min-height:27px;padding-inline:7px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}#roster-tab #sort-roster-btn .btn-label,#roster-tab #refresh-roster-btn .btn-label,#roster-tab #open-add-char-btn .btn-label,#roster-tab #import-mathi-btn .btn-label{font-size:var(--font-xs);line-height:1}#roster-tab #import-mathi-btn .btn-icon-image{width:18px;height:18px;object-fit:contain;flex-shrink:0}#roster-tab #sort-roster-btn,#roster-tab #refresh-roster-btn,#roster-tab #open-add-char-btn,#roster-tab #import-mathi-btn{background:var(--color-surface-light);border-color:color-mix(in srgb,var(--color-primary) 34%,var(--color-border));color:var(--color-text)}#roster-tab #sort-roster-btn{justify-self:start;grid-column:1}#roster-tab #refresh-roster-btn{justify-self:end;grid-column:3}#roster-tab .add-character-source-group{grid-column:2;justify-self:center;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:8px;min-width:0;padding:4px 8px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--color-primary) 26%,var(--color-border));background:color-mix(in srgb,var(--color-surface-light) 86%,var(--color-surface));box-shadow:inset 0 1px color-mix(in srgb,var(--color-primary-light) 10%,transparent)}#roster-tab .add-character-source-title{font-size:var(--font-xs);color:var(--color-text-secondary);font-weight:600;letter-spacing:.02em;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}#roster-tab .add-character-source-title:before,#roster-tab .add-character-source-title:after{content:"—";color:color-mix(in srgb,var(--color-primary) 46%,var(--color-border));font-weight:700}#roster-tab .add-character-source-actions{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:6px;min-width:216px}#roster-tab .add-character-source-actions #open-add-char-btn,#roster-tab .add-character-source-actions #import-mathi-btn{min-width:108px;width:100%;justify-content:center;height:32px;min-height:32px;padding-block:0}#roster-tab #sort-roster-btn:hover:not(.cooldown-active),#roster-tab #refresh-roster-btn:hover:not(:disabled),#roster-tab #open-add-char-btn:hover:not(:disabled),#roster-tab #import-mathi-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}#roster-tab #sort-roster-btn:hover:not(.cooldown-active),#roster-tab #refresh-roster-btn:hover:not(:disabled),#roster-tab #import-mathi-btn:hover:not(:disabled){background:color-mix(in srgb,var(--color-primary) 12%,var(--color-surface-light));color:var(--color-primary)}#roster-tab #roster-list{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;position:relative;z-index:1;width:100%;max-width:620px;margin-inline:auto}#roster-tab .roster-empty{grid-column:1 / -1;border:1px dashed color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));border-radius:var(--radius-lg);background:color-mix(in srgb,var(--color-surface-light) 78%,var(--color-surface));padding:var(--spacing-xl);text-align:center}#roster-tab .character-card{width:auto;min-height:224px;padding-bottom:var(--spacing-md);border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 90%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-darker)));box-shadow:var(--shadow-sm);position:relative;transition:transform var(--transition-fast) var(--roster-ease-out),box-shadow var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}#roster-tab .character-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--color-primary) 36%,var(--color-border))}#roster-tab .character-card:focus-within{border-color:color-mix(in srgb,var(--color-primary) 42%,var(--color-border));box-shadow:var(--roster-focus-ring),var(--shadow-md)}#roster-tab .character-card h3{max-width:calc(100% - 44px);margin-bottom:var(--spacing-sm)}#roster-tab .character-class-icon{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:30px;height:30px;pointer-events:none;z-index:1;transition:transform var(--transition-fast) var(--roster-ease-snap),filter var(--transition-fast)}#roster-tab .character-card:hover .character-class-icon{transform:translateY(-1px) scale(1.06);filter:drop-shadow(0 0 8px color-mix(in srgb,var(--color-primary) 26%,transparent))}#roster-tab .character-card .card-actions{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;column-gap:8px;row-gap:6px;margin-top:auto;align-items:center}#roster-tab .character-card .card-actions button{width:auto;max-width:100%;border:1px solid color-mix(in srgb,var(--color-border-light) 52%,var(--color-border));background:var(--color-surface);color:var(--color-text-secondary)}#roster-tab .character-card .card-buttons button:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:color-mix(in srgb,var(--color-primary) 34%,var(--color-border));transform:translateY(-1px)}#roster-tab .character-card .hide-weekly-btn{grid-column:1;grid-row:2;background:color-mix(in srgb,var(--color-surface-light) 84%,var(--color-surface))}#roster-tab .character-card .edit-btn{grid-column:1;grid-row:1;justify-self:start;background:color-mix(in srgb,var(--color-warning) 26%,var(--color-surface));color:var(--color-text);border-color:color-mix(in srgb,var(--color-warning) 42%,var(--color-border));padding-right:var(--spacing-sm)}#roster-tab .remove-icon{position:static;grid-column:2;grid-row:2;align-self:center;justify-self:end;width:28px;height:20px;z-index:3}#roster-tab .remove-icon:hover{transform:translateY(-1px) scale(1.08)}#roster-tab .remove-icon:hover img{filter:brightness(1.25)}#roster-tab .character-card.dragging{opacity:.72;transform:scale(.98);border-color:color-mix(in srgb,var(--color-primary) 52%,var(--color-border));box-shadow:var(--shadow-lg)}#roster-tab #roster-list.drag-active .character-card .card-buttons button,#roster-tab #roster-list.drag-active .character-card .remove-icon{pointer-events:none}#roster-tab .character-card:not(.dragging){animation:rosterCardIn .32s var(--roster-ease-out) both}#roster-tab .character-card:nth-child(2n){animation-delay:25ms}#roster-tab .character-card:nth-child(3n){animation-delay:45ms}#roster-tab .character-card:nth-child(4n){animation-delay:65ms}#roster-tab .roster-summary{animation:rosterFadeUp .34s var(--roster-ease-out) both}#roster-tab .roster-controls{animation:rosterFadeUp .38s var(--roster-ease-out) both}@keyframes rosterFadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes rosterCardIn{0%{opacity:0;transform:translateY(8px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){#roster-tab .roster-header,#roster-tab .roster-summary,#roster-tab .roster-controls,#roster-tab .character-card:not(.dragging){animation:none}#roster-tab .character-card,#roster-tab .character-class-icon,#roster-tab .sort-dropdown,#roster-tab .add-character input,#roster-tab .add-character select,#roster-tab .add-character button,#roster-tab #sort-roster-btn,#roster-tab #refresh-roster-btn,#roster-tab .roster-summary-chip,#roster-tab .character-card .card-buttons button,#roster-tab .remove-icon{transition:none}}@media(max-width:900px){#roster-tab .roster-header{flex-direction:column;align-items:stretch}#roster-tab .roster-header-actions{position:static;right:auto;top:auto;transform:none;justify-content:flex-start}#roster-tab .roster-controls{grid-template-columns:1fr;justify-items:stretch}#roster-tab .add-character-source-group{grid-column:1;justify-self:stretch;flex-direction:column;align-items:stretch;gap:6px;grid-template-columns:1fr;padding:6px}#roster-tab .add-character-source-title{text-align:center;justify-content:center}#roster-tab .add-character-source-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs);min-width:0}#roster-tab .add-character button{width:100%}#roster-tab #roster-list{grid-template-columns:repeat(2,minmax(0,1fr))}#roster-tab #sort-roster-btn,#roster-tab #refresh-roster-btn,#roster-tab #open-add-char-btn,#roster-tab #import-mathi-btn{width:100%;min-width:0;justify-self:stretch;grid-column:1;justify-content:center}}@media(max-width:640px){#roster-tab .add-character,#roster-tab #roster-list{grid-template-columns:minmax(0,1fr)}}.friends-heatmap-modal[style*="display: block"]{display:flex!important;align-items:center;justify-content:center}.friends-heatmap-modal .modal-overlay{pointer-events:auto}.friends-heatmap-modal__content{position:relative;width:min(99vw,1900px);height:min(97vh,1080px);max-width:none;max-height:none;display:flex;flex-direction:column;gap:var(--spacing-sm);overflow:hidden;transform:none;transition:none}.friends-heatmap{flex:1;min-height:0;overflow:visible}.friends-heatmap-dual{display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:0}.friends-heatmap-intro{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);padding:8px 10px;border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));border-radius:var(--radius-md);background:color-mix(in srgb,var(--color-surface-light) 86%,transparent)}.friends-heatmap-intro__title{margin:0;font-size:var(--font-md);color:var(--color-text);font-weight:700;letter-spacing:.2px}.friends-heatmap-intro__meta{margin:2px 0 0;font-size:var(--font-xs);color:var(--color-text-secondary)}.friends-heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}.friends-heatmap-legend__item{display:inline-flex;align-items:center;justify-content:center;min-height:18px;padding:0 7px;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:10px;font-weight:700;letter-spacing:.2px;color:var(--color-text-secondary);background:color-mix(in srgb,var(--color-surface) 86%,transparent);white-space:nowrap}.friends-heatmap-legend__item.state-self-done{color:color-mix(in srgb,var(--color-success) 88%,#fff);border-color:color-mix(in srgb,var(--color-success) 44%,var(--color-border))}.friends-heatmap-legend__item.state-self-available{color:var(--color-text)}.friends-heatmap-legend__item.state-none{color:var(--color-text-muted)}.friends-heatmap-legend__item.state-progress{color:color-mix(in srgb,var(--color-primary) 88%,#fff);border-color:color-mix(in srgb,var(--color-primary) 44%,var(--color-border))}.friends-heatmap-section-title{margin:0;font-size:var(--font-sm);color:var(--color-text-secondary);font-weight:700;letter-spacing:.2px}.friends-heatmap-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:visible;width:100%;max-width:none;height:auto;max-height:none;background:var(--color-bg-darker);margin:0 auto}.friends-heatmap-wrap--primary{border-color:color-mix(in srgb,var(--color-primary) 36%,var(--color-border));box-shadow:inset 0 1px color-mix(in srgb,var(--color-primary) 14%,transparent)}.friends-heatmap-wrap--secondary{border-color:color-mix(in srgb,var(--color-border-light) 56%,var(--color-border))}.friends-heatmap-table{border-collapse:collapse;table-layout:auto;width:max-content;min-width:max-content;font-size:var(--font-xs)}.friends-heatmap-table th,.friends-heatmap-table td{border:1px solid var(--color-border);padding:2px 3px;text-align:center;white-space:nowrap}.friends-heatmap-table thead th{background:var(--color-surface-light);position:sticky;top:0;z-index:2}.friends-heatmap-table thead th:first-child{left:0;z-index:4;background:color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface));box-shadow:1px 0 color-mix(in srgb,var(--color-border-light) 68%,var(--color-border)),10px 0 10px -10px #00000073}.friends-heatmap-table tbody th{background:var(--color-surface);text-align:center;position:sticky;left:0;z-index:3;box-shadow:1px 0 color-mix(in srgb,var(--color-border-light) 60%,var(--color-border)),10px 0 10px -10px #0006}.friends-heatmap-table--summary thead th:first-child,.friends-heatmap-table--summary tbody th.friends-heatmap-roster{width:140px;min-width:140px;max-width:140px;overflow:hidden;text-overflow:ellipsis}.friends-heatmap-table--detail thead th:first-child,.friends-heatmap-table--detail tbody th.friends-heatmap-char-name{width:124px;min-width:124px;max-width:124px;overflow:hidden;text-overflow:ellipsis}.friends-heatmap-table--detail tbody th.friends-heatmap-char-name{color:var(--friends-char-color, var(--color-text));font-weight:700}.friends-heatmap-table thead th:nth-child(n+2),.friends-heatmap-table tbody td{min-width:52px}.friends-heatmap-table--detail thead th:nth-child(n+2),.friends-heatmap-table--detail tbody td{min-width:44px}.friends-heatmap-group.is-self{box-shadow:inset 0 0 0 1px var(--color-primary)}.friends-heatmap-roster.is-self{color:var(--color-primary)}.friends-heatmap-table--summary tbody th.friends-heatmap-roster{color:var(--friends-row-color, var(--color-text));font-weight:700}.friends-heatmap-cell{font-weight:700}.friends-heatmap-cell.state-match{background:color-mix(in srgb,#2abf9e 32%,var(--color-bg-darker));color:var(--color-text)}.friends-heatmap-cell.state-completed{background:color-mix(in srgb,var(--color-surface) 74%,#000);color:var(--color-text-muted);opacity:.8}.friends-heatmap-cell.state-helper{background:color-mix(in srgb,var(--color-info) 30%,var(--color-bg-darker));color:var(--color-text)}.friends-heatmap-cell.state-warning{background:color-mix(in srgb,#a36bde 34%,var(--color-bg-darker));color:var(--color-text)}.friends-heatmap-cell.state-none{background:#0a0a0a;color:var(--color-text-muted)}.friends-heatmap-cell.state-self-done{background:color-mix(in srgb,var(--color-success) 30%,var(--color-bg-darker));color:var(--color-text)}.friends-heatmap-cell.state-self-available{background:#0a0a0a;color:var(--color-text)}.friends-heatmap-table .is-hover-row{outline:1px solid color-mix(in srgb,var(--color-primary) 28%,transparent);outline-offset:-1px}.friends-heatmap-table .is-hover-col{box-shadow:inset 0 0 0 999px color-mix(in srgb,var(--color-primary) 10%,transparent)}.friends-heatmap-table .is-hover-row.is-hover-col{outline:1px solid color-mix(in srgb,var(--color-primary) 45%,transparent);box-shadow:inset 0 0 0 999px color-mix(in srgb,var(--color-primary) 14%,transparent)}.friends-heatmap-empty{margin:0;padding:14px 16px;border:1px dashed color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));border-radius:var(--radius-md);background:color-mix(in srgb,var(--color-surface-light) 84%,transparent);text-align:center}.friends-heatmap-empty h3{margin:0;font-size:var(--font-md);color:var(--color-text)}.friends-heatmap-empty p{margin:6px 0 0;font-size:var(--font-sm);color:var(--color-text-secondary)}#friends-heatmap-modal[style*="display: block"]{display:flex!important;align-items:center!important;justify-content:center!important;padding:12px}#friends-heatmap-modal .friends-heatmap-modal__content{width:min(94vw,1000px);max-width:min(94vw,1000px);height:min(94vh,1020px);max-height:min(94vh,1020px);padding:10px 12px;overflow:auto;transform:none!important}@media(max-width:900px){.friends-heatmap-intro{flex-direction:column;align-items:stretch}.friends-heatmap-legend{justify-content:flex-start}}#friends-heatmap-modal #friends-heatmap{display:flex;flex-direction:column;min-height:0;overflow:visible}.friends-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-darker);overflow:hidden;flex:0 0 calc((100% - (2 * var(--spacing-md))) / 3);max-width:calc((100% - (2 * var(--spacing-md))) / 3);min-width:0}.friends-card--self{border-color:var(--color-primary)}.friends-card__title{margin:0;padding:0;background:transparent;color:var(--color-primary);font-size:var(--font-md);border-bottom:0;text-align:left}.friends-card__header{display:flex;flex-direction:column;gap:6px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border-bottom:1px solid var(--color-border)}.friends-card__meta{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:20px}.friends-card__summary{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.15px}.friends-card__sync-badge{display:inline-flex;align-items:center;justify-content:center;min-height:18px;padding:0 7px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface) 85%,var(--color-bg-darker));color:var(--color-text-secondary);font-size:10px;font-weight:700;letter-spacing:.22px;text-transform:uppercase;white-space:nowrap}.friends-card__sync-badge.is-self{border-color:color-mix(in srgb,var(--color-primary) 45%,var(--color-border));color:var(--color-primary)}.friends-card__sync-badge.is-fresh{border-color:color-mix(in srgb,var(--color-success) 45%,var(--color-border));color:color-mix(in srgb,var(--color-success) 88%,#fff)}.friends-card__sync-badge.is-stale{border-color:color-mix(in srgb,var(--color-warning) 42%,var(--color-border));color:color-mix(in srgb,var(--color-warning) 85%,#fff)}.friends-card__sync-badge.is-nosync{border-style:dashed;color:var(--color-text-muted)}.friends-table-wrap{overflow-x:auto;overflow-y:auto;max-width:100%;max-height:232px;border-radius:0}.friends-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:var(--font-xs);margin:0;border:0;border-radius:0;box-shadow:none;background:transparent}.friends-table th,.friends-table td{border:1px solid var(--color-border);padding:4px 6px;text-align:center}.friends-table th{position:sticky;top:0;background:var(--color-surface-light);z-index:1;white-space:nowrap}.friends-table th:first-child,.friends-table td:first-child{width:56px;min-width:56px;max-width:56px}.friends-table th:not(:first-child),.friends-table td:not(:first-child){width:58px;min-width:58px;max-width:58px}.friends-char-name{text-align:left!important;white-space:nowrap;width:56px;min-width:56px;max-width:56px;overflow:hidden;text-overflow:ellipsis;color:var(--color-text-secondary)}.friends-raid-cell{font-weight:700;transition:background var(--transition-fast),color var(--transition-fast);letter-spacing:.2px}.friends-raid-cell.is-pending{color:var(--color-text-muted);background:var(--color-bg-darker)}.friends-raid-cell.is-done{color:var(--color-text);background:color-mix(in srgb,var(--color-success) 35%,var(--color-bg-darker))}.friends-raid-cell.is-ignored{color:var(--color-text-muted);background:var(--color-surface)}.friends-row-empty,.friends-empty{color:var(--color-text-muted);text-align:center}@media(max-width:1200px){.friends-card{flex-basis:calc((100% - var(--spacing-md)) / 2);max-width:calc((100% - var(--spacing-md)) / 2)}}@media(max-width:860px){.friends-controls-row{flex-direction:column;align-items:flex-start}.friends-add-form{grid-template-columns:1fr}.friends-card{flex-basis:100%;max-width:100%}}#friends-tab,#friends-setup-modal,#friends-heatmap-modal{--friends-surface-soft: color-mix(in srgb, var(--color-surface-light) 90%, transparent);--friends-surface-panel: color-mix(in srgb, var(--color-bg-darker) 84%, var(--color-surface));--friends-surface-hover: color-mix(in srgb, var(--color-surface-hover) 78%, var(--color-surface));--friends-border-soft: color-mix(in srgb, var(--color-border-light) 56%, var(--color-border));--friends-border-strong: color-mix(in srgb, var(--color-primary) 24%, var(--color-border));--friends-card-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-primary) 14%, transparent), 0 6px 14px rgba(0, 0, 0, .18);--friends-card-shadow-soft: inset 0 1px 0 color-mix(in srgb, var(--color-primary) 10%, transparent), 0 3px 8px rgba(0, 0, 0, .12);--friends-item-hover-shadow: inset 2px 0 0 color-mix(in srgb, var(--color-primary) 40%, transparent), 0 3px 8px rgba(0, 0, 0, .12);--friends-btn-shadow: 0 0 0 1px color-mix(in srgb, var(--color-primary) 22%, transparent), 0 1px 2px rgba(0, 0, 0, .24);--friends-btn-shadow-hover: 0 0 0 1px color-mix(in srgb, var(--color-primary) 34%, transparent), 0 3px 6px rgba(0, 0, 0, .22);--friends-focus-ring: 0 0 0 2px color-mix(in srgb, var(--color-primary) 42%, transparent);--friends-panel-gradient: linear-gradient(180deg, color-mix(in srgb, var(--color-surface-light) 88%, transparent) 0%, color-mix(in srgb, var(--color-bg-darker) 92%, transparent) 160%);--friends-table-visible-rows: 7;--friends-table-row-height: 26px;--friends-table-head-height: 28px}#friends-tab .friends-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;margin:0 auto var(--spacing-md);text-align:center}#friends-tab .friends-header-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}#friends-tab .friends-header-actions__primary,#friends-tab .friends-header-actions__secondary{display:flex;align-items:center;gap:8px}#friends-tab .friends-header-actions__secondary{padding-left:12px;border-left:1px solid color-mix(in srgb,var(--friends-border-soft) 72%,transparent)}#friends-tab .friends-header h1{margin:0;letter-spacing:.25px;font-weight:700}#friends-tab .friends-header-actions .header-icon-btn{height:36px;min-width:36px;padding:6px;gap:6px;background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);box-shadow:none}#friends-tab .friends-header-actions .header-icon-btn:disabled{opacity:.5;border-color:color-mix(in srgb,var(--friends-border-soft) 80%,transparent);color:color-mix(in srgb,var(--color-text-secondary) 80%,var(--color-text-muted));transform:none}#friends-tab #friends-setup-btn.header-icon-btn{border-color:color-mix(in srgb,var(--color-primary) 52%,var(--color-border));background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 26%,var(--color-surface)),color-mix(in srgb,var(--color-primary-dark) 20%,var(--color-surface)));box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 26%,transparent),0 1px 2px #00000042}#friends-tab #friends-setup-btn.header-icon-btn:hover:not(:disabled),#friends-tab #friends-setup-btn.header-icon-btn.is-active{border-color:color-mix(in srgb,var(--color-primary) 68%,var(--color-border));background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 34%,var(--color-surface)),color-mix(in srgb,var(--color-primary-dark) 28%,var(--color-surface)));box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 38%,transparent),0 3px 7px #0000003d}#friends-tab .friends-header-actions .header-icon-btn:focus-visible,#friends-tab .friends-card:focus-within,#friends-setup-modal .friends-profile-upload-btn:focus-visible,#friends-setup-modal .friends-add-form button:focus-visible,#friends-setup-modal .friends-copy-code-btn:focus-visible,#friends-setup-modal .friends-visibility-btn:focus-visible,#friends-setup-modal .friends-list-item__remove:focus-visible,#friends-setup-modal .friends-setup-card input:focus-visible,#friends-setup-modal .friends-self-color input:focus-visible,#friends-setup-modal .friends-list-item__color:focus-visible{outline:none;box-shadow:var(--friends-focus-ring)}#friends-setup-modal .friends-setup-card{border-color:var(--friends-border-soft);box-shadow:var(--friends-card-shadow)}#friends-setup-modal .friends-setup-card--friends{box-shadow:var(--friends-card-shadow-soft)}#friends-setup-modal .friends-setup-titlebar p,#friends-setup-modal .friends-setup-card__subtitle{color:color-mix(in srgb,var(--color-text-secondary) 88%,var(--color-text-muted))}#friends-setup-modal .friends-add-form,#friends-setup-modal .friends-self-code--id-card,#friends-setup-modal .friends-controls-row{border-color:var(--friends-border-soft);background:var(--friends-panel-gradient)}#friends-setup-modal .friends-list-item{border-color:var(--friends-border-soft);background:var(--friends-surface-panel)}#friends-setup-modal .friends-list-item:hover{border-color:var(--friends-border-strong);background:var(--friends-surface-hover);box-shadow:var(--friends-item-hover-shadow)}#friends-setup-modal .friends-profile-upload-btn,#friends-setup-modal .friends-add-form button{box-shadow:var(--friends-btn-shadow)}#friends-setup-modal .friends-profile-upload-btn:hover:enabled,#friends-setup-modal .friends-add-form button:hover{box-shadow:var(--friends-btn-shadow-hover)}#friends-tab .friends-card{flex:0 0 calc((100% - (2 * var(--spacing-lg))) / 3);max-width:calc((100% - (2 * var(--spacing-lg))) / 3);border-color:var(--friends-border-soft);background:var(--friends-surface-panel);box-shadow:0 2px 8px #00000029;animation:friends-card-enter .26s cubic-bezier(.2,.7,.2,1) both;position:relative;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}#friends-tab .friends-card:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:2px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-primary) 64%,transparent);opacity:0;transition:opacity var(--transition-fast),transform var(--transition-fast);transform:scaleY(.7);pointer-events:none}#friends-tab .friends-card:hover,#friends-tab .friends-card:focus-within{transform:translateY(-1px);border-color:var(--friends-border-strong);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 14%,transparent),0 6px 14px #0003}#friends-tab .friends-card:hover:before,#friends-tab .friends-card:focus-within:before{opacity:.85;transform:scaleY(1)}#friends-tab .friends-card:nth-child(1){animation-delay:0ms}#friends-tab .friends-card:nth-child(2){animation-delay:30ms}#friends-tab .friends-card:nth-child(3){animation-delay:60ms}#friends-tab .friends-card:nth-child(4){animation-delay:90ms}#friends-tab .friends-card:nth-child(5){animation-delay:.12s}#friends-tab .friends-card:nth-child(6){animation-delay:.15s}#friends-tab .friends-card:nth-child(7){animation-delay:.18s}#friends-tab .friends-card:nth-child(8){animation-delay:.21s}#friends-tab .friends-card__title{background:var(--friends-surface-soft);border-bottom-color:var(--friends-border-soft);font-size:15px;font-weight:700;letter-spacing:.18px;line-height:1.2}#friends-tab .friends-card__header{background:var(--friends-surface-soft);border-bottom-color:var(--friends-border-soft);padding:9px 12px 8px;gap:5px}#friends-tab .friends-card__meta{padding-top:3px;border-top:1px solid color-mix(in srgb,var(--friends-border-soft) 72%,transparent)}#friends-tab .friends-card__summary{color:color-mix(in srgb,var(--color-text-secondary) 88%,var(--color-text-muted));font-size:10px;letter-spacing:.2px;font-weight:500}#friends-tab .friends-row-empty,#friends-tab .friends-empty{color:color-mix(in srgb,var(--color-text-secondary) 84%,var(--color-text))}#friends-tab .friends-char-name{color:color-mix(in srgb,var(--color-text-secondary) 86%,var(--color-text))}#friends-tab .friends-card__sync-badge{min-height:19px;padding:0 8px;font-size:9px}#friends-tab .friends-card__sync-badge.is-stale{color:color-mix(in srgb,var(--color-warning) 92%,#fff)}#friends-tab .friends-card__sync-badge.is-nosync{color:color-mix(in srgb,var(--color-text-secondary) 88%,var(--color-text))}#friends-tab .friends-table th{background:var(--friends-surface-soft)}#friends-tab .friends-table td,#friends-tab .friends-table th{border-color:color-mix(in srgb,var(--friends-border-soft) 86%,var(--color-border))}#friends-tab .friends-grid{gap:var(--spacing-lg)}#friends-tab .friends-table-wrap{height:calc(var(--friends-table-head-height) + (var(--friends-table-visible-rows) * var(--friends-table-row-height)));min-height:calc(var(--friends-table-head-height) + (var(--friends-table-visible-rows) * var(--friends-table-row-height)));max-height:calc(var(--friends-table-head-height) + (var(--friends-table-visible-rows) * var(--friends-table-row-height)));overflow-y:auto}@keyframes friends-card-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1200px){#friends-tab .friends-header{align-items:stretch}#friends-tab .friends-header-actions{justify-content:center}#friends-tab .friends-header-actions__secondary{padding-left:10px}#friends-tab .friends-grid{gap:var(--spacing-md)}#friends-tab .friends-card__header{padding:8px 10px 7px}}@media(max-width:860px){#friends-tab .friends-header-actions{flex-direction:column;align-items:stretch;gap:8px;width:100%;justify-content:center}#friends-tab .friends-header-actions__primary,#friends-tab .friends-header-actions__secondary{justify-content:center}#friends-tab .friends-header-actions__secondary{border-left:0;padding-left:0;padding-top:8px;border-top:1px solid color-mix(in srgb,var(--friends-border-soft) 70%,transparent)}#friends-tab .friends-header-actions .header-icon-btn{min-width:120px;justify-content:center}#friends-tab .friends-grid{gap:10px}#friends-tab .friends-card__meta{flex-wrap:wrap;align-items:flex-start;gap:6px;padding-top:2px}#friends-tab .friends-card__summary{width:100%}#friends-tab .friends-card__sync-badge{min-height:17px;padding:0 6px;font-size:9px}}@media(prefers-reduced-motion:reduce){#friends-tab .friends-card{animation:none;transition:none;transform:none}#friends-tab .friends-card:before{transition:none}}.friends-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-md)}.friends-header h1{margin:0}.friends-header-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.friends-self-code-row{display:inline-flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.friends-self-color input{width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);padding:0;cursor:pointer}.friends-self-code{display:inline-flex;align-items:center;gap:var(--spacing-sm);border:1px solid var(--color-border);background:var(--color-bg-darker);border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm)}.friends-self-label{color:var(--color-text-secondary);font-size:var(--font-sm)}#friends-self-code{color:var(--color-primary);font-size:var(--font-sm);font-weight:700;-webkit-user-select:text;user-select:text}.friends-copy-code-btn,.friends-visibility-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-sm);min-height:28px;min-width:28px;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.friends-visibility-btn:hover{background:var(--color-surface-hover);border-color:var(--color-border-light)}.friends-visibility-btn .friends-visibility-icon,.friends-copy-code-btn img{width:16px;height:16px;display:block}.friends-copy-code-btn img{filter:brightness(0) invert(1)}.friends-controls-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.friends-self-pin-label,.friends-autosync-toggle{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary)}.friends-self-pin-input-wrap{display:inline-flex;align-items:center;gap:6px}.friends-self-pin-label input{min-height:34px;background:var(--color-bg-darker);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:0 var(--spacing-sm);min-width:180px}.friends-add-form{display:grid;grid-template-columns:220px 110px 150px auto;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);align-items:center;width:fit-content;max-width:100%}.friends-add-form input,.friends-add-form button{min-height:34px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.friends-add-form input{background:var(--color-bg-darker);color:var(--color-text);padding:0 10px;font-size:var(--font-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}#friends-code-input{max-width:220px}#friends-pin-input{max-width:110px}#friends-alias-input{max-width:150px}.friends-add-form button{background:var(--color-primary);color:var(--color-bg-dark);font-weight:700;cursor:pointer;padding:0 12px;min-width:108px;justify-self:start;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.friends-add-form button:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.friends-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.friends-list-item{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"alias updated" "code actions";align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-darker);padding:var(--spacing-sm);row-gap:2px;column-gap:var(--spacing-sm)}.friends-list-item__alias{grid-area:alias;color:var(--color-text);font-size:var(--font-sm);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friends-list-item__updated-at{grid-area:updated;color:var(--color-text-muted);font-size:var(--font-xs);white-space:nowrap;flex-shrink:0}.friends-list-item__code{grid-area:code;color:var(--color-text-muted);font-size:var(--font-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friends-list-item__remove{grid-area:remove;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-sm);min-height:30px;padding:0 var(--spacing-sm);cursor:pointer;justify-self:end}.friends-list-item__actions{grid-area:actions;display:inline-flex;align-items:center;justify-self:end;gap:6px}.friends-list-item__color{width:24px;height:24px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);padding:0;cursor:pointer}.friends-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:start;align-content:flex-start;width:100%}.friends-header-actions .header-icon-btn.is-active{border-color:var(--color-primary)}.friends-heatmap-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200}.friends-setup-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1190}.friends-setup-modal[style*="display: block"]{display:flex!important;align-items:center;justify-content:center;padding:12px}.friends-setup-modal .modal-overlay{pointer-events:auto}.friends-setup-modal__content{position:relative;width:min(95vw,1080px);max-width:min(95vw,1080px);max-height:min(92vh,900px);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:var(--spacing-lg);transform:none;border:1px solid color-mix(in srgb,var(--color-primary) 28%,var(--color-border));background:color-mix(in srgb,var(--color-surface) 86%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}#friends-setup-modal .friends-add-form{width:100%;max-width:none;grid-template-columns:repeat(3,minmax(0,1fr));margin:0;padding:var(--spacing-sm);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-light)}#friends-setup-modal .friends-add-form>*{min-width:0}#friends-setup-modal .friends-add-form button{grid-column:1 / -1;justify-self:end;min-width:140px}#friends-setup-modal #friends-code-input,#friends-setup-modal #friends-pin-input,#friends-setup-modal #friends-alias-input{max-width:none}#friends-setup-modal .friends-list{margin-bottom:0;max-height:none;min-height:0;flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding-right:2px;grid-template-columns:repeat(2,minmax(0,1fr))}#friends-setup-modal .friends-list.friends-list--empty{display:flex;align-items:stretch}#friends-setup-modal .friends-setup-titlebar h2{margin:0}#friends-setup-modal .friends-setup-titlebar p{margin:0;color:var(--color-text-muted);font-size:var(--font-sm)}#friends-setup-modal .friends-setup-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,1.22fr);gap:var(--spacing-md);min-height:0}#friends-setup-modal .friends-setup-card{border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);padding:var(--spacing-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-md);min-height:0;min-width:0}#friends-setup-modal .friends-setup-card__header h3{margin:0;color:var(--color-primary);font-size:var(--font-lg);letter-spacing:.2px}#friends-setup-modal .friends-setup-card__subtitle{color:var(--color-text-muted);font-size:var(--font-xs)}#friends-setup-modal .friends-self-code-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;align-items:center;gap:var(--spacing-sm);margin-bottom:0}#friends-setup-modal .friends-self-code--id-card{display:grid;grid-template-columns:minmax(0,1fr);align-items:start;gap:2px;border:1px solid var(--color-border);background:var(--color-surface-light);min-height:40px;min-width:0;overflow:hidden}#friends-setup-modal .friends-self-label{text-transform:uppercase;letter-spacing:.4px;font-weight:600}#friends-setup-modal #friends-self-code{font-size:var(--font-sm);display:block;max-width:100%;white-space:normal;overflow-wrap:anywhere;word-break:break-word;text-overflow:clip}#friends-setup-modal .friends-copy-code-btn,#friends-setup-modal .friends-visibility-btn,#friends-setup-modal .friends-add-form button,#friends-setup-modal .friends-list-item__remove,#friends-setup-modal .friends-setup-card input{transition:all .3s ease}#friends-setup-modal .friends-copy-code-btn{min-width:88px;padding:0 10px;gap:6px;border-color:color-mix(in srgb,var(--color-primary) 40%,var(--color-border));background:color-mix(in srgb,var(--color-primary) 16%,var(--color-surface))}#friends-setup-modal .friends-copy-code-btn:hover{transform:translateY(-1px);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 42%,transparent),var(--shadow-sm)}#friends-setup-modal .friends-copy-code-btn__text{font-size:var(--font-xs);font-weight:700;letter-spacing:.3px}#friends-setup-modal .friends-copy-code-btn.is-copied{border-color:color-mix(in srgb,var(--color-success) 44%,var(--color-border));background:color-mix(in srgb,var(--color-success) 24%,var(--color-surface))}#friends-setup-modal .friends-self-pin-label{width:100%;justify-content:space-between}#friends-setup-modal .friends-controls-row{margin-bottom:0;width:100%;padding:10px 12px;border:1px solid color-mix(in srgb,var(--color-border-light) 52%,var(--color-border));border-radius:var(--radius-md);background:color-mix(in srgb,var(--color-surface-light) 82%,var(--color-bg-darker))}#friends-setup-modal .friends-self-pin-label{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:var(--spacing-sm)}#friends-setup-modal .friends-self-pin-label>span{color:var(--color-text-secondary);font-size:var(--font-xs);letter-spacing:.35px;text-transform:uppercase;font-weight:700}#friends-setup-modal .friends-self-pin-input-wrap{width:100%;max-width:320px;justify-self:end}#friends-setup-modal .friends-self-pin-label input{flex:1;min-width:0;margin:0}#friends-setup-modal .friends-profile-upload-btn{align-self:flex-start;min-height:36px;min-width:148px;padding:0 14px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--color-primary) 45%,var(--color-border));background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 76%,var(--color-surface)),color-mix(in srgb,var(--color-primary-dark) 74%,var(--color-surface)));color:var(--color-bg-dark);font-weight:700;letter-spacing:.2px;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 24%,transparent),var(--shadow-xs)}#friends-setup-modal .friends-profile-upload-btn:hover:enabled{transform:translateY(-1px);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 34%,transparent),var(--shadow-sm)}#friends-setup-modal .friends-profile-upload-btn:disabled{opacity:.56;cursor:not-allowed;transform:none;box-shadow:none;border-color:color-mix(in srgb,var(--color-border-light) 58%,var(--color-border))}#friends-setup-modal .friends-add-form input{width:100%;min-width:0;margin:0;border-color:color-mix(in srgb,var(--color-primary) 12%,var(--color-border));background:color-mix(in srgb,var(--color-bg-darker) 88%,transparent)}#friends-setup-modal .friends-add-form button{min-height:36px;border-color:color-mix(in srgb,var(--color-primary) 55%,var(--color-border));background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 82%,var(--color-surface)),color-mix(in srgb,var(--color-primary-dark) 80%,var(--color-surface)));color:var(--color-bg-dark);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 24%,transparent),var(--shadow-xs)}#friends-setup-modal .friends-add-form button:hover{transform:translateY(-1px);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-primary) 36%,transparent),var(--shadow-sm)}#friends-setup-modal .friends-empty-state{grid-column:1 / -1;width:100%;border:1px dashed var(--color-border);border-radius:var(--radius-md);min-height:100%;height:100%;flex:1 1 auto;display:grid;place-items:center;gap:6px;text-align:center;padding:var(--spacing-md);background:var(--color-surface-light)}#friends-setup-modal .friends-empty-state__icon{font-size:42px;color:color-mix(in srgb,var(--color-primary) 62%,transparent);opacity:.34;line-height:1}#friends-setup-modal .friends-empty-state__text{margin:0;color:var(--color-text-secondary);font-size:var(--font-sm)}#friends-setup-modal .friends-list-item{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"alias updated" "code actions";row-gap:6px;column-gap:10px;padding:10px 12px;border-color:var(--color-border);background:var(--color-surface);min-height:88px;align-content:center;align-items:center}#friends-setup-modal .friends-list-item:hover{border-color:var(--color-border-light);background:var(--color-surface-hover);box-shadow:var(--shadow-xs)}#friends-setup-modal #friends-list>div{width:100%;justify-self:stretch}#friends-setup-modal #friends-list>div.friends-list-item{height:88px}#friends-setup-modal .friends-list-item__alias{font-size:var(--font-sm);line-height:1.2;font-weight:700;letter-spacing:.15px}#friends-setup-modal .friends-list-item__code{color:var(--color-text-secondary);font-size:var(--font-xs);line-height:1.2;align-self:start}#friends-setup-modal .friends-list-item__updated-at{color:var(--color-text-muted);font-size:var(--font-xs);line-height:1.2;justify-self:end;align-self:center}#friends-setup-modal .friends-list-item__actions{align-items:center;gap:8px;justify-self:end;align-self:end}#friends-setup-modal .friends-list-item__remove{min-height:26px;min-width:30px;padding:0;opacity:0;pointer-events:none;transform:translate(6px);border-color:color-mix(in srgb,var(--color-primary) 25%,var(--color-border))}#friends-setup-modal .friends-list-item:hover .friends-list-item__remove,#friends-setup-modal .friends-list-item:focus-within .friends-list-item__remove{opacity:1;pointer-events:auto;transform:translate(0)}#friends-setup-modal .friends-list-item__remove:hover{border-color:color-mix(in srgb,var(--color-danger) 48%,var(--color-border));color:var(--color-danger)}#friends-setup-modal .friends-self-color input,#friends-setup-modal .friends-list-item__color{margin:0;width:28px;height:28px;min-width:28px;padding:0;border:1px solid color-mix(in srgb,var(--color-primary) 20%,var(--color-border));border-radius:var(--radius-sm);background:transparent;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;overflow:hidden}#friends-setup-modal .friends-list-item__color{width:24px;height:24px;min-width:24px}#friends-setup-modal .friends-self-color input::-webkit-color-swatch-wrapper,#friends-setup-modal .friends-list-item__color::-webkit-color-swatch-wrapper{padding:0}#friends-setup-modal .friends-self-color input::-webkit-color-swatch,#friends-setup-modal .friends-list-item__color::-webkit-color-swatch{border:0;border-radius:calc(var(--radius-sm) - 1px)}#friends-setup-modal .friends-self-color input::-moz-color-swatch,#friends-setup-modal .friends-list-item__color::-moz-color-swatch{border:0;border-radius:calc(var(--radius-sm) - 1px)}@media(max-width:980px){#friends-setup-modal .friends-setup-layout{grid-template-columns:1fr}#friends-setup-modal .friends-self-code-row{grid-template-columns:minmax(0,1fr) auto auto}#friends-setup-modal .friends-copy-code-btn{grid-column:1 / -1;justify-self:start}}@media(max-width:900px){#friends-setup-modal .friends-add-form{grid-template-columns:1fr}#friends-setup-modal .friends-add-form button{justify-self:stretch;width:100%}}@media(max-width:760px){#friends-setup-modal .friends-list{grid-template-columns:1fr}#friends-setup-modal .friends-self-pin-label{grid-template-columns:1fr;align-items:stretch}#friends-setup-modal .friends-self-pin-input-wrap{max-width:none;justify-self:stretch}#friends-setup-modal .friends-self-pin-label{flex-direction:column;align-items:flex-start}#friends-setup-modal .friends-self-pin-input-wrap{width:100%}}#friends-setup-modal .friends-profile-instructions{margin-top:10px;padding:10px 12px;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:#0c131e99;color:var(--color-text-muted);font-size:.74rem;line-height:1.35}#friends-setup-modal .friends-profile-instructions__title{display:block;margin-bottom:4px;color:var(--color-text);font-weight:600;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}#friends-setup-modal .friends-profile-instructions p{margin:0}#friends-setup-modal .friends-profile-instructions p+p{margin-top:3px}#confirm-modal{display:none;position:fixed;top:0;left:0;width:min(94vw,575px);max-width:575px;padding:12px;justify-content:center;align-items:center;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#settings-modal,#notification-modal,#column-settings-modal{display:none;font-size:1.15em;position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;justify-content:center;align-items:center;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#settings-modal{align-items:flex-start;padding:8px 0}#confirm-modal[style*="display: block"],#settings-modal[style*="display: block"],#notification-modal[style*="display: block"],#column-settings-modal[style*="display: block"]{display:flex!important}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:transparent;z-index:1;pointer-events:none}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#000000b3;opacity:0;transition:opacity .3s ease}.modal.modal-open{opacity:1}.modal-content{position:relative;z-index:2;background-color:var(--color-surface);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:500px;border:2px solid var(--color-border);transform:scale(.7);transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);font-size:16px}.modal-content p,.modal-content .confirm-message{font-size:18px;line-height:1.6;margin:0 0 var(--spacing-lg) 0;color:var(--color-text)}.modal.modal-open .modal-content{transform:scale(1)}.modal-content h2{margin-top:0;color:var(--color-primary);font-size:var(--font-2xl)}#friends-setup-modal .friends-setup-modal__content{width:min(95vw,1080px);max-width:min(95vw,1080px);max-height:min(92vh,900px);transform:none;padding:var(--spacing-xl);font-size:inherit}.modal-content input{width:100%;padding:var(--spacing-sm);margin:var(--spacing-sm) 0 var(--spacing-lg) 0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-dark);color:var(--color-text);font-size:var(--font-md);transition:all var(--transition-fast)}.modal-buttons{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.modal-buttons button{padding:12px 24px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;font-size:16px}.modal-buttons button.primary,.modal-buttons button:first-child{background-color:var(--color-primary);color:var(--color-bg-dark)}.modal-subtitle{color:#a8b2c7;margin:0 0 var(--spacing-md) 0;font-size:.95rem}.column-settings-modal{max-width:520px}.column-settings-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-md) 0 var(--spacing-lg)}.column-settings-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-light);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.column-settings-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.column-settings-item input{width:18px;height:18px;cursor:pointer;margin-top:2px}.column-settings-title{font-weight:700;color:var(--color-text)}.column-settings-sub{color:#a3adc2;font-size:.9rem}.modal-buttons button.primary:hover,.modal-buttons button:first-child:hover{background-color:var(--color-primary-dark)}.modal-buttons button:first-child:focus{outline:none;box-shadow:0 0 0 3px #d4af3766}.modal-buttons button:last-child{background-color:var(--color-surface-hover);color:var(--color-text)}.modal-buttons button:last-child:hover{background-color:var(--color-border-light)}.modal-buttons button:last-child:focus{outline:none;box-shadow:0 0 0 3px #40455899}#confirm-modal .modal-content{position:relative;z-index:2101}#settings-modal>.modal-content{position:relative;z-index:2001;width:min(92vw,500px);max-width:500px;padding:10px;max-height:calc(100vh - 18px);overflow-y:auto;transform:none;transition:none}.close-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-md);background:none;border:none;font-size:var(--font-2xl);cursor:pointer;color:var(--color-text);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.close-btn:hover{background-color:var(--color-surface-hover)}.close-btn:focus{outline:none;box-shadow:0 0 0 2px #d4af3766}#settings-close{z-index:2105;width:38px;height:38px;top:6px;right:8px;pointer-events:auto}#settings-modal h1{color:var(--color-primary);margin-bottom:8px;text-align:center;font-size:20px}#settings-modal .settings-section{margin-bottom:10px}#settings-modal .settings-section h3{margin-bottom:4px;font-size:16px}#settings-modal .settings-section input:not([type=checkbox]),#settings-modal .settings-section select{max-width:230px;padding:8px 10px;font-size:15px;height:38px}#settings-modal .db-drop-zone{min-height:64px;padding:8px;font-size:.82rem}#settings-modal .modal-buttons button{padding:8px 12px;font-size:13px}#settings-modal .db-status-label,#settings-modal .db-status-value{font-size:.8rem}#settings-modal .db-action-buttons button{min-height:32px;font-size:.78rem;padding:5px 8px}#settings-modal .settings-compact-hint,#settings-modal .settings-danger-copy,#settings-modal .db-permission-help{font-size:.75rem;line-height:1.35;margin:2px 0 6px;color:var(--color-text-secondary);text-align:center}#settings-modal .db-permission-help{margin-top:4px}#settings-modal .settings-danger-copy{margin-bottom:6px}#settings-modal .settings-danger-zone{margin-top:2px;margin-bottom:8px;padding-top:6px}#settings-modal .settings-auto-raid-toggle{display:flex;align-items:flex-start;justify-content:center;align-self:center;gap:8px;margin-top:6px;width:auto;max-width:none;color:var(--color-text);font-size:.86rem;line-height:1.35;text-align:left}#settings-modal .settings-auto-raid-toggle input[type=checkbox]{flex:0 0 auto;margin-top:1px;width:18px;height:18px;accent-color:var(--color-primary)}#settings-modal .settings-auto-raid-toggle span{display:block;flex:1;min-width:0;white-space:normal;overflow-wrap:break-word;word-break:normal}#settings-modal .modal-buttons{margin-top:8px}#settings-close{width:34px;height:34px}.settings-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:10px;position:relative}.settings-header h1{margin:0}.update-button-header{background-color:var(--color-primary);color:var(--color-text);border:1px solid var(--color-primary);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all var(--transition-fast);position:absolute;left:0}.update-button-header:hover:not(:disabled){background-color:#3d85d9;transform:translateY(-1px)}.update-button-header:disabled{opacity:.6;cursor:not-allowed}.update-button-header .update-icon{font-size:14px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.update-button-header .update-text{font-size:13px}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section h3{color:var(--color-primary);margin-bottom:var(--spacing-md);font-size:24px;font-weight:700;line-height:1.25}.settings-section input:not([type=checkbox]),.settings-section select{width:100%;max-width:300px;padding:14px 18px;background-color:var(--color-bg-dark);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:18px;height:50px;transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.settings-section:first-of-type{display:flex;flex-direction:column}.db-drop-zone{margin-top:var(--spacing-md);margin-bottom:var(--spacing-md);padding:18px;min-height:120px;border:1px dashed #6b7280;border-radius:var(--radius-md);color:#d1d5db;font-size:.95rem;text-align:center;background:#6b728014;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;justify-content:center;line-height:1.5}.db-drop-zone.dragover{border-color:#8b5cf6;background:#8b5cf61f;color:#f3e8ff}.db-drop-zone.success{border-color:#15803d;background:#15803d2e;color:#dcfce7}.db-drop-zone.error{border-color:#dc2626;background:#dc262629;color:#fecaca}.db-copy-progress{position:relative;height:22px;min-height:22px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-top:6px;overflow:hidden;flex-shrink:0}.db-copy-progress__bar{display:block;height:100%;width:0%;background:var(--color-primary);opacity:.35;transition:width .2s linear}.db-copy-progress__label{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);color:var(--color-text);font-weight:600;pointer-events:none}.db-guide-btn{align-self:center;margin:0 0 8px;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.9rem;font-weight:600;letter-spacing:.1px;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.db-guide-btn:hover{background:var(--color-surface-hover);border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.db-guide-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10010;display:none;align-items:center;justify-content:center;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.db-guide-modal .modal-overlay{display:none}.db-guide-modal .modal-content{transform:none;transition:none;border-width:1px;max-width:760px;width:94%;max-height:88vh;overflow-y:auto}.db-guide-content{padding-top:calc(var(--spacing-2xl) + 6px)}.db-guide-content h2{margin-bottom:var(--spacing-sm)}.db-guide-subtitle{margin:0 0 8px;color:var(--color-text-secondary);font-size:.92rem;line-height:1.45}.db-guide-steps{margin:0 0 12px;padding:12px 14px 12px 30px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-dark);color:var(--color-text);line-height:1.55;font-size:.92rem}.db-guide-steps li+li{margin-top:4px}.db-guide-steps li::marker{color:var(--color-primary);font-weight:700}.db-guide-media-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-dark);overflow:hidden}.db-guide-video,.db-guide-gif{width:100%;display:block;max-height:360px;object-fit:contain;background:#000}.db-guide-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}.db-guide-actions #db-guide-got-it{background:var(--color-primary);color:var(--color-bg-dark);border-color:var(--color-primary)}.db-guide-actions #db-guide-got-it:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.db-permission-status{font-size:.85rem;color:#9ca3af;margin-top:6px;text-align:center}.db-permission-status.granted{color:#22c55e}.db-permission-status.denied{color:#f97316}.db-status-list{display:flex;flex-direction:column;gap:6px;width:100%;margin-top:2px;margin-bottom:6px}.db-status-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-dark);padding:6px 10px}.db-status-label{color:var(--color-text-secondary);font-size:.88rem}.db-status-value{color:var(--color-text);font-size:.88rem;font-weight:700;text-align:right}.db-action-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-top:2px}.db-action-buttons button{margin-top:0;min-height:38px;font-size:.86rem;padding:7px 10px}.settings-danger-zone{border-top:1px solid var(--color-border);padding-top:8px}.settings-danger-copy{margin:0;color:var(--color-text-secondary);font-size:.9rem;text-align:center}.settings-section .danger-action-btn{background-color:#5f1d1d;color:#ffd4d4}.settings-section .danger-action-btn:hover{background-color:#7a2626}.settings-section:not(:first-of-type){display:flex;flex-direction:column;align-items:center}.settings-section:not(:first-of-type) h3{text-align:center}.settings-section button{margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background-color:var(--color-surface-hover);color:var(--color-text);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-md);transition:all var(--transition-normal)}.settings-section button:hover{background-color:var(--color-border-light);transform:translateY(-1px)}.settings-section button:focus{outline:none;box-shadow:0 0 0 2px #d4af374d}@media(max-width:700px){.db-action-buttons{grid-template-columns:1fr}.db-status-row{align-items:flex-start;flex-direction:column;gap:4px}.db-status-value{text-align:left}}#confirm-yes{background-color:var(--color-error)!important;color:var(--color-text)!important}#confirm-yes:hover{background-color:#d32f2f!important}#confirm-yes:focus{outline:none!important;box-shadow:0 0 0 3px #f4433666!important}#confirm-no{background-color:var(--color-surface-hover)!important;color:var(--color-text)!important}#confirm-no:hover{background-color:var(--color-border-light)!important}#confirm-no:focus{outline:none!important;box-shadow:0 0 0 3px #40455899!important}#settings-modal #settings-tab{display:flex;flex-direction:column;gap:8px}#settings-modal #settings-tab .settings-header{margin-bottom:2px;flex-direction:column;gap:4px}#settings-modal #settings-tab .settings-header .settings-compact-hint{margin:0;max-width:320px;text-align:center}#settings-modal #settings-tab .settings-section{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-light);padding:9px}#settings-modal #settings-tab .settings-section h3{margin-top:0;margin-bottom:6px}#settings-modal #settings-tab .db-action-buttons{margin-top:6px}#settings-modal #settings-tab .db-action-buttons button{font-size:.82rem;letter-spacing:.1px}#settings-modal #settings-tab .db-status-row{background:var(--color-bg-dark)}#settings-modal #settings-tab .settings-auto-raid-toggle{margin-top:8px;margin-bottom:2px}#settings-modal #settings-tab .db-permission-help{max-width:340px;margin-left:auto;margin-right:auto}#settings-modal #settings-tab .settings-danger-zone{border-top:1px solid var(--color-border)}#settings-modal #settings-tab .modal-buttons{margin-top:4px;padding-top:2px}#settings-modal>.modal-content{width:min(95vw,632px);max-width:632px;padding:12px}#settings-modal #settings-tab{gap:9px;font-size:1.26em}#settings-modal #settings-tab .settings-bottom-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}#settings-modal #settings-tab .settings-section--db{margin-bottom:0}#settings-modal #settings-tab .settings-header--professional{display:grid;gap:6px;justify-items:center;margin-bottom:4px}#settings-modal #settings-tab .settings-header--professional .settings-header-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}#settings-modal #settings-tab .settings-chip{border:1px solid color-mix(in srgb,var(--color-border-light) 60%,var(--color-border));background:color-mix(in srgb,var(--color-surface) 90%,var(--color-bg-dark));color:var(--color-text-secondary);border-radius:var(--radius-full);padding:3px 10px;font-size:var(--font-xs);line-height:1.4;letter-spacing:.02em}#settings-modal #settings-tab .settings-chip.is-positive{border-color:color-mix(in srgb,var(--color-success) 44%,var(--color-border));color:color-mix(in srgb,var(--color-success) 82%,#fff)}#settings-modal #settings-tab .settings-chip.is-warning{border-color:color-mix(in srgb,var(--color-warning) 44%,var(--color-border));color:color-mix(in srgb,var(--color-warning) 82%,#fff)}#settings-modal #settings-tab .settings-section{border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-darker)));box-shadow:var(--shadow-sm);padding:8px}#settings-modal #settings-tab .settings-section h3{font-size:19px;letter-spacing:.02em;margin-bottom:5px}#settings-modal #settings-tab .settings-bottom-grid .settings-section h3{text-align:center}#settings-modal #settings-tab .db-drop-zone{min-height:64px;border-style:solid;border-color:color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));background:color-mix(in srgb,var(--color-surface) 84%,var(--color-bg-dark))}#settings-modal #settings-tab .db-status-list{display:grid;grid-template-columns:1fr;gap:6px;margin-top:0;margin-bottom:2px}#settings-modal #settings-tab .db-status-row{align-items:center;justify-content:space-between;flex-direction:row;gap:8px;padding:5px 7px}#settings-modal #settings-tab .db-status-label,#settings-modal #settings-tab .db-status-value{font-size:.97rem;line-height:1.2}#settings-modal #settings-tab .db-status-value{text-align:right}#settings-modal #settings-tab .db-permission-help,#settings-modal #settings-tab .settings-danger-copy,#settings-modal #settings-tab .settings-compact-hint{font-size:.94rem;line-height:1.3;margin:2px 0 4px}#settings-modal #settings-tab .db-action-buttons{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}#settings-modal #settings-tab .db-action-buttons button,#settings-modal #settings-tab .modal-buttons button,#settings-modal #settings-tab .db-guide-btn,#settings-modal #settings-tab .danger-action-btn{min-height:41px;font-size:.99rem;padding:7px 12px}#settings-modal #settings-tab .settings-chip{font-size:.95rem;padding:5px 13px}#settings-modal #settings-tab .settings-confirm-card{width:min(95vw,506px)}#settings-modal #settings-tab .settings-confirm-card h3{font-size:1.26rem}#settings-modal #settings-tab .settings-confirm-card p{font-size:1.1rem}#settings-modal #settings-tab .settings-confirm-card label{font-size:1.05rem}#settings-modal #settings-tab .settings-auto-raid-toggle{margin-top:6px;margin-bottom:0}@media(max-width:760px){#settings-modal>.modal-content{width:min(94vw,506px);max-width:506px;max-height:calc(100vh - 14px)}#settings-modal #settings-tab .settings-bottom-grid,#settings-modal #settings-tab .db-status-list{grid-template-columns:1fr}}#settings-modal #settings-tab .db-drop-zone.dragover{border-color:color-mix(in srgb,var(--color-primary) 65%,var(--color-border));background:color-mix(in srgb,var(--color-primary) 14%,var(--color-surface));color:var(--color-text);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--color-primary) 34%,transparent)}#settings-modal #settings-tab .db-action-buttons button,#settings-modal #settings-tab .modal-buttons button,#settings-modal #settings-tab .db-guide-btn,#settings-modal #settings-tab .danger-action-btn{border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));box-shadow:var(--shadow-xs);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}#settings-modal #settings-tab .db-action-buttons button:hover:not(:disabled),#settings-modal #settings-tab .modal-buttons button:hover:not(:disabled),#settings-modal #settings-tab .db-guide-btn:hover:not(:disabled),#settings-modal #settings-tab .danger-action-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm)}#settings-modal #settings-tab .db-status-row{border-color:color-mix(in srgb,var(--color-border-light) 54%,var(--color-border))}#settings-modal #settings-tab .db-permission-help,#settings-modal #settings-tab .settings-danger-copy{color:#bac3d7}#settings-modal #settings-tab .settings-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2200;display:flex;align-items:center;justify-content:center;background:#05080ebd;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}#settings-modal #settings-tab .settings-confirm-card{width:min(94vw,460px);border:1px solid color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));border-radius:var(--radius-lg);background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-darker)));box-shadow:var(--shadow-lg);padding:14px;display:grid;gap:8px}#settings-modal #settings-tab .settings-confirm-card h3{margin:0;font-size:1.15rem;color:var(--color-primary)}#settings-modal #settings-tab .settings-confirm-card p{margin:0;color:var(--color-text-secondary);font-size:1rem;line-height:1.45}#settings-modal #settings-tab .settings-confirm-card label{color:var(--color-text);font-size:.95rem}#settings-modal #settings-tab .settings-confirm-card input{width:100%;padding:9px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-dark);color:var(--color-text)}#settings-modal #settings-tab .settings-confirm-actions{display:flex;justify-content:flex-end;gap:8px}#settings-modal #settings-tab .settings-confirm-actions button{min-height:34px;padding:0 12px}#settings-modal #settings-tab .settings-confirm-actions .danger-action-btn{border-color:color-mix(in srgb,var(--color-error) 45%,var(--color-border))}.daily-header{background:linear-gradient(135deg,var(--color-surface-hover),var(--color-border));color:var(--color-text);font-weight:700}.daily-subtext{display:block;font-size:10px;font-weight:400;color:var(--color-text-secondary);line-height:1.05;margin-top:1px}.daily-cell{width:120px}.daily-divider{border-left:6px solid var(--color-border);box-shadow:-8px 0 0 var(--color-surface)}.daily-checkmark{margin:0 auto;-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;background-color:#3b3b3b;border:1.5px solid #858585;border-radius:3px;cursor:pointer;position:relative;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.daily-checkmark:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.daily-checkmark:checked:after{content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;border:2px solid var(--color-bg-dark);border-top:none;border-left:none;transform:rotate(45deg)}.daily-checkmark:hover{border-color:var(--color-primary)}.reset-timer{color:var(--color-primary);font-size:.84rem;font-weight:700;background:color-mix(in srgb,var(--color-surface-light) 90%,var(--color-surface));padding:6px 12px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--color-primary) 32%,var(--color-border));box-shadow:var(--shadow-sm);letter-spacing:.02em}.weekly-header-block{display:flex;flex-direction:column;gap:10px;position:relative;padding-bottom:10px;border-bottom:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border))}.weekly-top-row{display:flex;align-items:flex-start;justify-content:center;gap:var(--spacing-md);flex-wrap:wrap;position:relative}.weekly-top-left{display:flex;flex-direction:column;align-items:center;width:100%;position:relative;gap:6px}.weekly-title{margin:0;text-align:center;width:100%;font-size:1.22rem;font-weight:800;letter-spacing:.01em}.weekly-roster-selector{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;font-size:.85rem;color:var(--color-text-muted);min-width:240px}.weekly-roster-selector__title{font-weight:600;color:var(--color-text-primary)}.weekly-roster-selector__list{display:flex;flex-wrap:wrap;gap:.5rem .75rem;justify-content:flex-end}.weekly-roster-selector__item{display:inline-flex;align-items:center;gap:.35rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.25rem .5rem;cursor:pointer;box-shadow:var(--shadow-xs)}.visible-rosters-popover{position:absolute;z-index:80;width:260px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-sm);display:none}.visible-rosters-popover.open{display:block}.visible-rosters-popover__header,.visible-rosters-popover__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.visible-rosters-popover__header{margin-bottom:var(--spacing-sm);font-weight:600}.visible-rosters-popover__footer{margin-top:var(--spacing-sm);justify-content:flex-end}.visible-rosters-popover__footer .primary{background:var(--color-primary);color:var(--color-bg-dark);border:1px solid var(--color-primary);border-radius:var(--radius-sm);padding:8px 14px;font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.visible-rosters-popover__footer .primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px)}.visible-rosters-list{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:240px;overflow-y:auto;margin:0;padding:0}.visible-rosters-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-light)}.roster-dailies{position:absolute;right:0;top:2px;display:inline-flex;align-items:center;gap:6px}.roster-daily-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);height:30px;min-width:42px}.roster-daily-btn img{width:20px;height:20px;display:block}.roster-daily-check{font-weight:700;color:var(--color-success);font-size:.9rem;line-height:1}.roster-daily-btn:not(.completed) .roster-daily-check{color:var(--color-text-secondary);opacity:.7}.roster-daily-btn:hover{border-color:var(--color-primary);transform:translateY(-1px)}.roster-daily-btn.completed{background:#4caf501a;border-color:#4caf5066}.weekly-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;width:100%}.weekly-actions-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.weekly-actions-right{display:flex;align-items:center;justify-content:flex-end}.weekly-columns-btn{height:36px;width:36px;min-width:36px;padding:4px;font-size:.82rem}.weekly-actions .header-icon-btn.weekly-columns-btn{width:36px;min-width:36px;height:36px;padding:0;font-size:.82rem}.weekly-actions .header-icon-btn{height:34px;min-width:120px;padding:6px 12px;font-size:.95rem;font-weight:600;gap:6px;background:color-mix(in srgb,var(--color-surface-light) 90%,var(--color-surface));border:1px solid color-mix(in srgb,var(--color-border-light) 60%,var(--color-border));color:var(--color-text);border-radius:var(--radius-md)}.weekly-actions .header-icon-btn img{width:18px;height:18px;filter:brightness(0) invert(1)}.weekly-actions .header-icon-btn:hover{background-color:var(--color-surface-hover);border-color:color-mix(in srgb,var(--color-primary) 40%,var(--color-border-light));transform:translateY(-1px)}.weekly-actions .header-icon-btn .btn-label{display:inline-flex;align-items:center;white-space:nowrap;font-size:.82rem;letter-spacing:.01em}.weekly-actions .weekly-action-btn{justify-content:center}.action-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:8px;background-color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;color:#fff}.action-icon-btn img{width:16px;height:16px;filter:brightness(0) invert(1)}.action-icon-btn:hover img{filter:invert(77%) sepia(52%) saturate(563%) hue-rotate(7deg) brightness(97%) contrast(100%)}.action-icon-btn:active{transform:translateY(0)}#load-api,#weekly-reset{border:none;background:transparent;padding:0;margin:0;color:inherit;line-height:1}#load-api.header-icon-btn,#weekly-reset.header-icon-btn{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);width:100px}table{width:auto;border-collapse:collapse;margin:12px auto 0;background-color:var(--color-surface);border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));border-radius:var(--radius-lg);overflow:visible;box-shadow:var(--shadow-sm)}th,td{border:1px solid var(--color-border);padding:8px;text-align:center;width:112px}th:first-child,td:first-child{width:170px}th{background:linear-gradient(135deg,var(--color-surface-hover),var(--color-border));color:var(--color-text);font-weight:700;font-size:.72rem;text-shadow:1px 1px 2px rgba(0,0,0,.7);text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--color-border)}tr:nth-child(2n){background-color:var(--color-surface-light)}.tracker-table tbody tr[draggable=true]{cursor:grab}.tracker-table tbody tr.dragging-row{opacity:.6}.tracker-table tbody tr.drag-over-row td{border-top:2px solid var(--color-primary)}.player-name{color:var(--color-primary);text-align:left;padding-left:var(--spacing-md)}.char-class,.char-ilvl{font-size:.68rem;color:var(--color-text-secondary)}.char-info{display:flex;gap:var(--spacing-xs);margin-top:2px;justify-content:flex-start}.char-cell{text-align:left;min-width:170px}.char-name{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.char-name img{border-radius:6px;border:1px solid color-mix(in srgb,var(--color-border-light) 60%,var(--color-border));background:color-mix(in srgb,var(--color-surface-light) 80%,var(--color-surface))}.char-name-text{font-weight:700;color:var(--color-primary);letter-spacing:.01em}.char-class{font-weight:600;text-transform:uppercase}.gold-cell{text-align:center;padding:6px 8px;min-width:100px;position:relative;overflow:visible}.gold-cell-inner{display:flex;align-items:center;justify-content:center;gap:.35rem}.gold-cell .gold-bonus-handle{position:absolute;right:4px;top:2px;bottom:auto;width:12px;border-left:2px solid rgba(255,255,255,.08);background:#2f343e;color:#d9dde7;cursor:pointer;font-weight:800;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:0 var(--radius-sm) var(--radius-sm) 0;box-shadow:inset 0 0 0 1px #ffffff08;padding:0;border:1px solid var(--color-border);height:20px;z-index:2}.gold-bonus-handle:hover{background:#3a404b}.gold-bonus-popover{position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);z-index:240;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:0 8px 24px #00000040;padding:.5rem;display:flex;align-items:center;gap:.5rem}.gold-bonus-input{width:90px;padding:.35rem .45rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-light);color:var(--color-text);-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.gold-bonus-input::-webkit-outer-spin-button,.gold-bonus-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.gold-bonus-confirm{padding:.35rem .65rem;border-radius:var(--radius-sm);cursor:pointer}.gold-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);position:static;overflow:visible}.gold-icon{display:inline-block;width:20px;height:20px;background-image:url(../assets/icons/items/gold.webp);background-size:contain;background-repeat:no-repeat;background-position:center}.gold-amount{font-weight:700;color:var(--color-primary);font-size:.92rem}.total-row{background-color:var(--color-surface-light);border-top:3px solid #8B7500}.total-row:hover{background-color:var(--color-surface-light)}.total-label{font-weight:700;font-size:.86rem;color:var(--color-primary);text-align:center;text-transform:uppercase;letter-spacing:.06em}.total-empty{background-color:transparent}.total-gold .gold-amount{font-size:var(--font-lg);font-weight:700;color:var(--color-primary-light)}.cell{display:flex;flex-direction:column;align-items:center;min-height:40px;position:relative}.cell-hidden{opacity:.2}.difficulty-box{font-size:var(--font-xs);padding:2px var(--spacing-xs);border-radius:2px;cursor:pointer;margin-bottom:var(--spacing-xs);font-weight:700;height:16px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);position:relative;z-index:2;-moz-appearance:none;appearance:none;-webkit-appearance:none;border:1px solid transparent;outline:none;box-shadow:none}.difficulty-box.inactive{opacity:.4}.difficulty-box.solo,.difficulty-box.normal{background-color:#2c3e50;color:#ecf0f1;border-color:#3d556e}.difficulty-box.hard{background-color:var(--color-hard);color:#000;border-color:color-mix(in srgb,var(--color-hard) 70%,#000)}.difficulty-box:hover:not(.inactive){filter:brightness(1.08)}.eye-icon{position:absolute;top:-10px;right:2px;opacity:.7;cursor:pointer;color:#555;font-size:var(--font-md);transition:opacity var(--transition-normal);padding:0;z-index:2}.cell:hover .eye-icon,.boss-cell:hover .eye-icon{opacity:1}.cell.cell-hidden .eye-icon{color:var(--color-text)}.chest-icon{position:absolute;bottom:-8px;right:2px;width:16px;height:16px;background-image:url(../assets/icons/items/darkchest.webp);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.4;cursor:pointer;transition:opacity var(--transition-normal),transform var(--transition-fast);z-index:2}.chest-icon.active{background-image:url(../assets/icons/items/chest.webp);opacity:1}.cell:hover .chest-icon,.boss-cell:hover .chest-icon,.chest-icon:hover{opacity:1;transform:scale(1.2)}@media(max-width:768px){.reset-timer{position:static;display:block;text-align:center;margin-bottom:var(--spacing-md)}table{font-size:var(--font-xs)}th,td{padding:var(--spacing-xs)}}@media(max-width:480px){table{font-size:10px}th:first-child,td:first-child{width:100px}th,td{width:60px;padding:2px}.difficulty-box{font-size:9px;padding:1px 2px}}.howto-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10020;display:none;align-items:center;justify-content:center;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.howto-modal .modal-overlay{display:none}.howto-content{transform:none;transition:none;border-width:1px;border-color:var(--color-border);max-width:940px;width:95%;max-height:90vh;overflow-y:auto;padding-top:calc(var(--spacing-2xl) + 8px);background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 90%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 86%,var(--color-bg-darker)));box-shadow:var(--shadow-lg)}.howto-content h2{margin:0 0 var(--spacing-xs);color:var(--color-primary);font-size:1.7rem;letter-spacing:.01em}.howto-subtitle{margin:0 0 14px;color:#c1cadd;line-height:1.5}.howto-section{border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));border-radius:var(--radius-md);background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 88%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 84%,var(--color-bg-dark)));padding:14px;margin-bottom:10px;box-shadow:var(--shadow-sm)}.howto-section h3{margin:0 0 8px;color:var(--color-primary);font-size:1.14rem;letter-spacing:.01em}.howto-section ul{margin:0;padding-left:20px;color:var(--color-text);line-height:1.58}.howto-section li+li{margin-top:7px}.howto-image-slot{margin:10px 0 12px;padding:14px;border:1px solid color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));border-radius:var(--radius-sm);background:color-mix(in srgb,var(--color-surface-light) 84%,var(--color-surface));color:var(--color-text-secondary);text-align:center;font-size:.9rem;box-shadow:inset 0 1px color-mix(in srgb,var(--color-primary) 12%,transparent)}.howto-guide-image{display:block;width:100%;max-width:400px;height:auto;margin:0 auto;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--color-border-light) 64%,var(--color-border));box-shadow:var(--shadow-sm)}.howto-guide-image--full{max-width:100%}.howto-actions{display:flex;justify-content:flex-end;margin-top:12px;padding-top:8px;border-top:1px solid color-mix(in srgb,var(--color-border-light) 52%,var(--color-border))}.howto-actions button{background:var(--color-primary);color:var(--color-bg-dark);border:1px solid var(--color-primary);border-radius:var(--radius-sm);padding:9px 16px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}.howto-actions button:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}#howto-tab>section:nth-child(5)>div:nth-child(4) .howto-guide-image{max-width:200px}#howto-tab>section:nth-child(4)>div:nth-child(6) .howto-guide-image{max-width:280px}@media(max-width:768px){.howto-content{width:96%;max-height:92vh}}.wizard-modal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;align-items:center;justify-content:center;padding:12px;background-color:#000000b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.wizard-modal[style*="display: block"]{display:flex!important}.wizard-modal .modal-overlay{display:none}body:has(.wizard-modal[style*="display: block"]) #main-content>.tab-content{filter:blur(3px);pointer-events:none!important;-webkit-user-select:none;user-select:none}body:has(.wizard-modal[style*="display: block"]) #roster-list .character-card{filter:blur(4px)}.wizard-modal>.modal-content{width:min(92vw,700px);max-width:700px;min-width:min(92vw,560px);max-height:calc(100vh - 24px);overflow-y:auto;position:relative;z-index:10001;padding:var(--spacing-lg);border-width:1px;transform:none;transition:none}.wizard-modal .modal-content #wizard-tab{position:relative}.wizard-modal .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.wizard-modal .form-row{display:flex;gap:var(--spacing-md);align-items:flex-end;margin-bottom:var(--spacing-md);flex-wrap:wrap}.wizard-modal .form-row .form-group{margin-bottom:0}.wizard-modal .wizard-mathimoe-row{display:grid;grid-template-columns:7fr 3fr;gap:var(--spacing-md);align-items:flex-end}.wizard-modal .wizard-mathimoe-row .form-group-name,.wizard-modal .wizard-mathimoe-row .form-group-region{min-width:0}@media(max-width:640px){.wizard-modal .wizard-mathimoe-row{grid-template-columns:1fr}}.wizard-modal .form-group label{color:var(--color-text);font-weight:600;font-size:.95rem}.wizard-modal .form-group input,.wizard-modal .form-group select{width:100%;padding:12px 14px;background:var(--color-bg-dark);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:1rem;margin:var(--spacing-sm) 0 var(--spacing-lg) 0;transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.wizard-modal .form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.wizard-modal-content h2{color:var(--color-primary);margin-top:0;margin-bottom:var(--spacing-sm);font-size:1.5rem}.wizard-modal-content>p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);line-height:1.5}.wizard-option{background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.wizard-option h3{color:var(--color-text);margin-top:0;margin-bottom:var(--spacing-sm);font-size:1.1rem}.wizard-option .wizard-option-title-with-icon{display:inline-flex;align-items:center;gap:8px}.wizard-option .wizard-bible-icon{width:22px;height:22px;object-fit:contain;flex-shrink:0}.wizard-option p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:.9rem}.wizard-option ul{list-style:none;padding:0;margin:var(--spacing-sm) 0}.wizard-option ul li{color:var(--color-text-secondary);padding:var(--spacing-xs) 0;padding-left:var(--spacing-lg);position:relative;font-size:.85rem;line-height:1.4}.wizard-option ul li:before{content:"✓";position:absolute;left:0;color:var(--color-success);font-weight:700}.wizard-primary-btn{background:var(--color-primary);color:var(--color-bg-dark);border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:background .2s;width:100%;font-size:.95rem}.wizard-primary-btn:hover:not(:disabled){background:var(--color-primary-light)}.wizard-primary-btn:disabled{opacity:.5;cursor:not-allowed}.wizard-secondary-btn{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background .2s;font-size:.9rem}.wizard-secondary-btn:hover{background:var(--color-surface-hover)}.wizard-manual{text-align:center;padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm)}.wizard-manual p{color:var(--color-text-muted);margin-bottom:var(--spacing-md);font-size:.9rem}.wizard-info{background:#2196f31a;border:1px solid rgba(33,150,243,.3);border-radius:var(--radius-md);padding:var(--spacing-lg);margin:var(--spacing-lg) 0}.wizard-info h4{color:var(--color-info);margin-bottom:var(--spacing-sm);font-size:.95rem}.wizard-warning{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:var(--radius-md);padding:var(--spacing-lg);margin:var(--spacing-lg) 0}.wizard-warning h4{color:#ffc107;margin-bottom:var(--spacing-sm);font-size:.95rem}.wizard-info code{display:block;background:#0000004d;padding:var(--spacing-sm);border-radius:var(--radius-sm);font-family:Courier New,monospace;font-size:.85rem;color:var(--color-text);word-break:break-all;margin:var(--spacing-sm) 0}.wizard-hint{color:var(--color-text-muted);font-size:.85rem;margin-top:var(--spacing-sm)}.wizard-progress-container{margin:var(--spacing-md) 0}.wizard-progress-bar{width:100%;height:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;position:relative}.wizard-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-light) 100%);transition:width .3s ease;width:0%;display:flex;align-items:center;justify-content:center;color:var(--color-bg-dark);font-weight:700;font-size:.85rem}.wizard-progress-text{text-align:center;margin-top:var(--spacing-xs);font-size:.9rem;color:var(--color-text-secondary)}.file-input-group,.add-character-form,.wizard-footer{display:flex;gap:var(--spacing-sm)}.file-input-group input{flex:1;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:.9rem}.file-input-group button{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background .2s;white-space:nowrap;min-width:80px;margin-top:8px;margin-bottom:16px}.file-input-group button:hover{background:var(--color-surface-hover)}.wizard-preview-content{max-width:800px}.wizard-preview-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);max-width:620px;margin-left:auto;margin-right:auto}.wizard-character-list-header{display:grid;grid-template-columns:calc(18px + var(--spacing-md) - var(--spacing-sm)) 1.2fr .95fr .85fr .85fr;gap:var(--spacing-sm);align-items:center;padding:var(--spacing-sm) var(--spacing-md);max-width:620px;margin-left:auto;margin-right:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md) var(--radius-md) 0 0;font-weight:600;font-size:.85rem;color:var(--color-text-secondary)}.wizard-sort-header-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);background:var(--color-surface-light);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;width:calc(100% - 14px);margin:0 auto;box-sizing:border-box;text-align:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;transition:all .2s}.wizard-modal #wizard-sort-ilvl-btn,.wizard-modal #wizard-sort-cp-btn{position:relative;width:calc(100% - 22px)!important}.wizard-modal #wizard-sort-ilvl-btn{transform:translate(-24px)!important}.wizard-modal #wizard-sort-cp-btn{transform:translate(-28px)!important}.wizard-sort-header-btn:hover{background:var(--color-surface-hover);border-color:var(--color-primary);color:var(--color-primary)}.wizard-sort-header-btn.active{background:var(--color-surface-hover);border-color:var(--color-primary);border-width:1px;box-shadow:inset 0 0 0 1px var(--color-primary);color:var(--color-primary)}.wizard-sort-arrow{color:var(--color-primary);font-size:.9rem}.wizard-character-list{background:var(--color-surface);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--spacing-sm);max-width:620px;margin-left:auto;margin-right:auto;max-height:430px;overflow-y:auto;margin-bottom:var(--spacing-lg)}.wizard-character-item{display:flex;align-items:center;gap:var(--spacing-md);min-height:58px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s}.wizard-character-item:hover{background:var(--color-surface-hover)}.wizard-character-item:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 24%,transparent)}.wizard-character-item[aria-pressed=true]{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,var(--color-surface-light))}.wizard-character-item input[type=checkbox]{margin:0;align-self:center}.wizard-character-info{flex:1;display:grid;grid-template-columns:1.2fr .95fr .85fr .85fr;gap:var(--spacing-sm);align-items:center;min-width:0}.wizard-character-name{font-weight:600;color:var(--color-text);cursor:pointer;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wizard-character-class,.wizard-character-ilvl,.wizard-character-cp{color:var(--color-text-secondary);font-size:.9rem}.wizard-character-class{color:var(--color-primary)}.roster-wizard{max-width:700px;width:100%}.modal-header,.selection-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;color:var(--color-primary)}.close-btn{background:none;border:none;font-size:2rem;color:var(--color-text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.wizard-modal .close-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);z-index:2}.close-btn:hover{color:var(--color-error)}.modal-footer{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-2xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.wizard-progress{margin-bottom:var(--spacing-2xl)}.progress-steps{display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.progress-step{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);flex:1;position:relative}.progress-step:after{content:"";position:absolute;top:16px;left:50%;width:100%;height:2px;background:var(--color-border);z-index:-1}.progress-step:last-child:after{display:none}.step-number{width:32px;height:32px;border-radius:50%;background:var(--color-surface);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--color-text-secondary);transition:all .3s}.progress-step.active .step-number{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-dark)}.progress-step.completed .step-number{background:var(--color-success);border-color:var(--color-success);color:#fff}.step-label{font-size:.85rem;color:var(--color-text-secondary);font-weight:500}.progress-step.active .step-label{color:var(--color-primary)}.progress-bar{height:4px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--color-primary);transition:width .3s}.wizard-body{min-height:300px;padding:var(--spacing-2xl) 0}.wizard-step h3{margin-bottom:var(--spacing-sm);color:var(--color-text)}.wizard-step>p{color:var(--color-text-secondary);margin-bottom:var(--spacing-2xl)}.step-name .form-group{margin-bottom:0}.character-selection{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg)}.selected-count{color:var(--color-primary);font-weight:600}.import-options{margin-bottom:var(--spacing-lg)}.import-options h4{margin:0 0 var(--spacing-md) 0;color:var(--color-text);font-size:.95rem;font-weight:600}.import-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.btn-block{width:100%;justify-content:center}.btn-block span{margin-right:var(--spacing-xs)}.divider{display:flex;align-items:center;text-align:center;margin:var(--spacing-lg) 0;color:var(--color-text-secondary)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.divider span{padding:0 var(--spacing-md);font-size:.85rem;font-weight:600}.add-character-form input{flex:1}.character-list{margin-top:var(--spacing-lg);max-height:400px;overflow-y:auto}.character-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);transition:background .2s}.character-item:hover{background:var(--color-surface-hover)}.character-name{font-weight:500;color:var(--color-text)}.btn-icon{background:transparent;border:none;color:var(--color-error);cursor:pointer;padding:var(--spacing-xs);font-size:1.5rem;line-height:1;transition:transform .2s}.btn-icon:hover{transform:scale(1.2)}.order-list{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg);max-height:500px;overflow-y:auto}.order-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);cursor:move;transition:all .2s}.order-item:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.order-item.dragging{opacity:.5;border-color:var(--color-primary)}.drag-handle{color:var(--color-text-secondary);cursor:grab;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.order-number{width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:var(--color-bg-dark);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}.order-item .character-name{flex:1}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.empty-state p{margin:0 0 var(--spacing-sm) 0;color:var(--color-text-muted)}.empty-state small{color:var(--color-text-muted)}.flex-spacer{flex:1}@media(max-width:768px){.wizard-modal>.modal-content{width:min(95vw,680px);min-width:0;max-height:calc(100vh - 20px);padding:var(--spacing-md)}.wizard-character-info{grid-template-columns:1fr;gap:var(--spacing-xs)}.roster-wizard{max-width:95%}.progress-steps{flex-direction:column;gap:var(--spacing-md)}.progress-step:after{display:none}}#wizard-open-db-guide-btn{margin-bottom:10px;align-self:center}.wizard-modal{background-color:#05090ec2}.wizard-modal>.modal-content{width:min(94vw,760px);max-width:760px;border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-darker)));box-shadow:var(--shadow-lg);padding:18px}.wizard-modal .modal-content #wizard-tab>h2{margin:0 0 6px;color:var(--color-primary);font-size:1.55rem;letter-spacing:.01em}.wizard-modal .modal-content #wizard-tab>p{margin:0 0 12px;color:#c2cbde;line-height:1.45}.wizard-modal .close-btn{top:10px;right:10px;width:34px;height:34px;border-radius:var(--radius-full);color:var(--color-text-secondary);transition:color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast)}.wizard-modal .close-btn:hover{color:var(--color-text);background:color-mix(in srgb,var(--color-surface-hover) 74%,transparent);transform:scale(1.05)}.wizard-option{border:1px solid color-mix(in srgb,var(--color-border-light) 58%,var(--color-border));background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 88%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 86%,var(--color-bg-dark)));box-shadow:var(--shadow-sm);padding:14px}.wizard-option h3{margin-bottom:6px}.wizard-option ul li{font-size:.9rem}.wizard-primary-btn,.wizard-secondary-btn{min-height:38px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--color-border-light) 54%,var(--color-border));box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.wizard-primary-btn:hover:not(:disabled),.wizard-secondary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.wizard-progress-container{margin:10px 0}.wizard-progress-bar{height:18px;border-radius:var(--radius-full)}.wizard-progress-text{margin-top:6px;font-size:.86rem}.wizard-character-list-header{border-color:color-mix(in srgb,var(--color-border-light) 60%,var(--color-border));background:color-mix(in srgb,var(--color-surface) 90%,var(--color-bg-dark));font-size:.88rem}.wizard-sort-header-btn{transform:none!important;width:100%!important;margin:0}.wizard-modal #wizard-sort-ilvl-btn,.wizard-modal #wizard-sort-cp-btn{transform:none!important;width:100%!important}.wizard-character-list{border-color:color-mix(in srgb,var(--color-border-light) 60%,var(--color-border));background:color-mix(in srgb,var(--color-surface) 90%,var(--color-bg-dark));max-height:420px}.wizard-character-item{border-color:color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));background:color-mix(in srgb,var(--color-surface-light) 86%,var(--color-surface))}.wizard-character-item:hover{border-color:color-mix(in srgb,var(--color-primary) 36%,var(--color-border));box-shadow:var(--shadow-sm)}.wizard-preview-actions{margin-bottom:12px}.wizard-modal .modal-buttons{margin-top:10px}@media(max-width:768px){.wizard-modal>.modal-content{width:min(95vw,700px);padding:14px}.wizard-character-list-header{grid-template-columns:26px 1fr .8fr;row-gap:6px}.wizard-character-list-header>:nth-child(4),.wizard-character-list-header>:nth-child(5){justify-self:stretch}}.toast-container{position:fixed;bottom:var(--spacing-xl);right:var(--spacing-xl);z-index:11050;pointer-events:none}.toast{background-color:var(--color-surface-hover);color:var(--color-text);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;max-width:300px;border-left:3px solid var(--color-info);pointer-events:all;animation:slideInUp .3s ease-out;font-size:var(--font-sm);transition:opacity .3s ease}.toast.success{background-color:#2d5016;border-left-color:#4caf50}.toast.error{background-color:#5c1e1e;border-left-color:var(--color-error)}.toast.warning{border-left-color:var(--color-warning)}.toast.info{border-left-color:var(--color-info)}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes highlight{0%{background-color:transparent}50%{background-color:var(--color-primary-light)}to{background-color:transparent}}.pulse{animation:pulse .3s ease-in-out}.shake{animation:shake .4s ease-in-out}.highlight{animation:highlight .6s ease-in-out}.input-error{border-color:var(--color-error)!important;animation:shake .4s ease-in-out}.input-error-message{color:var(--color-error);font-size:var(--font-xs);margin-top:var(--spacing-xs);display:block;animation:slideInUp .3s ease-out}input.input-error:focus{box-shadow:0 0 0 2px #f443364d!important}input.input-success{border-color:var(--color-success)}input.input-success:focus{box-shadow:0 0 0 2px #4caf504d}@media(max-width:768px){.toast-container{right:var(--spacing-sm);left:var(--spacing-sm)}.toast{min-width:auto}}.modal-content input:focus,.db-guide-btn:focus,.settings-section input:not([type=checkbox]):focus,.settings-section select:focus,.wizard-modal .form-group input:focus,.wizard-modal .form-group select:focus,.roster-select:focus,.friends-add-form input:focus,.add-character input:focus,.add-character select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 22%,transparent)}#friends-setup-modal .friends-setup-titlebar,#friends-setup-modal .friends-setup-card__header,.column-settings-copy{display:flex;flex-direction:column;gap:4px}.header-buttons,.weekly-title-row,.weekly-actions-left,.weekly-actions-right{display:flex;align-items:center;gap:var(--spacing-sm)}#friends-tab .friends-header-actions .header-icon-btn:hover:not(:disabled),#load-api.header-icon-btn:hover,#weekly-reset.header-icon-btn:hover{background-color:var(--color-surface-hover);border-color:var(--color-border);transform:scale(1.05)}#friends-tab .friends-header-actions .header-icon-btn .btn-label,.weekly-actions .header-icon-btn .btn-label{font-size:.85rem;font-weight:600;white-space:nowrap}.sort-roster-btn:hover,.action-icon-btn:hover{background-color:var(--color-surface-hover);border-color:var(--color-primary);color:var(--color-primary)}button{font-family:inherit;transition:all var(--transition-fast)}button:disabled{opacity:.6;cursor:not-allowed}button.loading{position:relative;color:transparent}button.loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid transparent;border-top-color:currentColor;border-radius:var(--radius-full);animation:spin .6s linear infinite}.checkmark,.wizard-character-item input[type=checkbox],.weekly-roster-selector__item input,.visible-rosters-item input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;background-color:#3b3b3b;border:1.5px solid #858585;border-radius:3px;cursor:pointer;position:relative;flex-shrink:0;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.checkmark:checked,.wizard-character-item input[type=checkbox]:checked,.weekly-roster-selector__item input:checked,.visible-rosters-item input[type=checkbox]:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.checkmark:checked:after,.wizard-character-item input[type=checkbox]:checked:after,.weekly-roster-selector__item input:checked:after,.visible-rosters-item input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;border:2px solid var(--color-bg-dark);border-top:none;border-left:none;transform:rotate(45deg)}.checkmark:hover,.wizard-character-item input[type=checkbox]:hover,.weekly-roster-selector__item input:hover,.visible-rosters-item input[type=checkbox]:hover{border-color:var(--color-primary)}.checkmark{z-index:2;transition:transform var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}.checkmark:hover{transform:scale(1.2)}.settings-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2200;display:flex;align-items:center;justify-content:center;background:#05080ebd;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.settings-confirm-card{width:min(94vw,472px);border:1px solid color-mix(in srgb,var(--color-border-light) 62%,var(--color-border));border-radius:var(--radius-lg);background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-light) 92%,var(--color-surface)),color-mix(in srgb,var(--color-surface) 88%,var(--color-bg-darker)));box-shadow:var(--shadow-lg);padding:16px;display:grid;gap:10px}.settings-confirm-card h3{margin:0;font-size:1.15rem;color:var(--color-primary)}.settings-confirm-card p{margin:0;color:var(--color-text-secondary);font-size:1rem;line-height:1.45}.settings-confirm-card p strong{color:var(--color-primary);font-weight:700}.settings-confirm-card label{color:var(--color-text);font-size:.95rem}.settings-confirm-card input{width:100%;padding:9px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-dark);color:var(--color-text)}.settings-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.settings-confirm-actions button{min-height:35px;padding:0 13px;border:1px solid color-mix(in srgb,var(--color-border-light) 56%,var(--color-border));border-radius:var(--radius-md);background:color-mix(in srgb,var(--color-surface-light) 88%,var(--color-surface));color:var(--color-text);box-shadow:var(--shadow-xs);font-size:.84rem;font-weight:600;line-height:1;letter-spacing:.01em;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.settings-confirm-actions button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:color-mix(in srgb,var(--color-primary) 34%,var(--color-border))}.settings-confirm-actions button:focus-visible{outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 26%,transparent)}.settings-confirm-actions button:disabled{opacity:.6;cursor:not-allowed}.settings-confirm-actions .danger-action-btn{border-color:color-mix(in srgb,var(--color-error) 48%,var(--color-border));background:color-mix(in srgb,var(--color-error) 18%,var(--color-surface));color:color-mix(in srgb,var(--color-error) 80%,var(--color-text))}.settings-confirm-actions .danger-action-btn:hover:not(:disabled){border-color:color-mix(in srgb,var(--color-error) 64%,var(--color-border));background:color-mix(in srgb,var(--color-error) 24%,var(--color-surface))}@media(max-width:768px){body{margin:var(--spacing-md)}.header{flex-direction:column;align-items:stretch}.tabs{width:100%}.tab-button{flex:1;text-align:center;font-size:var(--font-xs);padding:var(--spacing-sm) var(--spacing-md)}.header-help-btn,.settings-btn{width:100%}.tab-content{padding:var(--spacing-md)}.add-character{flex-direction:column;align-items:stretch}.add-character input,.add-character select,.add-character button,.character-card{width:100%}#roster-list{flex-direction:column}}
