:root{--color-bg-deep:#0d0509;--color-bg-main:#1a0510;--color-bg-elevated:#220814;--color-rose:#eaa2b1;--color-rose-light:#f2c4cf;--color-rose-bright:#ff5aaf;--color-rose-glow:#eaa2b126;--color-rose-glow-strong:#eaa2b14d;--color-bordeaux:#510e17;--color-bordeaux-light:#6b2d3e;--color-bordeaux-dark:#3a0a11;--color-gold:#b78832;--color-gold-light:#d4a84a;--color-text-primary:#f5e6ea;--color-text-secondary:#c49ba5;--color-text-muted:#8a6670;--color-border:#6b2d3e;--color-border-subtle:#6b2d3e66;--color-surface:#510e17;--color-surface-hover:#6b2d3e;--color-success:#4caf50;--color-error:#f44;--color-warning:#ffb347;--color-info:#5dade2;--font-display:"Playfair Display", Georgia, serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #eaa2b133;--shadow-glow-strong:0 0 40px #eaa2b159;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--sidebar-width:260px;--header-height:64px;--content-max-width:800px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background-color:var(--color-bg-deep);color:var(--color-text-primary);min-height:100dvh;line-height:1.6}#root{min-height:100dvh}a{color:var(--color-rose);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-rose-light)}img{max-width:100%;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);transition:border-color var(--transition-fast);background:0 0;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--color-rose)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg-deep)}::-webkit-scrollbar-thumb{background:var(--color-bordeaux);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-bordeaux-light)}.text-display{font-family:var(--font-display)}.text-muted{color:var(--color-text-secondary)}.text-rose{color:var(--color-rose)}.text-gold{color:var(--color-gold)}.user-link:hover{text-decoration:underline;color:var(--color-rose)!important}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;padding:10px 20px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-rose-bright), var(--color-rose));color:var(--color-bg-deep)}.btn-primary:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-rose)}.btn-ghost{color:var(--color-text-secondary);padding:8px 12px}.btn-ghost:hover{color:var(--color-rose);background:var(--color-rose-glow)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.card{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-base)}.card:hover{border-color:var(--color-border)}.card-surface{background:var(--color-surface)}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-group label{color:var(--color-text-secondary);font-size:.85rem;font-weight:500}.input-group input,.input-group textarea,.input-group select{background:var(--color-bg-main);border-radius:var(--radius-md);padding:10px 14px}.badge{border-radius:var(--radius-full);align-items:center;padding:2px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-rose{background:var(--color-rose-glow);color:var(--color-rose)}.badge-gold{color:var(--color-gold);background:#b7883226}.badge-success{color:var(--color-success);background:#4caf5026}.avatar{border-radius:var(--radius-full);background:var(--color-surface);width:40px;height:40px;color:var(--color-rose);flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-lg{width:64px;height:64px;font-size:1.2rem}.avatar-xl{width:96px;height:96px;font-size:1.6rem}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-rose);border-radius:var(--radius-full);width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-enter{animation:fadeIn var(--transition-base) ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-wall{max-width:420px;margin:var(--space-2xl) auto;text-align:center;background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.login-wall-icon{margin-bottom:var(--space-xs);font-size:2.4rem}.login-wall-title{font-family:var(--font-display);background:linear-gradient(135deg,#f5e6ea 0%,#eaa2b1 60%,#b78832 110%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.4rem}.login-wall-text{color:var(--color-text-secondary);margin:0 0 var(--space-md);font-size:.92rem;line-height:1.55}@media (width<=768px){:root{--sidebar-width:0px;--header-height:56px}}.layout{min-height:100dvh;display:flex}.sidebar{display:none}.main-content{padding:var(--space-md);padding-top:calc(var(--header-height) + var(--space-md));padding-bottom:calc(80px + var(--space-md));flex:1;width:100%;max-width:100%}.mobile-header{height:var(--header-height);background:var(--color-bg-main);border-bottom:1px solid var(--color-border-subtle);padding:0 var(--space-md);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.mobile-header-left{align-items:center;gap:var(--space-sm);display:flex}.mobile-logo-img{border-radius:var(--radius-sm);width:28px;height:28px}.mobile-logo{color:var(--color-rose);font-size:1.1rem;font-weight:800}.mobile-nav{background:var(--color-bg-main);border-top:1px solid var(--color-border-subtle);height:64px;padding-bottom:env(safe-area-inset-bottom,0);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--color-text-muted);padding:var(--space-xs) var(--space-sm);transition:color var(--transition-fast);cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;font-family:inherit;font-size:.6rem;text-decoration:none;display:flex}.nav-badge{background:var(--color-rose);color:var(--color-bg-deep);border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:.65rem;font-weight:700;display:flex}.mobile-nav-badge{background:var(--color-rose);color:var(--color-bg-deep);border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:15px;height:15px;padding:0 3px;font-size:.55rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-8px}.mobile-nav-item span:first-child{font-size:1.3rem}.mobile-nav-item.active{color:var(--color-rose)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150;background:#00000080;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-menu{background:var(--color-bg-main);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);width:100%;max-height:80vh;padding-bottom:env(safe-area-inset-bottom,var(--space-md));animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-header{padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.mobile-menu-nav{padding:var(--space-md);grid-template-columns:repeat(3,1fr);gap:2px;display:grid}.mobile-menu-item{align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);border-radius:var(--radius-lg);color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;flex-direction:column;width:100%;font-family:inherit;font-size:.78rem;font-weight:500;text-decoration:none;display:flex}.mobile-menu-item span:first-child{font-size:1.5rem}.mobile-menu-item:hover,.mobile-menu-item-active{background:var(--color-rose-glow);color:var(--color-rose)}.mobile-menu-item-admin{color:var(--color-gold)}.mobile-menu-item-admin:hover,.mobile-menu-item-admin.mobile-menu-item-active{color:var(--color-gold);background:#b788321f}.mobile-menu-item-logout{color:var(--color-error)}.mobile-menu-item-logout:hover{color:var(--color-error);background:#ff44441a}.nav-item-admin{border-top:1px solid var(--color-border-subtle);margin-top:var(--space-sm);padding-top:var(--space-md);color:var(--color-gold)!important}.sidebar-header{padding:var(--space-lg) var(--space-md) var(--space-md);align-items:center;gap:var(--space-sm);display:flex}.sidebar-logo-img{border-radius:var(--radius-md);flex-shrink:0;width:36px;height:36px}.sidebar-logo{color:var(--color-rose);font-size:1.2rem;font-weight:800;line-height:1.1;display:block}.sidebar-subtitle{color:var(--color-text-muted);font-size:.7rem;display:block}.sidebar-nav{padding:var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.nav-item{align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);font-size:.88rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--color-text-primary);background:var(--color-rose-glow)}.nav-item-active{color:var(--color-rose)!important;background:var(--color-rose-glow)!important}.nav-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.05rem}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--color-border-subtle);align-items:center;gap:var(--space-sm);display:flex}.sidebar-profile{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);transition:background var(--transition-fast);flex:1;text-decoration:none;display:flex}.sidebar-profile:hover{background:var(--color-rose-glow)}.sidebar-profile-info{flex-direction:column;display:flex;overflow:hidden}.sidebar-profile-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-profile-role{color:var(--color-text-muted);font-size:.72rem}.sidebar-logout{border-radius:var(--radius-md);padding:8px;font-size:1.1rem}@media (width>=769px){.sidebar{width:var(--sidebar-width);background:var(--color-bg-main);border-right:1px solid var(--color-border-subtle);z-index:100;flex-direction:column;height:100dvh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.mobile-header,.mobile-nav{display:none}.main-content{margin-left:var(--sidebar-width);padding:var(--space-xl);padding-bottom:var(--space-xl);max-width:calc(var(--content-max-width) + var(--space-xl) * 2 + var(--sidebar-width))}}@media (width<=380px){.mobile-nav-item{padding:var(--space-xs) 4px;font-size:.55rem}.mobile-nav-item span:first-child{font-size:1.1rem}.mobile-menu-nav{grid-template-columns:repeat(2,1fr)}}.login-page{min-height:100dvh;padding:var(--space-md);background:var(--color-bg-deep);justify-content:center;align-items:center;display:flex}.login-card{width:100%;max-width:400px;padding:var(--space-2xl) var(--space-xl);text-align:center}.login-header{margin-bottom:var(--space-xl);flex-direction:column;align-items:center;display:flex}.login-logo{border-radius:var(--radius-lg);width:72px;height:72px;margin-bottom:var(--space-md)}.login-title{color:var(--color-rose);margin-bottom:var(--space-xs);font-size:2rem;font-weight:800}.login-subtitle{color:var(--color-text-secondary);font-size:.95rem}.login-form{gap:var(--space-md);text-align:left;flex-direction:column;display:flex}.login-error{color:var(--color-error);text-align:center;padding:var(--space-sm);border-radius:var(--radius-sm);background:#ff44441a;font-size:.85rem}.login-submit{margin-top:var(--space-sm);width:100%}.login-submit .spinner{border-width:2px;border-top-color:var(--color-bg-deep);border-color:#0d05094d;border-top-color:var(--color-bg-deep);width:20px;height:20px}.login-hint{margin-top:var(--space-lg);color:var(--color-text-muted);font-size:.8rem}.puzzle-shell{gap:var(--space-md);flex-direction:column;display:flex}.puzzle-header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.puzzle-title{margin:0;font-size:1.2rem}.puzzle-subtitle{margin:2px 0 0;font-size:.78rem}.puzzle-chrono{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);flex-direction:column;align-items:flex-end;padding:6px 12px;display:flex}.puzzle-chrono-done{border-color:var(--color-rose);background:var(--color-rose-glow)}.puzzle-chrono-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.65rem}.puzzle-chrono-value{font-variant-numeric:tabular-nums;color:var(--color-rose);font-size:1.05rem;font-weight:800}.puzzle-result-banner{border:1px solid var(--color-rose);color:var(--color-text);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);text-align:center;background:linear-gradient(135deg,#ff5aaf29,#ff5aaf0f);font-size:.92rem}.puzzle-board-wrap{justify-content:center;display:flex}.puzzle-leaderboard{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-md)}.puzzle-leaderboard-title{margin:0 0 var(--space-sm) 0;font-size:.95rem}.puzzle-leaderboard-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.puzzle-leaderboard-row{gap:var(--space-sm);border-radius:var(--radius-sm);grid-template-columns:36px 28px 1fr auto auto;align-items:center;padding:6px 8px;font-size:.85rem;display:grid}.puzzle-leaderboard-row.is-me{background:var(--color-rose-glow);border:1px solid var(--color-rose)}.puzzle-leaderboard-rank{color:var(--color-rose);font-variant-numeric:tabular-nums;font-weight:800}.puzzle-leaderboard-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.puzzle-leaderboard-time{font-variant-numeric:tabular-nums;font-weight:600}.puzzle-leaderboard-mistakes{color:var(--color-text-muted);font-size:.7rem}.puzzle-actions{justify-content:center;gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.sudoku-grid{--cell:clamp(30px, 8vw, 48px);grid-template-columns:repeat(9, var(--cell));grid-template-rows:repeat(9, var(--cell));background:var(--color-rose);border:3px solid var(--color-rose);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;gap:0;display:grid}.sudoku-cell{width:var(--cell);height:var(--cell);background:var(--color-bg-main);font-weight:700;font-size:calc(var(--cell) * .5);cursor:pointer;border:1px solid #eaa2b140;justify-content:center;align-items:center;display:flex;position:relative}.sudoku-cell.given{background:var(--color-bg-elevated);cursor:default;color:var(--color-text-primary)}.sudoku-cell.user-filled{color:var(--color-rose)}.sudoku-cell.error{background:#ff4d6d1f;color:#ff4d6d!important}.sudoku-cell.selected{outline:2px solid var(--color-rose);outline-offset:-2px;z-index:1}.sudoku-cell.peer{background:#ffffff06}.sudoku-cell.given.peer{background:#ffffff0b}.sudoku-cell:nth-child(9n+3),.sudoku-cell:nth-child(9n+6){border-right:2px solid var(--color-rose)}.sudoku-cell:nth-child(n+19):nth-child(-n+27),.sudoku-cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid var(--color-rose)}.sudoku-keypad{max-width:460px;margin:var(--space-md) auto 0;grid-template-columns:repeat(9,1fr);gap:6px;display:grid}.sudoku-key{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);padding:10px 0;font-size:1rem;font-weight:700}.sudoku-key:hover{background:var(--color-rose-glow);border-color:var(--color-rose)}.sudoku-key.erase{background:#ff4d6d14;border-color:#ff4d6d;grid-column:1/-1}.queens-grid{--cell:clamp(36px, 9vw, 56px);grid-template-columns:repeat(8, var(--cell));grid-template-rows:repeat(8, var(--cell));border:2px solid var(--color-text);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;gap:0;display:grid}.queens-cell{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .55);cursor:pointer;border:1px solid #0000002e;justify-content:center;align-items:center;transition:filter .1s;display:flex}.queens-cell:hover{filter:brightness(1.15)}.queens-cell.error-queen{box-shadow:inset 0 0 0 3px #ff4d6d}.zip-grid{--cell:clamp(44px, 11vw, 64px);border:2px solid var(--color-text);border-radius:var(--radius-sm);background:var(--color-bg-main);-webkit-user-select:none;user-select:none;touch-action:none;gap:0;display:grid}.zip-cell{width:var(--cell);height:var(--cell);border:1px solid var(--color-border-subtle);justify-content:center;align-items:center;display:flex;position:relative}.zip-cell.in-path{background:#ff5aaf2e}.zip-cell.start-cell{background:#ff5aaf4d}.zip-cell.end-cell{background:#ff5aaf66}.zip-dot{background:var(--color-rose);width:65%;height:65%;color:var(--color-bg-deep);font-weight:800;font-size:calc(var(--cell) * .42);pointer-events:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.minigame-shell{gap:var(--space-md);flex-direction:column;max-width:640px;margin:0 auto;display:flex}.minigame-header{justify-content:space-between;align-items:flex-end;display:flex}.minigame-title{margin:0;font-size:1.4rem}.minigame-subtitle{margin:4px 0 0;font-size:.82rem}.minigame-progress{background:var(--color-bg-elevated);border-radius:var(--radius-full);border:1px solid var(--color-border-subtle);height:6px;overflow:hidden}.minigame-progress-fill{background:linear-gradient(90deg, var(--color-rose), var(--color-rose-bright));height:100%;transition:width .3s}.minigame-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.minigame-question{text-align:center;margin:0;font-size:1.05rem;font-weight:700;line-height:1.4}.minigame-input-row{gap:var(--space-sm);align-items:center;display:flex}.minigame-input-row input{background:var(--color-bg-main);border-radius:var(--radius-md);flex:1;padding:10px 14px}.minigame-feedback{text-align:center;margin:0;font-size:.95rem;font-weight:700}.minigame-feedback.is-correct{color:var(--color-success)}.minigame-feedback.is-wrong{color:var(--color-error)}.quiz-options{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.quiz-option{background:var(--color-bg-main);border:1px solid var(--color-border-subtle);color:var(--color-text-primary);text-align:left;transition:all var(--transition-fast);justify-content:flex-start;padding:12px 14px;font-weight:500}.quiz-option:hover:not(:disabled){border-color:var(--color-rose);background:var(--color-rose-glow)}.quiz-option.correct{border-color:var(--color-success);color:var(--color-success);background:#4caf502e}.quiz-option-letter{background:var(--color-rose-glow);width:24px;height:24px;color:var(--color-rose);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-right:10px;font-size:.78rem;font-weight:800;display:inline-flex}@media (width<=480px){.quiz-options{grid-template-columns:1fr}}.emoji-clue{text-align:center;letter-spacing:.08em;margin:0;font-size:3rem}.tf-statement{text-align:center;margin:0;font-size:1.05rem;font-style:italic;font-weight:600;line-height:1.5}.tf-buttons{gap:var(--space-md);justify-content:center;display:flex}.tf-btn{min-width:130px}.tf-correct{background:var(--color-success)!important;border-color:var(--color-success)!important;color:#fff!important}.tf-explain{margin-top:var(--space-sm);color:var(--color-text-secondary);background:var(--color-bg-main);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:.82rem;line-height:1.5}.tf-feedback{margin-top:var(--space-sm)}.anagram-scrambled{text-align:center;color:var(--color-rose);letter-spacing:.4em;font-size:2rem;font-weight:800;font-family:var(--font-display);margin:0}.who-hints{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.who-hints li{background:var(--color-bg-main);border-radius:var(--radius-md);border-left:3px solid var(--color-rose);padding:8px 12px;font-size:.92rem}.who-more-hint{align-self:flex-start}.chrono-card{gap:var(--space-md)}.chrono-instruction{text-align:center;color:var(--color-text-secondary);margin:0;font-size:.85rem}.chrono-slots{flex-direction:column;gap:6px;display:flex}.chrono-slot{align-items:center;gap:var(--space-sm);border:1px dashed var(--color-border);border-radius:var(--radius-md);min-height:44px;transition:all var(--transition-fast);padding:10px 14px;display:flex}.chrono-slot.filled{background:var(--color-bg-main);cursor:pointer;border-style:solid}.chrono-slot.filled:hover{border-color:var(--color-rose)}.chrono-slot-num{background:var(--color-rose-glow);width:26px;height:26px;color:var(--color-rose);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:800;display:flex}.chrono-slot-text{font-size:.92rem}.chrono-slot-empty{color:var(--color-text-muted);font-style:italic}.chrono-pool{flex-wrap:wrap;gap:6px;display:flex}.chrono-chip{background:var(--color-bg-main);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);padding:8px 14px;font-size:.85rem}.chrono-chip:hover:not(:disabled){border-color:var(--color-rose);background:var(--color-rose-glow)}.chrono-correct{color:var(--color-text-secondary);text-align:center;margin:6px 0 0;font-size:.78rem;line-height:1.5}.games-tabs{gap:var(--space-sm);margin-bottom:var(--space-lg);padding-bottom:var(--space-xs);display:flex;overflow-x:auto}.game-section{margin-top:var(--space-md)}.games-hub{gap:var(--space-lg);padding:var(--space-lg) 0;background:radial-gradient(at 30% 0,#eaa2b11a,#0000 55%),radial-gradient(at 80% 80%,#510e1773,#0000 60%);flex-direction:column;display:flex}.games-hub-header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.games-hub-title{letter-spacing:.01em;background:linear-gradient(135deg,#f5e6ea 0%,#eaa2b1 50%,#b78832 110%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(1.6rem,4vw,2.4rem)}.games-hub-subtitle{margin:4px 0 0;font-size:.92rem;font-style:italic}.games-hub-reset{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:right;padding:8px 14px}.games-hub-reset-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.65rem;display:block}.games-hub-reset-value{color:var(--color-rose);font-variant-numeric:tabular-nums;font-size:1rem;font-weight:700}.games-hub-plays{align-items:center;gap:var(--space-md);display:flex}.games-hub-progress{background:var(--color-bg-elevated);border-radius:var(--radius-full);border:1px solid var(--color-border-subtle);flex:1;height:8px;overflow:hidden}.games-hub-progress-fill{height:100%;transition:width .3s}.games-hub-plays-text{color:var(--color-text-muted);white-space:nowrap;font-size:.8rem}.games-hub-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));display:grid}.game-tile{align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-md);background:radial-gradient(ellipse at top, #eaa2b114, transparent 60%), var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);cursor:pointer;text-align:center;transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.game-tile:before{content:"";border-radius:var(--radius-xl);opacity:0;transition:opacity var(--transition-base);pointer-events:none;background:linear-gradient(135deg,#0000 30%,#b7883214 60%,#0000 90%);position:absolute;inset:0}.game-tile:hover{border-color:var(--color-rose);box-shadow:var(--shadow-glow-strong), 0 16px 32px #00000080;transform:translateY(-3px)}.game-tile:hover:before{opacity:1}.game-tile:active{transform:translateY(-1px)}.game-tile-medallion{filter:drop-shadow(0 6px 18px #00000080);width:140px;height:140px;transition:transform var(--transition-base);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.game-tile-medallion:after{content:"";opacity:0;transition:opacity var(--transition-base);z-index:-1;background:conic-gradient(#0000,#b788322e,#0000 25% 75%,#eaa2b12e,#0000);border-radius:50%;position:absolute;inset:-4px}.game-tile:hover .game-tile-medallion{transform:scale(1.06)rotate(-2deg)}.game-tile:hover .game-tile-medallion:after{opacity:1;animation:6s linear infinite medallion-spin}@keyframes medallion-spin{to{transform:rotate(360deg)}}.game-tile-medallion img{object-fit:contain;width:100%;height:100%}.game-tile-body{flex-direction:column;align-items:center;gap:6px;display:flex}.game-tile-title{color:var(--color-text-primary);letter-spacing:.02em;margin:0;font-size:1.35rem}.game-tile-tagline{color:var(--color-text-secondary);max-width:28ch;margin:0;font-size:.85rem;line-height:1.45}.game-tile-badge{text-transform:uppercase;letter-spacing:.1em;background:linear-gradient(135deg, var(--color-rose-bright), var(--color-rose));color:var(--color-bg-deep);border-radius:var(--radius-full);margin-top:4px;padding:3px 10px;font-size:.65rem;font-weight:700;display:inline-flex}.game-tile-daily:after{content:"★";color:var(--color-gold);opacity:.55;font-size:.9rem;position:absolute;top:12px;right:14px}.games-back-bar{margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.games-back-btn{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 12px;font-size:.85rem;display:inline-flex}.games-back-btn:hover{color:var(--color-rose);border-color:var(--color-rose);background:var(--color-rose-glow)}.games-back-meta{flex-direction:column;align-items:flex-end;display:flex}@media (width<=600px){.games-hub-grid{grid-template-columns:1fr}.game-tile-medallion{width:110px;height:110px}}.meme-preview{background:var(--color-bg-main);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:center;gap:var(--space-md);text-align:center;flex-direction:column;justify-content:space-between;min-height:200px;display:flex}.meme-preview-sm{min-height:140px;padding:var(--space-md)}.meme-top-text,.meme-bottom-text{text-transform:uppercase;color:var(--color-text-primary);font-size:1rem;font-weight:800}.meme-image-placeholder{color:var(--color-text-muted);padding:var(--space-md);border:1px dashed var(--color-border);border-radius:var(--radius-md);font-size:.85rem}.meme-creator{gap:var(--space-md);flex-direction:column;display:flex}.meme-live-preview{border-radius:var(--radius-lg);max-width:400px;margin:0 auto var(--space-md);position:relative;overflow:hidden}.meme-live-img{width:100%;display:block}.meme-live-text{text-align:center;color:#fff;text-transform:uppercase;text-shadow:2px 2px #000,-2px -2px #000,2px -2px #000,-2px 2px #000,0 2px #000,2px 0 #000,0 -2px #000,-2px 0 #000;word-break:break-word;pointer-events:none;padding:4px 8px;font-family:Impact,Arial Black,sans-serif;font-size:clamp(.8rem,3.5vw,1.4rem);font-weight:900;line-height:1.2;position:absolute;left:0;right:0}.vm-history-row{align-items:center;gap:var(--space-sm);font-size:.85rem;display:flex}.vm-history-word{white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:100px;font-weight:600;overflow:hidden}.vm-proximity-bar{background:var(--color-bg-main);border-radius:var(--radius-full);flex:1;min-width:60px;height:8px;overflow:hidden}.vm-proximity-fill{border-radius:var(--radius-full);height:100%;transition:width .4s}.vm-proximity-pct{text-align:right;flex-shrink:0;width:36px;font-size:.82rem;font-weight:700}.vm-proximity-label{flex-shrink:0;width:70px;font-size:.72rem}@media (width<=480px){.vm-history-word{width:70px}.vm-proximity-label{display:none}}.home-welcome{align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl);display:flex}.home-stats{gap:var(--space-sm);margin-bottom:var(--space-xl);grid-template-columns:repeat(2,1fr);display:grid}.home-stat-card{text-align:center;padding:var(--space-md)}.home-stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:var(--space-xs);font-size:.72rem;display:block}.home-stat-value{font-size:1.5rem;font-weight:800}.home-meme-card{margin-bottom:var(--space-xl);overflow:hidden}.home-meme-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.home-meme-img{object-fit:contain;border-radius:var(--radius-md);width:100%;max-height:300px;margin-bottom:var(--space-sm);background:var(--color-bg-main)}.home-meme-text{text-align:center;padding:var(--space-md);text-transform:uppercase;font-weight:700}.home-activity{margin-bottom:var(--space-xl)}.home-activity-list{gap:var(--space-xs);flex-direction:column;display:flex}.home-activity-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);color:inherit;text-decoration:none;display:flex}.home-activity-item:hover{border-color:var(--color-rose)}.home-activity-icon{flex-shrink:0;font-size:1.3rem}.home-activity-info{flex:1;min-width:0}.home-activity-title{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.home-activity-sub{color:var(--color-text-muted);font-size:.72rem}.home-quick{gap:var(--space-sm);flex-wrap:wrap;display:flex}.home-quick .btn{flex:1;justify-content:center;min-width:100px}@media (width<=380px){.home-stats{grid-template-columns:1fr 1fr}.home-stat-value{font-size:1.2rem}}.profile-preview{max-width:500px;margin-bottom:var(--space-xl);border-width:2px;overflow:hidden}.profile-preview-top{gap:var(--space-lg);padding-bottom:var(--space-md);margin-bottom:var(--space-md);align-items:center;display:flex}.profile-avatar-section{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.profile-avatar-clickable{cursor:pointer;transition:box-shadow var(--transition-fast), border-color var(--transition-fast);border:2px solid var(--color-rose)}.profile-avatar-clickable:hover{box-shadow:var(--shadow-glow)}.profile-preview-info{flex:1;min-width:0}.profile-preview-name{margin-bottom:2px;font-size:1.2rem;font-weight:700;display:block}.profile-preview-role{margin-bottom:var(--space-sm);font-size:.78rem;font-weight:600;display:block}.profile-preview-bio{color:var(--color-text-secondary);font-size:.82rem;line-height:1.4}.profile-badges{gap:var(--space-xs);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.profile-badge{border-radius:var(--radius-full);border:1px solid;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.profile-badge span:first-child{font-size:.85rem}.profile-stats-grid{gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-md) 0;border-top:1px solid var(--color-border-subtle);border-bottom:1px solid var(--color-border-subtle);grid-template-columns:repeat(4,1fr);display:grid}.profile-stat-item{flex-direction:column;align-items:center;gap:2px;display:flex}.profile-stat-value{color:var(--color-text-primary);font-size:1.2rem;font-weight:800}.profile-stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.68rem}.profile-socials-display{gap:var(--space-xs);flex-wrap:wrap;display:flex}.profile-social-chip{border-radius:var(--radius-full);background:var(--color-bg-main);border:1px solid var(--color-border-subtle);color:var(--color-text-secondary);align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;display:inline-flex}.profile-edit-sections{gap:var(--space-md);flex-direction:column;max-width:500px;display:flex}.profile-section{gap:var(--space-sm);flex-direction:column;display:flex}.profile-section-title{margin-bottom:var(--space-xs);font-size:.9rem;font-weight:700}.profile-section textarea,.profile-section input[type=text]{background:var(--color-bg-main);border-radius:var(--radius-md);resize:vertical;padding:10px 14px}.profile-socials-grid{gap:var(--space-sm);flex-direction:column;display:flex}.profile-social-input{align-items:center;gap:var(--space-sm);display:flex}.profile-social-input input{background:var(--color-bg-main);border-radius:var(--radius-md);flex:1;padding:8px 12px;font-size:.85rem}.profile-color-picker{align-items:center;gap:var(--space-md);display:flex}.profile-color-input{border-radius:var(--radius-md);cursor:pointer;background:0 0;border:none;width:44px;height:44px;padding:0}.profile-color-input::-webkit-color-swatch-wrapper{padding:0}.profile-color-input::-webkit-color-swatch{border:2px solid var(--color-border);border-radius:var(--radius-md)}.profile-color-preview{border-radius:var(--radius-full);width:24px;height:24px;box-shadow:0 0 12px}.profile-message{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-align:center;font-size:.85rem}.profile-message.success{color:var(--color-success);background:#4caf501a}.profile-message.error{color:var(--color-error);background:#ff44441a}@media (width<=480px){.profile-preview-top{text-align:center;flex-direction:column}.profile-stats-grid{grid-template-columns:repeat(2,1fr)}}.photo-upload{gap:var(--space-xs);flex-direction:column;display:flex}.photo-upload-btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-md);border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);transition:all var(--transition-fast);cursor:pointer;background:0 0;width:100%;font-family:inherit;font-size:.85rem;font-weight:500;display:flex}.photo-upload-btn:hover{border-color:var(--color-rose);color:var(--color-rose);background:var(--color-rose-glow)}.photo-upload-preview{border-radius:var(--radius-lg);max-height:200px;position:relative;overflow:hidden}.photo-upload-preview img{object-fit:cover;border-radius:var(--radius-lg);width:100%;max-height:200px;display:block}.photo-upload-remove{border-radius:var(--radius-full);color:#fff;cursor:pointer;width:28px;height:28px;transition:background var(--transition-fast);background:#000000b3;border:none;justify-content:center;align-items:center;font-size:.85rem;display:flex;position:absolute;top:8px;right:8px}.photo-upload-remove:hover{background:var(--color-error)}.photo-upload-spinner{background:#0006;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.photo-upload-error{color:var(--color-error);font-size:.78rem}.composer{margin-bottom:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.composer-top{align-items:center;gap:var(--space-md);display:flex}.composer-categories{gap:var(--space-xs);flex-wrap:wrap;display:flex}.composer-cat{border-radius:var(--radius-full);color:var(--color-text-muted);background:var(--color-bg-main);border:1px solid var(--color-border-subtle);transition:all var(--transition-fast);padding:4px 12px;font-size:.78rem;font-weight:500}.composer-cat:hover{color:var(--color-text-secondary);border-color:var(--color-border)}.composer-cat-active{color:var(--color-bg-deep);background:var(--color-rose);border-color:var(--color-rose)}.composer-title{background:var(--color-bg-main);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:10px 14px;font-size:.95rem;font-weight:600}.composer-content{background:var(--color-bg-main);border-radius:var(--radius-md);border:1px solid var(--color-border);resize:vertical;min-height:80px;padding:10px 14px;line-height:1.5}.composer-error{color:var(--color-error);padding:var(--space-sm);border-radius:var(--radius-sm);background:#ff44441a;font-size:.85rem}.composer-actions{justify-content:space-between;align-items:center;display:flex}.post-card{padding:var(--space-md) var(--space-lg)}.post-header{align-items:flex-start;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.post-meta{flex:1;min-width:0}.post-author{font-size:.9rem;font-weight:600;display:block}.post-meta-sub{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.post-category-tag{font-size:.75rem;font-weight:600}.post-time{color:var(--color-text-muted);font-size:.72rem}.post-title{margin-bottom:var(--space-xs);font-size:1.05rem;font-weight:700}.post-content{color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word;font-size:.9rem;line-height:1.6}.post-image{margin-top:var(--space-md);border-radius:var(--radius-md);object-fit:cover;width:100%;max-height:400px}.post-menu-wrapper{position:relative}.post-menu-btn{letter-spacing:1px;color:var(--color-text-muted);border-radius:var(--radius-sm);padding:4px 8px;font-size:1.2rem}.post-menu-btn:hover{color:var(--color-text-primary);background:var(--color-rose-glow)}.post-menu{background:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-xs);z-index:50;min-width:140px;box-shadow:var(--shadow-md);position:absolute;top:100%;right:0}.post-menu-item{text-align:left;border-radius:var(--radius-sm);width:100%;color:var(--color-text-secondary);transition:all var(--transition-fast);padding:8px 12px;font-size:.85rem;display:block}.post-menu-item:hover{background:var(--color-rose-glow);color:var(--color-text-primary)}.post-menu-danger{color:var(--color-error)}.post-menu-danger:hover{color:var(--color-error);background:#ff44441a}.post-report-form{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);gap:var(--space-sm);flex-direction:column;display:flex}.post-report-form input{background:var(--color-bg-main);border-radius:var(--radius-md);padding:8px 12px}.feed-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.feed-title{font-size:1.5rem}.feed-filters{gap:var(--space-sm);margin-bottom:var(--space-lg);padding-bottom:var(--space-xs);-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.feed-filter{border-radius:var(--radius-full);color:var(--color-text-secondary);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);white-space:nowrap;transition:all var(--transition-fast);padding:6px 16px;font-size:.82rem;font-weight:500}.feed-filter:hover{color:var(--color-text-primary);border-color:var(--color-border)}.feed-filter-active{color:var(--color-bg-deep);background:var(--color-rose);border-color:var(--color-rose)}.feed-list{gap:var(--space-md);flex-direction:column;display:flex}.feed-loading{padding:var(--space-2xl);justify-content:center;display:flex}.feed-empty{text-align:center;padding:var(--space-2xl)}.lb-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.lb-title{font-size:1.5rem}.lb-tabs{gap:var(--space-xs);margin-bottom:var(--space-lg);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);padding:4px;display:flex}.lb-tab{border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);flex:1;padding:10px;font-size:.88rem;font-weight:600}.lb-tab:hover{color:var(--color-text-primary)}.lb-tab-active{background:var(--color-rose);color:var(--color-bg-deep)}.lb-my-rank{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-md) var(--space-lg);display:flex}.lb-my-rank-number{font-size:1.5rem;font-weight:800}.lb-my-rank-pts{color:var(--color-text-primary);margin-left:auto;font-weight:700}.lb-table{margin-bottom:var(--space-xl);flex-direction:column;gap:4px;display:flex}.lb-row{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.lb-row:hover{background:var(--color-rose-glow)}.lb-row-me{background:var(--color-rose-glow);border:1px solid var(--color-border-subtle)}.lb-row-top{padding:var(--space-md)}.lb-rank{text-align:center;flex-shrink:0;width:32px;font-size:1.2rem}.lb-rank-num{color:var(--color-text-muted);font-size:.85rem;font-weight:600}.lb-player{align-items:center;gap:var(--space-sm);flex:1;min-width:0;display:flex}.lb-player-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.lb-pts{color:var(--color-text-secondary);flex-shrink:0;font-size:.9rem;font-weight:700}.lb-pts-top{color:var(--color-rose);font-size:1rem}.lb-history{margin-bottom:var(--space-lg)}.lb-history-list{flex-direction:column;gap:4px;max-height:300px;display:flex;overflow-y:auto}.lb-history-row{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-subtle);font-size:.85rem;display:flex}.lb-history-action{color:var(--color-text-secondary);flex:1}.lb-history-pts{flex-shrink:0;font-weight:700}.lb-history-pts.positive{color:var(--color-success)}.lb-history-pts.negative{color:var(--color-error)}.lb-history-date{color:var(--color-text-muted);flex-shrink:0;font-size:.75rem}.lb-info{margin-top:var(--space-lg);padding:var(--space-md);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle)}.lb-info summary{cursor:pointer;font-size:.85rem;font-weight:500}.lb-info-grid{margin-top:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.lb-info-item{padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;font-size:.85rem;display:flex}.lb-loading,.lb-empty{text-align:center;padding:var(--space-2xl)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-md);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:500px;max-height:80vh;animation:fadeIn var(--transition-base) ease;overflow-y:auto}.modal-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.modal-title{font-size:1.2rem;font-weight:700}.modal-meta{gap:var(--space-sm);margin-bottom:var(--space-md);flex-direction:column;display:flex}.modal-meta-item{align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:.88rem;display:flex}.modal-meta-icon{text-align:center;flex-shrink:0;width:24px;font-size:1rem}.modal-description{color:var(--color-text-secondary);white-space:pre-wrap;margin-bottom:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);font-size:.9rem;line-height:1.6}.modal-actions{gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);display:flex}.cal-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:flex-start;gap:var(--space-md);flex-wrap:wrap;display:flex}.cal-title{font-size:1.5rem}.cal-header-actions{gap:var(--space-sm);align-items:center;display:flex}.cal-filters{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.cal-filter-select{background:var(--color-bg-elevated);color:var(--color-text-primary);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);padding:6px 12px;font-size:.82rem}.cal-filter-select option{background:var(--color-bg-main)}.cal-month-nav{justify-content:center;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-lg);display:flex}.cal-month-label{text-align:center;min-width:180px;font-size:1.2rem;font-weight:700}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-day-header{text-align:center;color:var(--color-text-muted);padding:var(--space-sm);font-size:.75rem;font-weight:600}.cal-day{background:var(--color-bg-elevated);border-radius:var(--radius-sm);min-height:80px;padding:var(--space-xs);flex-direction:column;gap:2px;display:flex}.cal-day-empty{background:0 0}.cal-day-today{border:1px solid var(--color-rose)}.cal-day-has{background:var(--color-bg-main);border:1px solid var(--color-border-subtle)}.cal-day-num{color:var(--color-text-secondary);padding:2px 4px;font-size:.78rem;font-weight:600}.cal-day-today .cal-day-num{color:var(--color-rose)}.cal-day-event{background:var(--color-rose-glow);color:var(--color-rose);text-align:left;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;transition:background var(--transition-fast);border-radius:3px;padding:2px 4px;font-size:.65rem;overflow:hidden}.cal-day-event:hover{background:var(--color-rose-glow-strong)}.cal-day-more{color:var(--color-text-muted);padding:0 4px;font-size:.65rem}.cal-list{gap:var(--space-sm);flex-direction:column;display:flex}.cal-list-item{align-items:center;gap:var(--space-md);padding:var(--space-md);cursor:pointer;text-align:left;width:100%;display:flex}.cal-list-item:hover{border-color:var(--color-rose)}.cal-list-date{flex-direction:column;align-items:center;min-width:44px;display:flex}.cal-list-day{color:var(--color-rose);font-size:1.3rem;font-weight:800;line-height:1}.cal-list-month{color:var(--color-text-muted);text-transform:uppercase;font-size:.7rem}.cal-list-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cal-list-title{font-size:.92rem;font-weight:600}.cal-list-meta{color:var(--color-text-muted);font-size:.78rem}.cal-list-count{color:var(--color-text-muted);flex-shrink:0;font-size:.78rem}@media (width<=768px){.cal-day{min-height:56px}.cal-day-event{font-size:.6rem}.cal-header{flex-direction:column}.cal-header-actions{justify-content:space-between;width:100%}}.msg-page{height:calc(100dvh - var(--header-height) - var(--space-xl) * 2);margin:calc(-1 * var(--space-xl));gap:0;margin-top:0;display:flex}.msg-sidebar{border-right:1px solid var(--color-border-subtle);flex-direction:column;flex-shrink:0;width:320px;display:flex}.msg-sidebar-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.msg-search{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-subtle);gap:var(--space-xs);flex-direction:column;display:flex}.msg-search input{background:var(--color-bg-main);border-radius:var(--radius-md);padding:8px 12px}.msg-search-result{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);text-align:left;width:100%;transition:background var(--transition-fast);font-size:.88rem;display:flex}.msg-search-result:hover{background:var(--color-rose-glow)}.msg-conv-list{flex:1;overflow-y:auto}.msg-conv-item{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);text-align:left;border-bottom:1px solid var(--color-border-subtle);width:100%;transition:background var(--transition-fast);display:flex}.msg-conv-item:hover,.msg-conv-active{background:var(--color-rose-glow)}.msg-conv-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.msg-conv-top{justify-content:space-between;align-items:center;display:flex}.msg-conv-name{font-size:.88rem;font-weight:600}.msg-conv-time{color:var(--color-text-muted);flex-shrink:0;font-size:.7rem}.msg-conv-preview{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.msg-unread-badge{background:var(--color-rose);color:var(--color-bg-deep);border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;min-width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex}.msg-chat{flex-direction:column;flex:1;min-width:0;display:flex}.msg-chat-header{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-subtle);display:flex}.msg-chat-name{font-size:.95rem;font-weight:600}.msg-back-btn{display:none}.msg-messages{padding:var(--space-md) var(--space-lg);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.msg-bubble{max-width:75%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);flex-direction:column;gap:2px;display:flex}.msg-mine{background:var(--color-rose);color:var(--color-bg-deep);border-bottom-right-radius:var(--radius-sm);align-self:flex-end}.msg-theirs{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-bottom-left-radius:var(--radius-sm);align-self:flex-start}.msg-text{white-space:pre-wrap;word-break:break-word;font-size:.9rem;line-height:1.5}.msg-time{opacity:.7;align-self:flex-end;font-size:.65rem}.msg-bubble-img{border-radius:var(--radius-md);cursor:pointer;max-width:220px;max-height:200px;margin-bottom:4px}.msg-pending-img{padding:var(--space-sm) var(--space-lg);justify-content:center;align-items:center;display:flex;position:relative}.msg-pending-img img{border-radius:var(--radius-md);max-height:100px}.msg-pending-img-remove{top:4px;right:calc(var(--space-lg) + 4px);border-radius:var(--radius-full);color:#fff;cursor:pointer;background:#000000b3;border:none;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;display:flex;position:absolute}.msg-img-btn{border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:1.2rem}.msg-img-btn:hover{background:var(--color-rose-glow)}.msg-input-bar{gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-subtle);align-items:center;display:flex}.msg-input-bar input{background:var(--color-bg-elevated);border-radius:var(--radius-lg);flex:1;padding:10px 14px}.msg-empty{flex:1;justify-content:center;align-items:center;display:flex}.msg-typing-bubble{opacity:.85;align-items:center;gap:8px;animation:.25s ease-out msg-typing-fade;display:flex;flex-direction:row!important}.msg-typing-label{color:var(--color-text-muted);font-size:.78rem}.msg-typing-dots{align-items:center;gap:3px;display:inline-flex}.msg-typing-dots span{background:var(--color-rose);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite msg-typing-bounce;display:inline-block}.msg-typing-dots span:nth-child(2){animation-delay:.18s}.msg-typing-dots span:nth-child(3){animation-delay:.36s}@keyframes msg-typing-bounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}@keyframes msg-typing-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:.85;transform:translateY(0)}}.msg-pending{opacity:.65}.msg-failed{outline:1px solid #ff4d6d}.msg-chat-sub{color:var(--color-text-muted);font-size:.7rem}.msg-invites{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-subtle);background:var(--color-rose-glow);gap:var(--space-sm);flex-direction:column;display:flex}.msg-invites-title{letter-spacing:.08em;text-transform:uppercase;color:var(--color-rose);font-size:.75rem;font-weight:700}.msg-invite-card{gap:var(--space-xs);padding:var(--space-sm);background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);flex-direction:column;display:flex}.msg-invite-info{align-items:center;gap:var(--space-sm);display:flex}.msg-invite-name{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.msg-invite-meta{color:var(--color-text-muted);font-size:.72rem}.msg-invite-actions{gap:6px;display:flex}.msg-invite-actions .btn{flex:1}.msg-group-create{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-subtle);gap:var(--space-xs);flex-direction:column;display:flex}.msg-group-create input{background:var(--color-bg-main);border-radius:var(--radius-md);padding:8px 12px}.msg-group-picked{flex-wrap:wrap;gap:4px;display:flex}.msg-group-chip{background:var(--color-rose-glow);border:1px solid var(--color-rose);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;display:inline-flex}.msg-group-chip button{color:var(--color-rose);cursor:pointer;background:0 0;border:none;font-size:.95rem;line-height:1}@media (width<=768px){.msg-sidebar{width:100%}.msg-sidebar-hidden,.msg-chat-hidden{display:none}.msg-back-btn{display:block}.msg-page{height:calc(100dvh - var(--header-height) - 72px);margin:calc(-1 * var(--space-md));margin-top:0}}.housing-form{margin-bottom:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.housing-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.housing-card{gap:var(--space-sm);flex-direction:column;display:flex}.housing-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.housing-card-title{font-size:1rem;font-weight:700}.housing-card-price{color:var(--color-rose);white-space:nowrap;flex-shrink:0;font-size:1.2rem;font-weight:800}.housing-card-price small{color:var(--color-text-muted);font-size:.7rem;font-weight:500}.housing-card-meta{gap:var(--space-md);color:var(--color-text-secondary);flex-wrap:wrap;font-size:.82rem;display:flex}.housing-card-desc{color:var(--color-text-muted);font-size:.85rem;line-height:1.5}.housing-card-footer{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.housing-card-author{align-items:center;gap:var(--space-sm);display:flex}.housing-card-actions{gap:var(--space-xs);display:flex}@media (width<=768px){.housing-grid{grid-template-columns:1fr}.housing-form div[style*="grid-template-columns: 1fr 1fr 1fr"]{grid-template-columns:1fr!important}}.res-list{gap:var(--space-sm);flex-direction:column;display:flex}.res-card{align-items:center;gap:var(--space-md);padding:var(--space-md);display:flex}.res-card-left{flex-shrink:0}.res-icon{font-size:1.8rem}.res-card-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.res-card-title{font-size:.95rem;font-weight:600}.res-card-meta{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.res-card-desc{color:var(--color-text-muted);font-size:.8rem;line-height:1.4}.res-card-actions{gap:var(--space-xs);flex-direction:column;flex-shrink:0;display:flex}@media (width<=768px){.res-card{flex-direction:column;align-items:flex-start}.res-card-actions{flex-direction:row;width:100%}.res-card-actions .btn{flex:1}}.hh-stars{gap:4px;display:flex}.hh-star{color:var(--color-text-muted);transition:color var(--transition-fast);padding:0;font-size:1.4rem}.hh-star-active{color:var(--color-gold)}.hh-stars-display{color:var(--color-gold);flex-shrink:0;font-size:.9rem}.hh-stars-empty{color:var(--color-text-muted)}.poll-card{padding:var(--space-lg)}.poll-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.poll-question{font-size:1.05rem;font-weight:700}.poll-options{gap:var(--space-sm);margin-bottom:var(--space-md);flex-direction:column;display:flex}.poll-option-btn{padding:12px var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left;color:var(--color-text-primary);transition:all var(--transition-fast);font-size:.9rem}.poll-option-btn:hover{border-color:var(--color-rose);background:var(--color-rose-glow)}.poll-result{padding:10px var(--space-md);border-radius:var(--radius-md);background:var(--color-bg-main);justify-content:space-between;align-items:center;display:flex;position:relative;overflow:hidden}.poll-result-mine{border:1px solid var(--color-rose)}.poll-result-bar{background:var(--color-rose-glow);border-radius:var(--radius-md);transition:width .5s;position:absolute;top:0;bottom:0;left:0}.poll-result-label{z-index:1;font-size:.9rem;font-weight:500;position:relative}.poll-result-pct{z-index:1;color:var(--color-rose);flex-shrink:0;font-size:.82rem;font-weight:700;position:relative}.poll-footer{justify-content:space-between;gap:var(--space-md);flex-wrap:wrap;display:flex}.pred-card{padding:var(--space-lg)}.pred-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.pred-opponent{font-size:1.1rem;font-weight:700}.pred-time{color:var(--color-text-muted);font-size:.82rem}.pred-pool{margin-bottom:var(--space-md)}.pred-options{gap:var(--space-sm);flex-direction:column;display:flex}.pred-option{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--color-bg-main);border:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.pred-option-winner{border-color:var(--color-success);background:#4caf5014}.pred-option-mine{border-color:var(--color-rose)}.pred-option-info{flex:1}.pred-option-label{font-size:.9rem;font-weight:600;display:block}.pred-option-stats{color:var(--color-text-muted);font-size:.75rem}.pred-bet-input{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);display:flex}.pred-admin{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);flex-wrap:wrap;display:flex}.assos-page{gap:var(--space-lg);flex-direction:column;display:flex}.assos-header{justify-content:space-between;align-items:flex-end;gap:var(--space-md);flex-wrap:wrap;display:flex}.assos-title{background:linear-gradient(135deg,#f5e6ea 0%,#eaa2b1 60%,#b78832 110%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(1.6rem,3.5vw,2.2rem)}.assos-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.asso-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);color:inherit;flex-direction:column;text-decoration:none;display:flex;overflow:hidden}.asso-card:hover{border-color:var(--color-rose);box-shadow:var(--shadow-glow), 0 12px 28px #00000073;transform:translateY(-3px)}.asso-card-banner{background:linear-gradient(135deg, var(--color-bordeaux), var(--color-bg-deep));height:100px;position:relative}.asso-card-banner img{object-fit:cover;width:100%;height:100%}.asso-card-banner-placeholder{background:radial-gradient(#eaa2b133,#0000 70%);width:100%;height:100%}.asso-card-logo{bottom:-28px;left:var(--space-md);background:var(--color-bg-elevated);border:3px solid var(--color-bg-elevated);width:56px;height:56px;color:var(--color-rose);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:flex;position:absolute;overflow:hidden}.asso-card-logo img{object-fit:cover;width:100%;height:100%}.asso-card-body{padding:var(--space-xl) var(--space-md) var(--space-md);flex-direction:column;flex:1;gap:6px;display:flex}.asso-card-name{margin:0;font-size:1.15rem}.asso-card-desc{color:var(--color-text-secondary);margin:0;font-size:.85rem;line-height:1.5}.asso-card-stats{gap:var(--space-md);padding-top:var(--space-sm);color:var(--color-text-muted);margin-top:auto;font-size:.78rem;display:flex}.asso-detail{gap:var(--space-md);flex-direction:column;display:flex}.asso-back{color:var(--color-text-secondary);align-self:flex-start;padding:4px 0;font-size:.85rem}.asso-back:hover{color:var(--color-rose)}.asso-banner{border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);min-height:160px;position:relative;overflow:hidden}.asso-banner-bg{background-position:50%;background-size:cover;background-color:var(--color-bordeaux);filter:brightness(.45);position:absolute;inset:0}.asso-banner-content{padding:var(--space-lg);align-items:center;gap:var(--space-md);flex-wrap:wrap;min-height:160px;display:flex;position:relative}.asso-banner-logo{background:var(--color-bg-elevated);border:4px solid var(--color-bg-elevated);width:96px;height:96px;color:var(--color-rose);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.6rem;font-weight:800;display:flex;overflow:hidden}.asso-banner-logo img{object-fit:cover;width:100%;height:100%}.asso-banner-title{color:#fff;text-shadow:0 2px 8px #0009;margin:0;font-size:clamp(1.6rem,3.5vw,2.4rem)}.asso-banner-tagline{color:#ffffffd9;margin:4px 0 0}.asso-banner-cta{margin-left:auto}.asso-long-desc{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--space-md);color:var(--color-text-secondary);font-size:.92rem;line-height:1.6}.asso-tabs{border-bottom:1px solid var(--color-border-subtle);gap:0;display:flex;overflow-x:auto}.asso-tab{color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 18px;font-weight:600}.asso-tab.is-active{color:var(--color-rose);border-bottom-color:var(--color-rose)}.asso-tab:hover:not(.is-active){color:var(--color-text-primary)}.asso-section{padding:var(--space-md) 0}.asso-mandate-bar{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.asso-mandate-bar select{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:6px 12px;font-size:.88rem}.asso-mandate-badge{color:var(--color-gold);border-radius:var(--radius-full);background:#b7883226;padding:4px 10px;font-size:.72rem}.orgchart{gap:var(--space-lg);flex-direction:column;display:flex}.orgchart-empty{text-align:center;padding:var(--space-xl);gap:var(--space-md);flex-direction:column;align-items:center;display:flex}.orgchart-group-title{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-sm);text-align:center;font-size:.78rem;font-weight:700}.orgchart-row{justify-content:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.orgchart-group.is-top .orgchart-row>*{transform:scale(1.05)}.orgchart-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-md);text-align:center;min-width:160px;max-width:220px;transition:all var(--transition-base);flex-direction:column;align-items:center;gap:8px;display:flex;position:relative}.orgchart-card:hover{border-color:var(--color-rose);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.orgchart-card-photo{cursor:pointer;background:0 0;border:none;padding:0}.orgchart-card-name{font-size:.95rem;font-weight:700}.orgchart-card-role{color:var(--color-rose);font-size:.8rem;font-weight:600}.orgchart-card-bio{color:var(--color-text-secondary);margin-top:4px;font-size:.75rem}.orgchart-card-remove{color:#ff4d6d;cursor:pointer;background:#ff4d6d26;border:none;border-radius:50%;width:22px;height:22px;font-size:.85rem;line-height:1;position:absolute;top:6px;right:6px}.orgchart-role-select{background:var(--color-bg-main);border-radius:var(--radius-sm);color:var(--color-rose);padding:4px 8px;font-size:.78rem;font-weight:600}.orgchart-add-btn{margin-top:var(--space-md);align-self:center}.orgchart-add-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-md);gap:var(--space-xs);flex-direction:column;display:flex}.orgchart-add-result{align-items:center;gap:var(--space-sm);background:var(--color-bg-main);border-radius:var(--radius-sm);text-align:left;cursor:pointer;color:inherit;border:none;width:100%;padding:6px 8px;font-size:.85rem;display:flex}.orgchart-add-result:hover{background:var(--color-rose-glow)}.orgchart-fiche{align-items:center;gap:var(--space-sm);padding:var(--space-md);text-align:center;flex-direction:column;display:flex}.orgchart-fiche-assos{width:100%;margin-top:var(--space-md);flex-direction:column;gap:4px;display:flex}.orgchart-fiche-asso{background:var(--color-bg-main);border-radius:var(--radius-sm);color:inherit;justify-content:space-between;padding:6px 12px;font-size:.85rem;display:flex}.orgchart-fiche-asso:hover{background:var(--color-rose-glow)}.modal-overlay{z-index:100;padding:var(--space-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;padding:var(--space-lg);position:relative;overflow-y:auto}.modal-wide{max-width:880px}.modal-close{top:var(--space-sm);right:var(--space-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);cursor:pointer;border-radius:50%;width:32px;height:32px;font-size:1.2rem;line-height:1;position:absolute}.bureau-transfer-cols{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=720px){.bureau-transfer-cols{grid-template-columns:1fr}}.bureau-transfer-col{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--space-md)}.bureau-transfer-col-title{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:.78rem}.bureau-transfer-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.bureau-transfer-list li{background:var(--color-bg-main);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:6px 8px;font-size:.85rem;display:flex}.bureau-transfer-list-edit li{gap:6px}.bureau-transfer-list-edit select{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:4px 8px;font-size:.78rem}.bureau-remove-x{color:#ff4d6d;cursor:pointer;background:0 0;border:none;font-size:1rem}.bureau-transfer-results{flex-direction:column;gap:2px;max-height:180px;margin-top:6px;display:flex;overflow-y:auto}.bureau-transfer-result{text-align:left;background:var(--color-bg-elevated);cursor:pointer;color:inherit;border-radius:var(--radius-sm);border:none;padding:6px 8px;font-size:.85rem}.bureau-transfer-result:hover{background:var(--color-rose-glow)}.channels-layout{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);background:var(--color-bg-elevated);grid-template-columns:220px 1fr;gap:0;height:70vh;display:grid;overflow:hidden}@media (width<=720px){.channels-layout{grid-template-columns:1fr;height:auto}.channels-sidebar{border-bottom:1px solid var(--color-border-subtle);border-right:none!important}}.channels-sidebar{background:var(--color-bg-deep);border-right:1px solid var(--color-border-subtle);padding:var(--space-sm);flex-direction:column;display:flex;overflow-y:auto}.channels-sidebar-header{justify-content:space-between;align-items:center;margin-bottom:6px;padding:4px 8px;display:flex}.channel-create{align-items:center;gap:4px;padding:4px 0;display:flex}.channel-create input{background:var(--color-bg-main);border-radius:var(--radius-sm);flex:1;padding:6px 10px;font-size:.82rem}.channel-row{color:inherit;border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:6px 8px;font-size:.88rem;display:flex}.channel-row:hover:not(:disabled){background:var(--color-rose-glow)}.channel-row:disabled{opacity:.45;cursor:not-allowed}.channel-row.is-active{background:var(--color-rose-glow);color:var(--color-rose);font-weight:600}.channel-row-icon{color:var(--color-text-muted);font-weight:700}.channel-row-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.channel-row-del{color:#ff4d6d;font-size:.95rem;display:none}.channel-row:hover .channel-row-del{display:inline}.channels-main{flex-direction:column;min-height:0;display:flex}.channels-empty{flex:1;justify-content:center;align-items:center;display:flex}.channel-view{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.channel-header{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-subtle);gap:var(--space-sm);align-items:center;display:flex}.channel-pinned{border-bottom:1px solid var(--color-border-subtle);padding:var(--space-sm) var(--space-md);background:#b7883214;flex-direction:column;gap:4px;font-size:.85rem;display:flex}.channel-pinned-item{background:var(--color-bg-main);border-radius:var(--radius-sm);padding:6px 10px;font-size:.85rem}.channel-messages{padding:var(--space-sm) var(--space-md);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.channel-msg{gap:var(--space-sm);display:flex}.channel-msg-body{flex:1;min-width:0}.channel-msg-meta{align-items:center;gap:8px;font-size:.78rem;display:flex}.channel-msg-content{word-wrap:break-word;white-space:pre-wrap;margin:4px 0 0;font-size:.92rem}.channel-msg-pin{font-size:.82rem}.channel-msg-attachment{background:var(--color-bg-main);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);color:var(--color-rose);margin-top:4px;padding:4px 10px;font-size:.82rem;display:inline-block}.channel-msg-actions{gap:var(--space-md);margin-top:4px;display:flex}.channel-msg-action{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;font-size:.72rem}.channel-msg-action:hover{color:var(--color-rose)}.channel-composer{gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--color-border-subtle);flex-wrap:wrap;align-items:center;display:flex}.channel-composer input[type=text]{background:var(--color-bg-main);border-radius:var(--radius-md);flex:1;min-width:0;padding:8px 12px;font-size:.9rem}.channel-attach-btn{cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.1rem}.channel-attach-btn:hover{color:var(--color-rose)}.channel-file-preview{background:var(--color-bg-main);border-radius:var(--radius-sm);align-items:center;gap:8px;width:100%;padding:4px 10px;font-size:.8rem;display:flex}.channel-file-preview button{color:#ff4d6d;cursor:pointer;background:0 0;border:none;margin-left:auto}.thread-panel{background:var(--color-bg-deep);border-left:1px solid var(--color-border);z-index:5;flex-direction:column;width:360px;display:flex;position:absolute;top:0;bottom:0;right:0}.thread-panel header{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.thread-parent{padding:var(--space-md);border-bottom:1px solid var(--color-border-subtle);font-size:.9rem}.thread-parent p{margin:4px 0 0}.thread-replies{padding:var(--space-sm) var(--space-md);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.thread-reply{padding:4px 0;font-size:.88rem}.thread-reply p{margin:2px 0 0}.thread-composer{gap:var(--space-sm);padding:var(--space-sm);border-top:1px solid var(--color-border-subtle);display:flex}.thread-composer input{background:var(--color-bg-main);border-radius:var(--radius-md);flex:1;padding:8px 12px;font-size:.85rem}@media (width<=720px){.thread-panel{width:100%}}.drive{gap:var(--space-md);flex-direction:column;display:flex}.drive-bar{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;flex-wrap:wrap;display:flex}.drive-breadcrumb{flex-wrap:wrap;align-items:center;gap:4px;font-size:.88rem;display:flex}.drive-crumb{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 6px}.drive-crumb:hover{background:var(--color-rose-glow);color:var(--color-rose)}.drive-sep{color:var(--color-text-muted)}.drive-newfolder{gap:var(--space-sm);background:var(--color-bg-elevated);padding:var(--space-sm);border-radius:var(--radius-md);align-items:center;display:flex}.drive-newfolder input{background:var(--color-bg-main);border-radius:var(--radius-sm);flex:1;padding:6px 10px}.drive-list{flex-direction:column;gap:2px;display:flex}.drive-item{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);transition:border-color var(--transition-fast);display:flex}.drive-item:hover{border-color:var(--color-rose)}.drive-item-main{align-items:center;gap:var(--space-sm);cursor:pointer;color:inherit;text-align:left;background:0 0;border:none;flex:1;padding:10px 12px;font-size:.9rem;display:flex}.drive-icon{font-size:1.1rem}.drive-name{flex:1}.drive-meta{color:var(--color-text-muted);font-size:.78rem}.drive-item-del{cursor:pointer;color:#ff4d6d;visibility:hidden;background:0 0;border:none;padding:0 12px;font-size:1.1rem}.drive-item:hover .drive-item-del{visibility:visible}.admin-tabs{gap:var(--space-sm);margin-bottom:var(--space-lg);padding-bottom:var(--space-xs);-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.admin-bar{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.admin-search{background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);width:100%;max-width:300px;padding:8px 14px}.admin-table-wrap{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.85rem}.admin-table thead{background:var(--color-bg-elevated)}.admin-table th{text-align:left;padding:var(--space-sm) var(--space-md);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border-subtle);font-size:.75rem;font-weight:600}.admin-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-subtle);vertical-align:middle}.admin-table tbody tr:hover{background:var(--color-rose-glow)}.admin-select{background:var(--color-bg-main);color:var(--color-text-primary);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:4px 8px;font-size:.78rem}.admin-select option{background:var(--color-bg-main)}.admin-cards{gap:var(--space-sm);flex-direction:column;display:flex}.admin-report-card{padding:var(--space-md)}@media (width<=768px){.admin-table{font-size:.78rem}.admin-table th,.admin-table td{padding:var(--space-xs) var(--space-sm)}}
