:root{--black: #050507;--black-soft: #0b0b12;--purple: #552583;--purple-bright: #7d3cb5;--gold: #fdb927;--gold-dim: rgba(253, 185, 39, .12);--teal: #00d4ff;--text: rgba(255, 248, 231, .78);--text-strong: #fff8eb;--text-muted: rgba(255, 248, 231, .45);--border: rgba(253, 185, 39, .14);--border-strong: rgba(253, 185, 39, .35);--panel-bg: linear-gradient(180deg, rgba(18, 10, 28, .88), rgba(7, 7, 13, .95));--shadow-lg: 0 24px 80px rgba(0, 0, 0, .5);--radius-card: 1.5rem;--radius-sm: .85rem;--radius-pill: 999px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;color:var(--text);background:radial-gradient(ellipse at top,rgba(85,37,131,.45),transparent 50%),radial-gradient(ellipse at bottom right,rgba(0,60,80,.3),transparent 50%),linear-gradient(180deg,#12091c,#08080d 55%,#040406);min-height:100vh;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh}body,a,button{color:inherit}h1,h2,h3{font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--text-strong);line-height:1.05;margin:0}h1{font-size:clamp(2.2rem,6vw,3.8rem);letter-spacing:-.04em}h2{font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:-.03em}h3{font-size:1.1rem;letter-spacing:-.01em}p{margin:0}button{cursor:pointer;border:none;background:none;font:inherit}input{font:inherit}#root{min-height:100vh;display:flex;flex-direction:column}.register-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;position:relative;overflow:hidden}.register-card{position:relative;z-index:1;width:100%;max-width:440px;background:linear-gradient(180deg,#120a1ceb,#07070df7);border:1px solid rgba(253,185,39,.18);border-radius:2rem;padding:2.5rem 2rem;box-shadow:0 0 0 1px #00000080,0 32px 80px #0009,0 0 60px #55258333}.register-header{margin-bottom:2rem;text-align:center}.ornament{color:var(--gold);font-size:.9rem;letter-spacing:.2em;margin-bottom:1rem;opacity:.7}.register-header h1{font-size:clamp(1.8rem,5vw,2.4rem);margin-bottom:.65rem;background:linear-gradient(135deg,#fff8eb,var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-muted);font-size:.92rem;line-height:1.5}.register-form{display:flex;flex-direction:column;gap:1.1rem}.field-group{display:flex;flex-direction:column;gap:.4rem}.field-group label{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.field-group input{width:100%;padding:.85rem 1rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text-strong);font-size:1rem;transition:border-color .2s,box-shadow .2s;outline:none}.field-group input::placeholder{color:#fff8e74d}.field-group input:focus{border-color:#fdb92780;box-shadow:0 0 0 3px #fdb9271a}.field-group input:disabled{opacity:.5}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.form-error{color:#f87171;font-size:.85rem;padding:.65rem .9rem;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-sm)}.btn-primary{display:flex;align-items:center;justify-content:center;padding:.95rem 1.4rem;border-radius:var(--radius-pill);font-weight:700;font-size:1rem;color:#140912;background:linear-gradient(135deg,var(--gold),#ffd86f);box-shadow:0 8px 24px #fdb9274d;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease;margin-top:.4rem}.btn-primary:disabled{opacity:.55}.divider{display:flex;align-items:center;gap:.75rem;margin:1.5rem 0;color:var(--text-muted);font-size:.8rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.google-btn-wrapper{display:flex;justify-content:center;min-height:44px}.footer-note{margin-top:1.5rem;font-size:.76rem;color:var(--text-muted);text-align:center;line-height:1.5}.link-btn{background:none;border:none;padding:0;font-size:inherit;font-weight:700;color:var(--gold);cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:opacity .15s}.link-btn:hover{opacity:.8}.verify-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;position:relative;overflow:hidden}.verify-card{position:relative;z-index:1;width:100%;max-width:420px;background:linear-gradient(180deg,#120a1ceb,#07070df7);border:1px solid rgba(253,185,39,.18);border-radius:2rem;padding:2.5rem 2rem;box-shadow:0 0 0 1px #00000080,0 32px 80px #0009;display:flex;flex-direction:column;gap:0}.verify-header{text-align:center;margin-bottom:2rem}.code-icon{font-size:2.8rem;margin-bottom:1rem;filter:drop-shadow(0 0 12px rgba(253,185,39,.5))}.verify-header h2{margin-bottom:.75rem;background:linear-gradient(135deg,#fff8eb,var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.verify-header .subtitle{color:var(--text-muted);font-size:.92rem;line-height:1.6}.verify-header .subtitle strong{color:var(--text-strong)}.digits-row{display:flex;gap:.5rem;justify-content:center;margin-bottom:1.25rem}.digit-box{width:52px;height:60px;text-align:center;font-size:1.6rem;font-weight:800;border-radius:.75rem;border:2px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--text-strong);caret-color:var(--gold);transition:border-color .18s,box-shadow .18s;outline:none}.digit-box:focus{border-color:#fdb92799;box-shadow:0 0 0 3px #fdb9271f}.digit-box.filled{border-color:#fdb92766;background:#fdb9270f;color:var(--gold)}.digit-box.error{border-color:#f8717199;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.form-error{color:#f87171;font-size:.85rem;padding:.65rem .9rem;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-sm);text-align:center;margin-bottom:1rem}.btn-primary{display:flex;align-items:center;justify-content:center;padding:.95rem 1.4rem;border-radius:var(--radius-pill);font-weight:700;font-size:1rem;color:#140912;background:linear-gradient(135deg,var(--gold),#ffd86f);box-shadow:0 8px 24px #fdb9274d;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease;margin-bottom:1.25rem}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #fdb92766}.btn-primary:disabled{opacity:.45}.verify-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;color:var(--text-muted)}.resend-btn{color:var(--gold);font-size:.85rem;font-weight:600;transition:opacity .18s}.resend-btn:disabled{color:var(--text-muted);opacity:.7}.resend-btn:hover:not(:disabled){opacity:.8}.back-btn{margin-top:1.25rem;font-size:.85rem;color:var(--text-muted);align-self:center;transition:color .18s}.back-btn:hover{color:var(--text-strong)}.brand{display:flex;align-items:center;gap:.65rem;margin-bottom:2rem}.brand-rune{display:inline-grid;place-items:center;width:2rem;height:2rem;border-radius:50%;color:var(--gold);background:#fdb9271f;box-shadow:0 0 0 1px #fdb9274d;font-size:.85rem}.brand-name{font-weight:800;font-size:1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-strong)}.bg-orb{position:fixed;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}.orb-purple{width:36rem;height:36rem;top:-10rem;left:-10rem;background:#5525838c}.orb-gold{width:28rem;height:28rem;bottom:-6rem;right:-6rem;background:#fdb92740}@media (max-width: 400px){.digit-box{width:42px;height:50px;font-size:1.3rem}}.selection-shell{min-height:100vh;position:relative;overflow-x:hidden}.bg-orb{position:fixed;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}.orb-purple{width:40rem;height:40rem;top:-12rem;left:-12rem;background:#55258380}.orb-teal{width:30rem;height:30rem;bottom:-8rem;right:-8rem;background:#00648259}.orb-gold{width:28rem;height:28rem;bottom:-6rem;right:-6rem;background:#fdb92733}.selection-page{position:relative;z-index:1;max-width:620px;margin:0 auto;padding:2.5rem 1.25rem 7rem}.sel-header{text-align:center;margin-bottom:2rem}.sel-ornament{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem}.sel-ornament.bottom{margin-top:.75rem;margin-bottom:0}.orn-line{display:block;height:1px;width:5rem;background:linear-gradient(90deg,transparent,rgba(253,185,39,.5),transparent)}.orn-line.short{width:2.5rem}.orn-rune{color:var(--gold);font-size:1rem;opacity:.8}.orn-dots{color:#fdb92766;font-size:.8rem;letter-spacing:.2em}.sel-title{font-size:clamp(1.8rem,6vw,2.8rem);font-weight:900;letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg,#fff8eb 30%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sel-welcome{color:var(--text-muted);font-size:.88rem;margin-top:.5rem}.sel-welcome strong{color:var(--text-strong)}.cards-list{display:flex;flex-direction:column;gap:.85rem}.race-card{display:flex;align-items:stretch;width:100%;min-height:130px;border-radius:1.25rem;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,var(--race-from),var(--race-to));overflow:hidden;cursor:pointer;text-align:left;transition:border-color .22s,box-shadow .22s,transform .18s;position:relative}.race-card:hover{border-color:rgba(var(--race-color-rgb, 253, 185, 39),.3);transform:translate(4px)}.race-card.selected{border-color:var(--race-color);box-shadow:0 0 0 1px var(--race-color),0 0 28px var(--race-glow),inset 0 0 32px #0003}.card-portrait{position:relative;width:120px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.portrait-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,var(--race-glow) 0%,transparent 70%);opacity:.6}.portrait-symbol{position:relative;z-index:1;font-size:3.2rem;color:var(--race-color);filter:drop-shadow(0 0 16px var(--race-glow));line-height:1;font-family:serif;-webkit-user-select:none;user-select:none}.portrait-glow-ring{position:absolute;width:80px;height:80px;border-radius:50%;border:1px solid var(--race-color);opacity:.2}.race-card.selected .portrait-glow-ring{opacity:.5;animation:ring-pulse 2s ease-in-out infinite}@keyframes ring-pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.15);opacity:.2}}.card-info{flex:1;padding:1rem 1rem 1rem .5rem;display:flex;flex-direction:column;gap:.25rem;position:relative}.selected-badge{position:absolute;top:.75rem;right:.75rem;width:28px;height:28px;border-radius:6px;background:var(--race-color);color:#140912;display:grid;place-items:center;box-shadow:0 0 12px var(--race-glow)}.card-name{font-size:1.3rem;font-weight:800;color:var(--text-strong);margin-bottom:.1rem;padding-right:2rem}.race-card.selected .card-name{color:var(--race-color)}.card-desc{font-size:.85rem;font-weight:600;color:var(--text-muted)}.card-lore{font-size:.8rem;color:var(--text-muted);line-height:1.4;margin-top:.15rem}.card-bonuses{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.bonus-tag{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:700;padding:.25rem .6rem;border-radius:var(--radius-pill);background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text)}.bonus-icon{font-size:.9rem}.stat-bars{display:grid;grid-template-columns:1fr 1fr;gap:.35rem .75rem;margin-top:.4rem}.stat-bar-row{display:flex;align-items:center;gap:.4rem}.stat-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);width:3.5rem;flex-shrink:0}.stat-track{flex:1;height:4px;border-radius:999px;background:#ffffff14;overflow:hidden}.stat-fill{height:100%;border-radius:999px;transition:width .4s ease;opacity:.85}.card-cta{align-self:flex-end;font-size:.85rem;font-weight:700;color:var(--race-color);margin-top:auto;padding-top:.5rem;opacity:.9}.race-card.selected .card-cta{opacity:1}.sel-error{color:#f87171;font-size:.85rem;padding:.65rem .9rem;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-sm);text-align:center;margin:.75rem 0}.confirm-bar{position:fixed;bottom:0;left:0;right:0;z-index:10;padding:1rem 1.25rem 1.5rem;background:linear-gradient(to top,rgba(4,4,6,.98) 60%,transparent)}.btn-confirm{display:block;width:100%;max-width:620px;margin:0 auto;padding:1.1rem 1.5rem;border-radius:var(--radius-pill);font-weight:900;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:#140912;background:linear-gradient(135deg,var(--gold),#ffd86f);box-shadow:0 8px 32px #fdb92759,0 2px 8px #0006;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.btn-confirm:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 40px #fdb92773,0 4px 12px #0006}.btn-confirm:disabled{opacity:.4}@media (max-width: 480px){.card-portrait{width:90px}.portrait-symbol{font-size:2.5rem}.card-name{font-size:1.15rem}.stat-bars{grid-template-columns:1fr}}.ap-shell{min-height:100vh;position:relative;overflow-x:hidden}.ap-page{position:relative;z-index:1;max-width:500px;margin:0 auto;padding:2.5rem 1.25rem 9rem}.ap-character-badges{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.75rem}.ap-badge{font-size:.8rem;font-weight:700;padding:.3rem .8rem;border-radius:var(--radius-pill);background:#fdb9271a;border:1px solid rgba(253,185,39,.3);color:var(--gold);letter-spacing:.05em}.ap-badge-sep{color:#fdb9274d}.ap-tabs{display:flex;gap:.5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:1rem;padding:.3rem;margin-bottom:1.25rem}.ap-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.65rem .5rem;border-radius:.75rem;font-size:.78rem;font-weight:600;color:var(--text-muted);transition:background .18s,color .18s;white-space:nowrap}.ap-tab-icon{font-size:1.2rem;line-height:1}.ap-tab.active{background:#fdb9271f;color:var(--gold);border:1px solid rgba(253,185,39,.25)}.ap-tab:hover:not(.active){background:#ffffff0f;color:var(--text)}.ap-ai-notice{display:flex;align-items:flex-start;gap:.65rem;padding:.75rem 1rem;border-radius:.85rem;background:#00d4ff12;border:1px solid rgba(0,212,255,.2);color:var(--text);font-size:.82rem;line-height:1.4;margin-bottom:1rem}.ap-ai-notice.exhausted{background:#f8717112;border-color:#f8717140;color:#f87171}.ap-ai-icon{font-size:1rem;flex-shrink:0;margin-top:.05rem}.ap-drop-zone{aspect-ratio:1;border-radius:1.25rem;border:2px dashed rgba(253,185,39,.25);background:#ffffff06;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;cursor:pointer;overflow:hidden;transition:border-color .2s,background .2s;margin-bottom:1rem}.ap-drop-zone:hover{border-color:#fdb92780;background:#fdb9270a}.ap-drop-icon{font-size:2.5rem;line-height:1;opacity:.5}.ap-drop-label{font-weight:600;color:var(--text);font-size:.9rem}.ap-drop-sub{font-size:.78rem;color:var(--text-muted);text-align:center;padding:0 1rem}.ap-preview-img{width:100%;height:100%;object-fit:cover;border-radius:1.1rem;display:block}.ap-generate-area{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1rem}.ap-generate-placeholder{aspect-ratio:1;border-radius:1.25rem;background:#ffffff06;border:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;text-align:center}.ap-gen-icon{font-size:3rem;line-height:1;opacity:.45}.ap-generate-placeholder p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.ap-generate-placeholder strong{color:var(--text)}.ap-preview-wrap{aspect-ratio:1;border-radius:1.25rem;overflow:hidden;border:1px solid rgba(253,185,39,.2);box-shadow:0 0 32px #fdb9271f}.ap-btn-generate{width:100%;padding:.9rem;border-radius:var(--radius-pill);font-weight:800;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);color:#00d4ff;transition:background .18s,border-color .18s}.ap-btn-generate:hover:not(:disabled){background:#00d4ff2e;border-color:#00d4ff80}.ap-btn-generate:disabled{opacity:.35}.ap-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0;color:var(--text-muted);font-size:.85rem}.ap-spinner{width:28px;height:28px;border-radius:50%;border:3px solid rgba(253,185,39,.15);border-top-color:var(--gold);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ap-confirm-bar{display:flex;flex-direction:column;gap:.6rem;align-items:stretch}.ap-btn-skip{width:100%;max-width:500px;margin:0 auto;padding:.75rem;border-radius:var(--radius-pill);font-weight:600;font-size:.85rem;color:var(--text-muted);border:1px solid rgba(255,255,255,.1);background:transparent;transition:color .18s,border-color .18s}.ap-btn-skip:hover:not(:disabled){color:var(--text);border-color:#fff3}.ap-btn-skip:disabled{opacity:.35}.db-shell{min-height:100vh;position:relative;overflow-x:hidden}.db-shell .bg-orb{position:fixed;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}.db-shell .orb-purple{width:40rem;height:40rem;top:-12rem;left:-12rem;background:#5525838c}.db-shell .orb-gold{width:30rem;height:30rem;bottom:-8rem;right:-8rem;background:#fdb9274d}.db-shell .orb-teal{width:28rem;height:28rem;top:25%;right:-8rem;background:#0082a040}.db-page{position:relative;z-index:1;max-width:540px;margin:0 auto;padding:2rem 1.25rem 4rem;display:flex;flex-direction:column;gap:1.25rem}.db-player-card{display:flex;align-items:center;gap:1.25rem;background:linear-gradient(135deg,#120a1ceb,#07070df7);border:1px solid rgba(253,185,39,.2);border-radius:1.5rem;padding:1.25rem;box-shadow:0 8px 32px #0006}.db-avatar-wrap{flex-shrink:0;width:76px;height:76px;border-radius:50%;overflow:hidden;border:2px solid rgba(253,185,39,.35);box-shadow:0 0 20px #fdb92726}.db-avatar{width:100%;height:100%;object-fit:cover}.db-avatar-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#55258366;color:var(--gold);font-size:1.8rem;font-weight:800}.db-player-info{flex:1;min-width:0}.db-player-name-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}.db-player-name{font-size:1.25rem;font-weight:800;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.db-btn-logout{flex-shrink:0;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);padding:.3rem .7rem;border-radius:999px;border:1px solid rgba(255,255,255,.1);transition:color .15s,border-color .15s}.db-btn-logout:hover{color:#f87171;border-color:#f8717159}.db-player-badges{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.45rem}.db-badge{font-size:.8rem;font-weight:700;display:flex;align-items:center;gap:.3rem}.db-player-stats{display:flex;gap:.85rem;font-size:.78rem;color:var(--text-muted)}.db-section{background:linear-gradient(180deg,#120a1ce0,#07070df2);border:1px solid rgba(255,255,255,.07);border-radius:1.5rem;padding:1.25rem}.db-section-header{margin-bottom:1rem}.db-section-header h3{font-size:.78rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--text-strong);margin-bottom:.2rem}.db-section-sub{font-size:.75rem;color:var(--text-muted)}.db-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem 1rem;color:var(--text-muted);font-size:.85rem}.db-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(253,185,39,.15);border-top-color:var(--gold);animation:db-spin .7s linear infinite}@keyframes db-spin{to{transform:rotate(360deg)}}.db-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2.5rem 1rem;gap:.4rem}.db-empty-icon{font-size:2.4rem;opacity:.35;margin-bottom:.4rem}.db-empty p{font-size:.92rem;font-weight:600;color:var(--text)}.db-empty span{font-size:.8rem;color:var(--text-muted)}.db-error{font-size:.83rem;color:#f87171;padding:.65rem .9rem;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:.85rem;text-align:center;margin-bottom:.85rem}.db-campaign-list{display:flex;flex-direction:column;gap:.65rem}.db-campaign-card{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07);transition:border-color .2s,background .2s}.db-campaign-card.joined{border-color:#fdb92733;background:#fdb92709}.db-campaign-card:hover{background:#ffffff0d}.db-campaign-info{flex:1;min-width:0}.db-campaign-name{font-size:.95rem;font-weight:700;color:var(--text-strong);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-campaign-desc{font-size:.78rem;color:var(--text-muted);line-height:1.4;margin-bottom:.4rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.db-campaign-meta{display:flex;align-items:center;gap:.5rem}.db-campaign-players{font-size:.72rem;color:var(--text-muted)}.db-campaign-tag{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.15rem .5rem;border-radius:999px}.db-campaign-tag.joined{background:#fdb9271f;color:var(--gold);border:1px solid rgba(253,185,39,.25)}.db-campaign-tag.kicked{background:#f871711a;color:#f87171;border:1px solid rgba(248,113,113,.2)}.db-campaign-action{flex-shrink:0}.db-btn-join{padding:.5rem 1rem;border-radius:999px;font-size:.8rem;font-weight:700;background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);color:#00d4ff;white-space:nowrap;transition:background .15s,border-color .15s}.db-btn-join:hover:not(:disabled){background:#00d4ff2e;border-color:#00d4ff80}.db-btn-join:disabled{opacity:.4}.db-btn-enter{padding:.5rem 1rem;border-radius:999px;font-size:.8rem;font-weight:700;background:linear-gradient(135deg,var(--gold),#ffd86f);color:#140912;white-space:nowrap;box-shadow:0 4px 16px #fdb92733;transition:transform .15s,box-shadow .15s}.db-btn-enter:hover{transform:translateY(-1px);box-shadow:0 6px 20px #fdb92759}.db-campaign-banned{font-size:.78rem;color:#f87171}.cp-header{display:flex;align-items:center;gap:1rem}.cp-back{font-size:.8rem;color:var(--text-muted);padding:.4rem .85rem;border-radius:999px;border:1px solid rgba(255,255,255,.1);white-space:nowrap;flex-shrink:0;transition:color .15s,border-color .15s}.cp-back:hover{color:var(--text);border-color:#ffffff38}.cp-btn-map{flex-shrink:0;font-size:.78rem;font-weight:700;padding:.4rem .85rem;border-radius:999px;border:1px solid rgba(0,212,255,.3);background:#00d4ff14;color:#00d4ff;text-decoration:none;white-space:nowrap;transition:background .15s,border-color .15s}.cp-btn-map:hover{background:#00d4ff29;border-color:#00d4ff80}.cp-title{font-size:1.15rem;font-weight:800;color:var(--text-strong);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cp-player-strip{display:flex;align-items:center;gap:.9rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:1rem;padding:.8rem 1rem}.cp-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(253,185,39,.25);flex-shrink:0}.cp-avatar-ph{width:46px;height:46px;border-radius:50%;background:#55258366;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.15rem;font-weight:800;flex-shrink:0}.cp-player-name{font-size:.92rem;font-weight:700;color:var(--text-strong);display:block;margin-bottom:.2rem}.cp-player-meta{display:flex;align-items:center;gap:.35rem;font-size:.8rem}.cp-player-stats{color:var(--text-muted);font-size:.75rem}.cp-inventory{display:flex;flex-direction:column;gap:.55rem}.cp-item{display:flex;align-items:flex-start;gap:.85rem;padding:.85rem;border-radius:.9rem;background:#ffffff06;border:1px solid rgba(255,255,255,.06);transition:background .15s}.cp-item:hover{background:#ffffff0a}.cp-item-icon{font-size:1.6rem;flex-shrink:0;line-height:1;margin-top:.05rem}.cp-item-thumb{flex-shrink:0;width:54px;height:54px;border-radius:.65rem;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;cursor:zoom-in;padding:0;transition:transform .15s}.cp-item-thumb:hover{transform:scale(1.06)}.cp-item-thumb img{width:100%;height:100%;object-fit:cover;display:block}.lb-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;z-index:200;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.lb-img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:0 8px 48px #000000b3;cursor:default}.cp-item-info{flex:1;min-width:0}.cp-item-name{font-size:.9rem;font-weight:700;margin-bottom:.2rem}.cp-item-meta{font-size:.74rem;color:var(--text-muted);margin-bottom:.25rem;line-height:1.4}.cp-item-rarity{font-style:italic}.cp-item-desc{font-size:.77rem;color:var(--text-muted);line-height:1.45}.cp-item-qty{font-size:.85rem;font-weight:700;color:var(--text-muted);flex-shrink:0;padding-top:.1rem}.cs-panel{display:flex;flex-direction:column;gap:1rem}.cs-readiness{display:flex;align-items:center;gap:.55rem;padding:.55rem .9rem;border-radius:.75rem;background:color-mix(in srgb,var(--readiness-color) 12%,transparent);border:1px solid color-mix(in srgb,var(--readiness-color) 30%,transparent)}.cs-readiness-icon{font-size:1.1rem}.cs-readiness-label{font-size:.82rem;font-weight:700;color:var(--readiness-color);letter-spacing:.03em}.cs-hp-block{display:flex;flex-direction:column;gap:.4rem}.cs-hp-label-row{display:flex;justify-content:space-between;align-items:baseline}.cs-hp-title{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.cs-hp-value{font-size:1.15rem;font-weight:800;line-height:1}.cs-hp-max{font-size:.78rem;font-weight:500;color:var(--text-muted)}.cs-hp-track{height:10px;border-radius:999px;background:#ffffff12;overflow:hidden}.cs-hp-fill{height:100%;border-radius:999px;transition:width .5s ease,background .5s ease;box-shadow:0 0 8px currentColor}.cs-key-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.cs-key-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem .3rem .5rem;border-radius:.75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.07)}.cs-key-icon{font-size:1rem;line-height:1}.cs-key-val{font-size:1rem;font-weight:800;color:var(--gold, #fdb927);line-height:1}.cs-key-lbl{font-size:.6rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:center}.cs-attrs-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:-.25rem}.cs-attrs{display:grid;grid-template-columns:repeat(6,1fr);gap:.45rem}.cs-attr{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.55rem .25rem;border-radius:.7rem;background:#5525832e;border:1px solid rgba(85,37,131,.35)}.cs-attr-label{font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.cs-attr-val{font-size:1.05rem;font-weight:800;color:var(--text-strong, #f0e6ff);line-height:1}.cs-attr-mod{font-size:.68rem;font-weight:700;color:var(--gold, #fdb927)}.cs-gear{display:flex;flex-direction:column;gap:.35rem}.cs-gear-item{display:flex;align-items:center;gap:.55rem;padding:.5rem .75rem;border-radius:.65rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07)}.cs-gear-icon{font-size:1rem;flex-shrink:0}.cs-gear-name{flex:1;font-size:.82rem;font-weight:600;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-gear-stat{font-size:.75rem;font-weight:700;color:var(--gold, #fdb927);flex-shrink:0}.cs-death-saves{display:flex;flex-direction:column;gap:.45rem;padding:.75rem;border-radius:.75rem;background:#f8717112;border:1px solid rgba(248,113,113,.2)}.cs-ds-row{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--text-muted)}.cs-ds-pips{display:flex;gap:.4rem}.cs-ds-pip{width:14px;height:14px;border-radius:50%;border:1.5px solid rgba(255,255,255,.2);background:transparent;transition:background .2s,border-color .2s}.cs-ds-pip.success.filled{background:#4ade80;border-color:#4ade80;box-shadow:0 0 6px #4ade80}.cs-ds-pip.failure.filled{background:#f87171;border-color:#f87171;box-shadow:0 0 6px #f87171}@media (max-width: 360px){.cs-attrs,.cs-key-stats{grid-template-columns:repeat(3,1fr)}}
