@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Cinzel+Decorative:wght@700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,400&family=Inter:wght@400;500;600&display=swap";:root{--bg-void: #0d0a06;--bg-dark: #1a1209;--bg-card: #231808;--bg-card-hover: #2e2010;--bg-parchment: #f5ede0;--bg-parchment-dark: #ede0cb;--accent-red: #8b0000;--accent-red-hov: #a80000;--accent-gold: #c8a436;--accent-gold-dim:#8a6f22;--accent-blue: #1a3a5c;--text-light: #e8dcc8;--text-muted: #9a8a70;--text-ink: #1a1209;--text-ink-muted: #5a4a38;--border-gold: rgba(200, 164, 54, .4);--border-gold-bright: rgba(200, 164, 54, .8);--border-ink: #2a1e10;--border-parchment: #c8b090;--font-display: "Cinzel", serif;--font-display-deco: "Cinzel Decorative", serif;--font-body: "Crimson Pro", serif;--font-ui: "Inter", sans-serif;--shadow-card: 0 4px 24px rgba(0,0,0,.5), 0 0 0 1px rgba(200,164,54,.12);--shadow-glow: 0 0 20px rgba(200,164,54,.15);--shadow-parchment: 0 8px 40px rgba(0,0,0,.7)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text-light);background:var(--bg-void);min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}input,textarea,button,select{font-family:inherit}a{text-decoration:none;color:inherit}.page-bg{min-height:100vh;background:radial-gradient(ellipse at 20% 50%,rgba(139,0,0,.07) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(200,164,54,.05) 0%,transparent 50%),linear-gradient(180deg,#0d0a06,#1a1209)}.navbar{height:60px;background:#0d0a06f2;border-bottom:1px solid var(--border-gold);display:flex;align-items:center;padding:0 32px;gap:24px;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.navbar-brand{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--accent-gold);letter-spacing:1px;display:flex;align-items:center;gap:10px;flex-shrink:0}.navbar-brand-icon{width:32px;height:32px;background:var(--accent-red);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1rem}.navbar-links{display:flex;gap:8px;flex:1;margin-left:20px}.navbar-link{font-family:var(--font-ui);font-size:.85rem;font-weight:500;color:var(--text-muted);padding:6px 14px;border-radius:6px;cursor:pointer;transition:all .2s;border:none;background:none}.navbar-link:hover,.navbar-link.active{background:#c8a4361a;color:var(--accent-gold)}.navbar-right{display:flex;align-items:center;gap:12px;margin-left:auto}.avatar-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-red),#5a0000);border:2px solid var(--accent-gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--accent-gold);cursor:pointer;transition:border-color .2s}.avatar-btn:hover{border-color:var(--accent-gold)}.btn-primary{background:linear-gradient(135deg,var(--accent-red),#6a0000);color:var(--text-light);border:1px solid rgba(200,164,54,.3);padding:10px 24px;border-radius:6px;font-family:var(--font-display);font-size:.85rem;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-red-hov),#800000);border-color:var(--accent-gold-dim);transform:translateY(-1px);box-shadow:0 4px 16px #8b000066}.btn-secondary{background:transparent;color:var(--accent-gold);border:1px solid var(--border-gold);padding:10px 24px;border-radius:6px;font-family:var(--font-ui);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-secondary:hover{background:#c8a4361a;border-color:var(--accent-gold)}.btn-ghost{background:transparent;color:var(--text-muted);border:none;padding:8px 16px;border-radius:6px;font-family:var(--font-ui);font-size:.85rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.btn-ghost:hover{background:#ffffff0d;color:var(--text-light)}.card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:10px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:all .25s;cursor:pointer;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-gold),transparent);opacity:0;transition:opacity .25s}.card:hover{background:var(--bg-card-hover);border-color:var(--accent-gold-dim);transform:translateY(-2px);box-shadow:var(--shadow-card),var(--shadow-glow)}.card:hover:before{opacity:1}.card-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-light);letter-spacing:.5px}.card-subtitle{font-family:var(--font-ui);font-size:.78rem;color:var(--text-muted)}.card-add{border-style:dashed;border-color:#c8a43640;background:transparent;justify-content:center;align-items:center;min-height:120px;opacity:.7}.card-add:hover{opacity:1;border-color:var(--accent-gold-dim)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-family:var(--font-ui);font-size:.7rem;font-weight:600;letter-spacing:.3px}.badge-gold{background:#c8a43626;color:var(--accent-gold);border:1px solid rgba(200,164,54,.3)}.badge-red{background:#8b000040;color:#f66;border:1px solid rgba(139,0,0,.4)}.badge-green{background:#00640040;color:#6c6;border:1px solid rgba(0,100,0,.4)}.section-title{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent-gold);display:flex;align-items:center;gap:10px}.section-title:before,.section-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-gold))}.section-title:after{background:linear-gradient(90deg,var(--border-gold),transparent)}.hp-bar-track{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.hp-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#22c55e,#16a34a);transition:width .3s}.hp-bar-fill.low{background:linear-gradient(90deg,#f59e0b,#d97706)}.hp-bar-fill.critical{background:linear-gradient(90deg,#ef4444,#b91c1c)}.sheet-page-wrapper{min-height:100vh;background:var(--bg-dark);display:flex;flex-direction:column}.sheet-container{width:900px;max-width:100%;margin:0 auto;background-color:var(--bg-parchment);background-image:url(https://www.transparenttextures.com/patterns/paper-fibers.png);padding:30px;box-shadow:var(--shadow-parchment);display:flex;flex-direction:column;gap:18px;color:var(--text-ink)}.sheet-container input[type=text],.sheet-container textarea{border:none;background:transparent;width:100%;font-family:var(--font-body);font-size:1rem;color:var(--text-ink);outline:none;transition:background .15s}.sheet-container input[type=text]:focus,.sheet-container textarea:focus{background:#8b00000f;border-radius:3px;outline:1px solid rgba(139,0,0,.3)}.sheet-container textarea{resize:none;line-height:1.4}.sheet-label{font-family:var(--font-ui);font-weight:700;text-transform:uppercase;font-size:.52rem;letter-spacing:.8px;color:var(--text-ink-muted)}.sheet-box{border:2px solid #333;border-radius:4px;padding:8px;background:#fff;position:relative}.sheet-box-label{position:absolute;bottom:-9px;left:50%;transform:translate(-50%);background:var(--bg-parchment);padding:0 8px;white-space:nowrap;font-family:var(--font-ui);font-size:.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#333}.prof-bubble{width:14px;height:14px;border:1.5px solid #333;border-radius:50%;background:#fff;cursor:pointer;flex-shrink:0;transition:background .15s}.prof-bubble.filled{background:#333}.main-grid{display:grid;grid-template-columns:220px 1fr 180px;gap:16px;align-items:start}.column-left,.column-center,.column-right{display:flex;flex-direction:column;gap:12px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 60%,rgba(139,0,0,.16) 0%,transparent 55%),radial-gradient(ellipse at 70% 30%,rgba(200,164,54,.08) 0%,transparent 50%),linear-gradient(180deg,#0a070326,#1a1209a6),var(--bg-void);padding:24px}.login-card{background:#1a1209f5;border:1px solid rgba(200,164,54,.42);border-radius:18px;padding:42px 44px 38px;width:100%;max-width:456px;display:flex;flex-direction:column;align-items:center;gap:24px;box-shadow:0 24px 90px #000000c7,0 0 0 1px #00000040,0 0 36px #c8a43614}.login-logo{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.login-logo-crest{width:74px;height:74px;background:linear-gradient(135deg,var(--accent-red),#5a0000);border-radius:50%;border:2px solid var(--accent-gold-dim);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:0 0 30px #8b000080}.login-title{font-family:var(--font-display-deco);font-size:1.55rem;color:var(--accent-gold);letter-spacing:1.7px;text-transform:uppercase}.login-subtitle{font-family:var(--font-body);font-size:1rem;color:#b9a17d;font-style:italic}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-family:var(--font-ui);font-size:.75rem;font-weight:600;letter-spacing:.5px;color:var(--text-muted);text-transform:uppercase}.login-input{background:#ffffff0d;border:1px solid rgba(200,164,54,.2);border-radius:8px;padding:12px 16px;color:var(--text-light);font-family:var(--font-ui);font-size:.95rem;outline:none;transition:border-color .2s,background .2s;width:100%}.login-input:focus{border-color:var(--accent-gold-dim);background:#ffffff14}.login-divider{display:flex;align-items:center;gap:12px;font-family:var(--font-ui);font-size:.75rem;color:var(--text-muted)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-gold)}.btn-keycloak{width:100%;background:linear-gradient(135deg,#ac1111,#7a0707 64%,#5f0404);color:var(--text-light);border:1px solid rgba(200,164,54,.34);padding:14px 24px;border-radius:7px;font-family:var(--font-ui);font-size:.92rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}.btn-keycloak:hover{background:linear-gradient(135deg,#be1717,#8d0a0a 64%,#650505);border-color:#c8a43685;box-shadow:0 6px 22px #8b00005c}.login-keycloak-btn{min-height:54px;font-family:var(--font-display);font-size:.95rem;letter-spacing:1.1px;text-transform:uppercase}.login-keycloak-btn svg{flex-shrink:0}.login-error{width:100%;margin-top:-4px;background:#8b00002e;border:1px solid rgba(139,0,0,.4);border-radius:8px;padding:10px 14px;font-family:var(--font-ui);font-size:.82rem;color:#ffb0b0;line-height:1.35}.overview-layout{max-width:1280px;margin:0 auto;padding:40px 32px;display:flex;flex-direction:column;gap:48px}.overview-section{display:flex;flex-direction:column;gap:20px}.overview-section-header{display:flex;justify-content:space-between;align-items:center}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.campaign-card-thumb{width:100%;height:80px;border-radius:6px;margin-bottom:4px;overflow:hidden;position:relative;background:linear-gradient(135deg,var(--accent-red) 0%,#2a1808 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-display-deco);font-size:1.8rem}.char-class-icon{width:44px;height:44px;border-radius:8px;background:linear-gradient(135deg,var(--accent-red),#5a0000);border:1px solid var(--border-gold);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.char-card-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.level-badge{font-family:var(--font-display);font-size:.7rem;font-weight:600;color:var(--accent-gold);background:#c8a4361a;border:1px solid var(--border-gold);padding:1px 8px;border-radius:20px}.campaign-banner{background:linear-gradient(135deg,#8b00004d,#1a1209cc),url(https://www.transparenttextures.com/patterns/dark-matter.png);border-bottom:1px solid var(--border-gold);padding:32px;display:flex;align-items:center;justify-content:space-between;gap:24px}.campaign-banner-title{font-family:var(--font-display-deco);font-size:1.8rem;color:var(--accent-gold);text-shadow:0 2px 20px rgba(200,164,54,.4)}.player-sheet-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;overflow:hidden;transition:all .25s;cursor:pointer}.player-sheet-card:hover{border-color:var(--accent-gold-dim);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.player-sheet-card-header{background:linear-gradient(135deg,rgba(139,0,0,.3),transparent);padding:16px 20px;border-bottom:1px solid var(--border-gold);display:flex;align-items:center;gap:14px}.player-sheet-card-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.stat-pills{display:flex;gap:8px;flex-wrap:wrap}.stat-pill{background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px 10px;font-family:var(--font-ui);font-size:.75rem;color:var(--text-light);display:flex;flex-direction:column;align-items:center;min-width:44px}.stat-pill-label{font-size:.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box,.modal-content{background:linear-gradient(145deg,#231808f2,#1a1209fa);border:1px solid var(--border-gold);border-radius:12px;padding:24px;min-width:400px;max-width:600px;width:100%;box-shadow:0 24px 64px #000000e6,0 0 20px #c8a43626;animation:slideUp .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;position:relative;overflow:hidden;max-height:90vh}.modal-box:before,.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-gold),transparent)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header,.modal-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-gold);flex-shrink:0}.modal-title{font-family:var(--font-display);font-size:1.1rem;letter-spacing:1px;color:var(--accent-gold);margin:0}.modal-close{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-muted);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .2s;padding:0;line-height:1}.modal-close:hover{color:var(--accent-gold);background:#c8a4361a;border-color:var(--border-gold)}.modal-tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:8px;flex-shrink:0}.modal-tab{background:transparent;border:none;color:var(--text-muted);font-family:var(--font-ui);font-size:.85rem;font-weight:600;padding:6px 12px;cursor:pointer;border-radius:6px;transition:all .2s}.modal-tab:hover{color:var(--text-light);background:#ffffff0d}.modal-tab.active{color:var(--accent-gold);background:#c8a4361a}.modal-search{width:100%;padding:10px 14px;margin-bottom:16px;background:#0000004d;border:1px solid rgba(200,164,54,.25);border-radius:6px;color:var(--text-light);font-family:var(--font-ui);font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s;flex-shrink:0}.modal-search:focus{border-color:var(--accent-gold);box-shadow:0 0 10px #c8a4361a}.modal-list{display:flex;flex-direction:column;gap:8px;max-height:40vh;overflow-y:auto;padding-right:4px;flex:1}.modal-list::-webkit-scrollbar{width:6px}.modal-list::-webkit-scrollbar-track{background:#0003;border-radius:3px}.modal-list::-webkit-scrollbar-thumb{background:var(--border-gold);border-radius:3px}.modal-select-btn{background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--text-light);padding:12px 16px;font-family:var(--font-ui);text-align:left;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:4px}.modal-select-btn:hover{background:#c8a4361a;border-color:var(--border-gold);transform:translate(4px)}.modal-select-btn .btn-title{font-weight:600;font-size:.95rem;color:var(--accent-gold)}.modal-select-btn .btn-subtitle{font-size:.75rem;color:var(--text-muted)}.modal-custom-form{display:flex;flex-direction:column;gap:12px;overflow-y:auto;max-height:50vh;padding-right:4px}.modal-input-group{display:flex;flex-direction:column;gap:6px}.modal-input-group label{font-family:var(--font-ui);font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.modal-input-group input,.modal-input-group textarea,.modal-input-group select{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:10px 12px;color:var(--text-light);font-family:var(--font-ui);font-size:.9rem;outline:none;transition:border-color .2s}.modal-input-group input:focus,.modal-input-group textarea:focus,.modal-input-group select:focus{border-color:var(--accent-gold)}.modal-input-group textarea{resize:vertical;min-height:80px}.modal-body{margin-bottom:20px;flex:1;overflow-y:auto}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--border-gold);margin-top:auto;flex-shrink:0}.player-sheet-card.locked{opacity:.8;filter:saturate(.6) contrast(.9)}.player-sheet-card.locked:hover{transform:none!important;box-shadow:var(--shadow-card)!important;border-color:var(--border-gold)!important;cursor:default}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}
