.auth-page,.dashboard-page{min-height:100vh;padding:2rem}.auth-card,.dashboard-card{background:#1a1a24;border:1px solid #2e2e3d;border-radius:16px;width:100%;max-width:420px;padding:2rem;box-shadow:0 10px 30px #00000059}form{flex-direction:column;gap:.85rem;margin-top:1rem;display:flex}input,button{border:none;border-radius:10px;padding:.9rem 1rem;font-size:1rem}input{color:#fff;background:#101018;border:1px solid #2f2f40}button{color:#fff;cursor:pointer;background:#6c4cff;font-weight:700}.auth-error{color:#ff7b7b;margin:0}a{color:#b69cff}body{color:#f5f5f5;background:#0b0b14;margin:0;font-family:Arial,sans-serif}.container{width:100%;max-width:1600px;margin:0 auto;padding:1.5rem}.character-header{margin-bottom:1.75rem}.character-header h1{color:#fff;margin:.75rem 0 0;font-size:3.25rem;line-height:1.05}.character-sub{color:#f1f1f6;margin:.75rem 0 0;font-size:1.2rem;font-weight:600}button{cursor:pointer;border:none;border-radius:10px;padding:.9rem 1rem;font-size:1rem;font-weight:700;transition:background .18s,transform .18s,opacity .18s}button:hover:not(:disabled){transform:translateY(-1px)}button:disabled{opacity:.7;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(90deg,#6c4cff 0%,#8b6bff 100%);box-shadow:0 0 12px #6c4cff66}.btn-primary:hover:not(:disabled){background:linear-gradient(90deg,#7d5cff 0%,#9a7cff 100%);box-shadow:0 0 16px #6c4cff99}.btn-secondary{color:#fff;background:#31314a}input,select,textarea{color:#f5f5f5;box-sizing:border-box;background:linear-gradient(#111124 0%,#0c0c18 100%);border:1px solid #2e2e44;border-radius:10px;outline:none;width:100%;padding:.85rem 1rem;font-family:Arial,sans-serif;font-size:.95rem;transition:border-color .18s,box-shadow .18s,background .18s,opacity .18s}input::placeholder,textarea::placeholder{color:#8f90aa}input:focus,select:focus,textarea:focus{background:linear-gradient(#14142a 0%,#101020 100%);border-color:#6c4cff;box-shadow:0 0 0 3px #6c4cff2e}input:disabled,select:disabled,textarea:disabled{opacity:.6;cursor:not-allowed;color:#9a9ab3;background:linear-gradient(#0d0d18 0%,#090912 100%);border-color:#25253a}select{appearance:none;cursor:pointer;background-image:linear-gradient(#111124 0%,#0c0c18 100%),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23c9b2ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-position:0 0,right .85rem center;background-repeat:no-repeat,no-repeat;background-size:auto,14px;padding-right:2.5rem}select option{color:#f5f5f5;background:#111124}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1.8rem;display:grid}.stat-card{background:linear-gradient(#15152a 0%,#101022 100%);border:1px solid #29294a;border-radius:18px;padding:1rem;box-shadow:0 8px 24px #00000038}.stat-bar{background:#2a2a38;border-radius:999px;width:100%;height:12px;margin-bottom:.75rem;overflow:hidden}.stat-fill{border-radius:999px;height:100%;box-shadow:0 0 10px #8b5cf666}.stat-buttons{grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.9rem;display:grid}.main-layout{grid-template-columns:minmax(0,2fr) minmax(320px,.95fr);align-items:start;gap:1.5rem;display:grid}.summary-card{background:linear-gradient(#111124 0%,#0e0e1d 100%);border:1px solid #232344;border-radius:16px;margin-bottom:1.25rem;padding:1rem 1.1rem}.summary-card h3{color:#fff;margin:0 0 .5rem;font-size:1rem}.summary-card p{color:#d8daeb;margin:0;line-height:1.6}.abilities-heading{color:#fff;margin:0 0 1rem;font-size:2rem}.abilities-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));align-items:stretch;gap:1rem;display:grid}.ability-card{background:linear-gradient(#151529 0%,#101021 100%);border:1px solid #2e2e44;border-radius:18px;flex-direction:column;justify-content:space-between;gap:1rem;min-height:280px;padding:1.1rem;display:flex;box-shadow:0 8px 24px #0003}.ability-card:hover{border-color:#6c4cff;transition:all .2s;transform:translateY(-2px)}.ability-card-top{border-bottom:1px solid #ffffff0f;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:.35rem;display:flex}.ability-title{color:#fff;margin:0;font-size:1.08rem;font-weight:800;line-height:1.2}.ability-type{color:#b8b8c9;margin:.35rem 0 0;font-size:.92rem}.ability-description{color:#ededf7;margin-top:.9rem;margin-bottom:0;line-height:1.55}.ability-details{margin-top:.6rem}.ability-details p{color:#d7d7e6;margin:.22rem 0;font-size:.95rem;line-height:1.45}.nexus-pill{color:#fff;white-space:nowrap;background:#7c5cff;border-radius:999px;padding:.35rem .7rem;font-size:.82rem;font-weight:700}.nexus-pill.free{background:#2c7a4b}.status-effects{margin-top:.7rem}.status-effects-title{margin-bottom:.35rem;font-weight:700}.status-effects ul{margin:0;padding-left:1.25rem}.status-effects li{margin-bottom:.35rem;line-height:1.45}.ability-actions{margin-top:1rem}.side-panel-stack{align-self:start;gap:1rem;display:grid}.effects-panel{background:linear-gradient(#101020 0%,#0c0c18 100%);border:1px solid #2e2e44;border-radius:16px;max-height:300px;padding:1rem;overflow-y:auto}.effects-title{color:#fff;margin:0 0 1rem;font-size:1.4rem;font-weight:800}.effects-empty{color:#b8b8c9;background:#151523;border:1px solid #2e2e44;border-radius:12px;margin:0;padding:.9rem;line-height:1.5}.effect-card{background:#151523;border:1px solid #2e2e44;border-radius:12px;justify-content:space-between;align-items:center;gap:.75rem;padding:.9rem;display:flex}.effect-info{flex-direction:column;display:flex}.effect-name{color:#fff;margin:0;font-weight:700}.effect-meta{color:#b8b8c9;margin-top:.25rem;font-size:.85rem}.effect-turns{color:#8b6bff;font-size:.9rem;font-weight:800}.results-panel{background:linear-gradient(#101020 0%,#0c0c18 100%);border:1px solid #2e2e44;border-radius:16px;min-height:320px;padding:1rem;position:sticky;top:1rem}.results-title{color:#fff;margin:0 0 1rem;font-size:2rem;font-weight:800}.results-empty{color:#b8b8c9;margin:0;line-height:1.5}.results-list{gap:.85rem;max-height:500px;padding-right:.25rem;display:grid;overflow-y:auto}.result-card{background:#151523;border:1px solid #2e2e44;border-radius:12px;padding:.9rem}.result-card:hover{background:#1a1a2e;border-color:#6c4cff;transition:all .15s}.result-name{color:#fff;margin:0;font-size:1rem;font-weight:800}.result-detail{color:#d7d7e6;margin:.45rem 0 0;line-height:1.5}.result-time{color:#9ea0b8;margin:.45rem 0 0;font-size:.85rem}.storyweaver-player-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.storyweaver-player-grid .ability-card{min-height:180px}.summary-card select,.summary-card input,.result-card select,.result-card input{margin-bottom:.5rem}.summary-card form,.result-card form{gap:.75rem;display:grid}.result-card button+button{margin-left:.5rem}@media (width<=1100px){.main-layout{grid-template-columns:1fr}.results-panel{min-height:unset;position:static}}@media (width<=900px){.dashboard-page{padding:1rem}.character-header h1{font-size:2.4rem}.character-sub{font-size:1rem}.stats-grid{grid-template-columns:1fr}.abilities-heading,.results-title{font-size:1.7rem}.abilities-grid{grid-template-columns:1fr}.ability-card{min-height:unset}.storyweaver-player-grid{grid-template-columns:1fr}}@media (width<=520px){.stat-buttons{grid-template-columns:1fr}.ability-card-top{flex-direction:column;align-items:flex-start}button{width:100%}.result-card button+button{margin-top:.5rem;margin-left:0}}
