@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Spectral:ital,wght@0,400;0,600;1,400&family=Lora:ital,wght@0,400;0,600;1,400&display=swap";:root{--primary-dark: #1a0f2e;--primary-medium: #2d1b4e;--primary-light: #4a2c6b;--primary-accent: #6b46c1;--gold-dark: #8b6914;--gold-medium: #d4af37;--gold-light: #f4d03f;--gold-glow: #ffd700;--bg-darkest: #0d0a15;--bg-dark: #1a1425;--bg-medium: #2a1f3d;--bg-light: #3d2f5a;--bg-card: #251a38;--bg-hover: #32254a;--text-primary: #e8dff5;--text-secondary: #b8a8d4;--text-muted: #8a7a9d;--text-disabled: #5a4a6d;--red-dark: #7a1a1a;--red-medium: #c53030;--red-light: #fc8181;--green-dark: #1a4d2e;--green-medium: #2f855a;--green-light: #68d391;--blue-dark: #1e3a5f;--blue-medium: #2c5282;--blue-light: #63b3ed;--border-dark: #3d2f5a;--border-medium: #4a3b6b;--border-light: #6b5a8a;--border-gold: #8b6914;--shadow-sm: 0 2px 8px rgba(13, 10, 21, .4);--shadow-md: 0 4px 16px rgba(13, 10, 21, .6);--shadow-lg: 0 8px 32px rgba(13, 10, 21, .8);--glow-purple: 0 0 20px rgba(107, 70, 193, .3);--glow-gold: 0 0 20px rgba(212, 175, 55, .3);--font-primary: "Cinzel", "Georgia", serif;--font-secondary: "Spectral", "Times New Roman", serif;--font-body: "Lora", "Georgia", serif;--font-mono: "Courier New", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg-darkest);background-image:radial-gradient(ellipse at top,rgba(107,70,193,.1) 0%,transparent 50%),radial-gradient(ellipse at bottom,rgba(26,15,46,.5) 0%,transparent 50%);background-attachment:fixed;color:var(--text-primary);font-family:var(--font-secondary);font-size:16px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);font-weight:600;line-height:1.3;color:var(--text-primary);letter-spacing:.5px;margin-bottom:var(--spacing-md)}h1{font-size:2.5rem;background:linear-gradient(135deg,var(--gold-light),var(--gold-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:var(--glow-gold)}h2{font-size:2rem;color:var(--gold-medium)}h3{font-size:1.5rem;color:var(--gold-light)}h4{font-size:1.25rem}h5{font-size:1.1rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md);color:var(--text-secondary)}a{color:var(--gold-medium);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--gold-light);text-decoration:underline}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--bg-dark);border-radius:var(--radius-md)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--primary-accent),var(--primary-medium));border-radius:var(--radius-md);border:2px solid var(--bg-dark)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--gold-medium),var(--gold-dark))}::selection{background:var(--primary-accent);color:var(--text-primary)}::-moz-selection{background:var(--primary-accent);color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border-dark);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:all var(--transition-normal)}.card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-lg),var(--glow-gold);transform:translateY(-2px)}.card-header{border-bottom:2px solid var(--border-gold);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-primary);font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--gold-medium),var(--gold-dark));color:var(--bg-darkest);border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.btn-primary:hover{background:linear-gradient(135deg,var(--gold-light),var(--gold-medium));box-shadow:0 0 30px #d4af3780;transform:translateY(-2px)}.btn-secondary{background:var(--bg-medium);color:var(--text-primary);border-color:var(--border-medium)}.btn-secondary:hover{background:var(--bg-light);border-color:var(--border-light)}.btn-danger{background:var(--red-medium);color:var(--text-primary);border-color:var(--red-dark)}.btn-danger:hover{background:var(--red-light);box-shadow:0 0 20px #fc81814d}.btn-success{background:var(--green-medium);color:var(--text-primary);border-color:var(--green-dark)}.btn-success:hover{background:var(--green-light);box-shadow:0 0 20px #68d3914d}.btn-small{padding:var(--spacing-xs) var(--spacing-md);font-size:.8rem}.btn-large{padding:var(--spacing-md) var(--spacing-xl);font-size:1rem}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-family:var(--font-primary);font-size:.9rem;font-weight:600;color:var(--gold-medium);letter-spacing:.5px;text-transform:uppercase}.form-group input,.form-group textarea,.form-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-secondary);font-size:1rem;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.form-group textarea{resize:vertical;min-height:100px}.form-help{display:block;margin-top:var(--spacing-xs);font-size:.85rem;color:var(--text-muted);font-style:italic}.ornament-top,.ornament-bottom{width:100%;height:3px;background:linear-gradient(90deg,transparent,var(--gold-medium) 50%,transparent);margin:var(--spacing-lg) 0}.section-divider{height:2px;background:linear-gradient(90deg,transparent,var(--border-gold) 20%,var(--border-gold) 80%,transparent);margin:var(--spacing-xl) 0;position:relative}.section-divider:before{content:"⚔";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);padding:0 var(--spacing-md);color:var(--gold-medium);font-size:1.5rem}.spinner{width:40px;height:40px;border:3px solid var(--border-dark);border-top-color:var(--gold-medium);border-radius:50%;animation:spin 1s linear infinite}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-gold{color:var(--gold-medium)}.text-purple{color:var(--primary-accent)}.text-muted{color:var(--text-muted)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}@media(max-width:768px){body{font-size:14px}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.card{padding:var(--spacing-md)}}.parchment-bg{position:relative;background-image:linear-gradient(90deg,rgba(212,175,55,.03) 1px,transparent 1px),linear-gradient(rgba(212,175,55,.03) 1px,transparent 1px);background-size:50px 50px}.parchment-bg:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 30%,rgba(212,175,55,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(107,70,193,.05) 0%,transparent 50%);pointer-events:none;z-index:0}@keyframes float{0%,to{transform:translateY(0) translate(0);opacity:.3}25%{transform:translateY(-20px) translate(10px);opacity:.6}50%{transform:translateY(-10px) translate(-10px);opacity:.4}75%{transform:translateY(-30px) translate(5px);opacity:.5}}@keyframes twinkle{0%,to{opacity:.2}50%{opacity:.8}}.magic-particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.magic-particle{position:absolute;width:3px;height:3px;background:var(--gold-glow);border-radius:50%;box-shadow:0 0 10px var(--gold-glow);animation:float 8s infinite ease-in-out,twinkle 3s infinite}.magic-particle:nth-child(2n){background:var(--primary-accent);box-shadow:0 0 10px var(--primary-accent);animation-duration:10s,4s}.magic-particle:nth-child(3n){width:2px;height:2px;animation-duration:12s,5s}@keyframes diceRoll{0%{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.1)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.1)}to{transform:rotate(360deg) scale(1)}}.dice-icon{display:inline-block;animation:diceRoll 2s ease-in-out}.dice-icon.spinning{animation:diceRoll .5s ease-in-out infinite}.dragon-border{position:relative;border:2px solid var(--border-gold);padding:var(--spacing-lg)}.dragon-border:before,.dragon-border:after{content:"🐉";position:absolute;font-size:1.5rem;color:var(--gold-medium);opacity:.7}.dragon-border:before{top:-10px;left:20px}.dragon-border:after{bottom:-10px;right:20px;transform:scaleX(-1)}@keyframes flameFlicker{0%,to{opacity:.8;text-shadow:0 0 10px var(--gold-glow)}25%{opacity:.9;text-shadow:0 0 15px var(--gold-glow)}50%{opacity:1;text-shadow:0 0 20px var(--gold-glow)}75%{opacity:.9;text-shadow:0 0 15px var(--gold-glow)}}.flame-border{position:relative;padding:var(--spacing-md);border:2px solid transparent;background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,var(--gold-dark),var(--gold-medium),var(--gold-light)) border-box;border-radius:var(--radius-lg)}.flame-icon{animation:flameFlicker 2s ease-in-out infinite}@keyframes spellGlow{0%,to{box-shadow:0 0 5px var(--primary-accent),0 0 10px var(--primary-accent),0 0 15px var(--primary-accent)}50%{box-shadow:0 0 10px var(--primary-accent),0 0 20px var(--primary-accent),0 0 30px var(--primary-accent),0 0 40px var(--gold-medium)}}.spell-effect{animation:spellGlow 3s ease-in-out infinite}.scroll-container{position:relative;background:linear-gradient(to bottom,#2a1f3de6,#251a38f2);border-radius:var(--radius-lg);padding:var(--spacing-xl) var(--spacing-lg);box-shadow:inset 0 2px 10px #0000004d,var(--shadow-lg)}.scroll-container:before{content:"📜";position:absolute;top:10px;right:10px;font-size:1.5rem;opacity:.3}.rune{display:inline-block;font-family:var(--font-primary);color:var(--gold-medium);text-shadow:0 0 10px var(--gold-glow);font-weight:600;letter-spacing:2px}.rune-divider{text-align:center;margin:var(--spacing-lg) 0;color:var(--gold-medium);font-size:1.2rem;letter-spacing:var(--spacing-md)}.rune-divider:before,.rune-divider:after{content:"✦";margin:0 var(--spacing-md);opacity:.5}.stat-block{background:var(--bg-card);border:3px double var(--border-gold);border-radius:var(--radius-md);padding:var(--spacing-md);position:relative}.stat-block:before{content:"";position:absolute;inset:-3px;background:linear-gradient(45deg,var(--gold-dark),var(--primary-medium));border-radius:var(--radius-md);z-index:-1;opacity:.3}.stat-value{font-family:var(--font-mono);font-size:2rem;font-weight:700;color:var(--gold-light);text-shadow:0 0 10px var(--gold-glow);text-align:center}.stat-label{font-family:var(--font-primary);font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;text-align:center;display:block}.guild-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(135deg,var(--primary-medium),var(--primary-dark));border:1px solid var(--gold-dark);border-radius:20px;font-size:.85rem;font-weight:600;color:var(--gold-light);box-shadow:var(--glow-purple)}.guild-badge:before{content:"⚔️";font-size:1rem}.level-badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:radial-gradient(circle,var(--gold-medium),var(--gold-dark));border:3px solid var(--gold-dark);border-radius:50%;font-family:var(--font-primary);font-size:1.2rem;font-weight:700;color:var(--bg-darkest);box-shadow:0 0 20px var(--gold-glow)}.quest-banner{background:linear-gradient(135deg,var(--primary-medium),var(--primary-dark));border-left:4px solid var(--gold-medium);padding:var(--spacing-md) var(--spacing-lg);border-radius:0 var(--radius-md) var(--radius-md) 0;position:relative;overflow:hidden}.quest-banner:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(212,175,55,.05) 10px,rgba(212,175,55,.05) 20px);pointer-events:none}@keyframes chestGleam{0%,to{opacity:0}50%{opacity:1}}.treasure-shine{position:relative;overflow:hidden}.treasure-shine:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,transparent 40%,rgba(255,215,0,.3) 50%,transparent 60%,transparent);transform:rotate(45deg);animation:chestGleam 3s ease-in-out infinite}.resource-bar{width:100%;height:20px;background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:10px;overflow:hidden;position:relative}.resource-bar-fill{height:100%;background:linear-gradient(90deg,var(--green-medium),var(--green-light));border-radius:8px;transition:width .5s ease;position:relative;overflow:hidden}.resource-bar-fill.mana{background:linear-gradient(90deg,var(--blue-medium),var(--blue-light))}.resource-bar-fill.hp{background:linear-gradient(90deg,var(--red-medium),var(--red-light))}.resource-bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3) 50%,transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes criticalHit{0%{transform:scale(1);filter:brightness(1)}25%{transform:scale(1.2);filter:brightness(1.5)}50%{transform:scale(1.1);filter:brightness(1.3)}75%{transform:scale(1.15);filter:brightness(1.4)}to{transform:scale(1);filter:brightness(1)}}.critical-hit{animation:criticalHit .5s ease-out;color:var(--gold-light)!important;text-shadow:0 0 20px var(--gold-glow)!important}@media(max-width:768px){.dragon-border:before,.dragon-border:after{font-size:1rem}.magic-particle{width:2px;height:2px}.level-badge{width:32px;height:32px;font-size:1rem}}#root{width:100%;min-height:100vh}.Toastify__toast{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border-dark)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;font-family:var(--font-secondary)!important}.Toastify__toast--success{border-color:var(--green-medium)!important}.Toastify__toast--error{border-color:var(--red-medium)!important}.Toastify__toast--info{border-color:var(--blue-medium)!important}.Toastify__toast--warning{border-color:var(--gold-medium)!important}.Toastify__progress-bar{background:linear-gradient(90deg,var(--gold-medium),var(--gold-light))!important}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-md)}.loading-message{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.1rem;letter-spacing:1px}.error-container{background:var(--red-dark);border:2px solid var(--red-medium);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin:var(--spacing-lg);text-align:center}.error-message{color:var(--red-light);font-weight:600}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted)}.empty-state-icon{font-size:4rem;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-message{font-size:1.1rem;margin-bottom:var(--spacing-lg)}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.navbar{background:linear-gradient(135deg,var(--primary-dark),var(--primary-medium));border-bottom:3px solid var(--border-gold);box-shadow:var(--shadow-lg),0 4px 20px #d4af3733;position:sticky;top:0;z-index:1000;padding:0}.navbar-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg)}.navbar-brand{font-family:var(--font-primary);font-size:1.8rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg,var(--gold-light),var(--gold-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px var(--gold-glow);transition:all var(--transition-fast);text-decoration:none;position:relative}.navbar-brand:before{content:"⚔️";position:absolute;left:-30px;font-size:1.5rem;filter:drop-shadow(0 0 10px var(--gold-glow))}.navbar-brand:hover{transform:scale(1.05);text-shadow:0 0 40px var(--gold-glow)}.navbar-links{display:flex;align-items:center;gap:var(--spacing-lg)}.nav-link{font-family:var(--font-primary);font-size:.95rem;font-weight:600;color:var(--text-primary);text-decoration:none;text-transform:uppercase;letter-spacing:1px;padding:var(--spacing-sm) var(--spacing-md);border:2px solid transparent;border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative}.nav-link:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%) scaleX(0);width:80%;height:2px;background:linear-gradient(90deg,transparent,var(--gold-medium),transparent);transition:transform var(--transition-fast)}.nav-link:hover{color:var(--gold-light);border-color:var(--border-gold);background:#d4af371a}.nav-link:hover:after{transform:translate(-50%) scaleX(1)}.nav-user{display:flex;align-items:center;gap:var(--spacing-md);padding-left:var(--spacing-md);border-left:2px solid var(--border-dark)}.nav-user span{font-family:var(--font-secondary);color:var(--text-secondary);font-size:.9rem;font-style:italic}.btn-logout{font-family:var(--font-primary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(135deg,var(--red-medium),var(--red-dark));color:var(--text-primary);border:2px solid var(--red-dark);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 0 15px #c530304d}.btn-logout:hover{background:linear-gradient(135deg,var(--red-light),var(--red-medium));border-color:var(--red-light);box-shadow:0 0 25px #fc818166;transform:translateY(-2px)}.btn-logout:active{transform:translateY(0)}@media(max-width:768px){.navbar-container{flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.navbar-brand{font-size:1.5rem}.navbar-brand:before{left:-25px;font-size:1.2rem}.navbar-links{flex-wrap:wrap;justify-content:center;gap:var(--spacing-sm)}.nav-link{font-size:.85rem;padding:var(--spacing-xs) var(--spacing-sm)}.nav-user{flex-direction:column;gap:var(--spacing-xs);padding-left:0;border-left:none;border-top:2px solid var(--border-dark);padding-top:var(--spacing-sm)}.nav-user span{font-size:.85rem}}@media(max-width:480px){.navbar-brand:before{display:none}.navbar-links{width:100%}.nav-link{flex:1 1 auto;text-align:center}}.characters-container{max-width:1200px;margin:0 auto;padding:20px}.characters-container h1{font-family:var(--font-primary);color:var(--gold-light);text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 20px var(--gold-glow);margin-bottom:30px}.create-new{display:inline-block;margin-bottom:30px}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.character-card{background:var(--bg-card);border:2px solid var(--border-dark);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.character-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg),0 0 20px #d4af374d;border-color:var(--border-gold)}.card-banner{height:100px;background-size:cover;background-position:center;background:linear-gradient(135deg,var(--primary-medium),var(--primary-dark));position:relative}.banner-overlay-card{background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.5) 100%);height:100%}.card-content{padding:15px;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;margin-top:-40px}.card-profile-image{width:80px;height:80px;border-radius:var(--radius-sm);border:3px solid var(--border-gold);object-fit:cover;box-shadow:0 4px 10px #00000080,0 0 15px #d4af374d;margin-bottom:10px}.card-info h3{font-family:var(--font-primary);color:var(--gold-light);text-transform:uppercase;letter-spacing:1px;font-size:20px;margin:0 0 5px;text-shadow:0 0 15px var(--gold-glow)}.card-subtitle{font-family:var(--font-secondary);color:var(--text-primary);font-size:14px;margin:0 0 5px}.card-owner{font-family:var(--font-secondary);color:var(--text-muted);font-size:12px;font-style:italic;margin:0 0 10px}.card-stats{font-family:var(--font-mono);color:var(--text-muted);font-size:12px;padding-top:10px;border-top:1px solid var(--border-dark);width:100%}.characters-empty{text-align:center;padding:60px 20px;background:var(--bg-card);border:2px solid var(--border-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.characters-empty h2{font-family:var(--font-primary);color:var(--text-primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:20px}@media(max-width:768px){.characters-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:15px}}.dice-roller-container{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}.dice-roller-card,.roll-history-card{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-lg),var(--glow-gold)}.dice-roller-card h2{font-family:var(--font-primary);color:var(--gold-light);font-size:28px;text-transform:uppercase;letter-spacing:2px;text-align:center;margin:0 0 25px;text-shadow:0 0 20px var(--gold-glow)}.dice-selection{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:25px}.die-button{font-family:var(--font-primary);padding:10px 16px;background:var(--bg-dark);color:var(--text-primary);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all var(--transition-fast)}.die-button:hover:not(:disabled){border-color:var(--gold-medium);color:var(--gold-light);box-shadow:0 0 15px #d4af374d;transform:translateY(-2px)}.die-button.active{background:linear-gradient(135deg,var(--gold-medium),var(--gold-dark));color:var(--bg-darkest);border-color:var(--gold-medium);box-shadow:0 0 20px var(--gold-glow)}.die-button:disabled{opacity:.5;cursor:not-allowed}.dice-display{min-height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);border:3px solid var(--border-dark);border-radius:var(--radius-lg);margin-bottom:25px;position:relative;overflow:hidden}.dice-display:before{content:"";position:absolute;inset:0;background-image:radial-gradient(ellipse at 30% 30%,rgba(212,175,55,.05) 0%,transparent 50%),radial-gradient(ellipse at 70% 70%,rgba(107,70,193,.05) 0%,transparent 50%);pointer-events:none}.dice-display.rolling{animation:shake .1s infinite}@keyframes shake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-5px) rotate(-2deg)}75%{transform:translate(5px) rotate(2deg)}}.dice-result{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:1;animation:resultAppear .3s ease-out}@keyframes resultAppear{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.result-number{font-family:var(--font-primary);font-size:80px;font-weight:700;color:var(--gold-light);text-shadow:0 0 30px var(--gold-glow),0 0 60px rgba(212,175,55,.5);line-height:1}.result-label{font-family:var(--font-primary);font-size:24px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:2px}.dice-placeholder{display:flex;flex-direction:column;align-items:center;gap:15px;opacity:.5}.dice-placeholder span{font-size:60px}.dice-placeholder p{font-family:var(--font-secondary);color:var(--text-muted);font-size:16px;font-style:italic}.roll-button{width:100%;padding:18px;font-family:var(--font-primary);font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,var(--primary-accent),var(--primary-medium));color:var(--text-primary);border:2px solid var(--primary-accent);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.roll-button:hover:not(:disabled){background:linear-gradient(135deg,var(--gold-medium),var(--gold-dark));border-color:var(--gold-medium);box-shadow:var(--shadow-lg),0 0 30px var(--gold-glow);transform:translateY(-2px)}.roll-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.roll-history-card{display:flex;flex-direction:column;max-height:600px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-gold)}.history-header h3{font-family:var(--font-primary);color:var(--gold-light);font-size:24px;text-transform:uppercase;letter-spacing:1px;margin:0;text-shadow:0 0 15px var(--gold-glow)}.clear-history-btn{font-family:var(--font-primary);padding:8px 16px;background:var(--bg-dark);color:var(--red-medium);border:2px solid var(--red-dark);border-radius:var(--radius-sm);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all var(--transition-fast)}.clear-history-btn:hover{background:var(--red-dark);color:var(--text-primary);box-shadow:0 0 15px #c530304d}.roll-history-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.history-item{display:grid;grid-template-columns:60px 60px 1fr;gap:15px;align-items:center;padding:12px;background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);transition:all var(--transition-fast);animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}.history-item:hover{border-color:var(--border-gold);box-shadow:0 0 10px #d4af3733}.history-die{font-family:var(--font-primary);font-size:14px;font-weight:700;color:var(--primary-accent);text-align:center;text-transform:uppercase}.history-result{font-family:var(--font-primary);font-size:28px;font-weight:700;color:var(--gold-medium);text-align:center;text-shadow:0 0 10px var(--gold-glow)}.history-info{display:flex;flex-direction:column;gap:4px}.history-character{font-family:var(--font-secondary);font-size:14px;font-weight:600;color:var(--text-primary)}.history-time{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.roll-history-list::-webkit-scrollbar{width:8px}.roll-history-list::-webkit-scrollbar-track{background:var(--bg-darkest);border-radius:4px}.roll-history-list::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}.roll-history-list::-webkit-scrollbar-thumb:hover{background:var(--gold-dark)}@media(max-width:968px){.dice-roller-container{grid-template-columns:1fr}.roll-history-card{max-height:400px}}@media(max-width:768px){.dice-selection{gap:8px}.die-button{padding:8px 12px;font-size:12px}.result-number{font-size:60px}.result-label{font-size:18px}.history-item{grid-template-columns:50px 50px 1fr;gap:10px;padding:10px}.history-result{font-size:22px}}.home-container{max-width:1200px;margin:0 auto;padding:20px}.hero{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);padding:60px 40px;text-align:center;margin-bottom:40px;box-shadow:var(--shadow-lg),var(--glow-gold);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(ellipse at 20% 30%,rgba(212,175,55,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(107,70,193,.05) 0%,transparent 50%);pointer-events:none}.hero h1{font-family:var(--font-primary);color:var(--gold-light);font-size:48px;text-transform:uppercase;letter-spacing:3px;margin:0 0 15px;text-shadow:0 0 30px var(--gold-glow);position:relative;z-index:1}.hero-subtitle{font-family:var(--font-secondary);color:var(--text-secondary);font-size:18px;font-style:italic;margin:0 0 30px;position:relative;z-index:1}.hero-content{position:relative;z-index:1}.hero-content h2{font-family:var(--font-primary);color:var(--text-primary);font-size:28px;text-transform:uppercase;letter-spacing:1px;margin:30px 0 15px}.hero-content p{font-family:var(--font-secondary);color:var(--text-primary);font-size:16px;line-height:1.6;max-width:600px;margin:0 auto 30px}.home-actions{display:flex;gap:20px;justify-content:center;margin-top:30px}.home-actions a{padding:15px 40px;text-decoration:none;border-radius:var(--radius-md);font-family:var(--font-primary);font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:1px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.home-actions .btn-primary{background:linear-gradient(135deg,var(--gold-medium),var(--gold-dark));color:var(--bg-darkest);border:2px solid var(--gold-medium)}.home-actions .btn-primary:hover{background:linear-gradient(135deg,var(--gold-light),var(--gold-medium));box-shadow:var(--shadow-md),0 0 25px var(--gold-glow);transform:translateY(-2px)}.home-actions .btn-secondary{background:var(--bg-dark);color:var(--primary-accent);border:2px solid var(--primary-accent)}.home-actions .btn-secondary:hover{background:var(--primary-accent);color:var(--text-primary);box-shadow:var(--shadow-md),0 0 20px #6b46c166;transform:translateY(-2px)}.features{background:var(--bg-card);border:3px solid var(--border-dark);border-radius:var(--radius-lg);padding:50px 40px;box-shadow:var(--shadow-lg);margin-bottom:40px}.features h2{font-family:var(--font-primary);color:var(--gold-light);text-transform:uppercase;letter-spacing:2px;font-size:36px;text-align:center;margin:0 0 40px;text-shadow:0 0 20px var(--gold-glow)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:25px}.feature-card{background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);padding:30px 20px;text-align:center;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.feature-card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-md),0 0 20px #d4af3733;transform:translateY(-5px)}.feature-card h3{font-family:var(--font-primary);color:var(--gold-medium);font-size:20px;text-transform:uppercase;letter-spacing:1px;margin:0 0 15px;text-shadow:0 0 15px var(--gold-glow)}.feature-card p{font-family:var(--font-secondary);color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0}@media(max-width:768px){.hero{padding:40px 20px}.hero h1{font-size:32px}.hero-subtitle{font-size:16px}.home-actions{flex-direction:column;align-items:stretch}.home-actions a{width:100%;text-align:center}.features{padding:30px 20px}.features h2{font-size:28px}.features-grid{grid-template-columns:1fr}}.auth-container{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background-image:radial-gradient(ellipse at 20% 30%,rgba(212,175,55,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(107,70,193,.08) 0%,transparent 50%)}.auth-box{width:100%;max-width:480px;background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg),var(--glow-gold);position:relative}.auth-box:before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(212,175,55,.03) 1px,transparent 1px),linear-gradient(rgba(212,175,55,.03) 1px,transparent 1px);background-size:50px 50px;border-radius:var(--radius-xl);pointer-events:none;z-index:0}.auth-header{text-align:center;margin-bottom:var(--spacing-xl);position:relative;z-index:1}.auth-title{font-family:var(--font-primary);font-size:2.2rem;color:var(--gold-medium);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 20px var(--gold-glow);position:relative}.auth-title:before{content:"⚔️";position:absolute;left:50%;top:-50px;transform:translate(-50%);font-size:2.5rem;filter:drop-shadow(0 0 15px var(--gold-glow))}.auth-subtitle{font-family:var(--font-secondary);color:var(--text-secondary);font-size:1rem;margin-top:var(--spacing-md)}.auth-subtitle a{color:var(--primary-accent);text-decoration:none;font-weight:600;transition:color var(--transition-fast)}.auth-subtitle a:hover{color:var(--gold-medium);text-decoration:underline}.auth-form{position:relative;z-index:1}.auth-form .form-group{margin-bottom:var(--spacing-lg)}.auth-form .form-group label{display:block;margin-bottom:var(--spacing-sm);font-family:var(--font-primary);font-size:.95rem;font-weight:600;color:var(--gold-light);text-transform:uppercase;letter-spacing:1px}.auth-form .form-group input{width:100%;padding:var(--spacing-md);border:2px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-primary);font-family:var(--font-secondary);font-size:1rem;transition:all var(--transition-fast)}.auth-form .form-group input:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold);background:var(--bg-medium)}.auth-form .form-group input::placeholder{color:var(--text-disabled)}.auth-button{width:100%;font-family:var(--font-primary);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,var(--gold-medium),var(--gold-dark));color:var(--bg-darkest);border:2px solid var(--gold-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--spacing-lg);box-shadow:var(--glow-gold)}.auth-button:hover:not(:disabled){background:linear-gradient(135deg,var(--gold-light),var(--gold-medium));border-color:var(--gold-light);box-shadow:0 0 30px #d4af3799;transform:translateY(-2px)}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{height:2px;background:linear-gradient(90deg,transparent,var(--border-gold) 20%,var(--border-gold) 80%,transparent);margin:var(--spacing-xl) 0;position:relative;z-index:1}.auth-divider:before{content:"✦";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);padding:0 var(--spacing-md);color:var(--gold-medium);font-size:1.2rem}.auth-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:2px solid var(--border-dark);position:relative;z-index:1}.auth-footer p{font-family:var(--font-secondary);color:var(--text-secondary);font-size:.95rem;margin:0}.auth-footer a{color:var(--primary-accent);text-decoration:none;font-weight:600;transition:color var(--transition-fast)}.auth-footer a:hover{color:var(--gold-medium);text-decoration:underline}.auth-error{background:#c5303033;border:2px solid var(--red-medium);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--red-light);font-family:var(--font-secondary);font-size:.9rem;text-align:center;position:relative;z-index:1}.auth-success{background:#2f855a33;border:2px solid var(--green-medium);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--green-light);font-family:var(--font-secondary);font-size:.9rem;text-align:center;position:relative;z-index:1}.auth-loading{display:inline-block;width:20px;height:20px;border:3px solid var(--bg-darkest);border-top-color:var(--gold-light);border-radius:50%;animation:spin .8s linear infinite;margin-left:var(--spacing-sm)}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.auth-container{padding:var(--spacing-lg)}.auth-box{padding:var(--spacing-xl)}.auth-title{font-size:1.8rem}.auth-title:before{top:-40px;font-size:2rem}.auth-form .form-group input{padding:var(--spacing-sm) var(--spacing-md)}.auth-button{font-size:1rem;padding:var(--spacing-sm) var(--spacing-lg)}}@media(max-width:480px){.auth-box{padding:var(--spacing-lg)}.auth-title{font-size:1.5rem}.auth-title:before{display:none}}.character-form-container{max-width:900px;margin:0 auto;padding:var(--spacing-xl)}.character-form-container h1{font-family:var(--font-primary);color:var(--gold-medium);margin-bottom:var(--spacing-xl);text-align:center;font-size:2.5rem;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 20px var(--gold-glow)}.character-form{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg);position:relative}.character-form:before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(212,175,55,.03) 1px,transparent 1px),linear-gradient(rgba(212,175,55,.03) 1px,transparent 1px);background-size:50px 50px;border-radius:var(--radius-xl);pointer-events:none;z-index:0}.form-section{margin-bottom:var(--spacing-xl);position:relative;z-index:1}.form-section h2{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.5rem;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-gold);text-transform:uppercase;letter-spacing:1px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.image-drop-zone{border:2px dashed var(--border-medium);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-dark);position:relative;overflow:hidden}.image-drop-zone:hover{border-color:var(--gold-medium);background:var(--bg-hover);box-shadow:var(--glow-gold)}.image-drop-zone.drag-active{border-color:var(--gold-light);background:#d4af371a;border-width:3px;box-shadow:var(--glow-gold)}.banner-drop{min-height:200px;display:flex;align-items:center;justify-content:center}.profile-drop{max-width:350px;min-height:350px;margin:0 auto;display:flex;align-items:center;justify-content:center}.drop-zone-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.drop-zone-content p{font-family:var(--font-primary);color:var(--gold-light);font-weight:600;margin:0;text-transform:uppercase;letter-spacing:.5px}.file-hint{font-family:var(--font-secondary);color:var(--text-muted);font-size:.85rem;font-style:italic}.image-preview{max-width:100%;max-height:100%;object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--border-gold)}.banner-preview{width:100%;height:200px}.profile-preview{width:280px;height:280px;border-radius:var(--radius-lg)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.stat-input{display:flex;flex-direction:column}.stat-input label{font-family:var(--font-primary);font-weight:600;margin-bottom:var(--spacing-xs);color:var(--gold-light);text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.stat-input input{padding:var(--spacing-md);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:1.2rem;text-align:center;font-weight:700;background:var(--bg-dark);color:var(--gold-light);transition:all var(--transition-fast)}.stat-input input:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}textarea{width:100%;padding:var(--spacing-md);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-family:var(--font-secondary);resize:vertical;background:var(--bg-dark);color:var(--text-primary);line-height:1.6;transition:all var(--transition-fast)}textarea:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.char-count{display:block;text-align:right;color:var(--text-muted);font-family:var(--font-secondary);font-size:.85rem;margin-top:var(--spacing-xs);font-style:italic}select{width:100%;padding:var(--spacing-md);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-family:var(--font-secondary);font-size:.95rem;background:var(--bg-dark);color:var(--text-primary);transition:all var(--transition-fast)}select:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.form-actions{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:2px solid var(--border-gold);position:relative;z-index:1}.form-actions button{flex:1}@media(max-width:768px){.character-form-container{padding:var(--spacing-lg)}.character-form{padding:var(--spacing-xl)}.character-form-container h1{font-size:2rem}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.profile-drop{max-width:100%;min-height:250px}.form-actions{flex-direction:column}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.stat-block{background:var(--bg-card);border:2px solid var(--border-dark);border-radius:var(--radius-md);padding:15px;margin-bottom:20px;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.stat-block:hover{border-color:var(--border-gold);box-shadow:var(--shadow-md)}.stat-block h3{font-family:var(--font-primary);color:var(--gold-light);font-size:18px;text-transform:uppercase;letter-spacing:1px;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid var(--border-dark);text-shadow:0 0 15px var(--gold-glow)}.stats-grid-display{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-item{background:var(--bg-dark);border:1px solid var(--border-dark);border-radius:var(--radius-sm);padding:10px;text-align:center;transition:all var(--transition-fast)}.stat-item:hover{border-color:var(--primary-accent);box-shadow:0 0 10px #6b46c133}.stat-label{font-family:var(--font-secondary);font-weight:700;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.stat-value{font-family:var(--font-mono);font-size:24px;font-weight:700;color:var(--gold-medium);margin-bottom:3px;text-shadow:0 0 10px var(--gold-glow)}.stat-modifier{font-family:var(--font-mono);font-size:14px;color:var(--text-muted)}@media(max-width:768px){.stats-grid-display{grid-template-columns:repeat(2,1fr)}}.comment-form{background:var(--bg-dark);border:2px solid var(--border-medium);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.comment-form-reply{background:var(--bg-medium);margin:var(--spacing-md) 0 var(--spacing-md) 50px;padding:var(--spacing-md);border:2px solid var(--border-dark)}.comment-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.comment-form-header label{font-family:var(--font-primary);font-size:.9rem;font-weight:600;color:var(--gold-light);text-transform:uppercase;letter-spacing:.5px}.character-select{padding:var(--spacing-xs) var(--spacing-sm);border:2px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-medium);font-family:var(--font-secondary);font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.comment-textarea{width:100%;padding:var(--spacing-md);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-family:var(--font-secondary);font-size:.95rem;color:var(--text-primary);background:var(--bg-medium);resize:vertical;margin-bottom:var(--spacing-md);line-height:1.6;transition:all var(--transition-fast)}.comment-textarea:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.comment-textarea:disabled{background:var(--bg-dark);cursor:not-allowed;opacity:.6}.photo-preview{position:relative;margin-bottom:var(--spacing-md);max-width:300px}.photo-preview img{width:100%;height:auto;border-radius:var(--radius-md);border:2px solid var(--border-medium);box-shadow:var(--shadow-sm)}.remove-photo-btn{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);background:#0d0a15e6;color:var(--red-light);border:2px solid var(--red-medium);border-radius:50%;width:28px;height:28px;font-size:1.2rem;line-height:1;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.remove-photo-btn:hover{background:var(--red-dark);border-color:var(--red-light);box-shadow:0 0 15px #c5303080}.comment-form-footer{display:flex;justify-content:space-between;align-items:center}.comment-form-footer-left{display:flex;align-items:center;gap:var(--spacing-md)}.photo-attach-btn{font-size:1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform var(--transition-fast);color:var(--gold-medium);filter:drop-shadow(0 0 5px var(--gold-glow))}.photo-attach-btn:hover{transform:scale(1.2);color:var(--gold-light)}.character-count{font-family:var(--font-secondary);font-size:.85rem;color:var(--text-muted)}.character-count-warning{color:var(--red-light);font-weight:700}.comment-form-actions{display:flex;gap:var(--spacing-md)}.btn-small{padding:var(--spacing-xs) var(--spacing-md);font-size:.9rem}@media(max-width:768px){.comment-form{padding:var(--spacing-md)}.comment-form-reply{margin-left:var(--spacing-lg)}.comment-form-footer{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.comment-form-actions{width:100%}.comment-form-actions button{flex:1}}.comment-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.comment-item:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.comment-item-reply{margin-left:50px;margin-top:var(--spacing-md);background:var(--bg-medium);border-color:var(--border-medium)}.comment-author-link{flex-shrink:0}.comment-author-image{width:56px;height:56px;border-radius:var(--radius-md);object-fit:cover;border:2px solid var(--gold-dark);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.comment-author-image:hover{border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.comment-item-reply .comment-author-image{width:42px;height:42px}.comment-content-wrapper{flex:1;min-width:0}.comment-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.comment-author-name{font-family:var(--font-primary);font-weight:600;color:var(--gold-medium);text-decoration:none;font-size:1rem;letter-spacing:.5px;transition:color var(--transition-fast)}.comment-author-name:hover{color:var(--gold-light);text-decoration:underline}.comment-time{font-family:var(--font-secondary);font-size:.85rem;color:var(--text-muted);font-style:italic}.comment-edited{font-size:.85rem;color:var(--text-muted);font-style:italic}.comment-text{font-family:var(--font-secondary);margin:0 0 var(--spacing-md) 0;color:var(--text-primary);line-height:1.7;word-wrap:break-word;font-size:.95rem}.comment-photo{margin:var(--spacing-md) 0;max-width:500px}.comment-photo img{width:100%;height:auto;border-radius:var(--radius-md);border:2px solid var(--border-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.comment-photo img:hover{opacity:.9;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.comment-actions{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-sm)}.comment-action-btn{font-family:var(--font-primary);background:none;border:none;color:var(--primary-accent);font-size:.85rem;font-weight:600;cursor:pointer;padding:0;text-decoration:none;text-transform:uppercase;letter-spacing:.5px;transition:color var(--transition-fast)}.comment-action-btn:hover{color:var(--gold-medium);text-decoration:underline}.comment-delete-btn{color:var(--red-medium)}.comment-delete-btn:hover{color:var(--red-light)}.comment-edit-form{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-medium);border:2px solid var(--border-dark);border-radius:var(--radius-md)}.comment-edit-textarea{width:100%;padding:var(--spacing-sm);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-family:var(--font-secondary);font-size:.95rem;color:var(--text-primary);background:var(--bg-dark);resize:vertical;margin-bottom:var(--spacing-sm);line-height:1.6;transition:all var(--transition-fast)}.comment-edit-textarea:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.comment-edit-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.comment-replies{margin-top:var(--spacing-lg)}@media(max-width:768px){.comment-item{padding:var(--spacing-md);gap:var(--spacing-sm)}.comment-item-reply{margin-left:var(--spacing-lg)}.comment-author-image{width:48px;height:48px}.comment-item-reply .comment-author-image{width:36px;height:36px}.comment-actions{gap:var(--spacing-md)}.comment-photo{max-width:100%}}.comments-list{margin-top:20px}.comments-empty{text-align:center;padding:40px 20px;font-family:var(--font-secondary);color:var(--text-muted);font-style:italic}.comments-loading{text-align:center;padding:20px;font-family:var(--font-secondary);color:var(--text-muted)}.wall-container{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-md)}.wall-title{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.8rem;margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-md);border-bottom:3px double var(--border-gold);text-transform:uppercase;letter-spacing:1px}.gallery-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);font-style:italic;font-family:var(--font-secondary)}.photo-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-lg);padding:var(--spacing-lg) 0}.gallery-item{position:relative;height:220px;overflow:hidden;border-radius:var(--radius-lg);cursor:pointer;background:var(--bg-dark);border:2px solid var(--border-dark);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.gallery-item:hover{transform:scale(1.05);z-index:1;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.gallery-item img{width:100%;height:100%;object-fit:cover}.gallery-item-overlay{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;gap:var(--spacing-sm);pointer-events:none}.gallery-item-likes,.gallery-item-comments{background:#0d0a15e6;color:var(--gold-light);padding:var(--spacing-xs) var(--spacing-sm);border-radius:20px;border:1px solid var(--border-gold);font-size:.85rem;font-weight:600;font-family:var(--font-primary);box-shadow:var(--shadow-sm)}.gallery-item-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(13,10,21,.95),transparent);color:var(--text-primary);padding:40px var(--spacing-md) var(--spacing-sm);font-size:.9rem;line-height:1.4;font-family:var(--font-secondary)}.lightbox{position:fixed;inset:0;background:#000000f7;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s}.lightbox-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);width:60px;height:60px;border:2px solid var(--gold-medium);background:#0d0a15cc;color:var(--gold-light);font-size:2.5rem;line-height:1;cursor:pointer;border-radius:50%;z-index:1002;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;box-shadow:var(--glow-gold)}.lightbox-close:hover{background:#d4af374d;border-color:var(--gold-light);transform:scale(1.1)}.lightbox-content{max-width:90%;max-height:90%;display:flex;gap:var(--spacing-xl);overflow:hidden}.lightbox-image-container{flex:1;display:flex;align-items:center;justify-content:center;min-width:0}.lightbox-image-container img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-lg);border:3px solid var(--border-gold);box-shadow:var(--shadow-lg),var(--glow-gold)}.lightbox-sidebar{width:400px;max-height:80vh;overflow-y:auto;background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-xl);color:var(--text-primary);box-shadow:var(--shadow-lg)}.lightbox-sidebar::-webkit-scrollbar{width:8px}.lightbox-sidebar::-webkit-scrollbar-track{background:var(--bg-dark);border-radius:var(--radius-md)}.lightbox-sidebar::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:var(--radius-md)}.lightbox-sidebar::-webkit-scrollbar-thumb:hover{background:var(--gold-medium)}.lightbox-section{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-dark)}.lightbox-section:last-child{border-bottom:none}.lightbox-section h4,.lightbox-section h5{font-family:var(--font-primary);margin-bottom:var(--spacing-md);font-size:1rem;color:var(--gold-medium);text-transform:uppercase;letter-spacing:1px}.caption-display p{font-family:var(--font-secondary);margin:0 0 var(--spacing-sm);font-size:.95rem;line-height:1.6;color:var(--text-primary)}.caption-edit textarea{width:100%;padding:var(--spacing-sm);border:2px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-primary);font-family:var(--font-secondary);font-size:.95rem;resize:vertical;transition:all var(--transition-fast)}.caption-edit textarea:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.caption-edit-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.tagged-characters{display:flex;flex-direction:column;gap:var(--spacing-sm)}.tagged-character{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);transition:all var(--transition-fast)}.tagged-character:hover{border-color:var(--border-medium)}.tagged-character-link{font-family:var(--font-secondary);color:var(--primary-accent);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.tagged-character-link:hover{color:var(--gold-medium);text-decoration:underline}.btn-remove-tag{background:transparent;border:2px solid var(--red-dark);border-radius:var(--radius-sm);color:var(--red-medium);font-size:1.2rem;line-height:1;cursor:pointer;padding:var(--spacing-xs);width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-remove-tag:hover{color:var(--red-light);border-color:var(--red-medium);box-shadow:0 0 15px #c5303066}.likes-header{margin-bottom:var(--spacing-md)}.like-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.character-select{flex:1;padding:var(--spacing-sm);border:2px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-primary);font-family:var(--font-secondary);font-size:.9rem;transition:all var(--transition-fast)}.character-select:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.btn-like{font-family:var(--font-primary);padding:var(--spacing-sm) var(--spacing-lg);border:2px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-primary);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all var(--transition-fast)}.btn-like:hover{border-color:var(--gold-medium);color:var(--gold-light);box-shadow:var(--glow-gold)}.btn-like.liked{background:linear-gradient(135deg,var(--red-medium),var(--red-dark));border-color:var(--red-medium);color:var(--text-primary);box-shadow:0 0 15px #c530304d}.likes-modal{background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-md)}.likes-modal ul{list-style:none;padding:0;margin:var(--spacing-sm) 0 0 0}.likes-modal li{padding:var(--spacing-xs) 0}.likes-modal a{font-family:var(--font-secondary);color:var(--primary-accent);text-decoration:none;font-size:.9rem;transition:color var(--transition-fast)}.likes-modal a:hover{color:var(--gold-medium);text-decoration:underline}.comments-toggle{font-family:var(--font-secondary);font-size:1rem;margin-bottom:var(--spacing-md);color:var(--text-secondary)}.comments-section{margin-top:var(--spacing-md)}.comment-form{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.comment-form textarea{width:100%;padding:var(--spacing-sm);border:2px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-primary);font-family:var(--font-secondary);font-size:.9rem;resize:vertical;line-height:1.5;transition:all var(--transition-fast)}.comment-form textarea:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.comments-list{max-height:400px;overflow-y:auto}.no-comments{text-align:center;color:var(--text-muted);font-style:italic;font-family:var(--font-secondary);padding:var(--spacing-lg) 0}.comment-item{background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.comment-author{font-family:var(--font-primary);color:var(--primary-accent);text-decoration:none;font-weight:600;font-size:.9rem;letter-spacing:.5px;transition:color var(--transition-fast)}.comment-author:hover{color:var(--gold-medium);text-decoration:underline}.comment-date{font-family:var(--font-secondary);color:var(--text-muted);font-size:.85rem;font-style:italic}.comment-content{font-family:var(--font-secondary);margin:0 0 var(--spacing-sm);font-size:.9rem;line-height:1.6;word-wrap:break-word;color:var(--text-primary)}.btn-delete-comment{font-family:var(--font-primary);font-size:.85rem;color:var(--red-medium);background:none;border:none;cursor:pointer;padding:0;text-transform:uppercase;letter-spacing:.5px;transition:color var(--transition-fast)}.btn-delete-comment:hover{color:var(--red-light)}.btn-text{font-family:var(--font-primary);background:transparent;border:none;color:var(--primary-accent);cursor:pointer;padding:var(--spacing-xs);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:color var(--transition-fast)}.btn-text:hover{color:var(--gold-medium)}.btn-small{padding:var(--spacing-xs) var(--spacing-md);font-size:.85rem}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:70px;height:70px;border:2px solid var(--gold-medium);background:#0d0a15cc;color:var(--gold-light);font-size:3rem;line-height:1;cursor:pointer;border-radius:50%;z-index:1001;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;box-shadow:var(--glow-gold)}.lightbox-nav:hover{background:#d4af374d;border-color:var(--gold-light);transform:translateY(-50%) scale(1.1)}.lightbox-prev{left:var(--spacing-lg)}.lightbox-next{right:var(--spacing-lg)}.lightbox-counter{position:absolute;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);color:var(--text-primary);font-family:var(--font-primary);font-size:.95rem;font-weight:600;background:#0d0a15e6;border:2px solid var(--border-gold);padding:var(--spacing-sm) var(--spacing-lg);border-radius:30px;letter-spacing:1px;box-shadow:var(--shadow-md)}@media(max-width:1200px){.lightbox-content{flex-direction:column;max-width:95%}.lightbox-sidebar{width:100%;max-height:350px}.lightbox-image-container img{max-height:50vh}}@media(max-width:768px){.photo-gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-md)}.gallery-item{height:160px}.lightbox-nav{width:50px;height:50px;font-size:2rem}.lightbox-close{width:45px;height:45px;font-size:2rem}.lightbox-prev{left:var(--spacing-sm)}.lightbox-next{right:var(--spacing-sm)}.lightbox-sidebar{padding:var(--spacing-md);max-height:300px}.like-actions{flex-direction:column}.lightbox-counter{font-size:.85rem;padding:var(--spacing-xs) var(--spacing-md)}}.photo-upload{padding:20px}.upload-dropzone{border:3px dashed var(--border-medium);border-radius:var(--radius-lg);padding:40px 20px;text-align:center;background:var(--bg-dark);transition:all var(--transition-normal);cursor:pointer}.upload-dropzone:hover{border-color:var(--primary-accent);background:var(--bg-card);box-shadow:0 0 20px #6b46c133}.upload-dropzone.drag-active{border-color:var(--gold-medium);background:var(--bg-card);border-style:solid;box-shadow:0 0 30px #d4af374d}.dropzone-content{pointer-events:none}.dropzone-icon{font-size:48px;display:block;margin-bottom:10px;color:var(--gold-medium);text-shadow:0 0 15px var(--gold-glow)}.dropzone-text{font-size:16px;font-family:var(--font-secondary);color:var(--text-primary);margin:10px 0}.file-input-label{color:var(--primary-accent);text-decoration:underline;cursor:pointer;pointer-events:auto;font-weight:600;transition:color var(--transition-fast)}.file-input-label:hover{color:var(--gold-light)}.dropzone-subtext{font-size:13px;color:var(--text-muted);margin:5px 0 0;font-family:var(--font-mono)}.preview-section{margin-top:30px}.preview-section h3{font-family:var(--font-primary);color:var(--gold-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:15px;text-shadow:0 0 15px var(--gold-glow)}.previews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-bottom:20px}.preview-item{background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast)}.preview-item:hover{border-color:var(--border-gold);box-shadow:var(--shadow-md),0 0 15px #d4af3733}.preview-image-wrapper{position:relative;width:100%;height:200px;background:var(--bg-darkest)}.preview-image-wrapper img{width:100%;height:100%;object-fit:cover}.remove-preview-btn{position:absolute;top:5px;right:5px;width:30px;height:30px;border:none;border-radius:50%;background:#c53030e6;color:var(--text-primary);font-size:24px;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:0 2px 8px #0006}.remove-preview-btn:hover{background:var(--red-medium);transform:scale(1.1)}.remove-preview-btn:disabled{opacity:.5;cursor:not-allowed}.caption-input{width:100%;padding:10px;background:var(--bg-card);color:var(--text-primary);border:none;border-top:1px solid var(--border-dark);font-size:13px;font-family:var(--font-secondary);transition:all var(--transition-fast)}.caption-input:focus{outline:none;background:var(--bg-dark);box-shadow:inset 0 0 10px #6b46c133}.caption-input:disabled{background:var(--bg-darkest);color:var(--text-muted);opacity:.6}.tag-characters-section{padding:10px;background:var(--bg-card);border-top:1px solid var(--border-dark);position:relative}.tagged-characters{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;min-height:24px}.character-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;background:linear-gradient(135deg,var(--primary-accent),var(--primary-medium));color:var(--text-primary);border:1px solid var(--primary-accent);border-radius:12px;font-size:12px;font-family:var(--font-secondary);box-shadow:0 2px 5px #6b46c14d}.remove-tag-btn{background:none;border:none;color:var(--text-primary);font-size:16px;line-height:1;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.remove-tag-btn:hover{color:var(--gold-light)}.btn-tag-character{padding:6px 12px;background:var(--bg-dark);border:1px solid var(--primary-accent);color:var(--primary-accent);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-tag-character:hover{background:var(--primary-accent);color:var(--text-primary);box-shadow:0 0 15px #6b46c14d}.character-search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:2px solid var(--border-gold);border-radius:var(--radius-md);margin-top:5px;box-shadow:var(--shadow-lg);z-index:10;max-height:300px;display:flex;flex-direction:column}.character-search-input{padding:10px;background:var(--bg-dark);color:var(--text-primary);border:none;border-bottom:1px solid var(--border-dark);font-size:14px;font-family:var(--font-secondary)}.character-search-input:focus{outline:none;background:var(--bg-darkest)}.character-search-results{overflow-y:auto;max-height:250px}.character-search-item{display:flex;align-items:center;gap:10px;padding:10px;cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid var(--border-dark)}.character-search-item:hover{background:var(--bg-dark);border-color:var(--primary-accent)}.character-search-item img{width:32px;height:32px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border-dark)}.character-search-item span{font-size:14px;font-family:var(--font-secondary);color:var(--text-primary)}.no-results{padding:20px;text-align:center;color:var(--text-muted);font-style:italic;font-family:var(--font-secondary)}.upload-progress-bar{width:100%;height:4px;background:var(--bg-darkest);overflow:hidden;border-radius:2px}.upload-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-accent),var(--gold-medium));transition:width .3s ease;box-shadow:0 0 10px #6b46c180}.upload-actions{display:flex;gap:15px;justify-content:flex-end}@media(max-width:768px){.previews-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px}.preview-image-wrapper{height:150px}.upload-actions{flex-direction:column}.upload-actions button{width:100%}}.playlist-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);font-family:var(--font-secondary);font-style:italic}.playlist-container{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);position:relative}.playlist-container:before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(212,175,55,.02) 1px,transparent 1px),linear-gradient(rgba(212,175,55,.02) 1px,transparent 1px);background-size:50px 50px;border-radius:var(--radius-lg);pointer-events:none;z-index:0}.playlist-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:3px double var(--border-gold);position:relative;z-index:1}.playlist-header h3{font-family:var(--font-primary);margin:0 0 var(--spacing-xs) 0;font-size:1.8rem;color:var(--gold-medium);text-transform:uppercase;letter-spacing:1px}.playlist-description{margin:var(--spacing-xs) 0 0;color:var(--text-secondary);font-size:.95rem;font-family:var(--font-secondary);font-style:italic}.playlist-actions{display:flex;gap:var(--spacing-md);align-items:center}.btn-toggle{font-family:var(--font-primary);padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all var(--transition-fast)}.btn-toggle:hover{border-color:var(--gold-medium);color:var(--gold-light);box-shadow:var(--glow-gold)}.btn-toggle.active{background:linear-gradient(135deg,var(--primary-accent),var(--primary-medium));border-color:var(--primary-accent);color:var(--text-primary);box-shadow:var(--glow-purple)}.add-song-form{background:var(--bg-dark);border:2px dashed var(--border-medium);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);position:relative;z-index:1}.add-song-form h4{font-family:var(--font-primary);margin:0 0 var(--spacing-md);font-size:1.3rem;color:var(--gold-medium);text-transform:uppercase;letter-spacing:1px}.add-song-form .form-group{margin-bottom:var(--spacing-md)}.add-song-form .form-group label{display:block;margin-bottom:var(--spacing-sm);font-family:var(--font-primary);font-weight:600;color:var(--gold-light);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.add-song-form .form-group input,.add-song-form .form-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-dark);border-radius:var(--radius-md);font-size:.95rem;font-family:var(--font-secondary);background:var(--bg-medium);color:var(--text-primary);transition:all var(--transition-fast)}.add-song-form .form-group input:focus,.add-song-form .form-group select:focus{outline:none;border-color:var(--gold-medium);box-shadow:var(--glow-gold)}.add-song-form .form-help{display:block;margin-top:var(--spacing-xs);font-size:.85rem;color:var(--text-muted);font-style:italic;font-family:var(--font-secondary)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.playlist-owner-actions{margin-bottom:var(--spacing-md)}.playlist-owner-actions .btn-primary.btn-small{width:100%}.now-playing-widget{margin-bottom:var(--spacing-lg);background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);overflow:hidden;position:relative;z-index:1;transition:all var(--transition-fast)}.now-playing-widget:hover{border-color:var(--border-gold);box-shadow:0 0 15px #d4af3733}.now-playing-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:linear-gradient(135deg,var(--primary-accent),var(--primary-dark));border-bottom:2px solid var(--border-dark)}.now-playing-icon{font-size:1.5rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.now-playing-details{flex:1;min-width:0}.now-playing-title{font-family:var(--font-primary);font-size:.9rem;color:var(--gold-light);margin:0;text-shadow:0 0 10px var(--gold-glow);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-playing-artist{font-family:var(--font-secondary);font-size:.75rem;color:var(--text-secondary);margin:2px 0 0;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.embed-container-mini{position:relative;width:100%;background:var(--bg-darkest)}.embed-container-mini iframe{display:block;border:none;width:100%}.current-song-player{margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);background:linear-gradient(135deg,var(--primary-accent),var(--primary-dark));border-radius:var(--radius-lg);color:var(--text-primary);box-shadow:var(--shadow-lg),var(--glow-purple);border:2px solid var(--primary-accent);position:relative;z-index:1}.current-song-player h4{font-family:var(--font-primary);margin:0 0 var(--spacing-xs);font-size:1.5rem;color:var(--gold-light);text-shadow:0 0 15px var(--gold-glow);letter-spacing:1px}.song-artist{margin:0 0 var(--spacing-md);font-size:.95rem;opacity:.85;font-family:var(--font-secondary);font-style:italic}.embed-container{position:relative;width:100%;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-darkest);border:2px solid var(--border-dark);box-shadow:inset 0 2px 10px #00000080}.embed-container iframe{display:block;border:none;border-radius:var(--radius-md)}.song-list{margin-top:var(--spacing-xl);position:relative;z-index:1}.song-list h4{font-family:var(--font-primary);margin:0 0 var(--spacing-md);font-size:1.3rem;color:var(--gold-medium);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-gold);text-transform:uppercase;letter-spacing:1px}.songs{display:flex;flex-direction:column;gap:var(--spacing-md)}.song-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:default}.song-item:hover{background:var(--bg-hover);border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.song-item.playing{background:linear-gradient(135deg,#6b46c133,#2d1b4e4d);border-color:var(--primary-accent);box-shadow:var(--glow-purple)}.song-item.dragging{opacity:.5;cursor:move;transform:scale(.98)}.song-item.drag-over{border-color:var(--gold-medium);border-style:dashed;background:#d4af371a;box-shadow:var(--glow-gold)}.song-info{display:flex;align-items:center;gap:var(--spacing-xs);flex:1;min-width:0}.drag-handle{font-size:1.5rem;color:var(--border-medium);cursor:move;-webkit-user-select:none;user-select:none;padding:0 var(--spacing-xs);transition:color var(--transition-fast)}.drag-handle:hover{color:var(--gold-medium)}.song-number{font-family:var(--font-primary);font-weight:700;color:var(--gold-dark);min-width:30px;font-size:1.1rem}.song-details{flex:1;min-width:0}.song-title{font-family:var(--font-secondary);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:1rem}.song-item .song-artist{font-size:.85rem;color:var(--text-secondary);margin-top:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-secondary);font-style:italic}.song-actions{display:flex;gap:var(--spacing-sm);align-items:center}.btn-play{background:transparent;border:2px solid var(--border-medium);border-radius:var(--radius-sm);font-size:1.2rem;cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);color:var(--gold-medium);transition:all var(--transition-fast)}.btn-play:hover{border-color:var(--gold-medium);color:var(--gold-light);box-shadow:var(--glow-gold);transform:scale(1.1)}.btn-remove{background:transparent;border:2px solid var(--red-dark);border-radius:var(--radius-sm);color:var(--red-medium);font-size:1.2rem;cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-fast)}.btn-remove:hover{border-color:var(--red-medium);color:var(--red-light);box-shadow:0 0 15px #c5303066;transform:scale(1.1)}.drag-help{text-align:center;margin-top:var(--spacing-md);padding:var(--spacing-sm);background:#d4af371a;border:1px solid var(--border-gold);border-radius:var(--radius-md);font-size:.85rem;color:var(--text-muted);font-family:var(--font-secondary);font-style:italic}@media(max-width:768px){.playlist-container{padding:var(--spacing-lg)}.playlist-header{flex-direction:column;gap:var(--spacing-md)}.playlist-actions{width:100%;flex-direction:column}.btn-toggle,.playlist-actions button{width:100%}.current-song-player{padding:var(--spacing-lg)}.embed-container iframe{height:300px}.song-info{gap:var(--spacing-xs)}.drag-handle{display:none}.song-title,.song-item .song-artist{font-size:.9rem}.form-actions{flex-direction:column}.form-actions button{width:100%}}@media(max-width:480px){.playlist-container{padding:var(--spacing-md)}.song-item{padding:var(--spacing-sm)}.song-number{display:none}.playlist-header h3{font-size:1.4rem}.current-song-player h4{font-size:1.2rem}}.banner-editor-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.banner-editor-modal{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);max-width:900px;width:90%;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg),0 0 50px var(--gold-glow);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.banner-editor-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:2px solid var(--border-gold);background:linear-gradient(135deg,var(--primary-dark),var(--primary-medium))}.banner-editor-header h3{font-family:var(--font-primary);color:var(--gold-light);font-size:1.5rem;text-transform:uppercase;letter-spacing:1px;margin:0;text-shadow:0 0 20px var(--gold-glow)}.close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:2rem;line-height:1;cursor:pointer;transition:all var(--transition-fast);padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn:hover{color:var(--gold-light);background:#d4af371a;transform:rotate(90deg)}.banner-editor-instructions{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-dark);border-bottom:2px solid var(--border-dark)}.banner-editor-instructions p{font-family:var(--font-secondary);color:var(--text-primary);margin:0;text-align:center;font-size:.95rem}.banner-preview-container{position:relative;width:100%;height:300px;overflow:hidden;background:var(--bg-darkest);cursor:grab;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.banner-preview-container:active{cursor:grabbing}.banner-preview-image{position:absolute;min-width:100%;min-height:100%;width:auto;height:auto;max-width:none;object-fit:cover;user-select:none;-webkit-user-drag:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;transition:opacity .1s}.banner-preview-image.dragging{opacity:.9}.banner-overlay-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(to right,rgba(212,175,55,.1) 1px,transparent 1px),linear-gradient(to bottom,rgba(212,175,55,.1) 1px,transparent 1px);background-size:33.33% 33.33%;opacity:.5}.banner-editor-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);background:var(--bg-dark);border-top:2px solid var(--border-dark)}.banner-editor-actions .btn-primary,.banner-editor-actions .btn-secondary{font-family:var(--font-primary);padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all var(--transition-fast);border:2px solid}.banner-editor-actions .btn-primary{background:linear-gradient(135deg,var(--gold-medium),var(--gold-dark));color:var(--bg-darkest);border-color:var(--gold-medium);box-shadow:0 4px 10px #d4af374d}.banner-editor-actions .btn-primary:hover{background:linear-gradient(135deg,var(--gold-light),var(--gold-medium));box-shadow:0 6px 20px #d4af3780;transform:translateY(-2px)}.banner-editor-actions .btn-secondary{background:var(--bg-card);color:var(--text-secondary);border-color:var(--border-dark)}.banner-editor-actions .btn-secondary:hover{background:var(--bg-dark);color:var(--text-primary);border-color:var(--border-gold)}@media(max-width:768px){.banner-editor-modal{width:95%;max-height:95vh}.banner-editor-header{padding:var(--spacing-md)}.banner-editor-header h3{font-size:1.2rem}.banner-preview-container{height:200px}.banner-editor-actions{flex-direction:column}.banner-editor-actions button{width:100%}}@media(hover:none)and (pointer:coarse){.banner-preview-container,.banner-preview-image{cursor:default}}.character-profile{max-width:1400px;margin:0 auto;padding:var(--spacing-lg)}.profile-banner{height:300px;background-size:cover;background-position:center;background-color:var(--bg-dark);position:relative;border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow:hidden;border:3px solid var(--border-gold);border-bottom:none;box-shadow:var(--shadow-lg)}.profile-banner:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(212,175,55,.15),transparent 50%),radial-gradient(ellipse at bottom left,rgba(107,70,193,.15),transparent 50%);pointer-events:none}.banner-overlay{background:linear-gradient(to bottom,transparent 0%,rgba(13,10,21,.7) 70%,rgba(13,10,21,.95) 100%);height:100%;display:flex;align-items:flex-end;padding:var(--spacing-xl);position:relative;z-index:1}.profile-header-content{display:flex;align-items:flex-end;gap:var(--spacing-lg);width:100%}.profile-image{width:180px;height:180px;border-radius:var(--radius-md);border:4px solid var(--gold-medium);object-fit:cover;box-shadow:0 0 30px #d4af3780,var(--shadow-lg);position:relative;background:var(--bg-dark)}.profile-title h1{font-family:var(--font-primary);color:var(--gold-light);margin:0 0 var(--spacing-xs) 0;text-shadow:2px 2px 4px rgba(0,0,0,.9),0 0 20px var(--gold-glow);font-size:2.5rem;letter-spacing:1px}.profile-subtitle{color:var(--text-primary);margin:0 0 var(--spacing-xs) 0;text-shadow:1px 1px 3px rgba(0,0,0,.9);font-size:1.2rem;font-family:var(--font-secondary);font-style:italic}.profile-views{color:var(--text-secondary);margin:0;text-shadow:1px 1px 2px rgba(0,0,0,.9);font-size:.9rem;font-family:var(--font-secondary)}.adjust-banner-btn{position:absolute;top:15px;right:15px;padding:var(--spacing-xs) var(--spacing-md);font-family:var(--font-primary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#000000b3;color:var(--gold-light);border:2px solid var(--border-gold);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 2px 10px #00000080}.adjust-banner-btn:hover{background:#d4af3733;border-color:var(--gold-light);box-shadow:0 0 20px var(--gold-glow);transform:translateY(-2px)}.adjust-banner-btn:active{transform:translateY(0)}.owner-actions{background:var(--bg-card);border:3px solid var(--border-gold);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:var(--spacing-md);display:flex;gap:var(--spacing-md);justify-content:flex-end;box-shadow:var(--shadow-md)}.profile-layout{display:grid;grid-template-columns:350px 1fr;gap:var(--spacing-xl);margin-top:var(--spacing-xl)}.profile-sidebar{display:flex;flex-direction:column;gap:var(--spacing-lg)}.info-section{background:var(--bg-card);border:3px double var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);position:relative}.info-section:before{content:"";position:absolute;inset:-3px;background:linear-gradient(45deg,var(--gold-dark),var(--primary-medium));border-radius:var(--radius-lg);z-index:-1;opacity:.2}.info-section h3{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.3rem;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-gold);text-transform:uppercase;letter-spacing:1px}.detail-item{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-dark)}.detail-item:last-child{border-bottom:none}.detail-label{font-family:var(--font-primary);font-weight:600;color:var(--gold-light);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-family:var(--font-secondary);color:var(--text-primary);font-size:.95rem}.stats-section{background:var(--bg-card);border:3px double var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);position:relative}.stats-section:before{content:"";position:absolute;inset:-3px;background:linear-gradient(45deg,var(--gold-dark),var(--primary-medium));border-radius:var(--radius-lg);z-index:-1;opacity:.3}.stats-section h3{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.3rem;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-gold);text-transform:uppercase;letter-spacing:1px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat-item{background:var(--bg-dark);border:2px solid var(--border-dark);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center;transition:all var(--transition-fast)}.stat-item:hover{border-color:var(--gold-medium);box-shadow:var(--glow-gold);transform:translateY(-2px)}.stat-label{font-family:var(--font-primary);font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:var(--spacing-xs)}.stat-value{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--gold-light);text-shadow:0 0 10px var(--gold-glow)}.top-friends{background:var(--bg-card);border:3px double var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-lg)}.top-friends h3{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.3rem;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-gold);text-transform:uppercase;letter-spacing:1px}.sidebar-section{background:var(--bg-card);border:3px double var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-lg)}.sidebar-section h3{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.3rem;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-gold);text-transform:uppercase;letter-spacing:1px}.sidebar-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-gold)}.sidebar-section .section-header h3{margin:0;padding:0;border:none}.btn-add-photos{width:30px;height:30px;border-radius:50%;background:var(--primary-accent);color:var(--text-primary);border:2px solid var(--primary-accent);font-size:20px;font-weight:700;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:0}.btn-add-photos:hover{background:var(--gold-medium);border-color:var(--gold-medium);box-shadow:0 0 15px var(--gold-glow);transform:scale(1.1)}.sidebar-section .playlist-container{background:transparent;border:none;padding:0;box-shadow:none}.sidebar-section .song-list h4{font-size:1rem;margin-bottom:var(--spacing-sm)}.sidebar-section .song-item{padding:var(--spacing-sm);font-size:.85rem}.sidebar-section .song-info h5{font-size:.9rem}.sidebar-section .add-song-form{padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.sidebar-section .add-song-form h4{font-size:1rem}.sidebar-section .form-actions{flex-direction:column}.sidebar-section .form-actions button{width:100%}.sidebar-section .photo-gallery-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.sidebar-section .photo-item{max-height:250px}.sidebar-section .photo-item img{max-height:250px;object-fit:cover}.sidebar-section .photo-thumbnail{height:200px}.sidebar-section .gallery-empty{padding:var(--spacing-md);font-size:.9rem}.see-all-photos-btn{display:block;width:100%;padding:var(--spacing-md);margin-top:var(--spacing-md);background:var(--bg-dark);border:2px solid var(--primary-accent);border-radius:var(--radius-md);color:var(--primary-accent);font-family:var(--font-primary);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:center;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.see-all-photos-btn:hover{background:var(--primary-accent);color:var(--text-primary);box-shadow:0 0 20px #6b46c166;transform:translateY(-2px)}.friends-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.friend-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);border:2px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-dark);text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast)}.friend-card:hover{background:var(--bg-hover);border-color:var(--gold-medium);box-shadow:var(--glow-gold);transform:translateY(-2px)}.friend-card img{width:70px;height:70px;border-radius:var(--radius-sm);border:2px solid var(--border-medium);object-fit:cover}.friend-card span{font-family:var(--font-secondary);font-size:.85rem;text-align:center;word-break:break-word;color:var(--text-secondary)}.profile-main{display:flex;flex-direction:column;gap:var(--spacing-xl)}.bio-section,.wall-section,.photos-section,.playlist-section{background:var(--bg-card);border:3px solid var(--border-gold);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);position:relative}.bio-section{background-image:linear-gradient(90deg,rgba(212,175,55,.03) 1px,transparent 1px),linear-gradient(rgba(212,175,55,.03) 1px,transparent 1px);background-size:50px 50px;background-color:var(--bg-card)}.bio-section h2,.wall-section h2,.photos-section h2,.playlist-section h2{font-family:var(--font-primary);color:var(--gold-medium);font-size:1.8rem;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:3px double var(--border-gold);text-transform:uppercase;letter-spacing:1px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:3px double var(--border-gold)}.section-header h2{margin:0;padding:0;border:none}.bio-content p{font-family:var(--font-secondary);color:var(--text-primary);line-height:1.8;white-space:pre-wrap;font-size:1.05rem}.no-content,.coming-soon{color:var(--text-muted);font-style:italic;text-align:center;padding:var(--spacing-xl);font-family:var(--font-secondary)}.error-container{text-align:center;padding:var(--spacing-2xl);background:var(--bg-card);border:3px solid var(--red-medium);border-radius:var(--radius-lg);margin:var(--spacing-xl)}.error-container h2{font-family:var(--font-primary);color:var(--red-light);margin-bottom:var(--spacing-lg)}.profile-divider{height:2px;background:linear-gradient(90deg,transparent,var(--border-gold) 20%,var(--border-gold) 80%,transparent);margin:var(--spacing-xl) 0;position:relative}.profile-divider:before{content:"⚔";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);padding:0 var(--spacing-md);color:var(--gold-medium);font-size:1.5rem}@media(max-width:968px){.profile-layout{grid-template-columns:1fr}.profile-header-content{flex-direction:column;align-items:center;text-align:center}.friends-grid{grid-template-columns:repeat(4,1fr)}.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.character-profile{padding:var(--spacing-md)}.profile-banner{height:auto;min-height:200px}.banner-overlay{padding:var(--spacing-md)}.profile-image{width:120px;height:120px}.profile-title h1{font-size:1.8rem}.profile-subtitle{font-size:1rem}.owner-actions{flex-direction:column}.friends-grid{grid-template-columns:repeat(3,1fr)}.stats-grid{grid-template-columns:repeat(2,1fr)}.bio-section,.wall-section,.photos-section,.playlist-section{padding:var(--spacing-lg)}}@media(max-width:480px){.profile-layout{gap:var(--spacing-md)}.profile-image{width:100px;height:100px}.profile-title h1{font-size:1.5rem}.friends-grid{grid-template-columns:repeat(2,1fr)}.friend-card img{width:60px;height:60px}}.album-view{max-width:1200px;margin:0 auto;padding:20px}.album-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid var(--border-dark)}.album-header-left{flex:1}.back-link{display:inline-block;margin-bottom:15px;font-family:var(--font-primary);color:var(--primary-accent);text-decoration:none;font-size:14px;text-transform:uppercase;letter-spacing:.5px;transition:all var(--transition-fast)}.back-link:hover{color:var(--gold-light);text-decoration:none}.album-view h1{font-family:var(--font-primary);color:var(--gold-light);text-transform:uppercase;letter-spacing:2px;margin:0 0 10px;font-size:32px;text-shadow:0 0 20px var(--gold-glow)}.album-description-full{font-family:var(--font-secondary);color:var(--text-primary);margin:10px 0;line-height:1.5}.album-meta{font-family:var(--font-secondary);color:var(--text-muted);font-size:14px;font-style:italic;margin:10px 0 0}.album-header-actions{display:flex;gap:10px;margin-left:20px}.upload-section{background:var(--bg-card);border:2px solid var(--border-dark);border-radius:var(--radius-md);margin-bottom:30px;overflow:hidden;box-shadow:var(--shadow-sm)}@media(max-width:768px){.album-header{flex-direction:column}.album-header-actions{width:100%;margin-left:0;margin-top:15px}.album-header-actions button{flex:1}.album-view h1{font-size:24px}}#root{width:100%;min-height:100vh;background:transparent;margin:0;padding:0}
