*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f4f7f4;color:#1a2a1a;min-height:100vh}nav{display:flex;gap:24px;align-items:center;padding:0 24px;height:48px;background:#1a4a1a}nav a{color:#a8c8a8;text-decoration:none;font-size:.9rem;font-weight:500;padding:4px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}nav a:hover,nav a.router-link-active{color:#fff;border-bottom-color:#6aaa6a}button{cursor:pointer;font-size:.875rem;font-family:inherit;border-radius:5px;padding:8px 16px;border:none;background:#2d6a2d;color:#fff;font-weight:500;transition:background .15s}button:hover:not(:disabled){background:#1a4a1a}button:disabled{opacity:.45;cursor:default}button.secondary{background:transparent;border:1px solid #2d6a2d;color:#2d6a2d}button.secondary:hover:not(:disabled){background:#e8f0e8}input,textarea{border:1px solid #b8d0b8;border-radius:5px;padding:8px 12px;font-size:.875rem;font-family:inherit;background:#fff;color:#1a2a1a;outline:none;width:100%;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus{border-color:#2d6a2d;box-shadow:0 0 0 3px #2d6a2d18}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 48px);padding:24px}.auth-page h1{font-size:1.75rem;font-weight:700;color:#1a4a1a;margin-bottom:24px}.auth-page form{display:flex;flex-direction:column;gap:16px;width:100%;max-width:360px;background:#fff;padding:32px;border-radius:8px;border:1px solid #c0d4c0;box-shadow:0 2px 12px #1a4a1a0c}.auth-page label{display:block;font-size:.75rem;font-weight:700;color:#2d5a2d;margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em}.auth-page>p{margin-top:16px;font-size:.875rem;color:#4a6a4a}.auth-page>p a{color:#2d6a2d;font-weight:600;text-decoration:none}.auth-page>p a:hover{text-decoration:underline}.error{color:#b83232;font-size:.8rem}.campaigns{max-width:860px;margin:0 auto;padding:36px 24px}.campaigns-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.campaigns h1{font-size:2rem;font-weight:700;color:#1a4a1a}.header-actions{display:flex;gap:8px;align-items:center}.create-form{background:#fff;border:1px solid #c0d4c0;border-radius:8px;padding:24px;margin-bottom:24px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 4px #1a4a1a08}.campaign-list{display:flex;flex-direction:column;gap:12px}.campaign-card{background:#fff;border:1px solid #c0d4c0;border-left:4px solid #2d6a2d;border-radius:8px;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 1px 3px #1a4a1a06}.campaign-title{display:flex;align-items:center;gap:10px;margin-bottom:4px}.campaign-title h2{font-size:1.05rem;font-weight:600;color:#1a2a1a}.role-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:20px}.role-badge.gm{background:#1a4a1a;color:#fff}.role-badge.player{background:#e8f0e8;color:#2d6a2d;border:1px solid #b8d8b8}.campaign-actions{display:flex;gap:8px;flex-shrink:0}.wiki{max-width:1200px;margin:0 auto;padding:36px 24px}.wiki h1{font-size:2rem;font-weight:700;color:#1a4a1a;margin-bottom:24px}.wiki-filters{display:flex;gap:8px;margin-bottom:28px}.tab{background:transparent;border:1px solid #b8d0b8;color:#4a6a4a;padding:6px 18px}.tab:hover:not(.active){background:#e8f0e8}.tab.active{background:#1a4a1a;border-color:#1a4a1a;color:#fff}.wiki-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.wiki-card{background:#fff;border:1px solid #c0d4c0;border-radius:8px;padding:20px;box-shadow:0 1px 4px #1a4a1a08}.wiki-card.spell{border-left:4px solid #2d6a2d}.wiki-card.monster{border-left:4px solid #8a2d2d}.wiki-card.item{border-left:4px solid #2d4a8a}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.card-header h2{font-size:1.05rem;font-weight:600;color:#1a2a1a}.type-badge{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 8px;border-radius:20px;background:#e8f0e8;color:#2d6a2d;border:1px solid #b8d8b8}.description{font-size:.875rem;color:#4a6a4a;line-height:1.5;margin-bottom:12px}.stats{display:grid;grid-template-columns:auto 1fr;gap:3px 12px;font-size:.8rem}.stats dt{color:#2d5a2d;font-weight:600}.stats dd{color:#2a3a2a;white-space:pre-line}
