@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@600;700&display=swap";:root{--bg:#0b0a10;--panel:#13111b;--panel2:#0e0c15;--header:#100e17;--text:#d6d2dd;--muted:#8b8496;--dim:#6f6a7c;--gold-line:#d8b45047;--gold-text:#e9c766;--gold-title:#ece3ca;--discord:#5865f2}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif}::selection{background:#d8b4504d}input::placeholder{color:#5d5769}button{font-family:inherit}@keyframes goldPulse{0%,to{filter:drop-shadow(0 0 3px #d8b45059)}50%{filter:drop-shadow(0 0 9px #d8b450bf)}}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes toastIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.cinzel{font-family:Cinzel,serif}.login-wrap{background:radial-gradient(ellipse 70% 50% at 50% 28%, #785c1e29, transparent), var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--panel);border:1px solid var(--gold-line);text-align:center;border-radius:16px;width:430px;max-width:calc(100vw - 32px);padding:46px 42px;box-shadow:0 30px 80px #0009}.login-logo{object-fit:cover;border:1.5px solid #d8b450a6;border-radius:50%;width:96px;height:96px;margin:0 auto 20px;display:block;box-shadow:0 0 24px #d8b45040}.login-title{letter-spacing:2.5px;color:var(--gold-title);font-size:22px;font-weight:700}.login-sub{color:var(--muted);margin-top:8px;font-size:13px;line-height:1.5}.divider{background:linear-gradient(90deg,#0000,#d8b45066,#0000);height:1px;margin:28px 0}.discord-btn{background:var(--discord);color:#fff;cursor:pointer;border:none;border-radius:9px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px;font-size:14.5px;font-weight:600;display:flex}.discord-btn:hover{background:#4752c4}.discord-btn:disabled{opacity:.6;cursor:default}.login-note{color:var(--dim);margin-top:14px;font-size:11.5px;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.topbar{background:var(--header);border-bottom:1px solid #d8b45029;flex:none;align-items:center;gap:26px;height:60px;padding:0 24px;display:flex}.brand{align-items:center;gap:11px;display:flex}.brand img{object-fit:cover;border:1.5px solid #d8b45099;border-radius:50%;width:34px;height:34px}.brand-name{letter-spacing:3px;color:var(--gold-title);font-size:15px;font-weight:700}.brand-tag{color:var(--dim);border-left:1px solid #ffffff1f;padding-left:11px;font-size:11px}.tabs{gap:6px;display:flex}.tab{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:8px;align-items:center;padding:8px 13px;font-size:13px;font-weight:600;display:flex}.tab:hover{color:var(--gold-title)}.tab.active{color:var(--gold-title);background:#d8b4501a;box-shadow:inset 0 0 0 1px #d8b45059}.tab-badge{color:var(--gold-text);background:#d8b45033;border:1px solid #d8b45080;border-radius:20px;margin-left:7px;padding:1px 7px;font-size:10px;font-weight:700}.live{align-items:center;gap:7px;display:flex}.live-dot{background:#63c581;border-radius:50%;width:8px;height:8px;animation:1.8s infinite livePulse}.live-dot.off{background:#d97066;animation:none}.live-text{color:#7dc98f;font-size:11px}.live-text.off{color:#d97066}.me{align-items:center;gap:10px;display:flex}.me-name{color:#e6e2ee;font-size:13px;font-weight:600}.logout{color:var(--muted);cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:7px;padding:5px 10px;font-size:11px}.logout:hover{color:var(--text);border-color:#ffffff4d}.grow{flex:1}.body{flex:1;align-items:stretch;min-height:0;display:flex}.avatar{color:#fff;border-radius:50%;flex:none;justify-content:center;align-items:center;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.cal{flex:1;min-width:0;display:flex}.cal-main{flex:1;min-width:0;padding:20px 26px 30px}.week-switch{gap:8px;margin-bottom:14px;display:flex}.week-btn{cursor:pointer;color:#9b93a8;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:9px;align-items:baseline;gap:8px;padding:8px 14px;font-size:12.5px;display:flex}.week-btn .wl{font-weight:700}.week-btn .wd{color:var(--dim);font-size:11px}.week-btn .wm{color:var(--gold-text);font-size:11px;font-weight:700}.week-btn.active{color:var(--gold-text);background:#d8b45021;border-color:#d8b4508c}.week-btn.active .wd{color:#e6c464bf}.cal-toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.cal-toolbar .label{color:var(--muted);font-size:12px;font-weight:600}.cal-hint{color:var(--dim);font-size:11.5px}.chip{cursor:pointer;border-radius:8px;align-items:center;gap:7px;padding:7px 12px;font-size:12.5px;font-weight:600;display:flex}.chip:hover{filter:brightness(1.2)}.chip-badge{border-radius:4px;flex:none;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:800;display:flex}.grid{-webkit-user-select:none;user-select:none;grid-template-columns:52px repeat(7,1fr);column-gap:6px;margin-top:16px;display:grid;position:relative}.grid-col{flex-direction:column;row-gap:3px;min-width:0;display:flex}.grid-head{flex-direction:column;justify-content:center;align-items:center;height:36px;margin-bottom:5px;line-height:1.25;display:flex}.grid-head .d{color:#cfc9da;font-size:12.5px;font-weight:700}.grid-head .sub{color:var(--dim);font-size:9.5px}.grid-head.today .d{color:var(--gold-title)}.grid-head.today .sub{color:#e6c464cc}.hour-label{height:36px;color:var(--dim);justify-content:flex-end;align-items:center;padding-right:9px;font-size:11px;display:flex}.cell{border-radius:6px;justify-content:center;align-items:center;min-width:0;height:36px;font-size:11px;display:flex}.cell.clickable{cursor:pointer;transition:background .12s}.cell.clickable:hover{filter:brightness(1.35)}.overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:5;background:#0b0a10b8;border-radius:10px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.overlay-card{text-align:center;background:#17141f;border:1px solid #d8b45059;border-radius:12px;max-width:320px;padding:26px 30px}.overlay-card .t{color:var(--gold-title);font-size:14px;font-weight:600}.overlay-card .s{color:var(--muted);margin-top:6px;font-size:12px;line-height:1.5}.btn-gold{color:var(--gold-text);cursor:pointer;background:#d8b45026;border:1px solid #d8b45099;border-radius:8px;font-weight:600}.sidebar{background:var(--panel2);border-left:1px solid #ffffff12;flex-direction:column;flex:none;gap:16px;width:322px;padding:20px 18px;display:flex;overflow-y:auto}.card{background:var(--panel);border:1px solid #ffffff14;border-radius:12px;padding:14px 15px}.card-title{letter-spacing:1.2px;color:#9b93a8;font-size:11px;font-weight:700}.matches-card{border:1px solid var(--gold-line);background:linear-gradient(170deg, #d8b45014, transparent 55%), var(--panel);border-radius:12px;padding:15px 15px 12px}.matches-head{align-items:baseline;gap:8px;display:flex}.matches-head .t{letter-spacing:1.5px;color:var(--gold-text);font-family:Cinzel,serif;font-size:13px;font-weight:700}.matches-head .s{color:var(--muted);font-size:11px}.empty{color:var(--dim);margin-top:10px;font-size:12px;line-height:1.55}.match{cursor:pointer;background:#d8b4500f;border:1px solid #d8b45073;border-radius:10px;margin-top:10px;padding:10px 12px}.match:hover{border-color:var(--gold-text);background:#d8b4501f}.match-head{align-items:baseline;gap:8px;display:flex}.match-head .day{color:#f0d98a;font-size:13px;font-weight:700}.match-head .time{color:#bfa96a;font-size:11.5px}.match-head .cnt{color:var(--muted);font-size:10px}.match-five{align-items:flex-start;gap:7px;margin-top:9px;display:flex}.match-member{flex-direction:column;align-items:center;gap:3px;display:flex}.match-member .rl{color:#7f7890;letter-spacing:.5px;font-size:8.5px;font-weight:700}.near{align-items:baseline;gap:8px;margin-top:8px;font-size:12px;display:flex}.near .day{color:#cfc9da;font-weight:600}.near .time{color:#7f7890}.near .miss{color:#d98f6a;font-size:11px}.legend-row{align-items:center;gap:9px;margin-top:10px;display:flex}.legend-row .sw{border-radius:4px;flex:none;width:22px;height:16px}.legend-row span:last-child{color:#b9b3c4;font-size:11.5px}.chars{flex:1;max-width:1080px;padding:26px 32px}.chars-title{letter-spacing:2px;color:var(--gold-title);font-family:Cinzel,serif;font-size:20px;font-weight:700}.chars-sub{color:var(--muted);margin-top:6px;font-size:12.5px}.char-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:13px;margin-top:22px;display:grid}.char-card{background:var(--panel);border:1px solid #ffffff17;border-radius:12px;padding:16px 17px}.char-card .top{align-items:center;gap:12px;display:flex}.char-card .name{color:#e6e2ee;font-size:14.5px;font-weight:700}.char-card .cls{margin-top:2px;font-size:12px}.char-card .bottom{align-items:center;gap:8px;margin-top:13px;display:flex}.role-badge{letter-spacing:1px;text-transform:uppercase;color:#b9b3c4;background:#ffffff0f;border:1px solid #ffffff24;border-radius:20px;padding:3px 9px;font-size:10px;font-weight:800}.slot-count{color:var(--dim);font-size:11px}.del-btn{color:#d97066;cursor:pointer;background:#d9706614;border:1px solid #d9706659;border-radius:7px;align-items:center;gap:5px;padding:5px 10px;font-size:11px;font-weight:600;display:flex}.del-btn:hover{background:#d970662e;border-color:#d97066}.new-char{background:var(--panel);border:1px solid #ffffff17;border-radius:14px;max-width:660px;margin-top:26px;padding:22px 24px}.new-char h3{color:var(--gold-title);margin:0;font-size:14px;font-weight:700}.text-input{background:var(--panel2);color:#e6e2ee;border:1px solid #ffffff1f;border-radius:8px;outline:none;width:100%;margin-top:14px;padding:10px 13px;font-size:13px}.text-input:focus{border-color:#d8b45099}.field-label{letter-spacing:1px;color:#9b93a8;margin-top:16px;font-size:11px;font-weight:700}.pick-row{flex-wrap:wrap;gap:7px;margin-top:9px;display:flex}.pick{cursor:pointer;border-radius:7px;padding:6px 11px;font-size:12px;font-weight:600}.pick:hover{filter:brightness(1.25)}.pick.role{padding:7px 18px;font-size:12.5px}.add-btn{border:none;border-radius:8px;margin-top:20px;padding:11px 22px;font-size:13px;font-weight:700}.tooltip{z-index:50;pointer-events:none;background:#17141f;border:1px solid #d8b45066;border-radius:11px;min-width:230px;padding:12px 14px;position:fixed;transform:translate(-50%,-100%);box-shadow:0 14px 34px #0000008c}.tooltip .title{color:#9b93a8;letter-spacing:.4px;font-size:11px}.tooltip .match-flag{color:var(--gold-text);margin-top:5px;font-size:11.5px;font-weight:700}.tooltip .hr{background:#ffffff14;height:1px;margin:9px 0}.tt-group{margin-bottom:7px}.tt-group .gl{color:#7f7890;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:5px;font-size:9.5px;font-weight:700}.tt-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.tt-row .pn{color:#e6e2ee;font-size:12px}.tt-row .cl{white-space:nowrap;margin-left:auto;padding-left:10px;font-size:10.5px}.toast{z-index:60;color:#e6e2ee;background:#17141f;border:1px solid #d8b45073;border-radius:10px;align-items:center;gap:9px;max-width:340px;padding:12px 16px;font-size:12.5px;animation:.25s toastIn;display:flex;position:fixed;bottom:22px;right:22px;box-shadow:0 12px 28px #0000008c}.toast .dot{background:#63c581;border-radius:50%;flex:none;width:7px;height:7px;animation:1.6s infinite livePulse}.cell,.chip,.tab,.pick,button{touch-action:manipulation}@media (width<=980px){.cal{flex-direction:column}.sidebar{border-top:1px solid #ffffff12;border-left:none;width:auto}}@media (width<=640px){.topbar{flex-wrap:wrap;gap:8px 12px;height:auto;min-height:54px;padding:8px 12px}.brand-tag,.live-text,.me-name{display:none}.brand-name{letter-spacing:2px;font-size:13px}.brand img{width:28px;height:28px}.tabs{order:3;width:100%}.tab{padding:7px 11px;font-size:12.5px}.cal-main{padding:12px 8px 20px}.cal-toolbar{gap:7px}.cal-hint{display:none}.week-switch{gap:6px}.week-btn{flex-direction:column;flex:1;align-items:center;gap:1px;padding:7px 6px}.week-btn .wl{font-size:11.5px}.week-btn .wd{font-size:10px}.grid{grid-template-columns:34px repeat(7,1fr);column-gap:2px}.grid-col{row-gap:2px}.hour-label{height:32px;padding-right:5px;font-size:9.5px}.grid-head .d{font-size:11px}.grid-head .sub{font-size:8.5px}.cell{border-radius:4px;height:32px;font-size:10px}.cal-toolbar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.cal-toolbar .label{flex:none}.chip{flex:none;padding:6px 10px;font-size:12px}.sidebar{gap:12px;padding:14px 12px}.chars{padding:18px 14px}.chars-title{font-size:17px}.char-grid{grid-template-columns:1fr}.new-char{padding:16px 14px}.pick.role{padding:7px 12px}.login-card{padding:32px 22px}.login-title{letter-spacing:2px;font-size:18px}.toast{max-width:none;left:12px;right:12px}}@media (width<=380px){.grid{grid-template-columns:28px repeat(7,1fr)}.hour-label{height:28px;font-size:8.5px}.cell{height:28px;font-size:9px}}.setup{background:var(--panel);border:1px solid var(--gold-line);border-radius:14px;max-width:620px;margin:60px auto;padding:28px 32px}.setup h2{color:var(--gold-title);letter-spacing:1px;font-family:Cinzel,serif}.setup code{background:var(--panel2);color:var(--gold-text);border-radius:5px;padding:2px 6px}.setup ol{color:var(--text);line-height:1.7}.notice-backdrop{z-index:80;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#08060eb8;justify-content:center;align-items:center;padding:16px;animation:.22s noticeIn;display:flex;position:fixed;inset:0}@keyframes noticeIn{0%{opacity:0}to{opacity:1}}.notice-card{background:var(--panel);border:1px solid var(--gold-line);border-radius:16px;width:480px;max-width:100%;max-height:86vh;padding:28px 30px;overflow-y:auto;box-shadow:0 30px 80px #0009}.notice-title{letter-spacing:1.8px;color:var(--gold-title);font-size:17px;font-weight:700}.notice-text{color:var(--text);margin-top:12px;font-size:13px;line-height:1.6}.notice-sub{letter-spacing:1px;color:var(--gold-text);margin-top:18px;font-size:12px;font-weight:700}.notice-list{color:var(--muted);margin:10px 0 0;padding-left:18px;font-size:12.5px;line-height:1.55}.notice-list li{margin-top:7px}.notice-list b{color:var(--text)}.notice-btn{width:100%;color:var(--gold-text);cursor:pointer;background:#d8b45026;border:1px solid #d8b45099;border-radius:9px;margin-top:22px;padding:12px;font-size:13px;font-weight:600;display:block}.notice-btn:hover{background:#d8b4503d}.notice-link{cursor:pointer;color:var(--dim);background:0 0;border:none;margin-top:14px;padding:2px 4px;font-size:11px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.notice-link:hover{color:var(--muted)}.app-footer{text-align:center;flex:none;padding:4px 0 10px}@media (width<=640px){.notice-card{padding:22px 18px}}
