:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color-scheme:dark;background-color:#050816;color:#e2e8f0;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,rgba(77,91,255,.2),transparent 60%),#050816}a{color:inherit;text-decoration:none}#app{min-height:100vh}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;width:min(1200px,100%);margin:0 auto;padding:1.5rem}.navbar{background:#070c18e6;border-bottom:1px solid rgba(148,163,184,.1);position:sticky;top:0;width:100%;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.navbar__inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;margin:0 auto;width:min(1200px,100%)}.navbar__brand{display:flex;align-items:center;gap:.6rem;font-weight:600;letter-spacing:.02em}.navbar__logo{width:40px;height:40px;border-radius:12px;background:linear-gradient(120deg,#8b5cf6,#6366f1);display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#0b1120}.navbar__title{font-size:1.1rem}.navbar__links{display:flex;align-items:center;gap:.75rem}.navbar__links--open{display:flex}.navbar__link{padding:.4rem .9rem;border-radius:999px;font-size:.95rem;color:#94a3b8}.navbar__link--active{color:#f8fafc;background:#8b5cf626}.navbar__action{border:1px solid rgba(148,163,184,.4);background:transparent;border-radius:999px;padding:.4rem 1rem;color:#f1f5f9;font-weight:600;cursor:pointer}.navbar__toggle{display:none;background:none;border:none;color:#f8fafc;font-size:1.25rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.card{background:#090c20d9;border:1px solid rgba(148,163,184,.12);border-radius:24px;padding:2rem;box-shadow:0 15px 40px #02061799}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;width:100%}.auth,.dashboard{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px)}.auth__card,.dashboard__card{width:min(420px,100%)}.form{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.form__label{font-size:.95rem;color:#cbd5f5;display:flex;flex-direction:column;gap:.45rem}.form__input{border-radius:12px;border:1px solid rgba(148,163,184,.25);background:#0f172acc;color:#f8fafc;padding:.75rem 1rem;font-size:1rem}.btn{border:none;border-radius:999px;padding:.75rem 1.25rem;font-size:1rem;font-weight:600;background:linear-gradient(120deg,#c084fc,#6366f1);color:#0f172a;cursor:pointer;transition:transform .15s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn.small{padding:.45rem .9rem;font-size:.85rem}.btn.ghost{background:transparent;color:#e2e8f0;border:1px solid rgba(148,163,184,.5)}.alert{margin-top:1rem;padding:.75rem 1rem;border-radius:12px;font-size:.9rem}.alert--error{background:#f8717126;border:1px solid rgba(248,113,113,.4);color:#fecaca}.alert--success{background:#22c55e26;border:1px solid rgba(34,197,94,.4);color:#bbf7d0}.muted{color:#94a3b8}.dashboard__title{font-size:clamp(1.8rem,4vw,2.8rem);margin:.4rem 0 1rem}.details{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:1rem}.details li{display:flex;flex-direction:column;gap:.25rem;font-size:.95rem;color:#94a3b8}.details strong{font-size:1.1rem;color:#e2e8f0;word-break:break-all}.room-list{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:1rem}.room-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-radius:16px;border:1px solid rgba(148,163,184,.2);background:#0f172a99;gap:1rem}.room-name{font-weight:600;font-size:1.05rem;margin:0 0 .2rem}.invite-code{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.code-pill{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:999px;border:1px dashed rgba(99,102,241,.6);color:#c7d2fe;font-size:.85rem;letter-spacing:.08em}.link{background:none;border:none;color:#a5b4fc;text-decoration:underline;cursor:pointer;font-size:.85rem;padding:0}.mt-3{margin-top:1rem}.room-page{width:min(1100px,100%);margin:0 auto}.room-layout{display:flex;flex-direction:column;gap:1.25rem}.room-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.room-header-actions{display:flex;gap:.5rem}.tabs{display:flex;gap:.75rem;padding:.5rem}.tab{flex:1;background:transparent;border:none;border-radius:12px;padding:.75rem;color:#cbd5f5;font-weight:600;cursor:pointer}.tab--active{background:#6366f126;color:#f8fafc}.room-members{list-style:none;padding:0;margin:1rem 0 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.room-members li{display:flex;gap:.75rem;align-items:center;padding:.75rem;border-radius:16px;border:1px solid rgba(148,163,184,.2);background:#0f172ab3}.avatar{width:48px;height:48px;border-radius:16px;background:#6366f133;display:inline-flex;align-items:center;justify-content:center;font-weight:700;letter-spacing:.05em;color:#e2e8f0;background-size:cover;background-position:center}.member-name{margin:0;font-weight:600}.gm-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:1rem}.character-grid{display:grid;gap:1rem}.character-create{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:1.5rem}.character-create .form__label{flex:1}.character-card{border:1px solid rgba(148,163,184,.2);border-radius:20px;padding:1.25rem;background:#0f172ab3;display:flex;flex-direction:column;gap:1rem}.character-header{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.character-header h3{margin:.3rem 0;font-size:1.25rem}.points{display:flex;gap:1rem;text-align:right}.points .label{display:block;font-size:.7rem;text-transform:uppercase;color:#94a3b8}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.75rem}.stat-field{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem}.stat-field input{background:#0f172a99;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:.4rem;color:#f8fafc}.inline-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.inline-fields label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem}.inline-fields input{background:#0f172a99;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:.5rem;color:#f8fafc}.equipment{display:flex;flex-direction:column;gap:.75rem}.equipment h4{margin:0;font-size:.95rem;color:#cbd5f5}.equipment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem}.equipment-slot{border:1px dashed rgba(148,163,184,.3);border-radius:12px;padding:.5rem;min-height:70px;display:flex;flex-direction:column;justify-content:space-between}.equipment-slot .label{font-size:.7rem;text-transform:uppercase;color:#94a3b8}.ammo-table table{width:100%;border-collapse:collapse;font-size:.9rem}.ammo-table th,.ammo-table td{padding:.4rem .2rem;border-bottom:1px solid rgba(148,163,184,.15);text-align:left}.notes-field{display:flex;flex-direction:column;gap:.4rem}.notes-field textarea{min-height:100px;border-radius:12px;border:1px solid rgba(148,163,184,.25);background:#0f172a99;padding:.6rem;color:#f8fafc}.handout-grid{display:grid;gap:1rem;margin-top:1rem}.handout-card{border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:1rem;background:#0c101eb3;display:flex;flex-direction:column;gap:.6rem}.handout-card img{width:100%;border-radius:14px;object-fit:cover;max-height:220px}.gm-handout-grid{display:grid;gap:1.5rem}.gm-editor,.gm-card-list{border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:1rem;background:#0c101e99}.gm-card-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.gm-card-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .4rem;border-bottom:1px solid rgba(148,163,184,.15)}.handout-preview{width:100%;max-height:200px;object-fit:cover;border-radius:12px}.shortcut-section{display:flex;flex-direction:column;gap:.4rem}.shortcut-grid{display:flex;flex-wrap:wrap;gap:.5rem}.shortcut-button{border:1px solid rgba(148,163,184,.4);border-radius:999px;background:transparent;color:#e2e8f0;font-size:.8rem;padding:.35rem .75rem;cursor:pointer}.shortcut-button:hover{border-color:#a5b4fc;color:#a5b4fc}.skills-section{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.skills-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.skill-add{display:flex;gap:.5rem;align-items:center}.skill-add select{min-width:220px;border-radius:10px;border:1px solid rgba(148,163,184,.3);background:#0f172a99;color:#f8fafc;padding:.4rem .6rem}.skill-permission{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:#94a3b8;margin-top:.3rem}.skill-permission input{accent-color:#8b5cf6}.skills-grid{display:flex;flex-direction:column;gap:.75rem}.skill-row{display:flex;gap:1rem;justify-content:space-between;border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:.75rem;background:#0f172a66}.skill-info{flex:1}.skill-name{font-weight:600;margin-bottom:.2rem}.skill-description{font-size:.78rem;color:#94a3b8}.skill-controls{display:flex;align-items:center;gap:.5rem}.skill-controls input{width:4rem;padding:.35rem .5rem;border-radius:8px;border:1px solid rgba(148,163,184,.3);background:transparent;color:#f8fafc}.btn.ghost.small.danger{border-color:#f8717166;color:#fecaca}.shop-header{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.shop-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin:1rem 0}.shop-filters input,.shop-filters select,.character-selector select{width:100%;padding:.5rem .75rem;border-radius:10px;border:1px solid rgba(148,163,184,.25);background:#0f172a99;color:#f8fafc}.catalog-grid{display:grid;gap:1rem}.catalog-card{border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:1rem;background:#0c0f20b3;display:flex;flex-direction:column;gap:.6rem}.catalog-card__body{display:flex;justify-content:space-between;gap:1rem;align-items:center}.catalog-name{font-weight:600;margin:0}.catalog-price{font-size:1.1rem;color:#f4f1ff}.catalog-desc{margin:0;font-size:.9rem;color:#cbd5f5}.catalog-actions{display:flex;justify-content:space-between;gap:.75rem;align-items:center}.catalog-actions input{width:80px;border-radius:10px;border:1px solid rgba(148,163,184,.25);padding:.35rem;background:#0f172a99;color:#f8fafc}.orders-section{margin-top:1.25rem;border-top:1px solid rgba(148,163,184,.15);padding-top:1rem}.orders-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.orders-table{width:100%;border-collapse:collapse;font-size:.9rem}.orders-table th,.orders-table td{padding:.6rem .3rem;border-bottom:1px solid rgba(148,163,184,.15);vertical-align:top}.order-item{margin:0;font-weight:600}.status{display:inline-flex;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.status--pending{background:#facc1533;color:#facc15}.status--approved{background:#22c55e33;color:#34d399}.status--cancelled{background:#f8717133;color:#f87171}.status--fulfilled{background:#60a5fa33;color:#93c5fd}.order-actions{display:flex;gap:.4rem}.dice-panel{display:flex;flex-direction:column;gap:1rem}.dice-grid{display:grid;gap:1rem}.dice-form{display:flex;flex-direction:column;gap:.8rem}.dice-form input,.dice-form textarea,.dice-form select{width:100%;padding:.6rem .8rem;border-radius:10px;border:1px solid rgba(148,163,184,.25);background:#0f172a99;color:#f8fafc}.dice-history{border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:1rem;background:#0f172a80;max-height:420px;overflow-y:auto}.dice-entry{border-bottom:1px solid rgba(148,163,184,.15);padding:.6rem 0;display:flex;flex-direction:column;gap:.3rem}.dice-entry:last-child{border-bottom:none}.dice-entry__header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.3rem}.dice-entry__label{font-weight:600}.dice-entry__details{font-size:.85rem;color:#cbd5f5}.dice-entry__meta{font-size:.75rem;color:#94a3b8;display:flex;gap:.5rem;flex-wrap:wrap}.dice-entry__badges{display:flex;gap:.4rem;flex-wrap:wrap}.toast-stack{position:fixed;bottom:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:50}.toast{min-width:260px;max-width:320px;padding:.75rem 1rem;border-radius:14px;border:1px solid transparent;display:flex;justify-content:space-between;align-items:center;gap:.5rem;background:#0f172af2}.toast--success{border-color:#22c55e66}.toast--info{border-color:#3b82f666}.toast--error{border-color:#f8717166}.toast__close{border:none;background:transparent;color:#fff;cursor:pointer;font-size:1.1rem}.badge{border-radius:999px;padding:.2rem .6rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.badge--success{background:#22c55e33;color:#34d399}.badge--failure{background:#f8717133;color:#f87171}.badge--critical{background:#facc1533;color:#fde047}@media(min-width:768px){.character-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.handout-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dice-grid{grid-template-columns:minmax(280px,340px) 1fr}.gm-handout-grid{grid-template-columns:minmax(280px,360px) 1fr}}@media(max-width:768px){.navbar__links{position:absolute;top:100%;left:0;right:0;background:#070c18fa;padding:1rem 1.5rem 2rem;flex-direction:column;display:none}.navbar__links--open{display:flex}.navbar__toggle{display:inline-flex;align-items:center;justify-content:center}.app-main{padding:1rem}.card{padding:1.5rem}}
