:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:rgba(255,255,255,.9);background:linear-gradient(160deg,#0f172a,#1e293b 35%,#0f172a);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,:after,:before{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{font-weight:500;color:#7dd3fc;text-decoration:inherit}a:hover{color:#bae6fd}.app{min-height:100vh;display:flex;flex-direction:column}.header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:rgba(0,0,0,.4);border-bottom:1px solid rgba(255,255,255,.08)}.header-logo{height:2.5rem;width:auto;object-fit:contain}.header-title{font-size:1.35rem;font-weight:700;letter-spacing:.02em;color:#e8f4ea}.header-nav{margin-left:auto;display:flex;gap:1rem}.header-nav a{color:rgba(255,255,255,.85);text-decoration:none;font-weight:500}.header-nav a:hover{color:#7dd3fc}.hero{flex:1 1;padding:3rem 1.5rem}.hero,.hero-content{display:flex;align-items:center;justify-content:center}.hero-content{flex-wrap:wrap;gap:2.5rem;max-width:900px}.hero-image{width:100%;max-width:320px;height:auto;object-fit:contain}.hero-text{text-align:center}.hero-text h1{font-size:clamp(2rem,5vw,2.75rem);margin:0 0 .75rem;color:#fff;font-weight:800;letter-spacing:-.02em}.hero-tagline{font-size:1.15rem;line-height:1.6;color:rgba(255,255,255,.85);max-width:420px;margin:0 auto 1.5rem}.hero-tagline strong{color:#7dd3fc}.cta-discord{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.75rem;font-size:1.05rem;font-weight:600;color:#fff;background:#5865f2;border-radius:8px;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 4px 14px rgba(88,101,242,.4)}.cta-discord:hover{background:#4752c4;transform:translateY(-1px)}.cta-discord:focus-visible{outline:2px solid #7dd3fc;outline-offset:2px}.cta-specs-view{display:inline-flex;margin:1rem .5rem;align-items:center;justify-content:center;padding:.85rem 1.75rem;font-size:1.05rem;font-weight:600;color:#ffffff;background:#0a944f;border-radius:8px;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 4px 14px #0a944f98}.cta-specs-view:hover{background:#05b15b;transform:translateY(-1px)}.cta-specs-view:focus-visible{outline:2px solid #09e778;outline-offset:2px}.about{padding:3rem 1.5rem;max-width:640px;margin:0 auto;text-align:center}.about h2{font-size:1.5rem;margin:0 0 1.25rem;color:rgba(255,255,255,.95)}.about p{font-size:1rem;line-height:1.7;color:rgba(255,255,255,.8);margin:0 0 1rem}.about .cta-discord-secondary{margin-top:1rem}.footer{padding:1.5rem;text-align:center;background:rgba(0,0,0,.3);border-top:1px solid rgba(255,255,255,.06)}.footer p{margin:0 0 .35rem;font-size:.9rem;color:rgba(255,255,255,.6)}.footer a{color:#7dd3fc;text-decoration:none;font-size:.9rem}.footer a:hover{text-decoration:underline}.specs-page{flex:1 1;padding:2rem 1.5rem 3rem;max-width:1100px;margin:0 auto}.specs-hero{text-align:center;margin-bottom:2.5rem}.specs-hero h1{font-size:clamp(1.75rem,4vw,2.25rem);margin:0 0 .5rem;color:#fff}.specs-lead{color:rgba(255,255,255,.75);font-size:1rem;margin:0}.specs-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.25rem;gap:1.25rem}.class-card{background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem 1.35rem;display:flex;flex-direction:column;min-height:120px}.class-card__name{font-size:1.2rem;margin:0 0 .75rem;color:#e8f4ea;font-weight:700;letter-spacing:.02em}.class-card__specs{display:flex;flex-wrap:wrap;gap:.5rem}.spec-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;border-radius:6px;font-size:.875rem;border:1px solid transparent}.spec-badge__icon{flex-shrink:0;width:24px;height:24px;border-radius:4px;object-fit:contain;vertical-align:middle}.spec-badge__name{font-weight:600;color:#fff}.spec-badge__role{color:rgba(255,255,255,.7);font-size:.8em}.spec-badge__status{margin-left:.25rem;color:#86efac}.spec-badge__status--planned{color:rgba(255,255,255,.5)}.spec-badge--tank{background:rgba(0,112,221,.2);border-color:rgba(0,112,221,.4)}.spec-badge--healer{background:rgba(0,181,26,.2);border-color:rgba(0,181,26,.4)}.spec-badge--dps{background:rgba(255,82,82,.2);border-color:rgba(255,82,82,.4)}.spec-badge--supported{background:rgba(34,197,94,.35);border-color:rgba(34,197,94,.6)}.spec-badge--supported .spec-badge__status{color:#86efac}.spec-badge--unsupported{background:rgba(239,68,68,.3);border-color:rgba(239,68,68,.55)}.spec-badge--unsupported .spec-badge__status{color:#fca5a5}.specs-legend{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);text-align:center}.specs-legend h2{font-size:1rem;margin:0 0 .5rem;color:rgba(255,255,255,.8)}.specs-legend p{margin:0;font-size:.9rem;color:rgba(255,255,255,.65)}.specs-lead--skeleton{opacity:.8}.class-card--skeleton .class-card__name--skeleton{height:1.2rem;width:10rem;background:rgba(255,255,255,.1);border-radius:4px;animation:specs-skeleton-pulse 1.2s ease-in-out infinite}.spec-badge--skeleton{width:6rem;height:1.75rem;background:rgba(255,255,255,.08);border-radius:6px;animation:specs-skeleton-pulse 1.2s ease-in-out infinite}@keyframes specs-skeleton-pulse{0%,to{opacity:.6}50%{opacity:1}}.admin-layout{flex:1 1;min-height:0}.admin-login{flex:1 1;display:flex;align-items:center;justify-content:center;padding:2rem}.admin-login__card{width:100%;max-width:360px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem}.admin-login__card h1{margin:0 0 .5rem;font-size:1.5rem;color:#fff}.admin-login__hint{margin:0 0 1.25rem;font-size:.9rem;color:rgba(255,255,255,.7)}.admin-login__error{background:rgba(248,113,113,.2);color:#fca5a5}.admin-login__error,.admin-login__success{margin:0 0 1rem;padding:.5rem .75rem;border-radius:6px;font-size:.9rem}.admin-login__success{background:rgba(34,197,94,.2);color:#86efac}.admin-login__form{display:flex;flex-direction:column;gap:.75rem}.admin-login__form label{font-size:.9rem;font-weight:500;color:rgba(255,255,255,.9)}.admin-login__form input{padding:.6rem .75rem;font-size:1rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff}.admin-login__form input:focus{outline:2px solid #7dd3fc;outline-offset:2px}.admin-login__form button{margin-top:.5rem;padding:.7rem 1rem;font-size:1rem;font-weight:600;color:#fff;background:#5865f2;border:none;border-radius:8px;cursor:pointer}.admin-login__form button:hover{background:#4752c4}.admin-page{padding:2rem 1.5rem;max-width:1200px;margin:0 auto}.admin-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.admin-header h1{margin:0;font-size:1.35rem;color:#fff}.admin-header__actions{display:flex;align-items:center;gap:1rem}.admin-header__link{font-size:.9rem;color:#7dd3fc}.admin-header__logout{padding:.4rem .75rem;font-size:.9rem;color:rgba(255,255,255,.9);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer}.admin-header__logout:hover{background:rgba(255,255,255,.15)}.admin-intro{margin:0 0 1.5rem;font-size:.95rem;color:rgba(255,255,255,.8)}.admin-specs-form__message{margin:0 0 1rem;padding:.5rem .75rem;border-radius:6px;font-size:.9rem}.admin-specs-form__message:not([class*=error]){background:rgba(34,197,94,.2);color:#86efac}.admin-specs-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:1.25rem;gap:1.25rem;margin-bottom:1.5rem}@media (max-width:900px){.admin-specs-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:520px){.admin-specs-cards{grid-template-columns:1fr}}.admin-class-card{margin-bottom:0;padding:1.25rem;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);border-radius:12px;min-width:0}.admin-class-card--card{display:flex;flex-direction:column}.admin-class-card__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.admin-class-card__title{margin:0;font-size:1.1rem;font-weight:600;color:#e8f4ea}.admin-class-card__remove{padding:.3rem .6rem;font-size:.8rem;color:#fca5a5;background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.4);border-radius:6px;cursor:pointer}.admin-class-card__remove:hover{background:rgba(239,68,68,.3)}.admin-specs-grid{display:flex;flex-direction:column;gap:.6rem;margin-top:.75rem;min-width:0}.admin-spec-row{display:flex;flex-wrap:nowrap;align-items:center;gap:.5rem;min-width:0}.admin-spec-check{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;flex-shrink:0;min-width:120px}.admin-spec-icon{flex-shrink:0;width:22px;height:22px;border-radius:4px;object-fit:contain;vertical-align:middle}.admin-spec-check input{width:1.1rem;height:1.1rem}.admin-spec-name{font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-spec-role{font-size:.85rem;color:rgba(255,255,255,.6);flex-shrink:0}.admin-spec-notes{flex:1 1;min-width:0;padding:.4rem .6rem;font-size:.9rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;box-sizing:border-box}.admin-spec-remove{flex-shrink:0;padding:.2rem .5rem;font-size:1.1rem;line-height:1;color:#fca5a5;background:transparent;border:1px solid rgba(239,68,68,.4);border-radius:4px;cursor:pointer}.admin-spec-remove:hover{background:rgba(239,68,68,.2)}.admin-add-spec-btn{margin-top:.75rem;padding:.4rem .75rem;font-size:.9rem;color:#7dd3fc;background:rgba(125,211,252,.1);border:1px dashed rgba(125,211,252,.4);border-radius:6px;cursor:pointer;align-self:flex-start}.admin-add-spec-btn:hover{background:rgba(125,211,252,.2)}.admin-add-spec-inline{margin-top:.75rem;padding:.75rem;background:rgba(255,255,255,.05);border-radius:8px}.admin-add-spec-form{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.admin-add-spec-form input[type=text],.admin-add-spec-form select{padding:.4rem .6rem;font-size:.9rem;background:#1e293b;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff}.admin-add-spec-form select{cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.admin-add-spec-form select option{background:#1e293b;color:#fff}.admin-add-spec-form input[type=text]{min-width:120px}.admin-add-spec-form button{padding:.4rem .65rem;font-size:.85rem;border-radius:6px;cursor:pointer}.admin-add-spec-form button[type=submit]{color:#fff;background:#5865f2;border:none}.admin-add-spec-form button[type=button]{color:rgba(255,255,255,.8);background:transparent;border:1px solid rgba(255,255,255,.3)}.admin-add-spec-supported{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;color:rgba(255,255,255,.85);cursor:pointer}.admin-add-class-section{margin-bottom:1.5rem;padding:1.25rem;background:rgba(125,211,252,.08);border:1px dashed rgba(125,211,252,.3);border-radius:12px}.admin-add-class-title{margin:0 0 .75rem;font-size:1rem;color:#7dd3fc}.admin-add-class-form{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.admin-add-class-form input{padding:.5rem .75rem;font-size:.95rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff}.admin-add-class-form input:first-of-type{min-width:180px}.admin-add-class-form button{padding:.5rem 1rem;font-size:.95rem;font-weight:600;color:#fff;background:#5865f2;border:none;border-radius:8px;cursor:pointer}.admin-add-class-form button:hover{background:#4752c4}.admin-specs-form__actions{margin-top:1.5rem}.admin-specs-form__actions button{padding:.65rem 1.25rem;font-size:1rem;font-weight:600;color:#fff;background:#5865f2;border:none;border-radius:8px;cursor:pointer}.admin-specs-form__actions button:hover:not(:disabled){background:#4752c4}.admin-specs-form__actions button:disabled{opacity:.7;cursor:not-allowed}.admin-users-section{margin-bottom:2rem}.admin-users-section h2{font-size:1.1rem;margin:0 0 .75rem;color:rgba(255,255,255,.95)}.admin-users-form{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.admin-users-form input{padding:.5rem .65rem;font-size:.95rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff;min-width:120px}.admin-users-form button{padding:.5rem 1rem;font-size:.95rem;font-weight:600;color:#fff;background:#5865f2;border:none;border-radius:8px;cursor:pointer}.admin-users-form button:hover:not(:disabled){background:#4752c4}.admin-users-list{list-style:none;margin:0;padding:0}.admin-users-list__item{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.08)}.admin-users-list__name{font-weight:500;color:#fff;min-width:120px}.admin-users-list__date{font-size:.85rem;color:rgba(255,255,255,.5)}.admin-users-list__remove{margin-left:auto;padding:.35rem .65rem;font-size:.85rem;color:#fca5a5;background:rgba(248,113,113,.15);border:1px solid rgba(248,113,113,.3);border-radius:6px;cursor:pointer}.admin-users-list__remove:hover:not(:disabled){background:rgba(248,113,113,.25)}.admin-users-list__remove:disabled{opacity:.6;cursor:not-allowed}